deploy-dapp #7
Workflow file for this run
This file contains hidden or 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
| name: Deploy DApp Contract | |
| on: | |
| workflow_dispatch: | |
| inputs: | |
| environment: | |
| description: 'Deployment environment' | |
| required: true | |
| type: choice | |
| options: | |
| - dapp-dev | |
| - dapp-prod | |
| sconify-version: | |
| description: 'Version of the sconify image to use' | |
| type: string | |
| default: '5.9.0-v15' | |
| env: | |
| DEPLOY_ENVIRONMENT: ${{ inputs.environment }} | |
| jobs: | |
| build-and-push: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| image-name: ${{ steps.set-outputs.outputs.image-name }} | |
| image-tag: ${{ steps.set-outputs.outputs.image-tag }} | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v4 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v3 | |
| - name: Login to DockerHub | |
| uses: docker/login-action@v3 | |
| with: | |
| username: ${{ secrets.DOCKERHUB_USERNAME }} | |
| password: ${{ secrets.DOCKERHUB_PAT }} | |
| - name: Get dapp version | |
| id: version | |
| run: | | |
| VERSION=$(node -p "require('./dapp/package.json').version") | |
| echo "version=$VERSION" >> $GITHUB_OUTPUT | |
| echo "dapp-version=$VERSION" | |
| - name: Build and push Docker image | |
| id: build | |
| uses: docker/build-push-action@v5 | |
| with: | |
| context: ./dapp | |
| push: true | |
| tags: iexechub/web3telegram-dapp:${{ steps.version.outputs.version }}-non-tee | |
| cache-from: type=gha | |
| cache-to: type=gha,mode=max | |
| - name: Set outputs | |
| id: set-outputs | |
| run: | | |
| echo "image-name=iexechub/web3telegram-dapp" >> $GITHUB_OUTPUT | |
| echo "image-tag=${{ steps.version.outputs.version }}-non-tee" >> $GITHUB_OUTPUT | |
| sconify: | |
| needs: build-and-push | |
| uses: iExecBlockchainComputing/github-actions-workflows/.github/workflows/sconify.yml@sconify-v2 | |
| with: | |
| image-name: ${{ needs.build-and-push.outputs.image-name }} | |
| image-tag: ${{ needs.build-and-push.outputs.image-tag }} | |
| sconify-debug: false | |
| sconify-prod: true | |
| docker-registry: docker.io | |
| sconify-version: ${{ inputs.sconify-version }} | |
| binary: /usr/local/bin/node | |
| command: node /app/src/app.js | |
| host-path: | | |
| /etc/hosts | |
| /etc/resolv.conf | |
| binary-fs: true | |
| fs-dir: /app | |
| heap: 1G | |
| dlopen: 1 | |
| mprotect: 1 | |
| secrets: | |
| docker-password: ${{ secrets.DOCKERHUB_PAT }} | |
| scontain-password: ${{ secrets.SCONTAIN_REGISTRY_PAT }} | |
| scone-signing-key: ${{ secrets.SCONIFY_SIGNING_PRIVATE_KEY }} | |
| docker-username: ${{ secrets.DOCKERHUB_USERNAME }} | |
| scontain-username: ${{ secrets.SCONTAIN_REGISTRY_USERNAME }} | |
| display-sconify-results: | |
| runs-on: ubuntu-latest | |
| needs: sconify | |
| steps: | |
| - name: Display Sconify Results | |
| run: | | |
| echo "## Sconify Results" >> $GITHUB_STEP_SUMMARY | |
| echo "" >> $GITHUB_STEP_SUMMARY | |
| echo "### Production Image" >> $GITHUB_STEP_SUMMARY | |
| echo "- **Image**: ${{ needs.sconify.outputs.prod-image }}" >> $GITHUB_STEP_SUMMARY | |
| echo "- **Checksum**: ${{ needs.sconify.outputs.prod-checksum }}" >> $GITHUB_STEP_SUMMARY | |
| echo "- **MrEnclave**: ${{ needs.sconify.outputs.prod-mrenclave }}" >> $GITHUB_STEP_SUMMARY | |
| echo "" >> $GITHUB_STEP_SUMMARY | |
| echo "### Summary" >> $GITHUB_STEP_SUMMARY | |
| echo "Sconification completed successfully!" >> $GITHUB_STEP_SUMMARY | |
| deploy-dapp: | |
| runs-on: ubuntu-latest | |
| needs: [build-and-push, sconify] | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v4 | |
| - name: Setup Node.js | |
| uses: actions/setup-node@v4 | |
| with: | |
| node-version: '18.19' | |
| cache: 'npm' | |
| - name: Install dependencies | |
| run: | | |
| npm ci | |
| cd node_modules/whitelist-smart-contract | |
| npm install --save-dev ts-node | |
| cd ../../deployment-dapp | |
| npm ci | |
| - name: Create scone fingerprint file | |
| run: | | |
| MRENCLAVE="${{ needs.sconify.outputs.prod-mrenclave }}" | |
| echo "$MRENCLAVE" > deployment-dapp/.scone-fingerprint | |
| - name: Deploy dapp contract | |
| env: | |
| DEPLOY_ENVIRONMENT: ${{ inputs.environment }} | |
| WALLET_PRIVATE_KEY_DEV: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_DEV_PRIVATEKEY }} | |
| WALLET_PRIVATE_KEY_PROD: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_PROD_PRIVATEKEY }} | |
| DOCKER_IMAGE_CHECKSUM_DEV: ${{ needs.sconify.outputs.prod-checksum }} | |
| DOCKER_IMAGE_CHECKSUM_PROD: ${{ needs.sconify.outputs.prod-checksum }} | |
| run: | | |
| cd deployment-dapp | |
| npm run deploy-dapp | |
| - name: Push dapp secret | |
| env: | |
| DEPLOY_ENVIRONMENT: ${{ inputs.environment }} | |
| WALLET_PRIVATE_KEY_DEV: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_DEV_PRIVATEKEY }} | |
| WALLET_PRIVATE_KEY_PROD: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_PROD_PRIVATEKEY }} | |
| TELEGRAM_BOT_TOKEN_DEV: ${{ secrets.TELEGRAM_BOT_TOKEN_DEV }} | |
| TELEGRAM_BOT_TOKEN_PROD: ${{ secrets.TELEGRAM_BOT_TOKEN_PROD }} | |
| run: | | |
| cd deployment-dapp | |
| npm run push-dapp-secret | |
| - name: Publish free sell order | |
| env: | |
| DEPLOY_ENVIRONMENT: ${{ inputs.environment }} | |
| WALLET_PRIVATE_KEY_DEV: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_DEV_PRIVATEKEY }} | |
| WALLET_PRIVATE_KEY_PROD: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_PROD_PRIVATEKEY }} | |
| PRICE: '0' | |
| VOLUME: '1000000000' | |
| run: | | |
| cd deployment-dapp | |
| npm run publish-sell-order | |
| - name: Add resource to whitelist (dev) | |
| if: inputs.environment == 'dapp-dev' | |
| env: | |
| WALLET_PRIVATE_KEY: ${{ secrets.DEPLOYER_DEV_PRIVATEKEY }} | |
| CONTRACT_ADDRESS: ${{ secrets.WEB3TELEGRAM_WHITELIST_DEV_ADDRESS }} | |
| run: | | |
| cd node_modules/whitelist-smart-contract | |
| export ADDRESS_TO_ADD=$(cat ../../deployment-dapp/.app-address) && npm run addResourceToWhitelist | |
| - name: Add resource to whitelist (prod) | |
| if: inputs.environment == 'dapp-prod' | |
| env: | |
| WALLET_PRIVATE_KEY: ${{ secrets.DEPLOYER_PROD_PRIVATEKEY }} | |
| CONTRACT_ADDRESS: ${{ secrets.WEB3TELEGRAM_WHITELIST_PROD_ADDRESS }} | |
| run: | | |
| cd node_modules/whitelist-smart-contract | |
| export ADDRESS_TO_ADD=$(cat ../../deployment-dapp/.app-address) && npm run addResourceToWhitelist | |
| - name: Configure ENS | |
| env: | |
| DEPLOY_ENVIRONMENT: ${{ inputs.environment }} | |
| WALLET_PRIVATE_KEY_DEV: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_DEV_PRIVATEKEY }} | |
| WALLET_PRIVATE_KEY_PROD: ${{ secrets.WEB3TELEGRAM_DAPP_OWNER_PROD_PRIVATEKEY }} | |
| run: | | |
| cd deployment-dapp | |
| npm run configure-ens | |
| - name: Upload deployment artifacts | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: deployment-artifacts | |
| path: | | |
| deployment-dapp/.app-address | |
| deployment-dapp/.scone-fingerprint |