Skip to content

Commit

Permalink
Clarifications for DB2 connection for FHIR
Browse files Browse the repository at this point in the history
This is for additional information for making it more clear what to do to configure DB2 with IBM FHIR server.
Signed-off-by: Dag Roppe <[email protected]>
  • Loading branch information
d0roppe authored Dec 6, 2021
1 parent 988782a commit dbafd01
Showing 1 changed file with 14 additions and 13 deletions.
27 changes: 14 additions & 13 deletions docs/src/pages/guides/DB2OnCloudSetup.md
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ The IBM FHIR Server uses the access flow:

The steps to create the API key are:

1. On the IBM Cloud console, select `Manage` > `Access (IAM)`.
1. On the IBM Cloud console, upper right corner, select `Manage` > `Access (IAM)`.

1. Select the [Service IDs panel](https://cloud.ibm.com/iam/serviceids).

Expand Down Expand Up @@ -158,7 +158,7 @@ Before the API key can be used, you need to create a Db2 user and associate it w
1. Click Administration > User Management

- To confirm the IAM instance:
1. Click Run Sql
1. Click Run Sql (click create new if not brought into SQL edit session)
1. Enter the SQL
``` sql
SELECT CASE WHEN VALUE = 'IBMIAMauth' THEN 1 ELSE 0 END AS IAM_ENABLED FROM SYSIBMADM.DBMCFG WHERE NAME = 'srvcon_gssplugin_list'
Expand All @@ -173,7 +173,7 @@ Before the API key can be used, you need to create a Db2 user and associate it w

- IBMid: paste the service id (not service id name) from the Service Id created previously. To get that navigate to the service id you created earlier and click on `Details` link (top right side next to Actions Menu). A panel opens on the right-hand side which contains ID. This ID needs to be used as IBMid value.

- Note (1): The page forces the value to lower-case, so `ServiceId` becomes `serviceid`. Don't be alarmed, it still works.
- Note (1): The page forces the value to lower-case, so `ServiceId` becomes `serviceid`. Don't be alarmed, it still works. Same for the User ID.
- Note (2): Do NOT select Administrator. One should follow the least-privelege principal for the FHIRSERVER user.
Expand All @@ -195,22 +195,22 @@ You are now able to connect to the database as the FHIRSERVER user using only th
### **Testing the connection**
The [Db2 driver](https://repo1.maven.org/maven2/com/ibm/db2/jcc/11.5.0.0/jcc-11.5.0.0.jar) is able to execute a connectivity test to check the configuration of the combo of API-key/Service-Id/Db2-User-Id.
The [Db2 driver (click here to download)](https://repo1.maven.org/maven2/com/ibm/db2/jcc/11.5.6.0/jcc-11.5.6.0.jar) is able to execute a connectivity test to check the configuration of the combo of API-key/Service-Id/Db2-User-Id.
#### Test IAM Access
1. Copy the command to your code editor
``` bash
java -cp /path/to/db2jcc4.jar com.ibm.db2.jcc.DB2Jcc -url "jdbc:db2://<DB2-HOSTNAME>:50001/BLUDB:apiKey=<API-KEY>;securityMechanism=15;sslConnection=true;sslTrustStoreLocation=/path/to/truststore.jks;sslTrustStorePassword=<TRUSTSTORE-PASSWORD>;"
java -cp /path/to/db2jcc4.jar com.ibm.db2.jcc.DB2Jcc -url "jdbc:db2://<DB2-HOSTNAME>:<DB2-HOST-PORT>/BLUDB:apiKey=<API-KEY>;securityMechanism=15;sslConnection=true;"
```
- Note: Don't forget the trailing `;` in the URL. Some of the documented examples don't include it, but it is required in order for the connection to work, although this may be fixed in a future driver release. This only affects this test URL, not the actual FHIR server configuration.
1. Replace the following values with your service details:
- `/path/to/db2jcc4.jar` : replace with the path to your driver jar.
- `<DB-HOSTNAME>`: the hostname of your Db2 service from the Service Credentials page
- `<DB-HOST-PORT>`: the port of your Db2 service from the Service Credentials page
- `<API-KEY>`: the API key value created in the previous section
- `<TRUSTSTORE-PASSWORD>`: the password for your truststore
- Note: When using an API Key, no username needs to be provided. This is because the API Key maps to a ServiceId, and that ServiceId is mapped to the Db2 user.
Expand All @@ -224,17 +224,17 @@ The [Db2 driver](https://repo1.maven.org/maven2/com/ibm/db2/jcc/11.5.0.0/jcc-11.
1. Copy the command to your code editor
``` bash
java -cp /path/to/db2jcc4.jar com.ibm.db2.jcc.DB2Jcc -url "jdbc:db2://<DB2-HOSTNAME>:50001/bludb:user=<userid>;password=<your_password>;sslConnection=true;sslTrustStoreLocation=/path/to/truststore.jks;sslTrustStorePassword=<TRUSTSTORE-PASSWORD>;"
java -cp /path/to/db2jcc4.jar com.ibm.db2.jcc.DB2Jcc -url "jdbc:db2://<DB2-HOSTNAME>:<DB2-HOST-PORT>/bludb:user=<userid>;password=<your_password>;sslConnection=true;"
```
- Note: Don't forget the trailing `;` in the URL. Some of the documented examples don't include it, but it is required in order for the connection to work, although this may be fixed in a future driver release. This only affects this test URL, not the actual FHIR server configuration.
1. Replace the following values with your service details:
- `/path/to/db2jcc4.jar` : replace with the path to your driver jar.
- `<DB-HOSTNAME>`: the hostname of your Db2 service from the Service Credentials page
- `<DB-HOST-PORT>`: the port of your Db2 service from the Service Credentials page
- `<userid>`: The userid to acecss the db
- `<your_password>`: The password to access the db with
- `<TRUSTSTORE-PASSWORD>`: the password for your truststore
1. Run in your favorite terminal, and you should see no errors in the output. You should see output like:
Expand All @@ -251,11 +251,11 @@ Now that you've created the database and credentials, use the `fhir-persistence-
2. create a properties file named db2.properties with the Db2 Admin connection info from IBM Cloud; for example:

``` sh
db.host=1-2-3-4.databases.appdomain.cloud
db.port=50001
db.host=<DB-HOSTNAME>
db.port=<DB-HOST-PORT>
db.database=bludb
user=myuser
password=mypassword
user=<USERID>
password=<PASSWORD>
sslConnection=true
```

Expand Down Expand Up @@ -297,7 +297,7 @@ The IBM FHIR Server uses the native Open Liberty datasources. To configure a FHI

Since release 4.3.2 you can use the `search.reopt` query optimizer hint (shown above) to improve the performance of certain search queries involving multiple search parameters. This optimization is currently only available for Db2. Valid values are "ALWAYS" and "ONCE". See Db2 documentation for `REOPT` for more details.

To configure the datasource.xml for db2 create a datasource.xml for the configDropins folder.
To configure the datasource.xml for db2 create a datasource.xml for the configDropins folder. Note: CurrentSchema is case sensative to what you used in the fhir-persistance-schema tool used above.

#### For IAM User

Expand All @@ -321,6 +321,7 @@ Create a file as the following
securityMechanism="15"
sslConnection="true" />
</dataSource>
</server>
```

#### For Db2 Auth user
Expand Down

0 comments on commit dbafd01

Please sign in to comment.