name: Azure Static Web Apps CI/CD on: push: branches: - main paths: - "website/**" - "themes/**" workflow_dispatch: permissions: id-token: write contents: read jobs: build_and_deploy: runs-on: ubuntu-latest name: Build and Deploy steps: - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 with: submodules: true persist-credentials: false - name: Install Go uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe with: go-version: 1.21 cache-dependency-path: src/go.sum - uses: actions/setup-node@8f152de45cc393bb48ce5d89d36b731f54556e65 with: node-version: 17.6.0 # Create Kind cluster to have a Kubernetes context for cloud-native-azure theme # Images are defined on every Kind release # See https://github.com/kubernetes-sigs/kind/releases - name: Create k8s v1.23 Kind Cluster uses: helm/kind-action@dda0770415bac9fc20092cacbc54aa298604d140 with: node_image: kindest/node:v1.23.4@sha256:0e34f0d0fd448aa2f2819cfd74e99fe5793a6e4938b328f657c8e3f81ee0dfb9 cluster_name: posh - name: Create Kubernetes namespace run: | kubectl create ns demo - name: Set default Kubernetes namespace run: | kubectl config set-context posh --namespace demo - uses: azure/login@92a5484dfaf04ca78a94597f4f19fea633851fa2 with: creds: ${{ secrets.AZURE_CREDENTIALS }} - name: Build oh-my-posh 🔧 run: | cd src go build -o ./bin/oh-my-posh cd .. - name: Render themes 🎨 run: | export PATH="$PWD/src/bin:$PATH" cd website npm install --legacy-peer-deps npm run themes cd .. - name: Build Docs And Deploy 🚀 id: builddeploy uses: Azure/static-web-apps-deploy@1a947af9992250f3bc2e68ad0754c0b0c11566c9 with: azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_ASHY_MEADOW_063E9BA03 }} repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for Github integrations (i.e. PR comments) action: "upload" ###### Repository/Build Configurations - These values can be configured to match your app requirements. ###### # For more information regarding Static Web App workflow configurations, please visit: https://aka.ms/swaworkflowconfig app_location: "/website" # App source code path api_location: "/website/api" # Api source code path - optional output_location: "build" # Built app content directory - optional