{"id":43537247,"url":"https://github.com/cuioss/cuioss-organization","last_synced_at":"2026-03-03T11:02:48.009Z","repository":{"id":335333352,"uuid":"1145284802","full_name":"cuioss/cuioss-organization","owner":"cuioss","description":"Contains organization specific defaults and documentation ","archived":false,"fork":false,"pushed_at":"2026-02-19T20:25:37.000Z","size":531,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-02-19T21:39:34.554Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"Python","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/cuioss.png","metadata":{"files":{"readme":"README.adoc","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,"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},"funding":{"github":"cuioss"}},"created_at":"2026-01-29T16:33:01.000Z","updated_at":"2026-02-19T20:25:40.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/cuioss/cuioss-organization","commit_stats":null,"previous_names":["cuioss/cuioss-organization"],"tags_count":29,"template":false,"template_full_name":null,"purl":"pkg:github/cuioss/cuioss-organization","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/cuioss%2Fcuioss-organization","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/cuioss%2Fcuioss-organization/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/cuioss%2Fcuioss-organization/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/cuioss%2Fcuioss-organization/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/cuioss","download_url":"https://codeload.github.com/cuioss/cuioss-organization/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/cuioss%2Fcuioss-organization/sbom","scorecard":{"id":1243297,"data":{"date":"2026-02-12T20:28:19Z","repo":{"name":"github.com/cuioss/cuioss-organization","commit":"a3e4a8c761755449cd340e399f5a012c7c47cf57"},"scorecard":{"version":"v5.3.0","commit":"c22063e786c11f9dd714d777a687ff7c4599b600"},"score":6.9,"checks":[{"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":"Code-Review","score":0,"reason":"Found 0/23 approved changesets -- score normalized to 0","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":"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":"Maintained","score":0,"reason":"project was created within the last 90 days. Please review its contents carefully","details":["Warn: Repository was created within the last 90 days."],"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":"Pinned-Dependencies","score":8,"reason":"dependency not pinned by hash detected -- score normalized to 8","details":["Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-maven-build.yml:91: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-maven-build.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-maven-integration-tests.yml:91: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-maven-integration-tests.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-maven-release.yml:67: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-maven-release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-npm-build.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-npm-build.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-npm-publish.yml:51: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-npm-publish.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/reusable-pyprojectx-verify.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/cuioss/cuioss-organization/reusable-pyprojectx-verify.yml/main?enable=pin","Warn: npmCommand not pinned by hash: .github/workflows/reusable-npm-publish.yml:62","Info:  49 out of  49 GitHub-owned GitHubAction dependencies pinned","Info:  28 out of  34 third-party GitHubAction dependencies pinned","Info:   3 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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#pinned-dependencies"}},{"name":"Token-Permissions","score":10,"reason":"GitHub workflow tokens follow principle of least privilege","details":["Warn: jobLevel 'security-events' permission set to 'write': .github/workflows/codeql.yml:21","Info: jobLevel 'contents' permission set to 'read': .github/workflows/codeql.yml:22","Info: jobLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:14","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-codeql.yml:30","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-dependency-review.yml:29","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:71","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:99","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:136","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:180","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:233","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-integration-tests.yml:69","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-integration-tests.yml:99","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-integration-tests.yml:137","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-npm-build.yml:34","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-npm-build.yml:55","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-npm-build.yml:88","Warn: jobLevel 'contents' permission set to 'write': .github/workflows/reusable-npm-publish.yml:25","Info: jobLevel 'contents' permission set to 'read': .github/workflows/reusable-scorecards.yml:22","Info: jobLevel 'actions' permission set to 'read': .github/workflows/reusable-scorecards.yml:23","Info: jobLevel 'issues' permission set to 'read': .github/workflows/reusable-scorecards.yml:24","Info: jobLevel 'pull-requests' permission set to 'read': .github/workflows/reusable-scorecards.yml:25","Info: jobLevel 'checks' permission set to 'read': .github/workflows/reusable-scorecards.yml:26","Info: jobLevel 'contents' permission set to 'read': .github/workflows/scorecards.yml:20","Info: jobLevel 'actions' permission set to 'read': .github/workflows/scorecards.yml:21","Info: jobLevel 'issues' permission set to 'read': .github/workflows/scorecards.yml:22","Info: jobLevel 'pull-requests' permission set to 'read': .github/workflows/scorecards.yml:23","Info: jobLevel 'checks' permission set to 'read': .github/workflows/scorecards.yml:24","Warn: jobLevel 'security-events' permission set to 'write': .github/workflows/scorecards.yml:18","Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/dependency-review.yml:8","Info: topLevel 'contents' permission set to 'read': .github/workflows/python-verify.yml:10","Info: topLevel 'contents' permission set to 'read': .github/workflows/release.yml:7","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-codeql.yml:22","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-dependency-review.yml:23","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-build.yml:64","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-integration-tests.yml:62","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-maven-release.yml:37","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-npm-build.yml:27","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-npm-publish.yml:19","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-pyprojectx-verify.yml:29","Info: topLevel 'contents' permission set to 'read': .github/workflows/reusable-scorecards.yml:13","Info: topLevel 'contents' permission set to 'read': .github/workflows/scorecards.yml:12"],"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":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#vulnerabilities"}},{"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#cii-best-practices"}},{"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#signed-releases"}},{"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#packaging"}},{"name":"SAST","score":10,"reason":"SAST tool is run on all commits","details":["Info: SAST configuration detected: CodeQL","Info: all commits (24) 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":"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#fuzzing"}},{"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/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#license"}},{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: github.com/cuioss/.github/SECURITY.md:1","Info: Found linked content: github.com/cuioss/.github/SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: github.com/cuioss/.github/SECURITY.md:1","Info: Found text in security policy: github.com/cuioss/.github/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":"Branch-Protection","score":4,"reason":"branch protection is not maximal on development and all release branches","details":["Info: 'allow deletion' disabled on branch 'main'","Info: 'force pushes' disabled on branch 'main'","Warn: 'branch protection settings apply to administrators' is disabled on branch 'main'","Info: 'stale review dismissal' is required to merge on branch 'main'","Warn: branch 'main' does not require approvers","Warn: codeowners review is not required on branch 'main'","Warn: 'last push approval' is disabled on branch 'main'","Info: 'up-to-date branches' is required to merge on branch 'main'","Info: status check found to merge onto on branch 'main'","Info: PRs are required in order to make changes on branch 'main'"],"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":6,"reason":"project has 2 contributing companies or organizations -- score normalized to 6","details":["Info: found contributions from: actions, gip mbh"],"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"}},{"name":"CI-Tests","score":10,"reason":"18 out of 18 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"}}]},"last_synced_at":"2026-02-13T04:35:46.556Z","repository_id":335333352,"created_at":"2026-02-13T04:35:46.556Z","updated_at":"2026-02-13T04:35:46.556Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29647768,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-20T09:27:29.698Z","status":"ssl_error","status_checked_at":"2026-02-20T09:26:12.373Z","response_time":59,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"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":[],"created_at":"2026-02-03T17:08:35.493Z","updated_at":"2026-03-03T11:02:48.003Z","avatar_url":"https://github.com/cuioss.png","language":"Python","funding_links":["https://github.com/sponsors/cuioss"],"categories":[],"sub_categories":[],"readme":"= cuioss Organization Configuration\n:toc:\n:toc-placement: preamble\n\nimage:https://github.com/cuioss/cuioss-organization/actions/workflows/python-verify.yml/badge.svg[Python Verify,link=https://github.com/cuioss/cuioss-organization/actions/workflows/python-verify.yml]\n\nCentralized configuration, workflows, and tooling for all cuioss repositories.\n\n== Overview\n\nThis repository contains shared infrastructure for the cuioss organization:\n\n[cols=\"1,2\"]\n|===\n|Directory |Purpose\n\n|`docs/`\n|Documentation (workflows, secrets, releasing, release-bot)\n\n|`branch-protection/`\n|Scripts to apply consistent branch protection across repos\n\n|`repo-settings/`\n|Scripts to apply consistent repository settings (security, features, merge)\n\n|`.github/workflows/`\n|Reusable GitHub Actions workflows\n|===\n\n== Related Repository\n\nhttps://github.com/cuioss/.github[cuioss/.github] - Organization-wide community health files (SECURITY.md, CONTRIBUTING.md, issue templates) that are automatically inherited by all repos.\n\n== Quick Start: Setup a Consumer Repository\n\nThe fastest way to onboard a repository is the Claude Code `/setup-consumer-repo` command, which orchestrates all steps automatically:\n\n[source]\n----\n/setup-consumer-repo cui-java-tools\n----\n\nThis runs the following commands in sequence:\n\n1. `/verify-org-integration` — Remove repo-level secrets that should be org-level, delete duplicate community health files\n2. `/apply-repo-settings` — Apply features, merge options, security settings\n3. `/update-github-actions` — Synchronize workflow files from caller templates, update `project.yml`\n4. `/apply-branch-protection` — Configure branch protection ruleset with status checks and review requirements\n\nThen creates a PR, waits for CI, merges, and runs post-merge verification (Scorecard + SonarCloud analysis).\n\nSee: link:.claude/commands/setup-consumer-repo.md[setup-consumer-repo Command]\n\n== Manual Setup\n\nIf you prefer to run steps individually:\n\n=== 1. Verify Organization Integration\n\n[source,bash]\n----\ncd repo-settings\n./verify-org-integration.py --repo {repo-name} --diff   # Preview\n./verify-org-integration.py --repo {repo-name} --apply  # Apply\n----\n\nSee: link:repo-settings/README.adoc[Repository Settings Documentation]\n\n=== 2. Apply Repository Settings\n\n[source,bash]\n----\ncd repo-settings\n./setup-repo-settings.py --repo {repo-name} --diff    # Preview\n./setup-repo-settings.py --repo {repo-name} --apply   # Apply\n----\n\n=== 3. Update Workflows\n\nReplace inline workflows with reusable workflow callers:\n\n[source,yaml]\n----\n# In your repo's .github/workflows/maven.yml\njobs:\n  build:\n    uses: cuioss/cuioss-organization/.github/workflows/reusable-maven-build.yml@9200de84ce6498401852fc244b7fb4d523278f15 # v0.6.4\n    secrets:\n      SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}\n      OSS_SONATYPE_USERNAME: ${{ secrets.OSS_SONATYPE_USERNAME }}\n      OSS_SONATYPE_PASSWORD: ${{ secrets.OSS_SONATYPE_PASSWORD }}\n      GPG_PRIVATE_KEY: ${{ secrets.GPG_PRIVATE_KEY }}\n      GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}\n----\n\nSee: link:docs/Workflows.adoc[Workflows Documentation]\n\n=== 4. Apply Branch Protection\n\n[source,bash]\n----\ncd branch-protection\n./setup-branch-protection.py --repo {repo-name} --diff    # Preview\n./setup-branch-protection.py --repo {repo-name} --apply   # Apply\n----\n\nSee: link:branch-protection/README.adoc[Branch Protection Documentation]\n\n=== 5. Release Bot Setup\n\nThe `cuioss-release-bot` GitHub App enables release workflows to bypass branch protection.\n\nSee: link:docs/cuioss-release-bot.adoc[cuioss-release-bot Documentation]\n\n=== 6. Releasing Workflow Updates\n\nWhen you update the reusable workflows, create a new release:\n\n[source,bash]\n----\n# Update version in .github/project.yml, then:\ngh workflow run release.yml\ngh run watch\ngit pull  # Get the SHA-updated examples\n----\n\nSee: link:docs/Releasing.adoc[Releasing Documentation]\n\n== Secrets Management\n\n=== Organization-Level Secrets (Shared)\n\nSet once at: `https://github.com/organizations/cuioss/settings/secrets/actions`\n\n[cols=\"1,2\"]\n|===\n|Secret |Purpose\n\n|`RELEASE_APP_ID`\n|cuioss-release-bot App ID\n\n|`RELEASE_APP_PRIVATE_KEY`\n|cuioss-release-bot private key\n\n|`OSS_SONATYPE_USERNAME`\n|Maven Central deployment\n\n|`OSS_SONATYPE_PASSWORD`\n|Maven Central deployment\n\n|`GPG_PRIVATE_KEY`\n|Artifact signing\n\n|`GPG_PASSPHRASE`\n|Artifact signing\n\n|`SONAR_TOKEN`\n|SonarCloud analysis\n|===\n\nSee: link:docs/Secrets.adoc[Secrets Documentation] for details and migration guide.\n\n== Repository Checklist\n\nFor each repository in the organization, run `/setup-consumer-repo {repo-name}` which covers:\n\n* [ ] Verify no org-level secrets are duplicated at repo level\n* [ ] Remove duplicate community health files inherited from `cuioss/.github`\n* [ ] Apply standard repository settings (security, features, merge options)\n* [ ] Replace workflows with reusable workflow callers from `docs/workflow-examples/`\n* [ ] Ensure `.github/project.yml` exists with release metadata\n* [ ] Apply branch protection ruleset (includes cuioss-release-bot bypass)\n* [ ] Verify Scorecard and SonarCloud analysis after merge\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcuioss%2Fcuioss-organization","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fcuioss%2Fcuioss-organization","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcuioss%2Fcuioss-organization/lists"}