Skip to content

Merge pull request #21 from socraticDevBlog/addpastebin #63

Merge pull request #21 from socraticDevBlog/addpastebin

Merge pull request #21 from socraticDevBlog/addpastebin #63

Workflow file for this run

name: Deploy dailybuild site to server
on:
workflow_dispatch:
push:
branches:
- master
env:
BUILD_ARTIFACT_NAME: built-site
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Check out repository
uses: actions/checkout@v2
- name: Install dependencies
run: |
cd $GITHUB_WORKSPACE
npm install
- name: Build site locally
run: npm run start
- name: Upload artifact
uses: actions/upload-artifact@v2
with:
name: ${{ env.BUILD_ARTIFACT_NAME }}
path: ${{ github.workspace }}/public/
deploy:
runs-on: ubuntu-latest
needs: build
env:
WORKING_DIR: work
steps:
- name: Create SSH config folder
run: mkdir -pv ~/.ssh
- name: Add Known Hosts
run: |
echo "${{ secrets.SSH_DEPLOY_HOST_KEY }}" > ~/.ssh/known_hosts
- name: Add SSH key
# umask 177 is equivalent to chmod 600 permissions
run: |
umask 177
touch ~/.ssh/key
echo "${{ secrets.SSH_DEPLOY_RUNNER_KEY }}" > ~/.ssh/key
umask 022
- name: Get built site
uses: actions/download-artifact@v2
with:
name: ${{ env.BUILD_ARTIFACT_NAME }}
path: ${{ env.WORKING_DIR }}
- name: Clear directory on remote server
# -q is required to remove IP leakage when warning about adding the SSH host key that is already known
# We are using a temporary directory (HOME) in case something goes belly up and to limit downtime. We wouldn't want there to be no website, would we?
# This command is known to fail because it tried to delete the current directory . and the previous directory .. so we force it with true (remote)
run: ssh -q -i ~/.ssh/key "${{ secrets.SSH_DEPLOY_DESTINATION }}"
'rm -rf ~/* ~/.*; true'
- name: Send to remote server
run: scp -q -i ~/.ssh/key -r $WORKING_DIR/* "${{ secrets.SSH_DEPLOY_DESTINATION }}":~/
- name: Deploy on the remote server
run: ssh -q -i ~/.ssh/key "${{ secrets.SSH_DEPLOY_DESTINATION }}"
'rm -rf /srv/www/dailybuild/* &&
mv ~/* /srv/www/dailybuild'