Skip to content

feat: lerna monorepo config #163

feat: lerna monorepo config

feat: lerna monorepo config #163

name: Publish packages
on:
workflow_dispatch:
push:
branches:
- main
paths:
- 'lerna.json'
# Test the workflow on pull requests
pull_request:
branches:
- main
permissions:
id-token: write
contents: read
env:
CDN_BUCKET: gc-design-system-production-cdn
CDN_REGION: ca-central-1
jobs:
publish-web:
name: Publish @cdssnc/gcds-components
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
include:
- name: "@cdssnc/gcds-components"
package: "./packages/web"
dist: "./packages/web"
steps:
- name: Git Checkout
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- name: Setup Node
uses: actions/setup-node@d86ebcd40b3cb50b156bfa44dd277faf38282d12
with:
node-version: 18
- name: Install ${{ matrix.name }}
run: npm install
- name: Build ${{ matrix.name }}
run: npm run build
# - name: Publish ${{ matrix.name }}
# uses: JS-DevTools/npm-publish@fe58a596e87f1297b15f580ec0dbc833d51a4622
# id: publish
# with:
# token: ${{ secrets.NPM_TOKEN }}
# package: ${{ matrix.dist }}
#
# - name: Configure AWS credentials using OIDC
# if: steps.publish.outputs.id != ''
# uses: aws-actions/configure-aws-credentials@50ac8dd1e1b10d09dac7b8727528b91bed831ac0 # v3.0.2
# with:
# role-to-assume: arn:aws:iam::307395567143:role/gcds-components-apply
# role-session-name: CDNPublish
# aws-region: ${{ env.CDN_REGION }}
# - name: Update CDN ${{ matrix.name }}
# if: steps.publish.outputs.id != ''
# run: |
# PUBLISHED_PACKAGE="${{ steps.publish.outputs.id }}"
#
# mkdir -p ./tmp \
# && sleep 60 \
# && npm install --prefix ./tmp "$PUBLISHED_PACKAGE" \
# && cd ./tmp/node_modules
#
# aws s3 sync ./${{ matrix.name }} s3://${{ env.CDN_BUCKET }}/"$PUBLISHED_PACKAGE" --delete
# aws s3 sync ./${{ matrix.name }} s3://${{ env.CDN_BUCKET }}/${{ matrix.name }}@latest --delete
# aws s3api head-object --bucket ${{ env.CDN_BUCKET }} --key "$PUBLISHED_PACKAGE"/package.json
# aws s3api head-object --bucket ${{ env.CDN_BUCKET }} --key ${{ matrix.name }}@latest/package.json
#
# aws cloudfront create-invalidation --distribution-id ${{ secrets.CDN_CLOUDFRONT_DIST_ID }} --paths "/*"
# working-directory: ${{ matrix.package }}
# - name: Report deployment to Sentinel
# if: steps.publish.outputs.id != ''
# uses: cds-snc/sentinel-forward-data-action@main
# with:
# input_data: '{"product": "design-system", "sha": "${{ github.sha }}", "version": "${{steps.publish.outputs.id}}", "repository": "${{ github.repository }}", "environment": "production", "status": "${{ job.status }}"}'
# log_type: CDS_Product_Deployment_Data
# log_analytics_workspace_id: ${{ secrets.LOG_ANALYTICS_WORKSPACE_ID }}
# log_analytics_workspace_key: ${{ secrets.LOG_ANALYTICS_WORKSPACE_KEY }}
#
#
# - name: Slack notify on failure
# if: failure()
# run: |
# json='{"blocks":[{"type":"section","text":{"type":"mrkdwn","text":":red: Publish ${{ matrix.name }} failed: <https://github.com/cds-snc/gcds-components/actions/workflows/compile-and-publish.yml|Publish packages>"}}]}'
# curl -X POST -H 'Content-type: application/json' --data "$json" ${{ secrets.SLACK_WEBHOOK_OPS }}
publish-react-angular:
name: Publish @cdssnc/gcds-components-react and @cdssnc/gcds-components-angular
needs: publish-web
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
include:
- name: "@cdssnc/gcds-components-react"
package: "./packages/react"
dist: "./packages/react"
- name: "@cdssnc/gcds-components-angular"
package: "./packages/angular"
dist: "./packages/angular/dist"
steps:
- name: Git Checkout
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- name: Setup Node
uses: actions/setup-node@d86ebcd40b3cb50b156bfa44dd277faf38282d12
with:
node-version: 18
- name: Install monorepo
run: npm install
- name: Build gcds-components
run: npm run build
# - name: Publish ${{ matrix.name }}
# uses: JS-DevTools/npm-publish@fe58a596e87f1297b15f580ec0dbc833d51a4622
# id: publish
# with:
# token: ${{ secrets.NPM_TOKEN }}
# package: ${{ matrix.dist }}
#
# - name: Configure AWS credentials using OIDC
# if: steps.publish.outputs.id != ''
# uses: aws-actions/configure-aws-credentials@50ac8dd1e1b10d09dac7b8727528b91bed831ac0 # v3.0.2
# with:
# role-to-assume: arn:aws:iam::307395567143:role/gcds-components-apply
# role-session-name: CDNPublish
# aws-region: ${{ env.CDN_REGION }}
#
# - name: Update CDN ${{ matrix.name }}
# if: steps.publish.outputs.id != ''
# run: |
# PUBLISHED_PACKAGE="${{ steps.publish.outputs.id }}"
#
# mkdir -p ./tmp \
# && npm install --prefix ./tmp "$PUBLISHED_PACKAGE" \
# && cd ./tmp/node_modules
#
# aws s3 sync ./${{ matrix.name }} s3://${{ env.CDN_BUCKET }}/"$PUBLISHED_PACKAGE" --delete
# aws s3 sync ./${{ matrix.name }} s3://${{ env.CDN_BUCKET }}/${{ matrix.name }}@latest --delete
# aws s3api head-object --bucket ${{ env.CDN_BUCKET }} --key "$PUBLISHED_PACKAGE"/package.json
# aws s3api head-object --bucket ${{ env.CDN_BUCKET }} --key ${{ matrix.name }}@latest/package.json
#
# aws cloudfront create-invalidation --distribution-id ${{ secrets.CDN_CLOUDFRONT_DIST_ID }} --paths "/*"
# working-directory: ${{ matrix.package }}
#
# - name: Report deployment to Sentinel
# if: steps.publish.outputs.id != ''
# uses: cds-snc/sentinel-forward-data-action@main
# with:
# input_data: '{"product": "design-system", "sha": "${{ github.sha }}", "version": "${{steps.publish.outputs.id}}", "repository": "${{ github.repository }}", "environment": "production", "status": "${{ job.status }}"}'
# log_type: CDS_Product_Deployment_Data
# log_analytics_workspace_id: ${{ secrets.LOG_ANALYTICS_WORKSPACE_ID }}
# log_analytics_workspace_key: ${{ secrets.LOG_ANALYTICS_WORKSPACE_KEY }}
#
# - name: Slack notify on failure
# if: failure()
# run: |
# json='{"blocks":[{"type":"section","text":{"type":"mrkdwn","text":":red: Publish ${{ matrix.name }} failed: <https://github.com/cds-snc/gcds-components/actions/workflows/compile-and-publish.yml|Publish packages>"}}]}'
# curl -X POST -H 'Content-type: application/json' --data "$json" ${{ secrets.SLACK_WEBHOOK_OPS }}