(original) (raw)

{"date":"2025-06-19T09:04:27Z","repo":{"name":"github.com/aws-powertools/powertools-lambda-python","commit":"e47003a6a60ebe756db3847df3e62467997cb983"},"scorecard":{"version":"v5.2.1","commit":"ab2f6e92482462fe66246d9e32f642855a691dc1"},"score":8.8,"checks":[{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: detected update tool: Dependabot: .github/dependabot.yml:1"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#dependency-update-tool"}},{"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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#security-policy"}},{"name":"Code-Review","score":10,"reason":"all changesets reviewed","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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#code-review"}},{"name":"Maintained","score":10,"reason":"30 commit(s) and 0 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/ab2f6e92482462fe66246d9e32f642855a691dc1/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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#dangerous-workflow"}},{"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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#binary-artifacts"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT No Attribution: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#license"}},{"name":"Token-Permissions","score":9,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Info: jobLevel 'contents' permission set to 'read': .github/workflows/bootstrap_region.yml:42","Info: jobLevel 'contents' permission set to 'read': .github/workflows/bootstrap_region.yml:73","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build_changelog.yml:29","Info: jobLevel 'actions' permission set to 'read': .github/workflows/codeql-analysis.yml:27","Info: jobLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:19","Info: jobLevel 'discussions' permission set to 'read': .github/workflows/dispatch_analytics.yml:37","Info: jobLevel 'pages' permission set to 'read': .github/workflows/dispatch_analytics.yml:39","Info: jobLevel 'repository-projects' permission set to 'read': .github/workflows/dispatch_analytics.yml:41","Info: jobLevel 'statuses' permission set to 'read': .github/workflows/dispatch_analytics.yml:43","Info: jobLevel 'actions' permission set to 'read': .github/workflows/dispatch_analytics.yml:32","Info: jobLevel 'contents' permission set to 'read': .github/workflows/dispatch_analytics.yml:34","Info: jobLevel 'issues' permission set to 'read': .github/workflows/dispatch_analytics.yml:36","Info: jobLevel 'packages' permission set to 'read': .github/workflows/dispatch_analytics.yml:38","Info: jobLevel 'pull-requests' permission set to 'read': .github/workflows/dispatch_analytics.yml:40","Info: jobLevel 'security-events' permission set to 'read': .github/workflows/dispatch_analytics.yml:42","Info: jobLevel 'checks' permission set to 'read': .github/workflows/dispatch_analytics.yml:33","Info: jobLevel 'deployments' permission set to 'read': .github/workflows/dispatch_analytics.yml:35","Info: jobLevel 'actions' permission set to 'read': .github/workflows/label_pr_on_title.yml:35","Info: jobLevel 'contents' permission set to 'read': .github/workflows/label_pr_on_title.yml:36","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:92","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:160","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:47","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_python313.yml:152","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_python313.yml:47","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_python313.yml:88","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:27","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:57","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:88","Info: jobLevel 'actions' permission set to 'read': .github/workflows/on_label_added.yml:34","Info: jobLevel 'contents' permission set to 'read': .github/workflows/on_label_added.yml:35","Info: jobLevel 'actions' permission set to 'read': .github/workflows/on_merged_pr.yml:35","Info: jobLevel 'contents' permission set to 'read': .github/workflows/on_merged_pr.yml:36","Info: jobLevel 'actions' permission set to 'read': .github/workflows/on_opened_pr.yml:35","Info: jobLevel 'contents' permission set to 'read': .github/workflows/on_opened_pr.yml:36","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/on_push_docs.yml:29","Info: jobLevel 'contents' permission set to 'read': .github/workflows/on_schedule_monthly_roadmap_reminder.yml:15","Info: jobLevel 'pull-requests' permission set to 'read': .github/workflows/on_schedule_monthly_roadmap_reminder.yml:16","Info: jobLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:55","Info: jobLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:110","Info: jobLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:147","Info: jobLevel 'actions' permission set to 'read': .github/workflows/pre-release.yml:199","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:195","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:196","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:197","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:215","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:216","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:214","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:246","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:247","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v2_layer.yml:244","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:290","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:291","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:288","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:289","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v2_layer.yml:308","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:310","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:81","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:83","Info: found token with 'none' permissions: .github/workflows/publish_v2_layer.yml:84","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:159","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:177","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:295","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:296","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:297","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:298","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v3_layer.yml:315","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:317","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:97","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:99","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:100","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:181","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:198","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:214","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:215","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:216","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:231","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:232","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:233","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:262","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:263","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v3_layer.yml:260","Info: jobLevel 'contents' permission set to 'read': .github/workflows/quality_check.yml:53","Info: jobLevel 'contents' permission set to 'read': .github/workflows/quality_code_cdk_constructor.yml:40","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/rebuild_latest_docs.yml:32","Info: jobLevel 'contents' permission set to 'read': .github/workflows/record_pr.yml:47","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/release-drafter.yml:28","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:363","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:79","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:124","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:161","Info: jobLevel 'actions' permission set to 'read': .github/workflows/release-v3.yml:213","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release.yml:70","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release.yml:152","Info: jobLevel 'actions' permission set to 'read': .github/workflows/release.yml:204","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release.yml:115","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release.yml:352","Info: found token with 'none' permissions: .github/workflows/reusable_deploy_v2_layer_stack.yml:71","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v2_layer_stack.yml:72","Info: found token with 'none' permissions: .github/workflows/reusable_deploy_v2_layer_stack.yml:73","Info: found token with 'none' permissions: .github/workflows/reusable_deploy_v3_layer_stack.yml:64","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v3_layer_stack.yml:65","Info: found token with 'none' permissions: .github/workflows/reusable_deploy_v3_layer_stack.yml:66","Info: jobLevel 'actions' permission set to 'read': .github/workflows/reusable_export_pr_details.yml:62","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/reusable_publish_changelog.yml:25","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/reusable_publish_docs.yml:43","Info: jobLevel 'contents' permission set to 'read': .github/workflows/run-e2e-tests.yml:47","Info: jobLevel 'contents' permission set to 'read': .github/workflows/secure_workflows.yml:30","Info: jobLevel 'contents' permission set to 'read': .github/workflows/update_ssm.yml:61","Info: topLevel 'contents' permission set to 'read': .github/workflows/bootstrap_region.yml:35","Info: topLevel 'contents' permission set to 'read': .github/workflows/build_changelog.yml:24","Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql-analysis.yml:18","Info: topLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/dispatch_analytics.yml:20","Info: topLevel 'contents' permission set to 'read': .github/workflows/label_pr_on_title.yml:30","Info: topLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:40","Info: topLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_python313.yml:40","Warn: no topLevel permission defined: .github/workflows/layer_govcloud_verify.yml:1","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_closed_issues.yml:16","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_label_added.yml:29","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_merged_pr.yml:30","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_opened_pr.yml:30","Info: found token with 'none' permissions: .github/workflows/on_pr_updates.yml:1","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_push_docs.yml:24","Info: topLevel 'contents' permission set to 'read': .github/workflows/on_schedule_monthly_roadmap_reminder.yml:9","Info: topLevel permissions set to 'read-all': .github/workflows/ossf_scorecard.yml:12","Info: topLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:41","Info: topLevel 'contents' permission set to 'read': .github/workflows/publish_v2_layer.yml:71","Info: topLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:87","Info: topLevel 'contents' permission set to 'read': .github/workflows/quality_check.yml:41","Info: topLevel 'contents' permission set to 'read': .github/workflows/quality_code_cdk_constructor.yml:28","Info: topLevel 'contents' permission set to 'read': .github/workflows/rebuild_latest_docs.yml:27","Info: topLevel 'contents' permission set to 'read': .github/workflows/record_pr.yml:41","Info: topLevel 'contents' permission set to 'read': .github/workflows/release-drafter.yml:22","Info: topLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:68","Info: topLevel 'contents' permission set to 'read': .github/workflows/release.yml:59","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v2_layer_stack.yml:59","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v2_sar.yml:36","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v3_layer_stack.yml:52","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_deploy_v3_sar.yml:35","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_export_pr_details.yml:57","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_publish_changelog.yml:14","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable_publish_docs.yml:31","Info: topLevel 'contents' permission set to 'read': .github/workflows/run-e2e-tests.yml:40","Info: topLevel 'contents' permission set to 'read': .github/workflows/secure_workflows.yml:23","Info: topLevel 'contents' permission set to 'read': .github/workflows/update_ssm.yml:45"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":5,"reason":"badge detected: Passing","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#cii-best-practices"}},{"name":"Pinned-Dependencies","score":8,"reason":"dependency not pinned by hash detected -- score normalized to 8","details":["Warn: containerImage not pinned by hash: layer_v3/docker/Dockerfile:4","Warn: containerImage not pinned by hash: layer_v3/docker/Dockerfile:7","Warn: pipCommand not pinned by hash: layer_v3/docker/Dockerfile:30","Warn: pipCommand not pinned by hash: layer_v3/docker/Dockerfile:30","Warn: pipCommand not pinned by hash: layer_v3/docker/Dockerfile:32","Warn: npmCommand not pinned by hash: .github/workflows/bootstrap_region.yml:61","Warn: goCommand not pinned by hash: .github/workflows/bootstrap_region.yml:106","Warn: pipCommand not pinned by hash: .github/workflows/quality_code_cdk_constructor.yml:67","Info: 102 out of 102 GitHub-owned GitHubAction dependencies pinned","Info: 35 out of 35 third-party GitHubAction dependencies pinned","Info: 2 out of 4 containerImage dependencies pinned","Info: 6 out of 10 pipCommand dependencies pinned","Info: 5 out of 6 npmCommand dependencies pinned","Info: 0 out of 1 goCommand 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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#pinned-dependencies"}},{"name":"Vulnerabilities","score":5,"reason":"5 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: PYSEC-2024-187 / GHSA-rqc4-2hc7-8c8v","Warn: Project is vulnerable to: GHSA-9hjg-9r4m-mvj7","Warn: Project is vulnerable to: GHSA-48p4-8xcf-vxj5","Warn: Project is vulnerable to: GHSA-pq67-6m6q-mj2v","Warn: Project is vulnerable to: GHSA-79v4-65xg-pq4g"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#vulnerabilities"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (30) are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#sast"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by personal access token","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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#branch-protection"}},{"name":"Signed-Releases","score":10,"reason":"5 out of the last 5 releases have a total of 5 signed artifacts.","details":["Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.14.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.13.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.12.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.11.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.10.0"\],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#signed-releases"}},{"name":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/pre-release.yml:213"],"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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#packaging"}},{"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/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#fuzzing"}},{"name":"CI-Tests","score":10,"reason":"30 out of 30 merged PRs checked by a CI test -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#ci-tests"}},{"name":"Contributors","score":10,"reason":"project has 15 contributing companies or organizations","details":["Info: found contributions from: Cloud-Architects, adyen, amazon, apollographql, aws, aws-controllers-k8s, aws-powertools, aws-samples, awslabs, cyberark, gyft, javalite, jenkinsci, virtasant, zimfw"],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/ab2f6e92482462fe66246d9e32f642855a691dc1/docs/checks.md#contributors"}}\]}