Skip to content

Commit

Permalink
consolidate deploy
Browse files Browse the repository at this point in the history
  • Loading branch information
james-otten committed Aug 6, 2024
1 parent d327009 commit f5a9376
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 90 deletions.
101 changes: 11 additions & 90 deletions .github/workflows/deploy.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,97 +6,18 @@ on:

permissions: read-all

jobs:
deploy_to_dev3:
name: Deploy to dev3
deploy_to_dev3:
name: Deploy to dev 3
uses: ./.github/workflows/helm_deploy.yaml
with:
environment: dev3
runs-on: ubuntu-latest
#if: github.ref == 'refs/heads/master'
steps:
- name: Check out the repo
uses: actions/checkout@v4

- name: Install SSH key
uses: shimataro/ssh-key-action@d4fffb50872869abe2d9a9098a6d9c5aa7d16be4 # v2
with:
key: ${{ secrets.SSH_PRIVATE_KEY }}
name: id_ed25519 # optional
known_hosts: ${{ secrets.SSH_KNOWN_HOSTS }}
if_key_exists: fail # replace / ignore / fail; optional (defaults to fail)

- name: Setup WireGuard
run: |
sudo apt install wireguard
echo "${{ secrets.WIREGUARD_PRIVATE_KEY }}" > privatekey
sudo ip link add dev wg1 type wireguard
sudo ip address add dev wg1 ${{ secrets.WIREGUARD_OVERLAY_NETWORK_IP }} peer ${{ secrets.SSH_TARGET_IP }}
sudo wg set wg1 listen-port 48123 private-key privatekey peer ${{ secrets.WIREGUARD_PEER_PUBLIC_KEY }} allowed-ips 0.0.0.0/0 endpoint ${{ secrets.WIREGUARD_ENDPOINT }}
sudo ip link set up dev wg1
- name: Install Helm Chart
run: |
scp ${{ secrets.SSH_USER }}@${{ secrets.SSH_TARGET_IP }}:~/.kube/config ./
helm upgrade \
--install \
--kubeconfig ./config \
--kube-apiserver https://${{ secrets.SSH_TARGET_IP }}:6443 \
-n ${{ vars.APP_NAMESPACE }} \
--create-namespace \
wiki \
bookstack-helm \
-f ./bookstack-helm/values.yaml \
--set bookstack.db.username="${{ secrets.DB_USERNAME }}" \
--set bookstack.db.password="${{ secrets.DB_PASSWORD }}" \
--set bookstack.db.root_password="${{ secrets.ROOT_PASSWORD }}" \
--set bookstack.mail.username="${{ secrets.MAIL_USERNAME }}" \
--set bookstack.mail.password="${{ secrets.MAIL_PASSWORD }}" \
--set bookstack.aws.backup_s3_url="${{ secrets.BACKUP_S3_URL }}" \
--set bookstack.aws.access_key_id="${{ secrets.ACCESS_KEY_ID }}" \
--set bookstack.aws.secret_access_key="${{ secrets.SECRET_ACCESS_KEY }}"
secrets: inherit
#if: github.ref == 'refs/heads/main'

deploy_to_prod1:
name: Deploy to prod 1
name: Deploy to prod 1
uses: ./.github/workflows/helm_deploy.yaml
with:
environment: prod1
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/master'
steps:
- name: Check out the repo
uses: actions/checkout@v4

- name: Install SSH key
uses: shimataro/ssh-key-action@d4fffb50872869abe2d9a9098a6d9c5aa7d16be4 # v2
with:
key: ${{ secrets.SSH_PRIVATE_KEY }}
name: id_ed25519 # optional
known_hosts: ${{ secrets.SSH_KNOWN_HOSTS }}
if_key_exists: fail # replace / ignore / fail; optional (defaults to fail)

- name: Setup WireGuard
run: |
sudo apt install wireguard
echo "${{ secrets.WIREGUARD_PRIVATE_KEY }}" > privatekey
sudo ip link add dev wg2 type wireguard
sudo ip address add dev wg2 ${{ secrets.WIREGUARD_OVERLAY_NETWORK_IP }} peer ${{ secrets.SSH_TARGET_IP }}
sudo wg set wg2 listen-port 48123 private-key privatekey peer ${{ secrets.WIREGUARD_PEER_PUBLIC_KEY }} allowed-ips 0.0.0.0/0 endpoint ${{ secrets.WIREGUARD_ENDPOINT }}
sudo ip link set up dev wg2
- name: Install Helm Chart
run: |
scp ${{ secrets.SSH_USER }}@${{ secrets.SSH_TARGET_IP }}:~/.kube/config ./
helm upgrade \
--install \
--kubeconfig ./config \
--kube-apiserver https://${{ secrets.SSH_TARGET_IP }}:6443 \
-n ${{ vars.APP_NAMESPACE }} \
--create-namespace \
wiki \
bookstack-helm \
-f ./bookstack-helm/values.yaml \
--set bookstack.db.username="${{ secrets.DB_USERNAME }}" \
--set bookstack.db.password="${{ secrets.DB_PASSWORD }}" \
--set bookstack.db.root_password="${{ secrets.ROOT_PASSWORD }}" \
--set bookstack.mail.username="${{ secrets.MAIL_USERNAME }}" \
--set bookstack.mail.password="${{ secrets.MAIL_PASSWORD }}"
--set bookstack.aws.backup_s3_url="${{ secrets.BACKUP_S3_URL }}" \
--set bookstack.aws.access_key_id="${{ secrets.ACCESS_KEY_ID }}" \
--set bookstack.aws.secret_access_key="${{ secrets.SECRET_ACCESS_KEY }}"
secrets: inherit
if: github.ref == 'refs/heads/main'
56 changes: 56 additions & 0 deletions .github/workflows/helm_deploy.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
name: Deploy Helm Chart
permissions: read-all

on:
workflow_call:
inputs:
environment:
required: true
type: string

jobs:
helm_deploy:
name: Deploy helm chart
environment: ${{ inputs.environment }}
runs-on: ubuntu-latest
steps:
- name: Check out the repo
uses: actions/checkout@v4

- name: Install SSH key
uses: shimataro/ssh-key-action@d4fffb50872869abe2d9a9098a6d9c5aa7d16be4 # v2
with:
key: ${{ secrets.SSH_PRIVATE_KEY }}
name: id_ed25519 # optional
known_hosts: ${{ secrets.SSH_KNOWN_HOSTS }}
if_key_exists: fail # replace / ignore / fail; optional (defaults to fail)

- name: Setup WireGuard
run: |
sudo apt install wireguard
echo "${{ secrets.WIREGUARD_PRIVATE_KEY }}" > privatekey
sudo ip link add dev wg1 type wireguard
sudo ip address add dev wg1 ${{ secrets.WIREGUARD_OVERLAY_NETWORK_IP }} peer ${{ secrets.SSH_TARGET_IP }}
sudo wg set wg1 listen-port 48123 private-key privatekey peer ${{ secrets.WIREGUARD_PEER_PUBLIC_KEY }} allowed-ips 0.0.0.0/0 endpoint ${{ secrets.WIREGUARD_ENDPOINT }}
sudo ip link set up dev wg1
- name: Install Helm Chart
run: |
scp ${{ secrets.SSH_USER }}@${{ secrets.SSH_TARGET_IP }}:~/.kube/config ./
helm upgrade \
wiki \
bookstack-helm \
--install \
--kubeconfig ./config \
--kube-apiserver https://${{ secrets.SSH_TARGET_IP }}:6443 \
-n ${{ vars.APP_NAMESPACE }} \
--create-namespace \
-f ./bookstack-helm/values.yaml \
--set bookstack.db.username="${{ secrets.DB_USERNAME }}" \
--set bookstack.db.password="${{ secrets.DB_PASSWORD }}" \
--set bookstack.db.root_password="${{ secrets.ROOT_PASSWORD }}" \
--set bookstack.mail.username="${{ secrets.MAIL_USERNAME }}" \
--set bookstack.mail.password="${{ secrets.MAIL_PASSWORD }}" \
--set bookstack.aws.backup_s3_url="${{ secrets.BACKUP_S3_URL }}" \
--set bookstack.aws.access_key_id="${{ secrets.ACCESS_KEY_ID }}" \
--set bookstack.aws.secret_access_key="${{ secrets.SECRET_ACCESS_KEY }}"

0 comments on commit f5a9376

Please sign in to comment.