Alfresco Restore Docs Worker Process #11
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: Alfresco Restore Docs Worker Process | |
on: | |
workflow_dispatch: | |
inputs: | |
which_env: | |
description: Environment where this restore docs process will run | |
required: true | |
type: choice | |
options: | |
- poc | |
s3_object_key: | |
description: S3 Object which needs to be restored | |
required: true | |
job_tier: | |
description: Glacier job tier (Expedited, Standard, Bulk) | |
required: false | |
default: 'Expedited' | |
permissions: | |
contents: read | |
jobs: | |
restore-docs-worker: | |
runs-on: ubuntu-latest | |
environment: | |
name: ${{ github.event.inputs.which_env }} | |
steps: | |
- name: Checkout current repo | |
uses: actions/checkout@v3 | |
- name: Configure kubectl | |
run: | | |
echo "${{ secrets.KUBE_CERT }}" > ca.crt | |
kubectl config set-cluster ${KUBE_CLUSTER} --certificate-authority=./ca.crt --server=https://${KUBE_CLUSTER} | |
kubectl config set-credentials deploy-user --token=${{ secrets.KUBE_TOKEN }} | |
kubectl config set-context ${KUBE_CLUSTER} --cluster=${KUBE_CLUSTER} --user=deploy-user --namespace=${KUBE_NAMESPACE} | |
kubectl config use-context ${KUBE_CLUSTER} | |
env: | |
KUBE_NAMESPACE: ${{ secrets.KUBE_NAMESPACE }} | |
KUBE_CLUSTER: ${{ secrets.KUBE_CLUSTER }} | |
- name: Restore from Glacier by executing in the service pod | |
run: | | |
#!/bin/bash | |
set -xe | |
SERVICE_POD_DEPLOYMENT=$(kubectl get deployment -l app=service-pod -o jsonpath="{.items[0].metadata.name}") | |
SERVICE_POD_NAME=$(kubectl get pod -l app=$SERVICE_POD_DEPLOYMENT -o jsonpath="{.items[0].metadata.name}") | |
S3_BUCKET_NAME=$(kubectl get secrets s3-bucket-output -o jsonpath='{.data.BUCKET_NAME}' | base64 -d) | |
# Exec into the service pod and execute the script | |
kubectl exec $SERVICE_POD_NAME -- env S3_BUCKET_NAME=${S3_BUCKET_NAME} /bin/sh -c ' | |
# check if object is present or not | |
object_versions=$(aws s3api list-object-versions --bucket "$S3_BUCKET_NAME" --prefix "${S3_OBJECT_KEY}") | |
if [[ -z "$object_versions" ]]; then | |
echo "Object not found in bucket" | |
exit 1 | |
fi | |
# Delete the delete marker versions | |
version_id=$(aws s3api list-object-versions --bucket "$S3_BUCKET_NAME" --prefix "${S3_OBJECT_KEY}" --query "DeleteMarkers[0].[VersionId]" --output text) | |
aws s3api delete-object --bucket "$S3_BUCKET_NAME" --key "${S3_OBJECT_KEY}" --version-id "$version_id" | |
echo "Deleted marker version: $version_id" | |
# Restore from Glacier | |
aws s3api restore-object --bucket "$S3_BUCKET_NAME" --key "${S3_OBJECT_KEY}" --restore-request "{\"Days\":1,\"GlacierJobParameters\":{\"Tier\":\"$JOB_TIER\"}}" | |
# Wait for restoration to complete | |
wait_interval=30 | |
result=$(aws s3api head-object --bucket "$S3_BUCKET_NAME" --key "$S3_OBJECT_KEY") | |
# Check if the Restore field contains the substring "ongoing-request=\"false\"", that means restore complete. | |
restore_status=$(echo "$result" | grep -q 'ongoing-request=\\"false\\"' && echo true || echo false) | |
if ! $restore_status; then | |
#restore in progress | |
echo "Restore for object s3://${S3_BUCKET_NAME}/${S3_OBJECT_KEY} in progress. Please wait!" | |
sleep "$wait_interval" | |
fi | |
# Copy object within S3 bucket to update storage class | |
aws s3 cp "s3://$S3_BUCKET_NAME/${S3_OBJECT_KEY}" "s3://$S3_BUCKET_NAME/${S3_OBJECT_KEY}" --storage-class STANDARD | |
echo "Restore for object s3://${S3_BUCKET_NAME}/${S3_OBJECT_KEY} task complete." | |
' | |
env: | |
JOB_TIER: ${{ github.event.inputs.job_tier }} | |
S3_OBJECT_KEY: ${{ github.event.inputs.s3_object_key }} |