forked from NHSDigital/repository-template
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CCM-6405 Adding github workflow to sync template repo
- Loading branch information
1 parent
7887908
commit 925ec0c
Showing
3 changed files
with
182 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
name: Repository Template Sync | ||
|
||
on: | ||
schedule: | ||
- cron: '0 0 1 * *' | ||
workflow_dispatch: | ||
|
||
permissions: | ||
contents: write | ||
pull-requests: write | ||
checks: read | ||
|
||
jobs: | ||
update-external-repo: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Check out the repository | ||
uses: actions/checkout@v4 | ||
|
||
- name: Check out external repository | ||
uses: actions/checkout@v4 | ||
with: | ||
repository: NHSDigital/nhs-notify-repository-template | ||
path: nhs-notify-repository-template | ||
token: ${{ github.token }} | ||
|
||
- name: Run syncronisation script | ||
run: | | ||
./scripts/githooks/sync-template-repo.sh | ||
- name: Create Pull Request | ||
if: ${{ !env.ACT }} | ||
uses: peter-evans/create-pull-request@v7.0.1 | ||
with: | ||
token: ${{ secrets.GITHUB_TOKEN }} | ||
commit-message: Drift from template | ||
branch: scheduledTemplateRepositorySync | ||
delete-branch: true | ||
title: '[Template Sync] Drift from template-repository remediation' | ||
body: | | ||
# Resultant drift from repository template | ||
## Who should respond to this PR? | ||
The team which owns the responsibility for this component repository. You may want to consult other contributors. | ||
## How to progress this PR | ||
The repositories guardians should review the contents of the PR and decide how to proceed, you may wish to back-out certain changes or accept them from the upstream `nhsdigital/nhs-notify-repository-template` repository. | ||
If there are changes you do not wish to see again, it is recommended you add exclusions to `scripts/config/.repository-template-sync-ignore`. | ||
labels: | | ||
template | ||
automation | ||
draft: false |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# Files and folders to ignore when syncing nhs-notify-repository-template back in to this repository | ||
scripts/config/.repository-template-sync-ignore | ||
.github/workflows/ | ||
nhs-notify-repository-template/ | ||
|
||
# Files and Folders in this repository to ignore | ||
.vscode/ | ||
CHANGELOG.md | ||
project.code-workspace | ||
README.md | ||
VERSION | ||
|
||
# Files and Folders in the template repository to disregard | ||
.devcontainer/ | ||
.github/workflows/cicd-*.yaml | ||
*/examples/ | ||
docs/ | ||
infrastructure/terraform/components/ |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
#!/bin/bash | ||
|
||
set -euo pipefail | ||
|
||
# Script to synchronise the nhs-notify-template-repository with this repository | ||
# | ||
# Usage: | ||
# $ [options] ./check-terraform-format.sh | ||
# | ||
# Options: | ||
# new_only=true # Only identify new files from the template-repository | ||
# changes_only=true # Only identify files which have drifted from the template-repository | ||
|
||
# ============================================================================== | ||
|
||
# Command line prameters | ||
new_only=${new_only:-false} | ||
changes_only=${changes_only:-false} | ||
|
||
# Set variables | ||
TEMPLATE_REPO_DIR="nhs-notify-repository-template" | ||
IGNORE_FILE="scripts/config/.repository-template-sync-ignore" | ||
|
||
# Check if the template directory exists | ||
if [ ! -d "${TEMPLATE_REPO_DIR}" ]; then | ||
echo "Template directory ${TEMPLATE_REPO_DIR} not found!" | ||
exit 1 | ||
fi | ||
|
||
# Check if the .template-ignore file exists, create an empty one if not | ||
if [ ! -f "${IGNORE_FILE}" ]; then | ||
echo "# Files and folders to ignore when syncing ${TEMPLATE_REPO_DIR} back in to this repository" > ${IGNORE_FILE} | ||
echo "# Files and Folders in this repository to ignore" >> ${IGNORE_FILE} | ||
echo "# Files and Folders in the template repository to disregard" >> ${IGNORE_FILE} | ||
fi | ||
|
||
# Read the .template-ignore file into an array | ||
while IFS= read -r line || [ -n "$line" ]; do | ||
IGNORED_PATHS+=("$line") | ||
done < "$IGNORE_FILE" | ||
|
||
# Check if a file is ignored. | ||
is_ignored() { | ||
local file=${1} | ||
|
||
# Ignore .git directories and files | ||
if [[ "$file" == *.git/* ]]; then | ||
return 0 | ||
fi | ||
|
||
for ignored in "${IGNORED_PATHS[@]}"; do | ||
if [[ -n "$ignored" && "$file" =~ $ignored ]]; then | ||
return 0 | ||
fi | ||
done | ||
return 1 | ||
} | ||
|
||
# Navigate to the template directory | ||
cd "${TEMPLATE_REPO_DIR}" || exit | ||
FILES_ADDED=() | ||
FILES_WITH_CHANGES=() | ||
|
||
# Loop through all files in the template directory | ||
while IFS= read -r -d '' file; do | ||
relative_path="${file#./}" # Remove leading './' | ||
|
||
# Check if the file is ignored | ||
if is_ignored "$relative_path"; then | ||
echo "Ignoring $relative_path" | ||
continue | ||
fi | ||
|
||
target_path="../$relative_path" | ||
mkdir -p "$(dirname "$target_path")" | ||
|
||
# Copy the file to the root directory if it doesn't exist or is different | ||
if [ ! -f "$target_path" ] && [ "$changes_only" == false ]; then | ||
echo "Copying $relative_path to the repository" | ||
FILES_ADDED+=("${relative_path}") | ||
cp "$file" "$target_path" | ||
|
||
else | ||
# If the file exists, check if it's different | ||
if [ "$new_only" == false ]; then | ||
if ! diff -q "$file" "$target_path" > /dev/null 2>&1; then | ||
echo "Merging changes from $relative_path" | ||
FILES_WITH_CHANGES+=("${relative_path}") | ||
cp "$file" "$target_path" | ||
fi | ||
fi | ||
fi | ||
done < <(find . -type f -print0) | ||
|
||
echo "${#FILES_ADDED[@]}" files added, "${#FILES_WITH_CHANGES[@]}" files with changes detected. | ||
|
||
echo ------------------------------------------ | ||
|
||
if [ "$changes_only" == false ]; then | ||
echo ------------------------------------------ | ||
echo "New files added:" | ||
printf ' - %s\n' "${FILES_ADDED[@]}" | ||
fi | ||
|
||
|
||
if [ "$new_only" == false ]; then | ||
echo ------------------------------------------ | ||
echo "Changed files:" | ||
printf ' - %s\n' "${FILES_WITH_CHANGES[@]}" | ||
fi |