See More

{"date":"2026-04-28T09:48:08Z","repo":{"name":"github.com/aws-powertools/powertools-lambda-python","commit":"0834363e7da6da3354aa5af4965d1ee3658e1cfa"},"scorecard":{"version":"v5.3.0","commit":"c22063e786c11f9dd714d777a687ff7c4599b600"},"score":8.9,"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/c22063e786c11f9dd714d777a687ff7c4599b600/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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#security-policy"}},{"name":"Code-Review","score":9,"reason":"Found 19/20 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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#code-review"}},{"name":"Maintained","score":10,"reason":"30 commit(s) and 22 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/c22063e786c11f9dd714d777a687ff7c4599b600/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/c22063e786c11f9dd714d777a687ff7c4599b600/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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#binary-artifacts"}},{"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:78","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/build_changelog.yml:23","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 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:47","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:93","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud.yml:162","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_python313.yml:152","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:58","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:90","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layer_govcloud_verify.yml:27","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layers_partition_verify.yml:116","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layers_partition_verify.yml:75","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layers_partitions.yml:72","Info: jobLevel 'contents' permission set to 'read': .github/workflows/layers_partitions.yml:120","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:136","Info: jobLevel 'actions' permission set to 'read': .github/workflows/pre-release.yml:188","Info: jobLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:56","Info: jobLevel 'contents' permission set to 'read': .github/workflows/pre-release.yml:99","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:182","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:199","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:216","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:217","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:215","Info: jobLevel 'contents' permission set to 'read': .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:234","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v3_layer.yml:261","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:263","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:264","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","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:299","Info: jobLevel 'contents' permission set to 'read': .github/workflows/publish_v3_layer.yml:296","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/publish_v3_layer.yml:316","Info: found token with 'none' permissions: .github/workflows/publish_v3_layer.yml:318","Info: jobLevel 'contents' permission set to 'read': .github/workflows/quality_check.yml:53","Info: jobLevel 'contents' permission set to 'read': .github/workflows/quality_check_docs.yml:36","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","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: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-v3.yml:363","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:392","Info: jobLevel 'contents' permission set to 'read': .github/workflows/release-v3.yml:79","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","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/reusable_publish_changelog.yml:25","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:85","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:18","Info: topLevel 'contents' permission set to 'read': .github/workflows/cflite_scheduled.yml:10","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/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: found token with 'none' permissions: .github/workflows/layers_partition_verify.yml:1","Info: topLevel 'contents' permission set to 'read': .github/workflows/layers_partitions.yml:44","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:42","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:40","Info: topLevel 'contents' permission set to 'read': .github/workflows/quality_check_docs.yml:30","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/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/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_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:69"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#cii-best-practices"}},{"name":"Fuzzing","score":10,"reason":"project is fuzzed","details":["Info: ClusterFuzzLite integration found","Info: PythonAtherisFuzzer integration found: tests/fuzz/fuzz_event_sources.py:8","Info: PythonAtherisFuzzer integration found: tests/fuzz/fuzz_parser.py:7","Info: PythonAtherisFuzzer integration found: tests/fuzz/fuzz_validation.py:8"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#fuzzing"}},{"name":"Signed-Releases","score":10,"reason":"4 out of the last 4 releases have a total of 4 signed artifacts.","details":["Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.28.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.27.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.26.0","Info: provenance for release artifact: multiple.intoto.jsonl: https://github.com/aws-powertools/powertools-lambda-python/releases/tag/v3.25.0"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#signed-releases"}},{"name":"Vulnerabilities","score":6,"reason":"4 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-5239-wwwm-4pmq","Warn: Project is vulnerable to: GHSA-9hjg-9r4m-mvj7","Warn: Project is vulnerable to: GHSA-gc5v-m9x4-r6x2","Warn: Project is vulnerable to: GHSA-v638-38fc-rhfv"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#vulnerabilities"}},{"name":"Pinned-Dependencies","score":6,"reason":"dependency not pinned by hash detected -- score normalized to 6","details":["Info: Possibly incomplete results: error parsing shell code: invalid parameter name: .github/workflows/layers_partition_verify.yml:152","Warn: third-party GitHubAction not pinned by hash: .github/workflows/on_schedule_monthly_roadmap_reminder.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/aws-powertools/powertools-lambda-python/on_schedule_monthly_roadmap_reminder.yml/develop?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pre-release.yml:193: update your workflow using https://app.stepsecurity.io/secureworkflow/aws-powertools/powertools-lambda-python/pre-release.yml/develop?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release-v3.yml:218: update your workflow using https://app.stepsecurity.io/secureworkflow/aws-powertools/powertools-lambda-python/release-v3.yml/develop?enable=pin","Warn: containerImage not pinned by hash: .clusterfuzzlite/Dockerfile:1: pin your Docker image by updating gcr.io/oss-fuzz-base/base-builder-python to gcr.io/oss-fuzz-base/base-builder-python@sha256:a7652a04e2db56911868c9aeab9fa4eb1dbabb6a9e45772b2fa718dd4471fa25","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: .clusterfuzzlite/Dockerfile:9","Warn: pipCommand not pinned by hash: examples/build_recipes/build_multi_arch/Dockerfile.lambda:11","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: pipCommand not pinned by hash: examples/build_recipes/build_multi_arch/build-linux-wheels.sh:7","Warn: pipCommand not pinned by hash: examples/build_recipes/build_multi_arch/debug-arch-mismatch.sh:12","Warn: pipCommand not pinned by hash: examples/build_recipes/build_optimization/optimize-layer.sh:7","Warn: pipCommand not pinned by hash: examples/build_recipes/build_optimization/optimize-layer.sh:8","Warn: pipCommand not pinned by hash: examples/build_recipes/cdk/basic/build-cdk.sh:6","Warn: pipCommand not pinned by hash: examples/build_recipes/cdk/basic/cdk-commands.sh:3","Warn: npmCommand not pinned by hash: examples/build_recipes/cdk/basic/setup-cdk.sh:3","Warn: pipCommand not pinned by hash: examples/build_recipes/pip/build-cross-platform.sh:5","Warn: pipCommand not pinned by hash: examples/build_recipes/pip/build-cross-platform.sh:11","Warn: pipCommand not pinned by hash: examples/build_recipes/pip/build-with-layer.sh:5","Warn: pipCommand not pinned by hash: examples/build_recipes/pip/build-with-layer.sh:12","Warn: pipCommand not pinned by hash: examples/build_recipes/pip/build.sh:7","Warn: pipCommand not pinned by hash: examples/build_recipes/poetry/build-poetry-cross-platform.sh:8","Warn: pipCommand not pinned by hash: examples/build_recipes/poetry/build-poetry-cross-platform.sh:14","Warn: pipCommand not pinned by hash: examples/build_recipes/poetry/build-with-poetry.sh:10","Warn: pipCommand not pinned by hash: examples/build_recipes/sam/with-layers/build-sam-with-layers.sh:8","Warn: pipCommand not pinned by hash: examples/build_recipes/troubleshooting/debug-import-errors.sh:9","Warn: pipCommand not pinned by hash: examples/build_recipes/troubleshooting/fix-architecture-mismatch.sh:7","Warn: pipCommand not pinned by hash: examples/build_recipes/troubleshooting/fix-build-inconsistencies.sh:9","Warn: pipCommand not pinned by hash: examples/build_recipes/troubleshooting/fix-layer-compatibility.sh:13","Warn: pipCommand not pinned by hash: examples/build_recipes/troubleshooting/optimize-package-size.sh:3","Warn: pipCommand not pinned by hash: .github/workflows/quality_code_cdk_constructor.yml:66","Info: 74 out of 74 GitHub-owned GitHubAction dependencies pinned","Info: 34 out of 37 third-party GitHubAction dependencies pinned","Info: 3 out of 6 containerImage dependencies pinned","Info: 5 out of 31 pipCommand dependencies pinned","Info: 3 out of 4 npmCommand dependencies pinned","Info: 1 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/c22063e786c11f9dd714d777a687ff7c4599b600/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 (29) are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#sast"}},{"name":"Packaging","score":10,"reason":"packaging workflow detected","details":["Info: Project packages its releases by way of GitHub Actions.: .github/workflows/pre-release.yml:202"],"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#packaging"}},{"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#license"}},{"name":"CI-Tests","score":10,"reason":"29 out of 29 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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#ci-tests"}},{"name":"Branch-Protection","score":5,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'allow deletion' disabled on branch 'develop'","Info: 'force pushes' disabled on branch 'develop'","Info: 'branch protection settings apply to administrators' is required to merge on branch 'develop'","Info: 'stale review dismissal' is required to merge on branch 'develop'","Warn: required approving review count is 1 on branch 'develop'","Info: codeowner review is required on branch 'develop'","Warn: 'last push approval' is disabled on branch 'develop'","Info: 'up-to-date branches' is required to merge on branch 'develop'","Info: status check found to merge onto on branch 'develop'","Info: PRs are required in order to make changes on branch 'develop'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#branch-protection"}},{"name":"Contributors","score":10,"reason":"project has 13 contributing companies or organizations","details":["Info: found contributions from: Cloud-Architects, accenture, adyen, amazon, amazon web services, aws, aws-samples, gyft, javalite, jenkinsci, palo alto networks, 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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#contributors"}}]}