Add make-council-pages.sh script

This commit is contained in:
2024-07-28 19:05:20 +10:00
parent f149107943
commit 3018c1e30a
2 changed files with 47 additions and 0 deletions

43
make-council-pages.sh Normal file
View File

@@ -0,0 +1,43 @@
#!/bin/bash
# This script uses the wp and jq commands, make sure they are installed before running this script.
# The council_names.json file must contain a list of objects (one for each council).
# Each object must have a "shortName" field and a "wardNames" field.
# The "shortName" field must be a string.
# The "wardNames" field must be a list of strings.
JSON_FILE="council_names.json"
# Controls the flags that are passed to every usage of the wp command.
WP_FLAGS="--allow-root --path=/var/www/html"
function create_or_update_page() {
local council_block="$1"
local page_id="$2"
short_name=$(echo "$council_block" | jq -r '.shortName')
# TODO: Generate better content! This just outputs the name of each ward.
content=$(echo "$council_block" | jq -r '.wardNames | .[]')
if [[ -n "$page_id" ]]; then
echo "Update page $short_name (post $page_id)"
wp post update "$page_id" --post_content="$content" $WP_FLAGS
else
echo "Create page $short_name"
wp post create --post_type=page --post_title="$short_name" --post_status=publish --post_content="$content" $WP_FLAGS
fi
}
# Read JSON data
data=$(cat "$JSON_FILE")
# Get all page IDs in one go because the wp command is pretty slow
wp_posts=$(wp post list --post_type=page --format=json $WP_FLAGS)
# Iterate over JSON objects
jq -c '.[] | .' <<< "$data" | while IFS=' ' read -r council_block; do
short_name=$(echo "$council_block" | jq -r '.shortName')
page_id=$(echo $wp_posts | jq '.[] | select(.post_title == "'"$short_name"'") | .ID' | head -n 1)
create_or_update_page "$council_block" "$page_id"
done