-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy path.module_migration.sh
executable file
·85 lines (69 loc) · 2.54 KB
/
.module_migration.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/bin/bash
# This script assumes it will be invoked by 'yarn' through a 'package.json' command, making the CWD
# the same as the directory housing the 'package.json' file. It is not guaranteed to work in any
# other CWD.
# Give the module being worked on a special name for clearer referencing
MODULE=$1
set -vex
# Make sure there's no cruft left over, we need a blank postgres
docker container prune -f
docker volume prune -f
docker image prune -f
# Start a postgres container
docker container run -p 5432:5432 -e POSTGRES_PASSWORD=test --name migrate-postgres -d postgres:14.7
sleep 5 # Just in case
psql postgresql://postgres:test@localhost:5432/postgres -c "CREATE DATABASE __example__"
# Now, we need to move out of the root directory to pull our trickery below
cd src
# Get the list of modules this module depends upon and include itself for use in the temporary
# TypeORM configuration
MODULES=`ts-node scripts/list-deps ${MODULE}`
MODARR=($(echo ${MODULES} | sed 's/:/\n/g'))
#readarray -d ":" -t MODARR <<< "${MODULES}"
# Convert the array of modules into configuration paths for TypeORM
ENTITIES=""
MIGRATIONS=""
NL=$'\n'
for (( n=0; n < ${#MODARR[*]}; n++))
do
MOD=`echo ${MODARR[n]} | xargs`
ENTITIES="${ENTITIES}\"modules/${MOD}/entity/*.ts\",${NL}"
MIGRATIONS="${MIGRATIONS}\"modules/${MOD}/migration/*.ts\",${NL}"
done
# Generate a DataSource file
cat <<EOF > datasource.ts
import { SnakeNamingStrategy } from 'typeorm-naming-strategies';
import { DataSource } from "typeorm";
export const dataSource = new DataSource({
"type": "postgres",
"host": "localhost",
"port": 5432,
"username": "postgres",
"password": "test",
"database": "__example__",
"synchronize": true,
"logging": false,
"entities": [
${ENTITIES}
],
"migrationsTableName": "__migrations__",
"migrations": [
${MIGRATIONS}
],
namingStrategy: new SnakeNamingStrategy(),
});
EOF
# First, run all migrations that already exist (required because we blew it all away before, but
# also keeps things clean because we don't accidentally break the migration generation with bad
# cruft in the database)
ts-node scripts/migrate-dep-order ${MODULE}
# Blow away the existing migration for the specified module, if one exists
rm -rf modules/${MODULE}/migration
mkdir modules/${MODULE}/migration
# Now run the migration generation for the module
ts-node ../node_modules/.bin/typeorm migration:generate -d datasource.ts modules/${MODULE}/migration/${MODULE}
# Clean up the temporary files and docker containers
rm datasource.ts
docker container stop migrate-postgres
# And we're done!
echo Done!