{"id":2356759,"name":"shift-parser","ecosystem":"npm","description":"ECMAScript parser that produces a Shift format AST","homepage":"https://github.com/shapesecurity/shift-parser-js","licenses":"Apache-2.0","normalized_licenses":["Apache-2.0"],"repository_url":"https://github.com/shapesecurity/shift-parser-js","keywords_array":["Shift","AST","node","parser","SpiderMonkey","Parser","API","parse","spider","monkey","abstract","syntax","tree"],"namespace":null,"versions_count":36,"first_release_published_at":"2014-12-18T06:06:57.959Z","latest_release_published_at":"2022-04-27T02:15:41.115Z","latest_release_number":"8.0.0","last_synced_at":"2026-05-31T00:20:23.565Z","created_at":"2022-04-10T00:38:47.218Z","updated_at":"2026-05-31T00:20:23.566Z","registry_url":"https://www.npmjs.com/package/shift-parser","install_command":"npm install shift-parser","documentation_url":null,"metadata":{"funding":null,"dist-tags":{"latest":"8.0.0"}},"repo_metadata":{"id":24526772,"uuid":"27932959","full_name":"shapesecurity/shift-parser-js","owner":"shapesecurity","description":"ECMAScript parser that produces a Shift format AST","archived":false,"fork":false,"pushed_at":"2022-05-04T20:27:29.000Z","size":4801,"stargazers_count":259,"open_issues_count":31,"forks_count":29,"subscribers_count":18,"default_branch":"es2019","last_synced_at":"2026-05-16T06:48:37.083Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"http://shift-ast.org/parser.html","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/shapesecurity.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2014-12-12T18:34:15.000Z","updated_at":"2026-03-03T19:26:48.000Z","dependencies_parsed_at":"2022-08-22T23:40:46.491Z","dependency_job_id":null,"html_url":"https://github.com/shapesecurity/shift-parser-js","commit_stats":null,"previous_names":[],"tags_count":39,"template":false,"template_full_name":null,"purl":"pkg:github/shapesecurity/shift-parser-js","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/shapesecurity","download_url":"https://codeload.github.com/shapesecurity/shift-parser-js/tar.gz/refs/heads/es2019","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js/sbom","scorecard":{"id":816255,"data":{"date":"2025-08-11","repo":{"name":"github.com/shapesecurity/shift-parser-js","commit":"4c0c8042f7939e954929dd694ef2acf36a75c8ca"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.8,"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":"Code-Review","score":9,"reason":"Found 22/23 approved changesets -- score normalized to 9","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":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/check.yml:1","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":"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":"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":"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":"Pinned-Dependencies","score":2,"reason":"dependency not pinned by hash detected -- score normalized to 2","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/check.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/shapesecurity/shift-parser-js/check.yml/es2019?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/check.yml:40: update your workflow using https://app.stepsecurity.io/secureworkflow/shapesecurity/shift-parser-js/check.yml/es2019?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/check.yml:43: update your workflow using https://app.stepsecurity.io/secureworkflow/shapesecurity/shift-parser-js/check.yml/es2019?enable=pin","Warn: downloadThenRun not pinned by hash: .github/workflows/check.yml:25","Info:   0 out of   3 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   1 downloadThenRun 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":"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: Apache License 2.0: 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":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 30 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":"46 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-67hx-6x53-jw92","Warn: Project is vulnerable to: GHSA-6chw-6frg-f759","Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-89mq-4x47-5v83","Warn: Project is vulnerable to: GHSA-5cp4-xmrw-59wf","Warn: Project is vulnerable to: GHSA-mhp6-pxh8-r675","Warn: Project is vulnerable to: GHSA-2qqx-w9hr-q5gx","Warn: Project is vulnerable to: GHSA-2vrf-hf26-jrp5","Warn: Project is vulnerable to: GHSA-4w4v-5hc9-xrr2","Warn: Project is vulnerable to: GHSA-j58c-ww9w-pwp5","Warn: Project is vulnerable to: GHSA-m2h2-264f-f486","Warn: Project is vulnerable to: GHSA-m9gf-397r-hwpg","Warn: Project is vulnerable to: GHSA-mqm9-c95h-x2p6","Warn: Project is vulnerable to: GHSA-prc3-vjfx-vhm9","Warn: Project is vulnerable to: GHSA-qwqh-hm9m-p5hr","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-gxpj-cx7g-858c","Warn: Project is vulnerable to: GHSA-4gmj-3p3h-gm8h","Warn: Project is vulnerable to: GHSA-3gx7-xhv7-5mx3","Warn: Project is vulnerable to: GHSA-2j2x-2gpw-g8fm","Warn: Project is vulnerable to: GHSA-q42p-pg8m-cqh6","Warn: Project is vulnerable to: GHSA-w457-6q6x-cgp9","Warn: Project is vulnerable to: GHSA-62gr-4qp9-h98f","Warn: Project is vulnerable to: GHSA-f52g-6jhx-586p","Warn: Project is vulnerable to: GHSA-2cf5-4w76-r9qv","Warn: Project is vulnerable to: GHSA-3cqr-58rm-57f8","Warn: Project is vulnerable to: GHSA-g9r4-xpmj-mj65","Warn: Project is vulnerable to: GHSA-q2c6-c6pm-g3gh","Warn: Project is vulnerable to: GHSA-765h-qjxv-5f44","Warn: Project is vulnerable to: GHSA-f2jv-r9rf-7988","Warn: Project is vulnerable to: GHSA-43f8-2h32-f4cj","Warn: Project is vulnerable to: GHSA-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-4xcv-9jjx-gfj3","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-vh95-rmgr-6w4m","Warn: Project is vulnerable to: GHSA-xvch-5gv4-984h","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-c4w7-xm78-47vh","Warn: Project is vulnerable to: GHSA-p9pc-299p-vxgp"],"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-23T14:19:57.056Z","repository_id":24526772,"created_at":"2025-08-23T14:19:57.056Z","updated_at":"2025-08-23T14:19:57.056Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33715180,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-05-30T02:00:06.278Z","response_time":92,"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"},"tags":[]},"repo_metadata_updated_at":"2026-05-31T00:20:23.206Z","dependent_packages_count":52,"downloads":167269,"downloads_period":"last-month","dependent_repos_count":113,"rankings":{"downloads":1.3828445272040752,"dependent_repos_count":1.380811306065014,"dependent_packages_count":0.5874032349113106,"stargazers_count":3.8406889760554384,"forks_count":4.469928766581713,"docker_downloads_count":null,"average":2.3323353621635103},"purl":"pkg:npm/shift-parser","advisories":[],"docker_usage_url":"https://docker.ecosyste.ms/usage/npm/shift-parser","docker_dependents_count":null,"docker_downloads_count":null,"usage_url":"https://repos.ecosyste.ms/usage/npm/shift-parser","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/npm/shift-parser/dependencies","status":null,"funding_links":[],"critical":null,"issue_metadata":{"last_synced_at":"2025-11-18T12:20:50.096Z","issues_count":37,"pull_requests_count":63,"avg_time_to_close_issue":11206021.64,"avg_time_to_close_pull_request":5745424.294117647,"issues_closed_count":25,"pull_requests_closed_count":51,"pull_request_authors_count":8,"issue_authors_count":16,"avg_comments_per_issue":0.972972972972973,"avg_comments_per_pull_request":0.3968253968253968,"merged_pull_requests_count":43,"bot_issues_count":0,"bot_pull_requests_count":14,"past_year_issues_count":0,"past_year_pull_requests_count":0,"past_year_avg_time_to_close_issue":null,"past_year_avg_time_to_close_pull_request":null,"past_year_issues_closed_count":0,"past_year_pull_requests_closed_count":0,"past_year_pull_request_authors_count":0,"past_year_issue_authors_count":0,"past_year_avg_comments_per_issue":null,"past_year_avg_comments_per_pull_request":null,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0,"issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/shapesecurity%2Fshift-parser-js/issues","maintainers":[{"login":"bakkot","count":47,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/bakkot"},{"login":"michaelficarra","count":2,"url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/authors/michaelficarra"}],"active_maintainers":[]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/version_numbers","latest_version_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/latest_version","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/related_packages","codemeta_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/shift-parser/codemeta","maintainers":[{"uuid":"michaelficarra","login":"michaelficarra","name":null,"email":"npm@michael.ficarra.me","url":null,"packages_count":41,"html_url":"https://www.npmjs.com/~michaelficarra","role":null,"created_at":"2022-11-14T10:22:19.366Z","updated_at":"2022-11-14T10:22:19.366Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/maintainers/michaelficarra/packages"},{"uuid":"shapesecurity","login":"shapesecurity","name":null,"email":"npm@shapesecurity.com","url":null,"packages_count":21,"html_url":"https://www.npmjs.com/~shapesecurity","role":null,"created_at":"2022-11-14T10:22:19.440Z","updated_at":"2022-11-14T10:22:19.440Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/maintainers/shapesecurity/packages"},{"uuid":"bakkot","login":"bakkot","name":null,"email":"bakkot@gmail.com","url":null,"packages_count":39,"html_url":"https://www.npmjs.com/~bakkot","role":null,"created_at":"2022-11-14T10:22:19.422Z","updated_at":"2022-11-14T10:22:19.422Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/maintainers/bakkot/packages"}]}