⚠️ BEFORE YOU START! The demo dump is created from a cleaned/stripped version of the production database. Only reports under the PORI project are kept. If any changes have been made to these reports since the last dump then they must be manually reviewed by the developer creating the dump beforehand to double check nothing has been uploaded, edited or added that should not be included in public data (ex. identifiable or proprietary information).
FIRST: create a dump of the production database (see migrationTools create).
pg_dump -Fc -U <USER> -h <HOSTNAME> -d <DATABASE_NAME> > new_demo.dump
THE MIDDLE STEP: restore the dump as a new database and run the node script to clean any non-public data from the dump. There are two ways to do this. One way requires superuser and one way doesn't. If you are running a local postgres server for which you have root access, you have superuser, and the easiest way to do this is using the restore script. Instructions for both ways to do this are below.
FINALLY: create a dump of the newly cleaned database. This should be MUCH smaller than the original and is the one that will be included in the git repository.
pg_dump -Fc -U $USER -h localhost -d ipr_demo > demo/ipr_demodb.postgres.dump
Whichever way you decide to do this, note that if the database was dumped from an older version, you may need to migrate the schema to ensure it is up to date first.
npx sequelize-cli db:migrate --url postgres://${USER}@localhost:5432/ipr_demo
THE MIDDLE STEP:
IF YOU HAVE SUPERUSER:
- run the restore script,
- alter the tables to disable triggers,
- run the clean script,
- re-enable the triggers.
If you don't have superuser you won't be able to disable and re-enable the triggers.
You can ignore the password parameters for now since they will not be kept anyway.
POSTGRES_USER=$USER DB_DUMP_LOCATION=new_demo.dump SERVICE_PASSWORD=root READONLY_PASSWORD=root bash demo/restore_iprdb_dump.sh
ALTER TABLE reports DISABLE TRIGGER ALL;
ALTER TABLE reports_genes DISABLE TRIGGER ALL;
ALTER TABLE germline_small_mutations DISABLE TRIGGER ALL;
node demo/clean_db_for_demo.js --database.name ipr_demo --database.hostname localhost --database.password '' --graphkb.password ''
ALTER TABLE reports ENABLE TRIGGER ALL;
ALTER TABLE reports_genes ENABLE TRIGGER ALL;
ALTER TABLE germline_small_mutations ENABLE TRIGGER ALL;
IF YOU DON'T HAVE SUPERUSER:
export values for:
POSTGRES_USER POSTGRES_PASSWORD SERVICE_PASSWORD IPR_GRAPHKB_PASSWORD DATABASE_HOSTNAME=eg iprdevdb.bcgsc.ca DB_DUMP_LOCATION=the filesystem location of the pg_dump output file DATABASE_NAME=the name you want to use for the demo db
- run the restore script with the option to avoid loading triggers
- ssh to the db's host, or set it in the command. Then run the clean script command
- run the restore script again with the option to load triggers.
DB_DUMP_LOCATION=$DB_DUMP_LOCATION READONLY_PASSWORD=root TRIGGERS_OPTION="no_triggers" bash demo/restore_iprdb_dump.sh
node demo/clean_db_for_demo.js --database.name $DATABASE_NAME --database.hostname $DATABASE_HOSTNAME
DB_DUMP_LOCATION=$DB_DUMP_LOCATION READONLY_PASSWORD=root TRIGGERS_OPTION="only_triggers" bash demo/restore_iprdb_dump.sh
Expect error messages as the script tries to create a user that already exists. This should not affect the restore/clean of the db.