{"id":15016262,"url":"https://github.com/metacpan/metacpan-web","last_synced_at":"2025-12-18T02:58:01.236Z","repository":{"id":37580176,"uuid":"1630833","full_name":"metacpan/metacpan-web","owner":"metacpan","description":"Web interface for MetaCPAN","archived":false,"fork":false,"pushed_at":"2025-12-08T15:15:27.000Z","size":15525,"stargazers_count":470,"open_issues_count":215,"forks_count":234,"subscribers_count":41,"default_branch":"master","last_synced_at":"2025-12-09T21:17:12.111Z","etag":null,"topics":["cpan","hacktoberfest","metacpan","perl"],"latest_commit_sha":null,"homepage":"http://metacpan.org","language":"Perl","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/metacpan.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2011-04-18T14:25:49.000Z","updated_at":"2025-12-08T15:15:30.000Z","dependencies_parsed_at":"2025-11-28T04:07:18.204Z","dependency_job_id":null,"html_url":"https://github.com/metacpan/metacpan-web","commit_stats":{"total_commits":3749,"total_committers":146,"mean_commits":25.67808219178082,"dds":0.7356628434249133,"last_synced_commit":"4e47dd654483244430942b00849326dd407881b0"},"previous_names":[],"tags_count":2,"template":false,"template_full_name":null,"purl":"pkg:github/metacpan/metacpan-web","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/metacpan%2Fmetacpan-web","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/metacpan%2Fmetacpan-web/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/metacpan%2Fmetacpan-web/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/metacpan%2Fmetacpan-web/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/metacpan","download_url":"https://codeload.github.com/metacpan/metacpan-web/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/metacpan%2Fmetacpan-web/sbom","scorecard":{"id":287794,"data":{"date":"2025-08-11","repo":{"name":"github.com/metacpan/metacpan-web","commit":"eb15798a81f50793cafba8efbb9203f37b49e628"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":6.7,"checks":[{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: SECURITY.md:1","Info: Found linked content: SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: SECURITY.md:1","Info: Found text in security policy: 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":"Maintained","score":10,"reason":"30 commit(s) and 8 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"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":5,"reason":"Found 2/4 approved changesets -- score normalized to 5","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/automerge.yml:1","Warn: no topLevel permission defined: .github/workflows/build-container.yml:1","Warn: no topLevel permission defined: .github/workflows/codeql-analysis.yml:1","Warn: no topLevel permission defined: .github/workflows/test.yml:1","Warn: no topLevel permission defined: .github/workflows/update-snapshot.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":"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":"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":"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":9,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Warn: project license file does not contain an FSF or OSI license."],"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":"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/test.yml:54"],"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":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/automerge.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/automerge.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/automerge.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/automerge.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-container.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/build-container.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/build-container.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/build-container.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-container.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/build-container.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/build-container.yml:42: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/build-container.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql-analysis.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/codeql-analysis.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql-analysis.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/codeql-analysis.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql-analysis.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/codeql-analysis.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql-analysis.yml:48: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/codeql-analysis.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:60: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/test.yml:71: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:74: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/test.yml:83: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/test.yml:112: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/test.yml:113: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:119: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:124: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:134: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:148: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/test.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/test.yml:30: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/test.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/update-snapshot.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/update-snapshot.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/update-snapshot.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/update-snapshot.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/update-snapshot.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/update-snapshot.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/update-snapshot.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/update-snapshot.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/update-snapshot.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/metacpan/metacpan-web/update-snapshot.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:7","Warn: containerImage not pinned by hash: Dockerfile:32","Warn: containerImage not pinned by hash: Dockerfile:33","Warn: containerImage not pinned by hash: Dockerfile:36","Warn: containerImage not pinned by hash: Dockerfile:59","Warn: containerImage not pinned by hash: Dockerfile:94","Warn: containerImage not pinned by hash: Dockerfile:114","Warn: containerImage not pinned by hash: Dockerfile:153","Warn: npmCommand not pinned by hash: Dockerfile:15","Warn: downloadThenRun not pinned by hash: Dockerfile:123-126","Warn: npmCommand not pinned by hash: Dockerfile:126-129","Warn: npmCommand not pinned by hash: Dockerfile:135","Warn: npmCommand not pinned by hash: bin/install-playwright:4","Warn: downloadThenRun not pinned by hash: bin/install-precious:19","Warn: npmCommand not pinned by hash: .github/workflows/test.yml:117","Warn: npmCommand not pinned by hash: .github/workflows/test.yml:25","Info:   0 out of  14 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  14 third-party GitHubAction dependencies pinned","Info:   0 out of   6 npmCommand dependencies pinned","Info:   0 out of   2 downloadThenRun dependencies pinned","Info:   0 out of   8 containerImage 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":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (28) 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":8,"reason":"2 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-9mvj-f7w8-pvh2","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw"],"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-17T17:36:48.549Z","repository_id":37580176,"created_at":"2025-08-17T17:36:48.550Z","updated_at":"2025-08-17T17:36:48.550Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":27790053,"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-12-18T02:00:09.725Z","response_time":55,"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":["cpan","hacktoberfest","metacpan","perl"],"created_at":"2024-09-24T19:48:37.455Z","updated_at":"2025-12-18T02:58:01.216Z","avatar_url":"https://github.com/metacpan.png","language":"Perl","funding_links":[],"categories":[],"sub_categories":[],"readme":"![test](https://github.com/metacpan/metacpan-web/workflows/test/badge.svg?branch=master)\n[![Coverage Status](https://coveralls.io/repos/metacpan/metacpan-web/badge.svg)](https://coveralls.io/r/metacpan/metacpan-web)\n\n\u003c!-- vim-markdown-toc GFM --\u003e\n\n- [Getting Started](#getting-started)\n  - [Installing Manually](#installing-manually)\n    - [Building Static Assets](#building-static-assets)\n    - [Installing on macOS](#installing-on-macos)\n  - [Running Tests](#running-tests)\n  - [Running the App](#running-the-app)\n  - [Local Git and testing considerations](#local-git-and-testing-considerations)\n  - [Local Configuration Changes](#local-configuration-changes)\n  - [Compatibility Notes](#compatibility-notes)\n\n\u003c!-- vim-markdown-toc --\u003e\n\n# Getting Started\n\nWe strongly recommend using\n[metacpan-docker](https://github.com/metacpan/metacpan-docker). This will give\nyou a virtual machine already configured and ready to start developing on.\n\nIf you prefer not to use Docker, the following commands will get you started:\n\n## Installing Manually\n\n```bash\ncarton install\nnpm install\nexport PATH=\"$(realpath ./node_modules/.bin):$PATH\"\n```\n\n### Building Static Assets\n\n```bash\nnpm run build\n```\n\nWithout running this command you may get errors about a missing \"asset map\".\n\n### Installing on macOS\n\nIf you like, you can install `carton` and `cmark` via Homebrew:\n\n```bash\nbrew install carton cmark\n```\n\nOn an ARM Mac you may need to install\n[CommonMark](https://metacpan.org/pod/CommonMark) in the following way:\n\n```bash\nLIBRARY_PATH=/opt/homebrew/lib CPATH=/opt/homebrew/include cpm install -g CommonMark\n```\n\nIf your `carton install` is having issues with SSL-related modules, you may need\nto use an `OPENSSL_PREFIX`. Something like:\n\n```bash\nOPENSSL_PREFIX=\"/usr/local/Cellar/openssl@1.1/1.1.1q\" carton install\n```\n\nYou may need to check `/usr/local/Cellar/openssl@1.1` to find the latest\ninstalled path on your system.\n\n## Running Tests\n\nYou can use the supplied wrapper around `prove` to run tests:\n\n```bash\n./bin/prove t\n```\n\nTo run the tests in parallel, add `-j8` (or however many CPUs you have) to the\n`prove` command.\n\n## Running the App\n\n```bash\ncarton exec plackup -p 5001 -r\n```\n\nIf you'd like to use `Gazelle` rather than the default Plack server:\n\n```bash\ncarton exec plackup -p 5001 -s Gazelle -r\n```\n\n## Local Git and testing considerations\n\nYou will want to set up the supplied pre-commit Git hook like so:\n\n```bash\n./git/setup.sh\n```\n\nwhich causes `precious` to be run before each commit. You can manually run this\nwith `precious path/to/file`\n\n## Local Configuration Changes\n\nThe back end defaults to `api.metacpan.org/v1`. Running a local API server is\noptional and not required to hack on the front end. The address to the API being\nused can be changed in the `metacpan_web.yaml` file. Ideally you would create a\nnew file called `metacpan_web_local.yaml` that contains\n\n```bash\napi: http://127.0.0.1:5000\n```\n\nwhich will be loaded on top of the existing config file.\n\n## Compatibility Notes\n\nOn Win32 (and possibly also on other platforms) when using Perl \u003c 5.12, the\nserver started with plackup will generate warnings relating to date parsing.\nThese are caused by Plack due to a bug in the gmtime implementation and can be\nremoved by upgrading to Perl 5.12.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmetacpan%2Fmetacpan-web","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmetacpan%2Fmetacpan-web","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmetacpan%2Fmetacpan-web/lists"}