|
| 1 | +#!/bin/bash |
| 2 | +# This Source Code Form is subject to the terms of the Mozilla Public |
| 3 | +# License, v. 2.0. If a copy of the MPL was not distributed with this |
| 4 | +# file, You can obtain one at https://mozilla.org/MPL/2.0/. |
| 5 | +# |
| 6 | +# OpenCRVS is also distributed under the terms of the Civil Registration |
| 7 | +# & Healthcare Disclaimer located at http://opencrvs.org/license. |
| 8 | +# |
| 9 | +# Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS. |
| 10 | + |
| 11 | +set -e |
| 12 | + |
| 13 | +echo "🧹 Clearing all development data..." |
| 14 | + |
| 15 | +# Default PostgreSQL connection parameters for development |
| 16 | +POSTGRES_HOST=${POSTGRES_HOST:-localhost} |
| 17 | +POSTGRES_PORT=${POSTGRES_PORT:-5432} |
| 18 | +POSTGRES_USER=${POSTGRES_USER:-postgres} |
| 19 | +POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-postgres} |
| 20 | +ANALYTICS_POSTGRES_USER=${ANALYTICS_POSTGRES_USER:-events_analytics} |
| 21 | + |
| 22 | +print_usage_and_exit() { |
| 23 | + echo 'Usage: ./clear-all-data-dev.sh' |
| 24 | + echo "" |
| 25 | + echo "Environment variables (with defaults for development):" |
| 26 | + echo "POSTGRES_HOST=${POSTGRES_HOST}" |
| 27 | + echo "POSTGRES_PORT=${POSTGRES_PORT}" |
| 28 | + echo "POSTGRES_USER=${POSTGRES_USER}" |
| 29 | + echo "POSTGRES_PASSWORD=${POSTGRES_PASSWORD}" |
| 30 | + echo "ANALYTICS_POSTGRES_USER=${ANALYTICS_POSTGRES_USER}" |
| 31 | + echo "" |
| 32 | + echo "This script clears all development databases including:" |
| 33 | + echo "- PostgreSQL analytics schema and data" |
| 34 | + echo "- Metabase configuration database (H2)" |
| 35 | + echo "- Any additional custom databases (can be extended by country configurations)" |
| 36 | + exit 1 |
| 37 | +} |
| 38 | + |
| 39 | +# Check if PostgreSQL is accessible |
| 40 | +if ! PGPASSWORD="$POSTGRES_PASSWORD" psql -h "$POSTGRES_HOST" -p "$POSTGRES_PORT" -U "$POSTGRES_USER" -d postgres -c '\q' 2>/dev/null; then |
| 41 | + echo "❌ Cannot connect to PostgreSQL at ${POSTGRES_HOST}:${POSTGRES_PORT}" |
| 42 | + echo " Make sure PostgreSQL is running and credentials are correct." |
| 43 | + print_usage_and_exit |
| 44 | +fi |
| 45 | + |
| 46 | +# Clear PostgreSQL analytics schema |
| 47 | +echo "🗑️ Clearing PostgreSQL analytics schema..." |
| 48 | +PGPASSWORD="$POSTGRES_PASSWORD" psql -h "$POSTGRES_HOST" -p "$POSTGRES_PORT" -U "$POSTGRES_USER" -d events -v ON_ERROR_STOP=1 <<EOSQL || echo "⚠️ Analytics schema may not exist yet" |
| 49 | +-- Drop analytics schema and recreate it |
| 50 | +DROP SCHEMA IF EXISTS analytics CASCADE; |
| 51 | +CREATE SCHEMA analytics; |
| 52 | +
|
| 53 | +-- Drop and recreate analytics user |
| 54 | +DROP ROLE IF EXISTS "$ANALYTICS_POSTGRES_USER"; |
| 55 | +EOSQL |
| 56 | + |
| 57 | +echo "✅ PostgreSQL analytics data cleared" |
| 58 | + |
| 59 | +echo "" |
| 60 | +echo "🎉 All development data cleared successfully!" |
| 61 | +echo "" |
0 commit comments