-
Notifications
You must be signed in to change notification settings - Fork 168
PostgreSQL Installation Guide
You can install the PostgreSQL core distribution from the following URL: http://www.postgresql.org/download/.
Follow your platform specific installation to install the binary and start the service. Remember the PostgreSQL user and password that is set during the installation process since this will be needed later to administer the server (creating new databases and adding new schemas).
For the database administration, we will be using the pgAdmin3 tool available from the PostgreSQL downloads URL above. After launching, the main window will look similar to this:
If your environment already has application level administration and non-administrative access groups created, you can skip this section on creating the roles.
Before creating a database, roles and users should be created for administering the OHDSI WebAPI database and for non-administrative access (ie: application access) to the database. The 2 groups created in this guide are ohdsi_admin
and ohdsi_app
. The ohdsi_admin
group will have ownership of the OHDSI database and have rights to create/alter/drop database objects, and the ohdsi_app
group will have only the rights to access the database objects needed for the WebAPI service calls.
In pgAdmin, click on the server icon to expand the menu of options. Right click Group Roles
and select New Group Role
. This presents the following dialog:
Each tab will have values entered to configure the group. Two groups are created: the admin group (to create the database and administer tables) and the app group to grant limited rights to the applications for accessing the database.
- Role Name: ohdsi_admin
- Comment: Administration group for OHDSI applications
(Leave all values blank since we will not let this group log into the database)
Check: Inherits rights from parent roles, can create databases, can initiate streaming replication and backups
The ohdsi_admin role is not a member of any other parent group, so leave member empty. After these values are set, the generated SQL to create this role is produced:
CREATE ROLE ohdsi_admin
CREATEDB REPLICATION
VALID UNTIL 'infinity';
COMMENT ON ROLE ohdsi_admin
IS 'Administration group for OHDSI applications';
Role Name: ohdsi_app Comment: Application group for OHDSI applications
(Leave all values blank since we will not let this group log into the database)
Check: Inherits rights from parent roles
The ohdsi_app role is not a member of any other parent group, so leave member empty. After these values are set, the generated SQL to create this role is produced:
CREATE ROLE ohdsi_app
VALID UNTIL 'infinity';
COMMENT ON ROLE ohdsi_app
IS 'Application group for OHDSI applications';
In pgAdmin, right-click Login Roles and select ‘New Login Role’. This will present the dialog:
This dialog is similar to the group dialog, but in this case we will be setting the password for these logins and placing them into their corresponding roles (either _admin or _app). This allows us to define permissions to the database at the group level, and not the individual user level.
Role Name: ohdsi_admin_user
Comment: Admin user account for OHDSI applications
Password: admin1 {note: do not use this for your production environment!}
Check: Inherits rights from parent roles, Can Login
Add the ohdsi_admin
group to the "Member of" list for this login. After these values are set, the generated SQL to create this role is produced:
CREATE ROLE ohdsi_admin_user LOGIN ENCRYPTED PASSWORD 'md58d34c863380040dd6e1795bd088ff4a9'
VALID UNTIL 'infinity';
GRANT ohdsi_admin TO ohdsi_admin_user;
COMMENT ON ROLE ohdsi_admin_user
IS 'Admin user account for OHDSI applications';
Note the password is hashed using md5 with format {password}{user}
i.e. for the above example md5("admin1ohdsi_admin_user") == "8d34c863380040dd6e1795bd088ff4a9".
Role Name: ohdsi_app_user
Comment: Application user account for OHDSI applications
Password: app1 {note: do not use this for your production environment!}
Check: Inherits rights from parent roles, Can Login
Add ohdsi_app group to the "Member of" list for this login. After these values are set, the generated SQL to create this role is produced:
CREATE ROLE ohdsi_app_user LOGIN ENCRYPTED PASSWORD 'md55cc9d81d14edce93a4630b7c885c6410'
VALID UNTIL 'infinity';
GRANT ohdsi_app TO ohdsi_app_user;
COMMENT ON ROLE ohdsi_app_user
IS 'Application user account for OHDSI applications';
Note: if you have an existing database you can skip this step and proceed to the schema preparation section below. In pgAdmin, right click Databases and select ‘New Database’. The following dialog is displayed:
Then follow these steps for each tabbed option:
- Name: OHDSI
- Owner: ohdsi_admin
- Comment: OHDSI WebAPI database
Leave all attributes the default
Nothing to enter here
- Add role
ohdsi_admin
withALL
privileges - Add role ohdsi_app with
Temp
andConnect
.
The following SQL is generated:
CREATE DATABASE "OHDSI"
WITH ENCODING='UTF8'
OWNER=ohdsi_admin
CONNECTION LIMIT=-1;
COMMENT ON DATABASE "OHDSI"
IS 'OHDSI database';
GRANT ALL ON DATABASE "OHDSI" TO GROUP ohdsi_admin;
GRANT CONNECT, TEMPORARY ON DATABASE "OHDSI" TO GROUP ohdsi_app;
🙌 Note: this step is extremely important. 🙌
If you do not assign default permissions when connected as the ohdsi_admin_user
, the ohdsi_app_user
account will not be granted the correct access privileges when the WebAPI creates the tables in the database!_
In pgAdmin, create a new connection to the PostgreSQL server, using the ohdsi_admin_user account created above. This account will be used to create the database to host the WebAPI schema and tables. The new connection should be configured as follows:
Note: username and password was the admin user and password that was created above. Once connected, the pgAdmin3 as ohdsi_admin_user
, object browser should look as follows:
Expand the server icon, under Databases, open the ohdsi
database, and right click on Schemas
to create a new schema:
- Name: webapi
- Owner: ohdsi_admin
- Comment: Schema containing tables to support WebAPI functionality
- Add
PUBLIC
asUSAGE
- Add
ohdsi_admin
asALL
- Add
ohdsi_app
asUSAGE
.
The following SQL is generated:
CREATE SCHEMA webapi
AUTHORIZATION ohdsi_admin;
COMMENT ON SCHEMA webapi
IS 'Schema containing tables to support WebAPI functionality';
GRANT USAGE ON SCHEMA webapi TO PUBLIC;
GRANT ALL ON SCHEMA webapi TO GROUP ohdsi_admin;
GRANT USAGE ON SCHEMA webapi TO GROUP ohdsi_app;
Once the schema is created, right click on the new schema webapi
and select Properties
- Add group
ohdsi_app
withINSERT, SELECT, UPDATE, DELETE, REFERENCES and TRIGGER
.
- Add group
ohdsi_app
withSELECT and USAGE
- Add group
ohdsi_app
withEXECUTE
- Add group
ohdsi_app
withUSAGE
The following SQL is generated:
ALTER DEFAULT PRIVILEGES IN SCHEMA webapi
GRANT INSERT, SELECT, UPDATE, DELETE, REFERENCES, TRIGGER ON TABLES
TO ohdsi_app;
ALTER DEFAULT PRIVILEGES IN SCHEMA webapi
GRANT SELECT, USAGE ON SEQUENCES
TO ohdsi_app;
ALTER DEFAULT PRIVILEGES IN SCHEMA webapi
GRANT EXECUTE ON FUNCTIONS
TO ohdsi_app;
ALTER DEFAULT PRIVILEGES IN SCHEMA webapi
GRANT USAGE ON TYPES
TO ohdsi_app;
👉 Note: If you do not assign default privileges when connected as the ohdsi_admin_user
, the ohdsi_app_user
account will not be granted the correct access privileges when the WebAPI creates the tables in the database!
After creating the schemas and assigning the default privileges, the object browser should look as follows:
Keep handy the passwords for the accounts you set up in this process (ohdsi_admin_user
and ohdsi_app_user
) as they will be used in the configuration and setup of WebAPI.