-
-
Notifications
You must be signed in to change notification settings - Fork 399
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2005 from arduino/PNX-5069-deploy-to-docs-content
[PNX-5069] Deploy to docs-content
- Loading branch information
Showing
2 changed files
with
160 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
name: Deploy to docs-content.arduino.cc | ||
|
||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: | ||
- main | ||
|
||
concurrency: | ||
group: deploy-production | ||
cancel-in-progress: true | ||
|
||
permissions: | ||
id-token: write | ||
contents: read | ||
|
||
jobs: | ||
build: | ||
if: "github.repository == 'arduino/docs-content'" | ||
runs-on: ubuntu-latest | ||
environment: production | ||
env: | ||
REPO_ACCESS_TOKEN: ${{ secrets.REPO_ACCESS_TOKEN }} | ||
APP_ENV: prod | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: 18 | ||
cache: "npm" | ||
cache-dependency-path: "**/package-lock.json" | ||
|
||
- name: Render Datasheets | ||
run: cd ${GITHUB_WORKSPACE}/scripts/datasheet-rendering;./render-datasheets.sh | ||
|
||
- name: Copy Static Files | ||
run: | | ||
mkdir -p static/resources/datasheets static/resources/schematics static/resources/pinouts | ||
find ./content/hardware -type f -name "*-schematics.pdf" -exec cp {} ./static/resources/schematics/ \; | ||
find ./content/hardware -type f -name "*-datasheet.pdf" -exec cp {} ./static/resources/datasheets/ \; | ||
find ./content/hardware -type f -name "*-full-pinout.pdf" -exec cp {} ./static/resources/pinouts/ \; | ||
find ./content/hardware -type f -name "*-pinout.png" -exec cp {} ./static/resources/pinouts/ \; | ||
find ./content/hardware -type f -name "*-step.zip" -exec cp {} ./static/resources/models/ \; | ||
- name: Gatsby main cache | ||
uses: actions/cache@v4 | ||
id: gatsby-cache-folder | ||
with: | ||
path: .cache | ||
key: ${{ runner.os }}-cache-gatsby-${{ github.sha }} | ||
restore-keys: | | ||
${{ runner.os }}-cache-gatsby- | ||
- name: Gatsby Public Folder | ||
uses: actions/cache@v4 | ||
id: gatsby-public-folder | ||
with: | ||
path: public/ | ||
key: ${{ runner.os }}-public-gatsby-${{ github.sha }} | ||
restore-keys: | | ||
${{ runner.os }}-public-gatsby- | ||
- run: npm install | ||
- run: npm run build | ||
|
||
- name: Configure AWS credentials from Production account | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
role-to-assume: ${{ secrets.PRODUCTION_IAM_ROLE }} | ||
aws-region: us-east-1 | ||
|
||
- name: Sync all cacheable assets | ||
run: aws s3 sync --cache-control "public, max-age=31536000, immutable" --include "*.css" --include="*.js" --include="*.gif" --include="*.png" --include="*.svg" --exclude "*.html" --exclude="sw.js" --exclude="*.json" --delete public/ s3://${{ secrets.PRODUCTION_BUCKET_NAME }}/ | ||
|
||
- name: Sync all non-cacheable assets | ||
# Don't cache any HTML or JSON file: they should always be up-to-dates | ||
run: aws s3 sync --cache-control "public, max-age=0, must-revalidate" --include "*.html" --include="sw.js" --include="*.json" --include "*.css" --exclude="*.js" --exclude="*.gif" --exclude="*.png" --exclude="*.svg" --delete public/ s3://${{ secrets.PRODUCTION_BUCKET_NAME }}/ |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
name: Deploy to docs-content.oniudra.cc | ||
|
||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: | ||
- ghaction | ||
|
||
concurrency: | ||
group: deploy-staging | ||
cancel-in-progress: true | ||
|
||
permissions: | ||
id-token: write | ||
contents: read | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
environment: staging | ||
env: | ||
REPO_ACCESS_TOKEN: ${{ secrets.REPO_ACCESS_TOKEN }} | ||
APP_ENV: staging | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- run: git log -1 --pretty=format:%aI content/learn/04.electronics/05.servo-motors/servo-motors.md | ||
- uses: actions/setup-node@v4 | ||
with: | ||
node-version: 18 | ||
cache: "npm" | ||
cache-dependency-path: "**/package-lock.json" | ||
|
||
- name: Render Datasheets | ||
run: cd ${GITHUB_WORKSPACE}/scripts/datasheet-rendering;./render-datasheets.sh | ||
|
||
- name: Copy Static Files | ||
run: | | ||
mkdir -p static/resources/datasheets static/resources/schematics static/resources/pinouts | ||
find ./content/hardware -type f -name "*-schematics.pdf" -exec cp {} ./static/resources/schematics/ \; | ||
find ./content/hardware -type f -name "*-datasheet.pdf" -exec cp {} ./static/resources/datasheets/ \; | ||
find ./content/hardware -type f -name "*-full-pinout.pdf" -exec cp {} ./static/resources/pinouts/ \; | ||
find ./content/hardware -type f -name "*-pinout.png" -exec cp {} ./static/resources/pinouts/ \; | ||
find ./content/hardware -type f -name "*-step.zip" -exec cp {} ./static/resources/models/ \; | ||
- name: Gatsby main cache | ||
uses: actions/cache@v4 | ||
id: gatsby-cache-folder | ||
with: | ||
path: .cache | ||
key: ${{ runner.os }}-cache-gatsby-${{ github.sha }} | ||
restore-keys: | | ||
${{ runner.os }}-cache-gatsby- | ||
- name: Gatsby Public Folder | ||
uses: actions/cache@v4 | ||
id: gatsby-public-folder | ||
with: | ||
path: public/ | ||
key: ${{ runner.os }}-public-gatsby-${{ github.sha }} | ||
restore-keys: | | ||
${{ runner.os }}-public-gatsby- | ||
- run: npm install | ||
- run: npm run build | ||
|
||
- name: Configure AWS credentials from Staging account | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
role-to-assume: ${{ secrets.STAGING_IAM_ROLE }} | ||
aws-region: us-east-1 | ||
|
||
- name: Sync all cacheable assets | ||
run: aws s3 sync --cache-control "public, max-age=31536000, immutable" --include "*.css" --include="*.js" --include="*.gif" --include="*.png" --include="*.svg" --exclude "*.html" --exclude="sw.js" --exclude="*.json" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | ||
|
||
- name: Sync all non-cacheable assets | ||
# Don't cache any HTML or JSON file: they should always be up-to-dates | ||
run: aws s3 sync --cache-control "public, max-age=0, must-revalidate" --include "*.html" --include="sw.js" --include="*.json" --include "*.css" --exclude="*.js" --exclude="*.gif" --exclude="*.png" --exclude="*.svg" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ |