chore: Added workflow for generating the certificate for signing #676
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
name: Test and Deploy | |
on: | |
push: | |
branches: [ '*' ] | |
tags: [ '*' ] | |
pull_request: | |
branches: [ main ] | |
schedule: | |
# Run automatically at 8AM PST Monday-Friday | |
- cron: '0 15 * * 1-5' | |
workflow_dispatch: | |
jobs: | |
test: | |
name: Test | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
env: | |
DOCKER_LOGIN: ${{ secrets.DOCKER_USERNAME && secrets.DOCKER_AUTH_TOKEN }} | |
steps: | |
- name: Checkout sendgrid-csharp | |
uses: actions/checkout@v2 | |
with: | |
fetch-depth: 0 | |
- name: Login to Docker Hub | |
if: env.DOCKER_LOGIN | |
uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_AUTH_TOKEN }} | |
- name: Setup .NET Core SDK | |
uses: actions/[email protected] | |
with: | |
dotnet-version: '3.1.x' | |
- run: dotnet build -c Release | |
- name: Build & Test | |
run: make test-docker release | |
- run: bash <(curl -s https://codecov.io/bash) | |
import-certificate: | |
runs-on: windows-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- run: make install | |
- name: import-certificate | |
run: | | |
New-Item -ItemType directory -Path certificate | |
Set-Content -Path certificate\certificate.txt -Value ${{ secrets.CODE_SIGNING_CERTIFICATE }} | |
certutil -decode certificate\certificate.txt certificate\certificate.pfx | |
- name: Upload Artifact | |
uses: actions/upload-artifact@v3 | |
with: | |
name: certificate.pem | |
path: certificate\certificate.pem | |
retention-days: 1 | |
deploy: | |
name: Deploy | |
if: success() && github.ref_type == 'tag' | |
needs: [ test ] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout sendgrid-csharp | |
uses: actions/checkout@v2 | |
- name: Setup .NET Core SDK | |
uses: actions/[email protected] | |
with: | |
dotnet-version: '3.1.x' | |
- name: Create GitHub Release | |
uses: sendgrid/dx-automator/actions/release@main | |
with: | |
footer: '**[NuGet](https://www.nuget.org/packages/Sendgrid/${version})**' | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Publish package to NuGet | |
run: | | |
make release | |
dotnet nuget sign **/*.nupkg --certificate-path certificate.pfx --certificate-password ${{ secrets.CERTIFICATE_PASSWORD }} --timestamper http://timestamp.digicert.com | |
dotnet nuget push **/*.nupkg -k ${{ secrets.NUGET_API_KEY }} -s https://api.nuget.org/v3/index.json --skip-duplicate | |
- name: Submit metric to Datadog | |
uses: sendgrid/dx-automator/actions/datadog-release-metric@main | |
env: | |
DD_API_KEY: ${{ secrets.DATADOG_API_KEY }} | |
notify-on-failure: | |
name: Slack notify on failure | |
if: failure() && github.event_name != 'pull_request' && (github.ref == 'refs/heads/main' || github.ref_type == 'tag') | |
needs: [ test, deploy ] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: rtCamp/action-slack-notify@v2 | |
env: | |
SLACK_COLOR: failure | |
SLACK_ICON_EMOJI: ':github:' | |
SLACK_MESSAGE: ${{ format('Test *{0}*, Deploy *{1}*, {2}/{3}/actions/runs/{4}', needs.test.result, needs.deploy.result, github.server_url, github.repository, github.run_id) }} | |
SLACK_TITLE: Action Failure - ${{ github.repository }} | |
SLACK_USERNAME: GitHub Actions | |
SLACK_MSG_AUTHOR: twilio-dx | |
SLACK_FOOTER: Posted automatically using GitHub Actions | |
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }} | |
MSG_MINIMAL: true |