CRM-19346 Patch API also to ensure that same value cannot be used as well
[civicrm-core.git] / bin / regen.sh
... / ...
CommitLineData
1#!/usr/bin/env /bin/bash
2set -e
3set -x
4
5source `dirname $0`/setup.conf
6source `dirname $0`/setup.lib.sh
7
8# someone might want to use empty password for development,
9# let's make it possible - we asked before.
10if [ -z $DBPASS ]; then # password still empty
11 PASSWDSECTION=""
12else
13 PASSWDSECTION="-p$DBPASS"
14fi
15
16pushd .
17cd $CIVISOURCEDIR
18# svn up .
19cd $CIVISOURCEDIR/bin
20./setup.sh
21cd $CIVISOURCEDIR/sql
22
23echo; echo "Dropping civicrm_* tables from database $DBNAME"
24# mysqladmin -f -u $DBUSER $PASSWDSECTION $DBARGS drop $DBNAME
25MYSQLCMD=$(mysql_cmd)
26MYSQLADMCMD=$(mysqladmin_cmd)
27MYSQLDUMP=$(mysqldump_cmd)
28echo "SELECT table_name FROM information_schema.TABLES WHERE TABLE_SCHEMA='${DBNAME}' AND TABLE_TYPE = 'VIEW'" \
29 | $MYSQLCMD \
30 | grep '^\(civicrm_\|log_civicrm_\)' \
31 | awk -v NOFOREIGNCHECK='SET FOREIGN_KEY_CHECKS=0;' 'BEGIN {print NOFOREIGNCHECK}{print "drop view " $1 ";"}' \
32 | $MYSQLCMD
33echo "SELECT table_name FROM information_schema.TABLES WHERE TABLE_SCHEMA='${DBNAME}' AND TABLE_TYPE = 'BASE TABLE'" \
34 | $MYSQLCMD \
35 | grep '^\(civicrm_\|log_civicrm_\)' \
36 | awk -v NOFOREIGNCHECK='SET FOREIGN_KEY_CHECKS=0;' 'BEGIN {print NOFOREIGNCHECK}{print "drop table " $1 ";"}' \
37 | $MYSQLCMD
38
39$MYSQLCMD < civicrm.mysql
40$MYSQLCMD < civicrm_data.mysql
41$MYSQLCMD < civicrm_sample.mysql
42echo "DROP TABLE IF EXISTS zipcodes" | $MYSQLCMD
43$MYSQLCMD < zipcodes.mysql
44
45## For first boot on fresh DB, boot CMS before CRM.
46cms_eval 'civicrm_initialize();'
47
48php GenerateData.php
49
50## Prune local data
51$MYSQLCMD -e "DROP TABLE zipcodes; DROP TABLE IF EXISTS civicrm_install_canary; UPDATE civicrm_domain SET config_backend = NULL; DELETE FROM civicrm_extension; DELETE FROM civicrm_cache; DELETE FROM civicrm_setting;"
52TABLENAMES=$( echo "show tables like 'civicrm_%'" | $MYSQLCMD | grep ^civicrm_ | xargs )
53
54cd $CIVISOURCEDIR/sql
55
56$MYSQLDUMP -cent --skip-triggers $DBNAME $TABLENAMES > civicrm_generated.mysql
57#cat civicrm_sample_report.mysql >> civicrm_generated.mysql
58cat civicrm_sample_custom_data.mysql >> civicrm_generated.mysql
59#cat civicrm_devel_config.mysql >> civicrm_generated.mysql
60cat civicrm_dummy_processor.mysql >> civicrm_generated.mysql
61$MYSQLADMCMD -f drop $DBNAME
62$MYSQLADMCMD create $DBNAME
63$MYSQLCMD < civicrm.mysql
64$MYSQLCMD < civicrm_generated.mysql
65popd