Compare commits
21 commits
infisical-
...
s3-backup
Author | SHA1 | Date | |
---|---|---|---|
bf54b80924 | |||
b8805d941b | |||
f3acd807bf | |||
181c35fac5 | |||
f4f89dad0d | |||
f0038b6b69 | |||
962ca38ff9 | |||
ba73b418a8 | |||
30096f817f | |||
bb8787fded | |||
1e3c32b3e7 | |||
75bd9ebc6d | |||
8fd38af4f8 | |||
8646f62cbe | |||
41d4305f3a | |||
2dc6d1bbd1 | |||
02ebb4634f | |||
4d55f5c1e7 | |||
7b513727bb | |||
26eff76d90 | |||
881621c35c |
2 changed files with 39 additions and 22 deletions
|
@ -6,9 +6,8 @@ The actions are used by Elysium to run CI/CD tasks and this repo will be archive
|
||||||
|
|
||||||
The actions available are:
|
The actions available are:
|
||||||
- [S3 Backup](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/s3-backup/action.yml)
|
- [S3 Backup](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/s3-backup/action.yml)
|
||||||
- [Oasis Auto Setup](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/oasis-setup-auto/action.yml)
|
- [Oasis Deploy](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/oasis-deploy/action.yml)
|
||||||
- [Infisical Env](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/infisical-env/action.yml)
|
- [Infisical Env](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/infisical-env/action.yml)
|
||||||
- [Oasis Advanced Setup](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/oasis-setup-advanced/action.yml)
|
|
||||||
- [Elysium CI/CD](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/elysium-ci-cd/action.yml)
|
- [Elysium CI/CD](https://gitea.dunemask.dev/elysium/elysium-actions/src/branch/elysium-ci-cd/action.yml)
|
||||||
|
|
||||||
## Workflow Template
|
## Workflow Template
|
||||||
|
|
58
action.yml
58
action.yml
|
@ -1,28 +1,46 @@
|
||||||
# Based on https://github.com/zerodays/action-infisical/blob/master/action.yml
|
name: "S3 Backup Action"
|
||||||
name: 'Elysium Infisical Secrets'
|
description: "Backup to S3 Bucket"
|
||||||
description: 'Fetch secrets from Infisical and add them to the env'
|
|
||||||
inputs:
|
inputs:
|
||||||
infisical-token:
|
infisical-token:
|
||||||
description: 'Infisical API Token'
|
description: Infisical token for backup envars
|
||||||
required: true
|
required: true
|
||||||
environment:
|
infisical-project:
|
||||||
description: 'The environment to fetch secrets for (e.g., staging, production)'
|
description: Infisical Project
|
||||||
required: true
|
required: true
|
||||||
secret-matrix:
|
s3-backup-path:
|
||||||
description: 'Secret Matrix'
|
description: "Workspace to setup Oasis"
|
||||||
required: true
|
|
||||||
api-url:
|
|
||||||
description: 'Infisical API URL (defaults to https://infisical.dunemask.dev/api)'
|
|
||||||
required: false
|
required: false
|
||||||
default: 'https://infisical.dunemask.dev/api'
|
default: backups/forgejo-repositories/${{ gitea.repository }}
|
||||||
runs:
|
runs:
|
||||||
using: 'composite'
|
using: "composite"
|
||||||
steps:
|
steps:
|
||||||
- name: Infisical CLI install
|
# Checkout Repository
|
||||||
shell: bash
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
path: repo
|
||||||
|
# Load Backup Envars
|
||||||
|
- name: Setup Backup Envars
|
||||||
|
uses: https://forgejo.dunemask.dev/elysium/elysium-actions@infisical-env
|
||||||
|
with:
|
||||||
|
infisical-token: ${{ inputs.infisical-token }}
|
||||||
|
project-id: ${{ inputs.infisical-project }}
|
||||||
|
secret-envs: edge
|
||||||
|
secret-paths: /devops/forgejo-backups
|
||||||
|
# Fix Envar Format
|
||||||
|
- name: Fix Env Format
|
||||||
run: |
|
run: |
|
||||||
echo ${{inputs.secret-matrix}}
|
echo BACKUP_S3_ENDPOINT=${{ env.DEVOPS_FORGEJO_ELYSIUM_ORG_S3_ENDPOINT }} >> $GITHUB_ENV
|
||||||
curl -s -L https://github.com/Infisical/infisical/releases/download/infisical-cli%2Fv0.16.10/infisical_0.16.10_linux_amd64.tar.gz | tar xvz
|
echo BACKUP_S3_KEY_ID=${{ env.DEVOPS_FORGEJO_ELYSIUM_ORG_S3_KEY_ID }} >> $GITHUB_ENV
|
||||||
./infisical export --domain ${{ inputs.api-url }} --token ${{ inputs.infisical-token}} --env ${{ inputs.environment }} --path / >> $GITHUB_ENV
|
echo BACKUP_S3_KEY=${{ env.DEVOPS_FORGEJO_ELYSIUM_ORG_S3_KEY }} >> $GITHUB_ENV
|
||||||
- shell: bash
|
# Backup Repository
|
||||||
run: echo "Secrets added to environment!".
|
- name: S3 Backup
|
||||||
|
uses: https://github.com/peter-evans/s3-backup@v1
|
||||||
|
env:
|
||||||
|
STORAGE_SERVICE_URL: ${{ env.BACKUP_S3_ENDPOINT }}
|
||||||
|
ACCESS_KEY_ID: ${{ env.BACKUP_S3_KEY_ID }}
|
||||||
|
SECRET_ACCESS_KEY: ${{ env.BACKUP_S3_KEY }}
|
||||||
|
MIRROR_TARGET: ${{ inputs.s3-backup-path }}
|
||||||
|
MIRROR_SOURCE: repo
|
||||||
|
with:
|
||||||
|
args: --overwrite --remove
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue