The "georchestra" database hosts several schemas, which are specific to the deployed modules:
CREATE USER georchestra WITH NOCREATEDB NOCREATEROLE PASSWORD 'georchestra';
CREATE DATABASE georchestra WITH OWNER georchestra TEMPLATE template0 ENCODING UTF8;
Note 1: It is of course possible to store webapp-specific schemas in separate databases, taking advantage of geOrchestra's extreme configurability.
Note 2: PostGIS extensions are not required in the georchestra database, unless GeoFence is deployed (see below).
If mapfishapp is deployed:
psql -d georchestra -f postgresql/020-mapfishapp.sql
If the console webapp is deployed:
psql -d georchestra -f postgresql/040-console.sql
If geofence is deployed:
psql -d georchestra -f postgresql/010-create-extension.sql
psql -d georchestra -f postgresql/080-geofence.sql
If the security proxy is deployed and its log4j uses the org.georchestra.ogcservstatistics.log4j.OGCServicesAppender
as configured in the datadir:
psql -d georchestra -f postgresql/050-ogc-server-statistics.sql
If the extractor app is deployed:
psql -d georchestra -f postgresql/010-create-extension.sql
psql -d georchestra -f postgresql/090-extractorapp.sql
If the Atlas is deployed:
psql -d georchestra -f postgresql/060-atlas.sql
Ensure geOrchestra database user is owner of database. If your database is dedicated to geOrchestra (no other
apps are running in same database), you can use following procedure to reset ownership of all objects to selected user, for
example georchestra
:
wget https://raw.githubusercontent.com/georchestra/georchestra/master/postgresql/fix-owner.sql -O /tmp/fix-owner.sql
psql -d georchestra -f /tmp/fix-owner.sql
psql -d georchestra -c "SELECT change_owner('mapfishapp', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('console', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('ogcstatistics', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('extractorapp', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('geofence', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('atlas', 'georchestra');";
psql -d georchestra -c "SELECT change_owner('public', 'georchestra');";
If geonetwork is to be deployed, you need to create a dedicated user and schema:
createuser -SDRI geonetwork
psql -d georchestra -c "ALTER USER geonetwork WITH PASSWORD 'georchestra';"
psql -d georchestra -c "CREATE SCHEMA AUTHORIZATION geonetwork;"
psql -d georchestra -c "SELECT change_owner('geonetwork', 'geonetwork');"
psql -d georchestra -c "GRANT geonetwork TO georchestra;"
Finally, you can drop maintenance function :
psql -d georchestra -c "DROP FUNCTION change_owner(text, text);";