{"id":3892,"url":"https://github.com/typicode/husky","last_synced_at":"2026-06-10T06:20:15.478Z","repository":{"id":18065052,"uuid":"21125024","full_name":"typicode/husky","owner":"typicode","description":"Git hooks made easy 🐶 woof!","archived":false,"fork":false,"pushed_at":"2024-11-26T00:20:16.000Z","size":4438,"stargazers_count":34080,"open_issues_count":97,"forks_count":1071,"subscribers_count":157,"default_branch":"main","last_synced_at":"2025-09-04T12:56:27.323Z","etag":null,"topics":["commit","git","hooks","pre-commit"],"latest_commit_sha":null,"homepage":"https://typicode.github.io/husky","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/typicode.png","metadata":{"files":{"readme":".github/README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null},"funding":{"github":"typicode","open_collective":"husky"}},"created_at":"2014-06-23T12:14:21.000Z","updated_at":"2025-09-04T11:32:18.000Z","dependencies_parsed_at":"2024-01-01T05:07:48.626Z","dependency_job_id":"d1c2d349-ff93-429d-8552-e1813c6b511a","html_url":"https://github.com/typicode/husky","commit_stats":{"total_commits":974,"total_committers":133,"mean_commits":7.323308270676692,"dds":0.1652977412731006,"last_synced_commit":"0692639896ea5b5dd5ffc607575f6f870b21cb0f"},"previous_names":[],"tags_count":196,"template":false,"template_full_name":null,"purl":"pkg:github/typicode/husky","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/typicode%2Fhusky","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/typicode%2Fhusky/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/typicode%2Fhusky/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/typicode%2Fhusky/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/typicode","download_url":"https://codeload.github.com/typicode/husky/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/typicode%2Fhusky/sbom","scorecard":{"id":905494,"data":{"date":"2025-08-11","repo":{"name":"github.com/typicode/husky","commit":"0692639896ea5b5dd5ffc607575f6f870b21cb0f"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":4.5,"checks":[{"name":"Code-Review","score":2,"reason":"Found 8/30 approved changesets -- score normalized to 2","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":"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":"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":"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":10,"reason":"GitHub workflow tokens follow principle of least privilege","details":["Info: topLevel 'contents' permission set to 'read': .github/workflows/deploy.yml:16","Info: topLevel 'contents' permission set to 'read': .github/workflows/node.js.yml:8","Info: topLevel 'contents' permission set to 'read': .github/workflows/npm_publish.yml:11","Info: no jobLevel write permissions found"],"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":"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/deploy.yml:35: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/deploy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/deploy.yml:41: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/deploy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/deploy.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/deploy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/deploy.yml:52: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/deploy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/deploy.yml:67: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/deploy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/node.js.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/node.js.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/node.js.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/node.js.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/npm_publish.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/npm_publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/npm_publish.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/npm_publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/npm_publish.yml:29: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/npm_publish.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/npm_publish.yml:30: update your workflow using https://app.stepsecurity.io/secureworkflow/typicode/husky/npm_publish.yml/main?enable=pin","Warn: npmCommand not pinned by hash: test/3_from-sub-dir.sh:15","Warn: npmCommand not pinned by hash: test/functions.sh:28","Info:   0 out of  11 GitHub-owned GitHubAction dependencies pinned","Info:   2 out of   4 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":"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":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"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":"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":"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":"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":"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":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/npm_publish.yml:23"],"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":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 8 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":0,"reason":"11 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-67mh-4wv8-2f99","Warn: Project is vulnerable to: GHSA-mwcw-c2x4-8c55","Warn: Project is vulnerable to: GHSA-gcx4-mw62-g8wm","Warn: Project is vulnerable to: GHSA-64vr-g452-qvp3","Warn: Project is vulnerable to: GHSA-9cwx-2883-4wfx","Warn: Project is vulnerable to: GHSA-vg6x-rcgg-rjx6","Warn: Project is vulnerable to: GHSA-x574-m823-4x7w","Warn: Project is vulnerable to: GHSA-4r4m-qw57-chr8","Warn: Project is vulnerable to: GHSA-xcj6-pq6g-qj4x","Warn: Project is vulnerable to: GHSA-356w-63v5-8wf4","Warn: Project is vulnerable to: GHSA-859w-5945-r5v3"],"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-24T17:12:46.475Z","repository_id":18065052,"created_at":"2025-08-24T17:12:46.475Z","updated_at":"2025-08-24T17:12:46.475Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273641898,"owners_count":25142249,"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-09-04T02:00:08.968Z","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":["commit","git","hooks","pre-commit"],"created_at":"2024-01-11T16:48:51.471Z","updated_at":"2025-09-11T12:28:17.113Z","avatar_url":"https://github.com/typicode.png","language":"JavaScript","project_url":"https://opencollective.ecosyste.ms/api/v1/projects/3892","html_url":"https://opencollective.ecosyste.ms/projects/3892","collective":{"id":2462,"uuid":"eeng0kzd-yvor4pz7-kkbqbma8-37xlw95j","slug":"husky","name":"Husky","description":"Modern native Git hooks made easy 🐶 woof!","website":"","github":"typicode/husky","twitter":"typicode","repository_url":null,"social_links":[{"type":"TWITTER","url":"https://twitter.com/typicode"},{"type":"GITHUB","url":"https://github.com/typicode/husky"}],"currency":"USD","projects_count":1,"last_synced_at":"2026-06-11T06:15:17.311Z","created_at":"2024-01-10T13:17:52.387Z","updated_at":"2026-06-11T06:15:17.642Z","transactions_count":1248,"balance":3538.479999999994,"account_type":"COLLECTIVE","owner":{"login":"typicode","name":null,"uuid":"5502029","kind":"user","description":"","email":"","website":null,"location":null,"twitter":"typicode","company":null,"icon_url":"https://avatars.githubusercontent.com/u/5502029?u=775f8ac3302e61c2c1fcb75894cc9a2c27c8f24a\u0026v=4","repositories_count":73,"last_synced_at":"2023-04-09T05:32:05.469Z","metadata":{"has_sponsors_listing":true},"html_url":"https://github.com/typicode","funding_links":["https://github.com/sponsors/typicode"],"total_stars":147147,"followers":null,"following":null,"created_at":"2022-11-02T16:21:00.677Z","updated_at":"2024-03-25T17:31:44.007Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/typicode","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/typicode/repositories"},"last_project_activity_at":"2024-11-26T00:20:16.000Z","archived":false,"no_funding":false,"no_license":false,"host":"opensource","collective_created_at":"2019-06-23T22:59:38.010Z","collective_updated_at":"2024-05-30T13:47:29.611Z","html_url":"https://opencollective.com/husky","icon_url":"https://images.opencollective.com/husky/logo/40.png","total_donations":31694.009999999915,"total_expenses":-30142.389999999978,"current_balance":3538.479999999994,"api_url":"https://opencollective.ecosyste.ms/api/v1/collectives/husky","url":"https://opencollective.ecosyste.ms/collectives/husky","projects_url":"https://opencollective.ecosyste.ms/api/v1/collectives/husky/projects"}}