decided to re-add the usesSubquadrats property to the PlotRDS type to… #41
Workflow file for this run
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
# Docs for the Azure Web Apps Deploy action: https://github.com/Azure/webapps-deploy | |
# More GitHub Actions for Azure: https://github.com/Azure/actions | |
name: ForestGEO Live Site Deployment Pipeline | |
on: | |
push: | |
branches: | |
- main | |
- 'forestgeo-app-*' | |
workflow_dispatch: | |
jobs: | |
build-and-deploy: | |
runs-on: ubuntu-latest | |
environment: development | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Node.js version | |
uses: actions/setup-node@v3 | |
with: | |
node-version: '18.x' | |
- name: create env file (in frontend/ directory) -- production | |
id: create-env-file-prod | |
if: github.ref == 'refs/heads/main' | |
run: | | |
touch frontend/.env | |
echo AZURE_AD_CLIENT_SECRET=${{ secrets.AZURE_AD_CLIENT_SECRET }} >> frontend/.env | |
echo AZURE_AD_CLIENT_ID=${{ secrets.AZURE_AD_CLIENT_ID }} >> frontend/.env | |
echo AZURE_AD_TENANT_ID=${{ secrets.AZURE_AD_TENANT_ID }} >> frontend/.env | |
echo AZURE_AD_SUBSCRIPTION_ID=${{ secrets.AZURE_AD_SUBSCRIPTION_ID }} >> frontend/.env | |
echo NEXTAUTH_SECRET=${{ secrets.NEXTAUTH_SECRET }} >> frontend/.env | |
echo NEXTAUTH_URL=${{ secrets.NEXTAUTH_URL }} >> frontend/.env | |
echo AZURE_SQL_USER=${{ secrets.AZURE_SQL_USER }} >> frontend/.env | |
echo AZURE_SQL_PASSWORD=${{ secrets.AZURE_SQL_PASSWORD }} >> frontend/.env | |
echo AZURE_SQL_SERVER=${{ secrets.AZURE_SQL_SERVER }} >> frontend/.env | |
echo AZURE_SQL_DATABASE=${{ secrets.AZURE_SQL_DATABASE }} >> frontend/.env | |
echo AZURE_SQL_PORT=${{ secrets.AZURE_SQL_PORT }} >> frontend/.env | |
echo AZURE_STORAGE_SAS_CONNECTION_STRING=${{ secrets.AZURE_STORAGE_SAS_CONNECTION_STRING }} >> frontend/.env | |
echo AZURE_SQL_SCHEMA=${{ secrets.AZURE_SQL_SCHEMA }} >> frontend/.env | |
echo AZURE_SQL_CATALOG_SCHEMA=${{ secrets.AZURE_SQL_CATALOG_SCHEMA }} >> frontend/.env | |
echo AZURE_STORAGE_CONNECTION_STRING=${{ secrets.AZURE_STORAGE_CONNECTION_STRING }} >> frontend/.env | |
echo NODE_ENV=development >> frontend/.env | |
echo PORT=3000 >> frontend/.env | |
- name: create env file (in frontend/ directory) -- development | |
id: create-env-file-dev | |
if: startsWith(github.ref, 'refs/heads/forestgeo-app-') | |
run: | | |
touch frontend/.env | |
echo AZURE_AD_CLIENT_SECRET=${{ secrets.AZURE_AD_DEVELOPMENT_CLIENT_SECRET }} >> frontend/.env | |
echo AZURE_AD_CLIENT_ID=${{ secrets.AZURE_AD_DEVELOPMENT_CLIENT_ID }} >> frontend/.env | |
echo AZURE_AD_TENANT_ID=${{ secrets.AZURE_AD_DEVELOPMENT_TENANT_ID }} >> frontend/.env | |
echo AZURE_AD_SUBSCRIPTION_ID=${{ secrets.AZURE_AD_SUBSCRIPTION_ID }} >> frontend/.env | |
echo NEXTAUTH_SECRET=${{ secrets.NEXTAUTH_SECRET }} >> frontend/.env | |
echo NEXTAUTH_URL=${{ secrets.NEXTAUTH_DEV_URL }} >> frontend/.env | |
echo AZURE_SQL_USER=${{ secrets.AZURE_SQL_USER }} >> frontend/.env | |
echo AZURE_SQL_PASSWORD=${{ secrets.AZURE_SQL_PASSWORD }} >> frontend/.env | |
echo AZURE_SQL_SERVER=${{ secrets.AZURE_SQL_SERVER }} >> frontend/.env | |
echo AZURE_SQL_DATABASE=${{ secrets.AZURE_SQL_DATABASE }} >> frontend/.env | |
echo AZURE_SQL_PORT=${{ secrets.AZURE_SQL_PORT }} >> frontend/.env | |
echo AZURE_STORAGE_SAS_CONNECTION_STRING=${{ secrets.AZURE_STORAGE_SAS_CONNECTION_STRING }} >> frontend/.env | |
echo AZURE_SQL_SCHEMA=${{ secrets.AZURE_SQL_SCHEMA }} >> frontend/.env | |
echo AZURE_SQL_CATALOG_SCHEMA=${{ secrets.AZURE_SQL_CATALOG_SCHEMA }} >> frontend/.env | |
echo AZURE_STORAGE_CONNECTION_STRING=${{ secrets.AZURE_STORAGE_CONNECTION_STRING }} >> frontend/.env | |
echo NODE_ENV=development >> frontend/.env | |
echo PORT=3000 >> frontend/.env | |
- name: Write Certificate to File | |
run: | | |
echo "${{ secrets.CERTIFICATE }}" > frontend/DigiCertGlobalRootCA.crt.pem | |
- name: Cache node modules | |
uses: actions/cache@v2 | |
with: | |
path: frontend/node_modules | |
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-node- | |
- name: Cache Next.js build | |
uses: actions/cache@v2 | |
with: | |
path: frontend/.next/cache | |
key: ${{ runner.os }}-next-${{ hashFiles('**/package-lock.json') }}-${{ hashFiles('**/.next/cache') }} | |
restore-keys: | | |
${{ runner.os }}-next- | |
${{ runner.os }}-next-${{ hashFiles('**/package-lock.json') }} | |
- name: move into frontend --> npm install, build, and test | |
run: | | |
cd frontend/ | |
npm install | |
npm run build | |
npm run test --if-present | |
- name: Move directories into build/standalone to reduce app load | |
run: | | |
mv ./frontend/build/static ./frontend/build/standalone/build | |
mv ./frontend/public ./frontend/build/standalone | |
mv ./frontend/*.pem ./frontend/build/standalone/ | |
# - name: 'Login to Azure' | |
# uses: azure/login@v1 | |
# with: | |
# client-id: ${{ secrets.AZURE_AD_CLIENT_ID }} | |
# client-secret: ${{ secrets.AZURE_AD_CLIENT_SECRET }} | |
# tenant-id: ${{ secrets.AZURE_AD_TENANT_ID }} | |
# subscription-id: ${{ secrets.AZURE_AD_SUBSCRIPTION_ID }} | |
- name: 'Deploy to Azure Web App (main)' | |
id: deploy-to-webapp-main | |
if: github.ref == 'refs/heads/main' | |
uses: azure/webapps-deploy@v2 | |
with: | |
app-name: 'forestgeo-livesite' | |
slot-name: 'Production' | |
publish-profile: ${{ secrets.AZUREAPPSERVICE_PUBLISHPROFILE_852346BD764D45D08854E6679137F844 }} | |
package: ./frontend/build/standalone | |
- name: 'Deploy to Azure Web App (development)' | |
id: deploy-to-webapp-dev | |
if: startsWith(github.ref, 'refs/heads/forestgeo-app-') | |
uses: azure/webapps-deploy@v2 | |
with: | |
app-name: 'forestgeo-livesite' | |
slot-name: 'development' | |
publish-profile: ${{ secrets.AZUREAPPSERVICE_PUBLISHPROFILE_DEVELOPMENT }} | |
package: ./frontend/build/standalone |