All Projects β†’ bcanseco β†’ github-contribution-graph-action

bcanseco / github-contribution-graph-action

Licence: MIT license
πŸ™ˆ This GitHub action will automatically push empty commits to one of your repositories.

Programming Languages

javascript
184084 projects - #8 most used programming language
Dockerfile
14818 projects

Projects that are alternatives of or similar to github-contribution-graph-action

commit-bot
Automatically generates GitHub activity
Stars: ✭ 65 (+54.76%)
Mutual labels:  contribution-graph, contributions-chart, contributions-graph
action-my-broken-link-checker
A GitHub Action for checking broken links
Stars: ✭ 32 (-23.81%)
Mutual labels:  github-action
realworld-springboot-java
ReadWorld.io project using spring boot
Stars: ✭ 74 (+76.19%)
Mutual labels:  github-action
ghdecoy
[DEPRECATED] artisanly crafted github contribution calendars. Now succeeded by https://github.com/tickelton/impost0r
Stars: ✭ 63 (+50%)
Mutual labels:  contribution-graph
memorable-milestones
A GitHub Action that puts your milestones on auto-pilot, using memorable emoji names πŸ€–
Stars: ✭ 18 (-57.14%)
Mutual labels:  github-action
Rishit-dagli
My GitHub profile README
Stars: ✭ 50 (+19.05%)
Mutual labels:  contribution-graph
build-godot-action
GitHub action that builds a Godot project for multiple platforms
Stars: ✭ 62 (+47.62%)
Mutual labels:  github-action
npm-audit-action
GitHub Action to run `npm audit`
Stars: ✭ 30 (-28.57%)
Mutual labels:  github-action
Gitfiti
abusing github commit history for the lulz
Stars: ✭ 6,750 (+15971.43%)
Mutual labels:  contribution-graph
WikiContrib
A tool for Wikimedia community members to visualize their technical contributions
Stars: ✭ 21 (-50%)
Mutual labels:  contribution-graph
contrib-awakens
Play games in GitHub's contribution graph.
Stars: ✭ 37 (-11.9%)
Mutual labels:  contribution-graph
Github Pages Deploy Action
Automatically deploy your project to GitHub Pages using GitHub Actions. This action can be configured to push your production-ready code into any branch you'd like.
Stars: ✭ 2,507 (+5869.05%)
Mutual labels:  github-action
Github-Contribution-Graph
Jquery plugin to render like contribution graph on Github.
Stars: ✭ 43 (+2.38%)
Mutual labels:  contribution-graph
github-run-tests-action
mabl Github Actions implementation
Stars: ✭ 39 (-7.14%)
Mutual labels:  github-action
dnscontrol-action
Deploy your DNS configuration using GitHub Actions using DNSControl.
Stars: ✭ 64 (+52.38%)
Mutual labels:  github-action
letterbot
Github Action 으둜 λ§Œλ“  λ””μŠ€μ½”λ“œ, μŠ¬λž™μ— 맀일 μ•„μΉ¨ 8μ‹œμ— λΈŒλ¦¬ν•‘μ„ ν•΄μ£ΌλŠ” λ΄‡μž…λ‹ˆλ‹€
Stars: ✭ 37 (-11.9%)
Mutual labels:  github-action
grass-graph
PNG Generator of GitHub Public Contribution Graph
Stars: ✭ 102 (+142.86%)
Mutual labels:  contribution-graph
action-devcard
GitHub Action to download the devcard from https://daily.dev
Stars: ✭ 59 (+40.48%)
Mutual labels:  github-action
mypy-check
github action for python's mypy type checker tool
Stars: ✭ 23 (-45.24%)
Mutual labels:  github-action
github-contribution-graph
Add beautiful GitHub contribution/commit graph to your profile README!
Stars: ✭ 37 (-11.9%)
Mutual labels:  contribution-graph

Contribution Graph Action

Maybe most of your coding happens on another version control host, like GitLab or Bitbucket. Maybe your company uses GitHub Enterprise but hasn't enabled unified contributions. Maybe you're looking for a new software development job and are worried that recruiters will prejudge you by your scarce contribution graph.
Or maybe you have other reasons. Whatever the case may be, you've come to the right place.

Quick start without leaving your browser ⚑

  1. Create a new repo (preferably private unless you have no shame)
  2. Click on Create a new file
  3. In the Name your file... field, type in .github/workflows/main.yml
  4. Paste in one of the YAML file contents below, depending on what you want to do. Be sure to update GIT_EMAIL.
  5. Click the Commit new file button at the bottom of the page. You're all set!
    • Note that you must enable the option below in your contribution settings for private commits to count on the graph.

If you change your mind about these commits later, you can delete the repository and they'll disappear from your contribution graph.

Push a commit to GitHub once a day 🍺

# .github/workflows/main.yml

on:
  schedule:
  - cron: '0 12 * * *' # every day at noon

jobs:
  single-commit:
    runs-on: ubuntu-latest
    permissions:
      contents: write
    steps:
    - uses: bcanseco/github-contribution-graph-action@v2
      env:
        GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        GIT_EMAIL: [email protected] # replace me

If you need help with cron job syntax, crontab guru is a great resource.

Backfill a year of commits whenever you push to GitHub 🍻

This rolls a pseudorandom number generator between 1 and 5 (inclusive) to determine how many commits to make per-day.

# .github/workflows/main.yml

on: push

jobs:
  backfill-commits:
    runs-on: ubuntu-latest
    permissions:
      contents: write
    steps:
    - uses: bcanseco/github-contribution-graph-action@v2
      env:
        GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        GIT_EMAIL: [email protected] # replace me
        MAX_DAYS: 365
        MIN_COMMITS_PER_DAY: 1
        MAX_COMMITS_PER_DAY: 5

Keep reading for more cool stuff like:

  • skipping weekends/weekdays
  • backfilling specific time periods
  • custom commit messages
  • and more!

Environment variables 🌳

Key Description Default value Required?
GITHUB_TOKEN Allows this GitHub Action to make commits for you. Simply pass in ${{ secrets.GITHUB_TOKEN }}. Read more. 🟩
GIT_EMAIL An email address associated with your GitHub account. Without this, contributions won't show up. Read more. 🟩
GIT_BRANCH Must either be the default branch or gh-pages for contributions to show up. The branch that triggered this Github Action
GIT_COMMIT_MESSAGE The message to use for commits made by this GitHub Action. chore(actions): empty commit for contribution graph
ORIGIN_TIMESTAMP The unix timestamp to start commits on. If you set MAX_DAYS greater than 1, commits will be made on days prior to this time. The current timestamp
MAX_DAYS The maximum integer number of days to commit on. If you want to backfill a year of commits, set this to 365. 1
MIN_COMMITS_PER_DAY The minimum integer number of commits to make per day (inclusive). Used by a pseudo-RNG. 1
MAX_COMMITS_PER_DAY The maximum integer number of commits to make per day (inclusive). Used by a pseudo-RNG. 1
INCLUDE_WEEKDAYS A boolean indicating whether or not to make commits on weekdays. true
INCLUDE_WEEKENDS A boolean indicating whether or not to make commits on weekends. true
FORCE_PUSH A boolean indicating whether or not to force push. WARNING: Setting this to true will clear out your repo on each run! false

Advanced environment variables πŸ§™β€β™‚οΈ

There's also some advanced environment variables you can provide. Click here!

Only set these if you know what you're doing:

Key Description Default value Required?
GIT_HOST You may be able to override this to support a GitHub Enterprise environment. github.com
GIT_SSH_COMMAND ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no
GITHUB_ACTOR Set by the GitHub Actions runner
GITHUB_REPOSITORY Set by the GitHub Actions runner

How do I know this is secure? πŸ”’

Explore the code! It's tiny and there aren't many dependencies.

Speaking of dependencies, all production npm dependencies used by this GitHub Action are automatically audited for vulnerabilities. If the badge at the top of this README is green, you're good to go.

If you're still worried about malicious code in this repository, GitHub recommends always using a specific version of any GitHub Actions you add to your repositories. Read more.

- uses: bcanseco/github-contribution-graph-action@v2
+ uses: bcanseco/[email protected]

As far as data security, there's two sensitive pieces of data that this Action handles:

GITHUB_TOKEN πŸ”‘

GitHub has a great article about the token. It's the standard way that all GitHub Actions interact with GitHub on your behalf. The permissions of this token are both short-lived and scoped to one repo only.

You don't need to create this secret yourself; GitHub handles that for you. All you need to do is provide the token in your workflow, job, or step:

env:
  GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

Getting 403 errors? ❌

Make sure your token has write permission for the contents scope. If you're using the examples in this README, this is already done for you.

You can alternatively set this as a repo-level default:

GIT_EMAIL πŸ“§

This GitHub Action requires an email associated with your GitHub account. If you provide a random or throwaway email, contributions won't show up on your GitHub profile. Read more.

Chances are, your email is already public if you're making commits with it. But if you're concerned about privacy, you can do either of the following:

Contribute πŸ‘ͺ

PRs are welcome! Please read the contributing guide. This project is MIT licensed.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].