{"id":28377257,"url":"https://github.com/bcanseco/github-contribution-graph-action","last_synced_at":"2025-10-13T08:40:44.512Z","repository":{"id":42067932,"uuid":"268364436","full_name":"bcanseco/github-contribution-graph-action","owner":"bcanseco","description":"🙈 This GitHub action will automatically push empty commits to one of your repositories.","archived":false,"fork":false,"pushed_at":"2024-11-19T05:53:23.000Z","size":580,"stargazers_count":219,"open_issues_count":6,"forks_count":26,"subscribers_count":4,"default_branch":"master","last_synced_at":"2025-10-04T12:37:23.601Z","etag":null,"topics":["contribution-graph","contribution-spoofing","contributions-chart","contributions-graph","github-action","github-actions"],"latest_commit_sha":null,"homepage":"https://github.com/marketplace/actions/autopopulate-your-contribution-graph","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/bcanseco.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":".github/CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":".github/SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2020-05-31T21:08:07.000Z","updated_at":"2025-09-26T05:05:11.000Z","dependencies_parsed_at":"2024-06-18T21:29:59.023Z","dependency_job_id":"ef0cc9f5-12a1-4bbb-9b9e-77d4cf432df1","html_url":"https://github.com/bcanseco/github-contribution-graph-action","commit_stats":{"total_commits":44,"total_committers":2,"mean_commits":22.0,"dds":"0.11363636363636365","last_synced_commit":"31a07d74b3430073cd5dd4fcc7238464e9f7d0d9"},"previous_names":[],"tags_count":10,"template":false,"template_full_name":null,"purl":"pkg:github/bcanseco/github-contribution-graph-action","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bcanseco%2Fgithub-contribution-graph-action","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bcanseco%2Fgithub-contribution-graph-action/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bcanseco%2Fgithub-contribution-graph-action/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bcanseco%2Fgithub-contribution-graph-action/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/bcanseco","download_url":"https://codeload.github.com/bcanseco/github-contribution-graph-action/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bcanseco%2Fgithub-contribution-graph-action/sbom","scorecard":{"id":228297,"data":{"date":"2025-08-11","repo":{"name":"github.com/bcanseco/github-contribution-graph-action","commit":"44c9b6450b760e82e540bb15253fb23bd9e0c803"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":4.7,"checks":[{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Code-Review","score":0,"reason":"Found 0/25 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: .github/SECURITY.md:1","Info: Found linked content: .github/SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: .github/SECURITY.md:1","Info: Found text in security policy: .github/SECURITY.md:1"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build.yml:26","Warn: no topLevel permission defined: .github/workflows/audit.yml:1","Warn: no topLevel permission defined: .github/workflows/build.yml:1","Warn: no topLevel permission defined: .github/workflows/release.yml:1","Warn: no topLevel permission defined: .github/workflows/tests.yml:1"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Pinned-Dependencies","score":1,"reason":"dependency not pinned by hash detected -- score normalized to 1","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/audit.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/audit.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/audit.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/audit.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/audit.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/audit.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/audit.yml:22: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/audit.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/build.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/build.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/build.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/build.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/build.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/release.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/tests.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/bcanseco/github-contribution-graph-action/tests.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:1: pin your Docker image by updating node:16.11.1 to node:16.11.1@sha256:d6a8cd069ab740759394a9338dc4bc4b9b32b15209cccd0c7faa32d438b1076e","Info:   0 out of   8 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   3 third-party GitHubAction dependencies pinned","Info:   0 out of   1 containerImage dependencies pinned","Info:   1 out of   1 npmCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":7,"reason":"SAST tool detected but not run on all commits","details":["Info: SAST configuration detected: CodeQL","Warn: 0 commits out of 5 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":7,"reason":"3 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-968p-4wvh-cqc8","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-17T04:16:09.482Z","repository_id":42067932,"created_at":"2025-08-17T04:16:09.482Z","updated_at":"2025-08-17T04:16:09.482Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279014324,"owners_count":26085492,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-13T02:00:06.723Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["contribution-graph","contribution-spoofing","contributions-chart","contributions-graph","github-action","github-actions"],"created_at":"2025-05-30T01:04:22.049Z","updated_at":"2025-10-13T08:40:44.496Z","avatar_url":"https://github.com/bcanseco.png","language":"JavaScript","readme":"\u003cp align=\"center\"\u003e\n  \u003cimg width=\"150px\" src=\"./.github/images/cover.png\"\u003e\n\u003c/p\u003e\n\n\u003ch1 align=\"center\"\u003e\n  Contribution Graph Action\n\u003c/h1\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/bcanseco/github-contribution-graph-action/actions?query=workflow%3Abuild\"\u003e\n    \u003cimg src=\"https://github.com/bcanseco/github-contribution-graph-action/workflows/build/badge.svg\"\u003e\n  \u003c/a\u003e\n\n  \u003ca href=\"https://github.com/bcanseco/github-contribution-graph-action/actions?query=workflow%3Atests\"\u003e\n    \u003cimg src=\"https://github.com/bcanseco/github-contribution-graph-action/workflows/tests/badge.svg\"\u003e\n  \u003c/a\u003e\n\n  \u003ca href=\"https://github.com/bcanseco/github-contribution-graph-action/actions?query=workflow%3Aaudit\"\u003e\n    \u003cimg src=\"https://github.com/bcanseco/github-contribution-graph-action/workflows/audit/badge.svg\"\u003e\n  \u003c/a\u003e\n\n  \u003ca href=\"https://github.com/marketplace/actions/autopopulate-your-contribution-graph\"\u003e\n    \u003cimg src=\"https://img.shields.io/badge/action-marketplace-orange?logo=github\"\u003e\n  \u003c/a\u003e\n\n  \u003ca href=\"https://github.com/bcanseco/github-contribution-graph-action/releases\"\u003e\n    \u003cimg src=\"https://img.shields.io/github/v/release/bcanseco/github-contribution-graph-action.svg?logo=github\"\u003e\n  \u003c/a\u003e\n\u003c/p\u003e\n\n\u003e 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](https://docs.github.com/en/enterprise-server@latest/admin/configuration/configuring-github-connect/enabling-unified-contributions-for-your-enterprise). Maybe you're looking for a new software development job and are worried that recruiters will prejudge you by your scarce contribution graph.  \n\u003e Or maybe you have [other reasons](https://twitter.com/jacobmparis/status/1265740598277025792). Whatever the case may be, you've come to the right place.\n\n## Quick start without leaving your browser ⚡\n\n1. [Create a new repo](https://github.com/new) (preferably private unless you have no shame)\n1. Click on **Create a new file**  \n   ![](./.github/images/create-new-file.png)\n1. In the **Name your file...** field, type in `.github/workflows/main.yml`\n   ![](./.github/images/name-new-file.png)\n1. Paste in one of the YAML file contents below, depending on what you want to do. Be sure to update `GIT_EMAIL`.\n1. Click the **Commit new file** button at the bottom of the page. You're all set!\n   * Note that you must enable the option below in your contribution settings for private commits to count on the graph.\n   ![](.github/images/private-contributions.png)\n\nIf you change your mind about these commits later, you can delete the repository and they'll disappear from your contribution graph.\n\n### Push a commit to GitHub once a day 🍺\n\n```yml\n# .github/workflows/main.yml\n\non:\n  schedule:\n  - cron: '0 12 * * *' # every day at noon\n\njobs:\n  single-commit:\n    runs-on: ubuntu-latest\n    permissions:\n      contents: write\n    steps:\n    - uses: bcanseco/github-contribution-graph-action@v2\n      env:\n        GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}\n        GIT_EMAIL: you@youremail.com # replace me\n```\n\nIf you need help with cron job syntax, [crontab guru](https://crontab.guru/) is a great resource.\n\n### Backfill a year of commits whenever you push to GitHub 🍻\n\nThis rolls a pseudorandom number generator between 1 and 5 (inclusive) to determine how many commits to make per-day.\n\n```yml\n# .github/workflows/main.yml\n\non: push\n\njobs:\n  backfill-commits:\n    runs-on: ubuntu-latest\n    permissions:\n      contents: write\n    steps:\n    - uses: bcanseco/github-contribution-graph-action@v2\n      env:\n        GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}\n        GIT_EMAIL: you@youremail.com # replace me\n        MAX_DAYS: 365\n        MIN_COMMITS_PER_DAY: 1\n        MAX_COMMITS_PER_DAY: 5\n```\n\nKeep reading for more cool stuff like:\n\n* skipping weekends/weekdays\n* backfilling specific time periods\n* custom commit messages\n* and more!\n\n## Environment variables 🌳\n\n| Key                   | Description                                                                                                                    | Default value                                         | Required? |\n|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------|\n| `GITHUB_TOKEN`        | Allows this GitHub Action to make commits for you. Simply pass in `${{ secrets.GITHUB_TOKEN }}`. [Read more](#github_token-).  |                                                       |    🟩     |\n| `GIT_EMAIL`           | An email address associated with your GitHub account. Without this, contributions won't show up. [Read more](#git_email-).     |                                                       |    🟩     |\n| `GIT_BRANCH`          | Must either be the default branch or `gh-pages` for contributions to show up.                                                  | The branch that triggered this Github Action          |           |\n| `GIT_COMMIT_MESSAGE`  | The message to use for commits made by this GitHub Action.                                                                     | `chore(actions): empty commit for contribution graph` |           |\n| `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                                 |           |\n| `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`                                                   |           |\n| `MIN_COMMITS_PER_DAY` | The minimum integer number of commits to make per day (inclusive). Used by a pseudo-RNG.                                       | `1`                                                   |           |\n| `MAX_COMMITS_PER_DAY` | The maximum integer number of commits to make per day (inclusive). Used by a pseudo-RNG.                                       | `1`                                                   |           |\n| `INCLUDE_WEEKDAYS`    | A boolean indicating whether or not to make commits on weekdays.                                                               | `true`                                                |           |\n| `INCLUDE_WEEKENDS`    | A boolean indicating whether or not to make commits on weekends.                                                               | `true`                                                |           |\n| `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`                                               |           |\n\n### Advanced environment variables 🧙‍♂️\n\n\u003cdetails\u003e\n\n\u003csummary\u003eThere's also some advanced environment variables you can provide. Click here!\u003c/summary\u003e\n\nOnly set these if you know what you're doing:\n\n| Key                 | Description                                                                  | Default value                                                     | Required? |\n|---------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------|\n| `GIT_HOST`          | You may be able to override this to support a GitHub Enterprise environment. | `github.com`                                                      |           |\n| `GIT_SSH_COMMAND`   |                                                                              | `ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no` |           |\n| `GITHUB_ACTOR`      |                                                                              | Set by the GitHub Actions runner                                  |           |\n| `GITHUB_REPOSITORY` |                                                                              | Set by the GitHub Actions runner                                  |           |\n\n\u003c/details\u003e\n\n## How do I know this is secure? 🔒\n\nExplore the [code](src/index.js)! It's tiny and there aren't many dependencies.\n\nSpeaking of dependencies, all production npm dependencies used by this GitHub Action are [automatically audited](./.github/workflows/audit.yml) for vulnerabilities. If the badge at the top of this README is green, you're good to go.\n\nIf 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](https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsuses).\n\n```diff\n- uses: bcanseco/github-contribution-graph-action@v2\n+ uses: bcanseco/github-contribution-graph-action@2.0.0\n```\n\nAs far as data security, there's two sensitive pieces of data that this Action handles:\n\n* [`GITHUB_TOKEN`](#github_token-)\n* [`GIT_EMAIL`](#git_email-)\n\n### `GITHUB_TOKEN` 🔑\n\nGitHub has [a great article](https://docs.github.com/en/actions/security-guides/automatic-token-authentication#using-the-github_token-in-a-workflow) 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.\n\nYou 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:\n\n```yml\nenv:\n  GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}\n```\n\n#### Getting 403 errors? ❌\n\nMake sure your token has [write permission for the `contents` scope](https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs). If you're using the examples in this README, this is already done for you.\n\nYou can alternatively set this as a repo-level default:\n\n![](./.github/images/token-permissions.png)\n\n### `GIT_EMAIL` 📧\n\nThis 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](https://docs.github.com/en/account-and-profile/setting-up-and-managing-your-github-profile/managing-contribution-settings-on-your-profile/why-are-my-contributions-not-showing-up-on-my-profile#you-havent-added-your-local-git-commit-email-to-your-profile).\n\nChances 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:\n\n* [Add your email as a secret](https://docs.github.com/en/actions/security-guides/encrypted-secrets#creating-encrypted-secrets-for-a-repository) and pass it in the same way as the `GITHUB_TOKEN`\n* [Use your GitHub-provided `noreply` email address](https://docs.github.com/en/account-and-profile/setting-up-and-managing-your-personal-account-on-github/managing-email-preferences/setting-your-commit-email-address#about-commit-email-addresses)\n\n## Contribute 👪\n\nPRs are welcome! Please read the [contributing guide](.github/CONTRIBUTING.md). This project is [MIT](LICENSE) licensed.\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbcanseco%2Fgithub-contribution-graph-action","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fbcanseco%2Fgithub-contribution-graph-action","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbcanseco%2Fgithub-contribution-graph-action/lists"}