{"id":18578856,"url":"https://github.com/libre-devops/azure-pulumi-gh-action","last_synced_at":"2026-04-11T14:34:34.182Z","repository":{"id":65160648,"uuid":"490876451","full_name":"libre-devops/azure-pulumi-gh-action","owner":"libre-devops","description":"A GitHub action to run Pulumi for Azure resources.","archived":false,"fork":false,"pushed_at":"2022-05-14T22:58:05.000Z","size":50,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-03-02T01:36:13.965Z","etag":null,"topics":["actions","azure","devops","github","github-actions","pulumi","pulumi-azure"],"latest_commit_sha":null,"homepage":"","language":"Shell","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/libre-devops.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":"2022-05-10T22:16:12.000Z","updated_at":"2022-05-16T23:17:50.000Z","dependencies_parsed_at":"2023-01-13T15:44:03.120Z","dependency_job_id":null,"html_url":"https://github.com/libre-devops/azure-pulumi-gh-action","commit_stats":{"total_commits":29,"total_committers":2,"mean_commits":14.5,"dds":0.4137931034482759,"last_synced_commit":"aa515a5e9f6bd26e416adf211148198237e588bc"},"previous_names":[],"tags_count":1,"template":false,"template_full_name":"libre-devops/azure-terraform-gh-action","purl":"pkg:github/libre-devops/azure-pulumi-gh-action","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/libre-devops%2Fazure-pulumi-gh-action","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/libre-devops%2Fazure-pulumi-gh-action/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/libre-devops%2Fazure-pulumi-gh-action/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/libre-devops%2Fazure-pulumi-gh-action/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/libre-devops","download_url":"https://codeload.github.com/libre-devops/azure-pulumi-gh-action/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/libre-devops%2Fazure-pulumi-gh-action/sbom","scorecard":{"id":588238,"data":{"date":"2025-08-11","repo":{"name":"github.com/libre-devops/azure-pulumi-gh-action","commit":"aa515a5e9f6bd26e416adf211148198237e588bc"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.4,"checks":[{"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":"Code-Review","score":0,"reason":"Found 0/29 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"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":"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":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/build-docker.yml:1","Warn: no topLevel permission defined: .github/workflows/pulumi-destroy.yml:1","Warn: no topLevel permission defined: .github/workflows/pulumi-preview.yml:1","Warn: no topLevel permission defined: .github/workflows/pulumi-up.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":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"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":"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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"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":"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":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: 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":"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":"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/build-docker.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/build-docker.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/pulumi-destroy.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-destroy.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pulumi-destroy.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-destroy.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/pulumi-preview.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-preview.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pulumi-preview.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-preview.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/pulumi-up.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-up.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/pulumi-up.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/libre-devops/azure-pulumi-gh-action/pulumi-up.yml/main?enable=pin","Warn: containerImage not pinned by hash: Base.Dockerfile:2: pin your Docker image by updating docker.io/ubuntu:focal to docker.io/ubuntu:focal@sha256:8feb4d8ca5354def3d8fce243717141ce31e2c428701f6682bd2fafe15388214","Warn: containerImage not pinned by hash: Dockerfile:2: pin your Docker image by updating ghcr.io/libre-devops/azure-pulumi-gh-action-base:latest to ghcr.io/libre-devops/azure-pulumi-gh-action-base:latest@sha256:a0b676a24f6c2980f9dde44f608e58755df2f62e8ce47ceca18d50eafc18ebde","Info:   0 out of   4 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   3 third-party GitHubAction dependencies pinned","Info:   0 out of   2 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":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for 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/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"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"}}]},"last_synced_at":"2025-08-20T21:08:19.024Z","repository_id":65160648,"created_at":"2025-08-20T21:08:19.024Z","updated_at":"2025-08-20T21:08:19.024Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31684525,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-11T13:07:20.380Z","status":"ssl_error","status_checked_at":"2026-04-11T13:06:47.903Z","response_time":54,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5: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":["actions","azure","devops","github","github-actions","pulumi","pulumi-azure"],"created_at":"2024-11-06T23:38:02.399Z","updated_at":"2026-04-11T14:34:34.161Z","avatar_url":"https://github.com/libre-devops.png","language":"Shell","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Libre DevOps - Azure Pulumi GitHub Action\n\nHello :wave:\n\nThis is a repository for the heavily opinionated GitHub Action to run Pulumi, mainly targetting Azure. As stated, this action is opinionated, in that it expects all parameters to provided to it, and will only run on the assumption these work - or else, it should error.  It is mainly used for the development of Libre DevOps pulumi modules - but could be used by others, but be aware that it is not for everyone!\n\n## What it does\n\n- Pulls a Docker container - `ghcr.io/libre-devops/azure-pulumi-gh-action-base:latest`\n- Runs a Standard Pulumi Workflow as Follows:\n```shell\npulumi login\npulumi preview\n``` \n\n- Then, based on some parameters to the action, will run other parts:\n```shell\npulumi up\npulumi destroy\n```\n\n### Example Usage\n\nCheck out the [workflows](https://github.com/libre-devops/azure-pulumi-gh-action/tree/main/.github/workflows) folder for more examples\n\n```yaml\nname: 'Pulumi Up'\n\n#Allow run manually or on push to main or in PR closure\non:\n  workflow_dispatch:\n\njobs:\n  azure-pulumi-job:\n    name: 'Pulumi Build'\n    runs-on: ubuntu-latest\n    environment: tst\n\n    # Use the Bash shell regardless whether the GitHub Actions runner is ubuntu-latest, macos-latest, or windows-latest\n    defaults:\n      run:\n        shell: bash\n\n    steps:\n      - uses: actions/checkout@v3\n\n      - name: Libre DevOps - Run Pulumi for Azure - GitHub Action\n        id: pulumi-build\n        uses: libre-devops/azure-pulumi-gh-action@v1\n        with:\n          pulumi-path: \"pulumi/hello-world\"\n          pulumi-stack-name: \"dev\"\n          pulumi-config-passphrase: ${{ secrets.SpokeSaRgName }}\n          pulumi-backend-storage-account-name: ${{ secrets.SpokePulumiPassphrase }}\n          pulumi-backend-url-prefix: \"azblob://\"\n          pulumi-backend-blob-container-name: ${{ secrets.SpokeSaBlobContainerName }}\n          pulumi-backend-storage-access-key: ${{ secrets.SpokeSaPrimaryKey }}\n          pulumi-provider-client-id: ${{ secrets.SpokeSvpClientId }}\n          pulumi-provider-client-secret: ${{ secrets.SpokeSvpClientSecret }}\n          pulumi-provider-subscription-id: ${{ secrets.SpokeSubId }}\n          pulumi-provider-tenant-id: ${{ secrets.SpokeTenantId }}\n          run-pulumi-destroy: \"false\"\n          run-pulumi-preview-only: \"false\"\n\n```\n\n\n### Inputs\n\n```yaml\n  # action.yml\nname: 'Libre DevOps - Run Pulumi for Azure -  GitHub Action'\ndescription: 'The heavily opinionated Libre DevOps Action to run Pulumi in Azure.'\nauthor: \"Craig Thacker \u003ccraig@craigthacker.dev\u003e\"\nbranding:\n  icon: 'terminal'\n  color: 'red'\n\ninputs:\n  pulumi-path:\n    description: 'The absolute path in Linux format to your pulumi code'\n    required: true\n\n  pulumi-stack-name:\n    description: 'The name of a pulumi stack, should be in plain text string'\n    required: true\n\n  pulumi-config-passphrase:\n    description: 'The secret passphrase to your state, needed for security'\n    required: true\n\n  pulumi-backend-storage-account-name:\n    description: 'The name of your storage account , needed for state file storage'\n    required: true\n\n  pulumi-backend-url-prefix:\n    description: 'The backend url of your backend, for Azure. it should be azblob:// needed for state file storage'\n    required: true\n\n  pulumi-backend-blob-container-name:\n    description: 'The name of your storage account blob container, needed for state file storage'\n    required: true\n\n  pulumi-backend-storage-access-key:\n    description: 'The key to access your storage account, needed for state file storage'\n    required: true\n\n  pulumi-provider-client-id:\n    description: 'The client ID for your service principal, needed to authenticate to your tenant'\n    required: true\n\n  pulumi-provider-client-secret:\n    description: 'The client secret for your service principal, needed to authenticate to your tenant'\n    required: true\n\n  pulumi-provider-subscription-id:\n    description: 'The subscription id of the subscription you wish to deploy to, needed to authenticate to your tenant'\n    required: true\n\n  pulumi-provider-tenant-id:\n    description: 'The tenant id of which contains subscription you wish to deploy to, needed to authenticate to your tenant'\n    required: true\n\n  run-pulumi-destroy:\n    description: 'Do you want to run pulumi destroy? - Set to true to trigger pulumi plan -destroy'\n    required: true\n    default: \"false\"\n    \n  run-pulumi-preview-only:\n    description: 'Do you only want to run pulumi plan \u0026 never run the apply or apply destroy? - Set to true to trigger pulumi plan only.'\n    required: true\n    default: \"true\"\n\nruns:\n  using: 'docker'\n  image: 'Dockerfile'\n  args:\n    - ${{ inputs.pulumi-path }}\n    - ${{ inputs.pulumi-stack-name }}\n    - ${{ inputs.pulumi-config-passphrase }}\n    - ${{ inputs.pulumi-backend-storage-account-name }}\n    - ${{ inputs.pulumi-backend-url-prefix }}\n    - ${{ inputs.pulumi-backend-blob-container-name }}\n    - ${{ inputs.pulumi-backend-storage-access-key }}\n    - ${{ inputs.pulumi-provider-client-id }}\n    - ${{ inputs.pulumi-provider-client-secret }}\n    - ${{ inputs.pulumi-provider-subscription-id }}\n    - ${{ inputs.pulumi-provider-tenant-id }}\n    - ${{ inputs.run-pulumi-destroy }}\n    - ${{ inputs.run-pulumi-preview-only }}\n```\n\n### Outputs\n\nNone\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flibre-devops%2Fazure-pulumi-gh-action","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flibre-devops%2Fazure-pulumi-gh-action","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flibre-devops%2Fazure-pulumi-gh-action/lists"}