diff options
Diffstat (limited to 'academic/pgrouting/create_template.sh')
-rw-r--r-- | academic/pgrouting/create_template.sh | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/academic/pgrouting/create_template.sh b/academic/pgrouting/create_template.sh new file mode 100644 index 0000000000000..777be827c108f --- /dev/null +++ b/academic/pgrouting/create_template.sh @@ -0,0 +1,52 @@ +# ------------------------------------------------------------------------------ +# Setup template containing PostGIS and/or pgRouting +# ------------------------------------------------------------------------------ +# +# To create a GIS database as non-superuser run: +# +# "createdb -h hostname -W -T template_postgis mydb +# +# Source: http://geospatial.nomad-labs.com/2006/12/24/postgis-template-database/ +# +# Note: requires "libpq-dev" package + +if [ -e `pg_config --sharedir` ] +then + echo "PostGIS installed in" `pg_config --sharedir` + POSTGIS_SQL_PATH=`pg_config --sharedir`/contrib +else + POSTGIS_SQL_PATH=/usr/share/postgresql/contrib +fi +echo "PostGIS path set as $POSTGIS_SQL_PATH" + +ROUTING_SQL_PATH=/usr/share/postlbs + +# Create "template_routing" +# ------------------------- +if sudo -u postgres psql --list | grep -q template_routing ; +then + echo "pgRouting template already exists!" +else + echo "Create pgRouting template ..." + sudo -u postgres createdb -E UTF8 template_routing + + sudo -u postgres psql --quiet -d template_routing -c "create extension postgis;" + sudo -u postgres psql --quiet -d template_routing -c "create extension postgis_topology;" + + sudo -u postgres psql --quiet -d template_routing -f $ROUTING_SQL_PATH/routing_core.sql + sudo -u postgres psql --quiet -d template_routing -f $ROUTING_SQL_PATH/routing_core_wrappers.sql + sudo -u postgres psql --quiet -d template_routing -f $ROUTING_SQL_PATH/routing_topology.sql + sudo -u postgres psql --quiet -d template_routing -f $ROUTING_SQL_PATH/matching.sql + + sudo -u postgres psql --quiet -d template_routing -c "GRANT ALL ON geometry_columns TO PUBLIC;" + sudo -u postgres psql --quiet -d template_routing -c "GRANT ALL ON geography_columns TO PUBLIC;" + sudo -u postgres psql --quiet -d template_routing -c "GRANT ALL ON raster_columns TO PUBLIC;" + sudo -u postgres psql --quiet -d template_routing -c "GRANT ALL ON spatial_ref_sys TO PUBLIC;" + + sudo -u postgres psql --quiet -d template_routing -c "VACUUM FULL;" + sudo -u postgres psql --quiet -d template_routing -c "VACUUM FREEZE;" + + sudo -u postgres psql --quiet -d postgres -c "UPDATE pg_database SET datistemplate='true' WHERE datname='template_routing';" + sudo -u postgres psql --quiet -d postgres -c "UPDATE pg_database SET datallowconn='false' WHERE datname='template_routing';" + echo "... template_routing created." +fi |