Skip to content

[NR-343531] Workflows for lambda code and templates deployment #4

[NR-343531] Workflows for lambda code and templates deployment

[NR-343531] Workflows for lambda code and templates deployment #4

Workflow file for this run

name: Build and Deploy Lambda
on:
pull_request:
branches:
- main
env:
log_forwarder_zip_file_name: new-relic-log-forwarder.zip
jobs:
build-and-deploy:
runs-on: ubuntu-latest
permissions:
id-token: write
contents: write
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Go
uses: actions/setup-go@v5
with:
go-version: '1.22'
- name: Build and Package Go executable
run: |
cd src
go mod tidy
GOOS=linux GOARCH=amd64 go build -o bootstrap main.go
zip -r ../$log_forwarder_zip_file_name .
cd ..
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: log-forwarder-zip
path: |
${{ env.log_forwarder_zip_file_name }}
- name: Install AWS SAM CLI
run: |
pip install aws-sam-cli
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3
with:
role-to-assume: ${{ secrets.AWS_S3_PUBLISH_ROLE_TEMP }}
aws-region: us-east-2
- name: Build and Package SAM Application and Upload to S3
env:
bucket_name: anusha-test-ansuha
region: us-east-1
run: |
BUILD_DIR_BASE=".aws-sam/build"
TEMPLATES=(
"logging-lambda-metric-polling.yaml"
"logging-lambda-metric-stream.yaml"
"logging-firehose-metric-polling.yaml"
"logging-firehose-metric-stream.yaml"
"logging-lambda-firehose-metric-polling.yaml"
"logging-lambda-firehose-metric-stream.yaml"
"lambda-template.yaml"
"logging-lambda-firehose-template.yaml"
)
for TEMPLATE_FILE in "${TEMPLATES[@]}"; do
BASE_NAME=$(basename "$TEMPLATE_FILE" .yaml)
BUILD_DIR=".aws-sam/build/$BASE_NAME"
sam build --template-file "$TEMPLATE_FILE" --build-dir "$BUILD_DIR"
sam package --s3-bucket "$bucket_name" --template-file "$BUILD_DIR/template.yaml" --output-template-file "$BUILD_DIR/$TEMPLATE_FILE" --region $region
aws s3 cp "$BUILD_DIR/$TEMPLATE_FILE" "s3://$bucket_name/$TEMPLATE_FILE"
done
deploy-lambda-code-parallelly-to-all-region:
needs: build-and-deploy
permissions:
id-token: write
contents: write
runs-on: ubuntu-latest
strategy:
matrix:
region:
- us-east-1
- us-east-2
# - eu-west-1
# - eu-west-2
# - us-west-1
# - us-west-2
# - af-south-1
# - ap-east-1
# - ap-south-2
# - ap-southeast-3
# - ap-southeast-5
# - ap-southeast-4
# - ap-south-1
# - ap-northeast-3
# - ap-northeast-2
# - ap-southeast-1
# - ap-southeast-2
# - ap-northeast-1
# - ca-central-1
# - ca-west-1
# - eu-central-1
# - eu-south-1
# - eu-west-3
# - eu-south-2
# - eu-north-1
# - eu-central-2
# - me-south-1
# - me-central-1
# - il-central-1
# - sa-east-1
steps:
- name: Download Artifact
uses: actions/download-artifact@v3
with:
name: log-forwarder-zip
path: ./build-artifacts
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v3
with:
role-to-assume: ${{ secrets.AWS_S3_PUBLISH_ROLE_TEMP }}
aws-region: us-east-2
- name: Upload lambda code to S3 buckets in all AWS region
env:
bucket_prefix: new-relic-log-forwarder-folder
region: ${{ matrix.region }}
run: |
bucket_name="unified-logging-lambda-code-test-$region"
aws s3 cp "./build-artifacts/$log_forwarder_zip_file_name" "s3://$bucket_name/$bucket_prefix/" --region "$region"
echo "Deploying $log_forwarder_zip_file_name to region $REGION"