Move snap_manageAccounts
to a gated permitted method
#5459
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Main | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
jobs: | |
check-workflows: | |
name: Check workflows | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Download actionlint | |
id: download-actionlint | |
run: bash <(curl https://raw.githubusercontent.com/rhysd/actionlint/7fdc9630cc360ea1a469eed64ac6d78caeda1234/scripts/download-actionlint.bash) 1.6.25 | |
shell: bash | |
- name: Check workflow files | |
run: ${{ steps.download-actionlint.outputs.executable }} -color | |
shell: bash | |
lint-build-test: | |
name: Build, lint, and test | |
needs: check-workflows | |
uses: ./.github/workflows/build-lint-test.yml | |
secrets: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
publish-staging-simulator: | |
name: Publish Snaps Simulator to `staging` folder | |
needs: lint-build-test | |
if: ${{ github.ref_name == 'main' }} | |
permissions: | |
contents: write | |
uses: ./.github/workflows/publish-github-pages.yml | |
with: | |
build_script: yarn workspace @metamask/snaps-simulator build | |
publish_dir: ./packages/snaps-simulator/dist/webpack/main | |
destination_dir: snaps-simulator/staging | |
secrets: | |
PUBLISH_PAGES_TOKEN: ${{ secrets.PUBLISH_PAGES_TOKEN }} | |
is-release: | |
name: Determine whether this is a release merge commit | |
needs: lint-build-test | |
if: github.event_name == 'push' | |
runs-on: ubuntu-latest | |
outputs: | |
IS_RELEASE: ${{ steps.is-release.outputs.IS_RELEASE }} | |
steps: | |
- id: is-release | |
uses: MetaMask/action-is-release@v1 | |
with: | |
commit-starts-with: 'Release [version]' | |
publish-release: | |
name: Publish release | |
needs: is-release | |
if: needs.is-release.outputs.IS_RELEASE == 'true' | |
permissions: | |
id-token: write | |
contents: write | |
uses: ./.github/workflows/publish-release.yml | |
with: | |
slack-subteam: S05RL9W7H54 # @metamask-snaps-publishers | |
secrets: | |
NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | |
PUBLISH_PAGES_TOKEN: ${{ secrets.PUBLISH_PAGES_TOKEN }} | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} | |
all-jobs-complete: | |
name: All jobs complete | |
runs-on: ubuntu-latest | |
needs: lint-build-test | |
outputs: | |
passed: ${{ steps.set-output.outputs.passed }} | |
steps: | |
- name: Set passed output | |
id: set-output | |
run: echo "passed=true" >> "$GITHUB_OUTPUT" | |
all-jobs-pass: | |
name: All jobs pass | |
if: ${{ always() }} | |
runs-on: ubuntu-latest | |
needs: all-jobs-complete | |
steps: | |
- name: Check that all jobs have passed | |
run: | | |
passed="${{ needs.all-jobs-complete.outputs.passed }}" | |
if [[ $passed != "true" ]]; then | |
exit 1 | |
fi | |
re-run: | |
name: Re-run failed jobs | |
needs: lint-build-test | |
if: failure() && fromJSON(github.run_attempt) < 3 | |
runs-on: ubuntu-latest | |
permissions: | |
actions: write | |
steps: | |
- env: | |
GH_REPO: ${{ github.repository }} | |
GH_TOKEN: ${{ github.token }} | |
GH_DEBUG: api | |
run: gh workflow run re-run.yml -F run-id=${{ github.run_id }} |