2024-10-16 22:55:47 -05:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Directories for schema and population scripts
|
|
|
|
CREATE_DIR="create"
|
|
|
|
POPULATE_DIR="populate"
|
|
|
|
|
|
|
|
# List of databases
|
|
|
|
DATABASES=("auth" "blueprints" "fights" "live")
|
|
|
|
|
|
|
|
# Function to create a database and apply the schema
|
|
|
|
create_db() {
|
|
|
|
for db in "${DATABASES[@]}"; do
|
|
|
|
db_file="${db}.db"
|
|
|
|
schema_file="${CREATE_DIR}/${db}.sql"
|
|
|
|
|
|
|
|
if [[ -f "$schema_file" ]]; then
|
|
|
|
echo "Creating $db_file and applying schema from $schema_file..."
|
|
|
|
sqlite3 "$db_file" < "$schema_file"
|
|
|
|
else
|
|
|
|
echo "Schema file for $db not found. Skipping."
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
# Function to populate the database with data
|
|
|
|
populate_db() {
|
|
|
|
for db in "${DATABASES[@]}"; do
|
|
|
|
db_file="${db}.db"
|
|
|
|
populate_file="${POPULATE_DIR}/${db}.sql"
|
|
|
|
|
|
|
|
if [[ -f "$populate_file" ]]; then
|
|
|
|
echo "Populating $db_file using data from $populate_file..."
|
|
|
|
sqlite3 "$db_file" < "$populate_file"
|
|
|
|
else
|
|
|
|
echo "Population file for $db not found. Skipping."
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
# Function to drop (delete) the databases
|
|
|
|
drop_db() {
|
|
|
|
for db in "${DATABASES[@]}"; do
|
|
|
|
db_file="${db}.db"
|
|
|
|
|
|
|
|
if [[ -f "$db_file" ]]; then
|
|
|
|
echo "Dropping $db_file..."
|
|
|
|
rm "$db_file"
|
|
|
|
else
|
|
|
|
echo "$db_file does not exist. Skipping."
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
# Function for a full reset (create and populate)
|
|
|
|
full_reset() {
|
|
|
|
create_db
|
|
|
|
populate_db
|
|
|
|
}
|
|
|
|
|
|
|
|
# Main script
|
|
|
|
case $1 in
|
|
|
|
create)
|
|
|
|
create_db
|
|
|
|
;;
|
|
|
|
populate)
|
|
|
|
populate_db
|
|
|
|
;;
|
|
|
|
reset)
|
|
|
|
full_reset
|
|
|
|
;;
|
|
|
|
drop)
|
|
|
|
drop_db
|
|
|
|
;;
|
|
|
|
*)
|
2024-12-03 21:00:07 -06:00
|
|
|
echo "Usage: $0 {create|populate|reset|drop}"
|
2024-10-16 22:55:47 -05:00
|
|
|
;;
|
|
|
|
esac
|