Deploy Module #21
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: 'Deploy Module' | |
on: | |
workflow_call: | |
secrets: | |
PUSH_TO_OTHER_REPOS_TOKEN_ADMIN: | |
required: true | |
workflow_dispatch: | |
# release:? [published] | |
# push: | |
# branches: | |
# - '*' | |
permissions: | |
contents: read | |
jobs: | |
copy_module_to_new_repo: | |
name: 'Export module' | |
runs-on: ubuntu-latest | |
# Use the Bash shell regardless whether the GitHub Actions runner is ubuntu-latest, macos-latest, or windows-latest | |
defaults: | |
run: | |
shell: bash | |
strategy: | |
fail-fast: false | |
matrix: | |
include: | |
- source_module: "aws/sonar-upgrader" | |
destination_repo: "terraform-aws-dsf-sonar-upgrader" | |
begin_tag: 1.5.4 | |
env: | |
source_module: ${{ matrix.source_module }} | |
destination_repo: ${{ matrix.destination_repo }} | |
hidden_submodules: ${{ matrix.hidden_submodules }} | |
public_submodule: ${{ matrix.public_submodule }} | |
outputs: | |
module_github_repo: ${{ format('https://github.com/imperva/{0}', matrix.destination_repo) }} | |
steps: | |
# Checkout the repository to the GitHub Actions runner | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: '0' | |
ref: 'deploy-upgrade-module' | |
- name: Filter branch | |
run: | | |
set -x | |
set -e | |
git branch | |
if [ -n "${hidden_submodules}" ]; then | |
cmd="" | |
for i in ${hidden_submodules}; do | |
target_dir=_modules/$i | |
cmd="$cmd mkdir -p $(dirname modules/${source_module}/$target_dir); mv modules/$i modules/${source_module}/$target_dir;" | |
cmd="$cmd sed -i \"s/\/modules\//\/_modules\//g\" modules/${source_module}/${target_dir}/*.tf;" | |
done | |
cmd="$cmd sed -i \"s/..\/..\/..\/modules/.\/_modules/g\" modules/${source_module}/*.tf;" | |
cmd="$cmd true;" | |
git filter-branch -f --prune-empty --tree-filter "$cmd" --tag-name-filter cat -- --all HEAD | |
fi | |
if [ -n "${public_submodule}" ]; then | |
for m in ${public_submodule}; do | |
git filter-branch -f --prune-empty --tree-filter 'mkdir -p modules/'${source_module}'/modules; mv modules/'${m}' modules/'${source_module}'/modules/; true;' --tag-name-filter cat -- --all HEAD | |
done | |
fi | |
all_tags=$(git tag) | |
filtered_tags=() | |
# Loop through each tag and filter if greater than or equal to begin_tag | |
for tag in $all_tags; do | |
if [[ "$tag" == "${begin_tag}" || "$tag" > "${begin_tag}" ]]; then | |
filtered_tags+=("$tag") | |
fi | |
done | |
echo "Begin tag: ${begin_tag}, filtered Tags: ${filtered_tags[@]}" | |
for tag in $filtered_tags; do | |
git filter-branch -f --prune-empty --tree-filter 'mv LICENSE.md modules/'${source_module}'/ 2>/dev/null || true' --tag-name-filter "if [ \$GIT_TAG = $tag ]; then echo \$GIT_TAG; fi" -- --all HEAD | |
git filter-branch -f --prune-empty --subdirectory-filter modules/${source_module}/ --tag-name-filter "if [ \$GIT_TAG = $tag ]; then echo \$GIT_TAG; fi" -- --all HEAD | |
done | |
- name: Push to module repo | |
env: | |
github_token: ${{ secrets.PUSH_TO_OTHER_REPOS_TOKEN_ADMIN }} | |
run: | | |
set -x | |
git branch | |
pwd | |
find . | grep -v ".git/" | |
git config --unset-all http.https://github.com/.extraheader # override github_action own authentication method | |
git remote set-url origin https://${github_token}@github.com/imperva/${destination_repo}.git | |
git branch -m main | |
refs=$(git ls-remote --tags 2>/dev/null | awk '{print $NF}') | |
if [ -n "$refs" ]; then | |
git push origin --delete $(git ls-remote --tags 2>/dev/null | awk '{print $NF}') | |
fi | |
latest_tag=$(git tag -l | sort -V | tail -n 1) | |
# push all repo but latest tag | |
git tag -d ${latest_tag} | |
git push -f origin HEAD:main --tags | |
# push latest tag (to trigger terraform registery latest release discovery) | |
git tag ${latest_tag} | |
git push -f origin HEAD:main --tags |