2024-11-17 14:43:48 +01:00
|
|
|
name: PR Deployment cleanup
|
2024-11-16 23:24:00 +01:00
|
|
|
|
|
|
|
on:
|
|
|
|
pull_request:
|
|
|
|
types: [opened, synchronize, reopened, closed]
|
|
|
|
|
|
|
|
permissions:
|
|
|
|
contents: write
|
|
|
|
pull-requests: write
|
|
|
|
|
|
|
|
env:
|
|
|
|
SERVER_IP: ${{ secrets.VPS_IP }} # Add this to your GitHub secrets
|
2024-11-20 09:41:29 +01:00
|
|
|
CLEANUP_PERFORMED: 'false' # Add flag to track if cleanup occurred
|
2024-11-16 23:24:00 +01:00
|
|
|
|
|
|
|
jobs:
|
|
|
|
cleanup:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
if: github.event.action == 'closed'
|
|
|
|
|
|
|
|
steps:
|
2024-12-21 13:28:35 +01:00
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.2
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
|
|
|
|
2024-11-16 23:24:00 +01:00
|
|
|
- name: Set up SSH
|
|
|
|
run: |
|
|
|
|
mkdir -p ~/.ssh/
|
|
|
|
echo "${{ secrets.VPS_SSH_KEY }}" > ../private.key
|
|
|
|
sudo chmod 600 ../private.key
|
|
|
|
|
|
|
|
- name: Cleanup PR deployment
|
2024-11-20 09:41:29 +01:00
|
|
|
id: cleanup
|
2024-11-16 23:24:00 +01:00
|
|
|
run: |
|
2024-11-20 09:41:29 +01:00
|
|
|
CLEANUP_STATUS=$(ssh -i ../private.key -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -T ${{ secrets.VPS_USERNAME }}@${{ secrets.VPS_HOST }} << 'ENDSSH'
|
2024-11-16 23:24:00 +01:00
|
|
|
if [ -d "/stirling/PR-${{ github.event.pull_request.number }}" ]; then
|
|
|
|
echo "Found PR directory, proceeding with cleanup..."
|
|
|
|
|
|
|
|
# Stop and remove containers
|
|
|
|
cd /stirling/PR-${{ github.event.pull_request.number }}
|
|
|
|
docker-compose down || true
|
|
|
|
|
|
|
|
# Go back to root before removal
|
|
|
|
cd /
|
|
|
|
|
|
|
|
# Remove PR-specific directories
|
|
|
|
rm -rf /stirling/PR-${{ github.event.pull_request.number }}
|
|
|
|
|
|
|
|
# Remove the Docker image
|
2024-11-17 14:43:48 +01:00
|
|
|
docker rmi --no-prune ${{ secrets.DOCKER_HUB_USERNAME }}/test:pr-${{ github.event.pull_request.number }} || true
|
2024-11-16 23:24:00 +01:00
|
|
|
|
2024-11-20 09:41:29 +01:00
|
|
|
echo "PERFORMED_CLEANUP"
|
2024-11-16 23:24:00 +01:00
|
|
|
else
|
|
|
|
echo "PR directory not found, nothing to clean up"
|
2024-11-20 09:41:29 +01:00
|
|
|
echo "NO_CLEANUP_NEEDED"
|
2024-11-16 23:24:00 +01:00
|
|
|
fi
|
|
|
|
ENDSSH
|
2024-11-20 09:41:29 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
if [[ $CLEANUP_STATUS == *"PERFORMED_CLEANUP"* ]]; then
|
|
|
|
echo "cleanup_performed=true" >> $GITHUB_OUTPUT
|
|
|
|
else
|
|
|
|
echo "cleanup_performed=false" >> $GITHUB_OUTPUT
|
|
|
|
fi
|
2024-11-16 23:24:00 +01:00
|
|
|
|
|
|
|
- name: Post cleanup notice to PR
|
2024-11-20 09:41:29 +01:00
|
|
|
if: steps.cleanup.outputs.cleanup_performed == 'true'
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
|
2024-11-16 23:24:00 +01:00
|
|
|
with:
|
|
|
|
script: |
|
|
|
|
const { GITHUB_REPOSITORY } = process.env;
|
|
|
|
const [repoOwner, repoName] = GITHUB_REPOSITORY.split('/');
|
|
|
|
const prNumber = context.issue.number;
|
|
|
|
|
|
|
|
const commentBody = `## 🧹 Deployment Cleanup\n\n` +
|
|
|
|
`The test deployment for this PR has been cleaned up.`;
|
|
|
|
|
|
|
|
await github.rest.issues.createComment({
|
|
|
|
owner: repoOwner,
|
|
|
|
repo: repoName,
|
|
|
|
issue_number: prNumber,
|
|
|
|
body: commentBody
|
|
|
|
});
|