diff --git a/.github/deploy.yml b/.github/deploy.yml
new file mode 100644
index 0000000..8ac9c23
--- /dev/null
+++ b/.github/deploy.yml
@@ -0,0 +1,95 @@
+name: Deploy
+
+# Run on pushes to main or PRs
+on:
+ # Pull request hook without any config. Launches for every pull request
+ pull_request:
+ # Launches for pushes to main or dev
+ push:
+ branches:
+ - main
+ - dev
+ - release
+ # Launches build when release is published
+ release:
+ types: [published]
+
+jobs:
+ deploy:
+ name: Deployment
+ runs-on: ubuntu-latest
+ defaults:
+ run:
+ working-directory: ./website
+
+ steps:
+ - name: Cancel Previous Runs
+ uses: styfle/cancel-workflow-action@0.8.0
+ with:
+ access_token: ${{ github.token }}
+
+ - name: Remove broken apt repos [Ubuntu]
+ if: ${{ matrix.os }} == 'ubuntu-latest'
+ run: |
+ for apt_file in `grep -lr microsoft /etc/apt/sources.list.d/`; do sudo rm $apt_file; done
+
+ - uses: actions/checkout@v2
+ with:
+ fetch-depth: 0
+
+ - uses: actions/cache@v2
+ with:
+ path: '**/node_modules'
+ key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
+
+ - name: Setup Node.js
+ uses: actions/setup-node@v2
+
+ - name: Install
+ run: |
+ rm -rf .cache
+ rm -rf build
+ yarn config set cache-folder .yarn
+ yarn install
+ pip install awscli --upgrade --user
+
+ - name: Build App
+ run: yarn build
+
+ - name: Configure AWS Development credentials
+ uses: aws-actions/configure-aws-credentials@v1
+ if: ( github.ref == 'refs/heads/dev' || github.ref == 'refs/heads/main' )
+ with:
+ aws-access-key-id: ${{ secrets.DEV_AWS_ACCESS_KEY_ID }}
+ aws-secret-access-key: ${{ secrets.DEV_AWS_SECRET_ACCESS_KEY }}
+ aws-region: ${{ secrets.DEV_AWS_DEFAULT_REGION }}
+
+ - name: Configure AWS Production credentials
+ uses: aws-actions/configure-aws-credentials@v1
+ if: ( github.ref == 'refs/heads/release' )
+ with:
+ aws-access-key-id: ${{ secrets.PROD_AWS_ACCESS_KEY_ID }}
+ aws-secret-access-key: ${{ secrets.PROD_AWS_SECRET_ACCESS_KEY }}
+ aws-region: ${{ secrets.PROD_AWS_DEFAULT_REGION }}
+
+ # Script to deploy to development environment
+ - name: 'Deploy to S3: Development'
+ if: github.ref == 'refs/heads/dev'
+ run: |
+ aws s3 sync build/ s3://${{ secrets.DEV_BUCKET_NAME }}/dev --exclude "*.html" --cache-control max-age=0,no-cache,no-store,public
+ aws s3 sync build/ s3://${{ secrets.DEV_BUCKET_NAME }}/dev --exclude "*" --include "*.html" --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type text/html
+
+ # Script to deploy to staging environment
+ - name: 'Deploy to S3: Staging'
+ if: github.ref == 'refs/heads/main'
+ run: |
+ aws s3 sync build/ s3://${{ secrets.DEV_BUCKET_NAME }}/staging --exclude "*.html" --cache-control max-age=0,no-cache,no-store,public
+ aws s3 sync build/ s3://${{ secrets.DEV_BUCKET_NAME }}/staging --exclude "*" --include "*.html" --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type text/html
+
+ # Script to deploy to release environment
+ - name: 'Deploy to S3: Release'
+ if: github.ref == 'refs/heads/release'
+ run: |
+ aws s3 sync build/ s3://${{ secrets.RELEASE_BUCKET_NAME }} --delete --exclude "*.html" --exclude "sitemap.xml" --cache-control max-age=86400,public
+ aws s3 sync build/ s3://${{ secrets.RELEASE_BUCKET_NAME }} --delete --exclude "*" --include "*.html" --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type text/html
+ aws s3 sync build/ s3://${{ secrets.RELEASE_BUCKET_NAME }} --delete --exclude "*" --include "sitemap.xml" --cache-control max-age=0,no-cache,no-store,must-revalidate --content-type text/xml
\ No newline at end of file
diff --git a/.idea/.gitignore b/.idea/.gitignore
deleted file mode 100644
index e7e9d11..0000000
--- a/.idea/.gitignore
+++ /dev/null
@@ -1,2 +0,0 @@
-# Default ignored files
-/workspace.xml
diff --git a/.idea/gnosis-docs.iml b/.idea/gnosis-docs.iml
deleted file mode 100644
index c956989..0000000
--- a/.idea/gnosis-docs.iml
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
deleted file mode 100644
index 24eb271..0000000
--- a/.idea/misc.xml
+++ /dev/null
@@ -1,6 +0,0 @@
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
deleted file mode 100644
index 5342f1b..0000000
--- a/.idea/modules.xml
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
deleted file mode 100644
index 94a25f7..0000000
--- a/.idea/vcs.xml
+++ /dev/null
@@ -1,6 +0,0 @@
-
-
-
-
-
-
\ No newline at end of file
diff --git a/travis/prepare_production_deployment.sh b/travis/prepare_production_deployment.sh
deleted file mode 100755
index 11acafa..0000000
--- a/travis/prepare_production_deployment.sh
+++ /dev/null
@@ -1,17 +0,0 @@
-#!/bin/bash
-
-set -ev
-
-# Only:
-# - Tagged commits
-# - Security env variables are available.
-if [ -n "$TRAVIS_TAG" ] && [ -n "$PROD_DEPLOYMENT_HOOK_TOKEN" ] && [ -n "$PROD_DEPLOYMENT_HOOK_URL" ]
-then
- curl --silent --output /dev/null --write-out "%{http_code}" -X POST \
- -F token="$PROD_DEPLOYMENT_HOOK_TOKEN" \
- -F ref=master \
- -F "variables[TRIGGER_RELEASE_COMMIT_TAG]=$TRAVIS_TAG" \
- $PROD_DEPLOYMENT_HOOK_URL
-else
- echo "[ERROR] Production deployment could not be prepared"
-fi
diff --git a/website/.nvmrc b/website/.nvmrc
new file mode 100644
index 0000000..0cf077e
--- /dev/null
+++ b/website/.nvmrc
@@ -0,0 +1 @@
+16.14