trigger #7
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: Liat Workflow | |
on: | |
push: | |
branches: | |
- liats/wip/ci_cd | |
permissions: | |
id-token: write | |
contents: read | |
jobs: | |
deploy: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v2 # Checks out the repository under $GITHUB_WORKSPACE. | |
- name: Configure AWS Credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
role-to-assume: arn:aws:iam::081569964966:role/github_cicd | |
aws-region: eu-west-1 | |
# Check the account role and region | |
- name: Check AWS Account | |
run: aws sts get-caller-identity | |
- name: Launch EC2 Instance | |
id: launch-ec2 | |
run: | | |
AMI_ID=ami-056d2deb35634ac41 # AmazonLinux2 Mate | |
ISNTANCE_TYPE=t3.large | |
SUBNET_ID=subnet-08f168b88d687e3ae # PhenoVPC-PublicSubnet1 | |
INSTANCE_ID=$(aws ec2 run-instances --image-id $AMI_ID --instance-type $ISNTANCE_TYPE --subnet-id $SUBNET_ID --query 'Instances[0].InstanceId' --output text --tag-specifications 'ResourceType=instance,Tags=[{Key=Name,Value=GitHubActionsInstance}]') | |
echo "::set-output name=INSTANCE_ID::$INSTANCE_ID" | |
aws ec2 wait instance-running --instance-ids $INSTANCE_ID | |
PUBLIC_IP=$(aws ec2 describe-instances --instance-ids $INSTANCE_ID --query 'Reservations[0].Instances[0].PublicIpAddress' --output text) | |
echo "Instance ID: $INSTANCE_ID, Public IP: $PUBLIC_IP" | |
- name: Run command on EC2 instance | |
run: | | |
aws ssm send-command --document-name "AWS-RunShellScript" --document-version "1" \ | |
--targets '[{"Key":"InstanceIds","Values":["$INSTANCE_ID"]}]' \ | |
--parameters '{"commands":["echo Hello World > /tmp/hello_world.txt; cat /tmp/hello_world.txt"]}' \ | |
--timeout-seconds 600 --max-concurrency 50 --max-errors 0 --region eu-west-1 | |
# - name: Create and Upload Artifact to S3 | |
# run: | | |
# # Example of creating a tar.gz archive and uploading it | |
# tar -czvf artifact.tar.gz /path/to/your/files | |
# aws s3 cp artifact.tar.gz s3://YOUR_S3_BUCKET_NAME/path/to/upload/ | |
- name: Cleanup - Terminate EC2 Instance | |
if: always() | |
run: | | |
INSTANCE_ID=${{ steps.launch-ec2.outputs.INSTANCE_ID }} | |
aws ec2 terminate-instances --instance-ids $INSTANCE_ID | |
aws ec2 wait instance-terminated --instance-ids $INSTANCE_ID |