Skip to content

Commit

Permalink
Merge pull request #44 from NHSDigital/aiva2/CCM-6405_TemplateRepoSync
Browse files Browse the repository at this point in the history
CCM-6405 Adding github workflow to sync template repo
  • Loading branch information
aidenvaines-bjss authored Sep 20, 2024
2 parents a256ef4 + 6b79f76 commit dd543a7
Show file tree
Hide file tree
Showing 2 changed files with 128 additions and 0 deletions.
18 changes: 18 additions & 0 deletions scripts/config/.repository-template-sync-ignore
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/
110 changes: 110 additions & 0 deletions scripts/githooks/sync-template-repo.sh
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

0 comments on commit dd543a7

Please sign in to comment.