ExternalDb
The ExternalDb Moobot module allows Moogsoft Onprem to access the following external relational databases, as well as any relational database that supports JDBC:
MySQL
Microsoft SQL Server
IBM DB2
Oracle
PostgreSQL
Using ExternalDb, Moogsoft Onprem can retrieve information from external databases for use in alerts and Situations. The ExternalDb method can also update external databases with information from Moogsoft Onprem.
Load the module
The ExternalDb Moobot module is available to load into any standard Moobot. To load it, define a new global variable at the top of the Moobot Javascript file. For example:
var externalDb = MooBot.loadModule('ExternalDb');
Method reference
The ExternalDb module uses the following methods.
connect
Establishes a connection to an external database with defined connection properties.
Request arguments
The method takes the following arguments.
Name | Type | Required | Description |
---|---|---|---|
| Object | Yes | A Javascript object containing connection properties. See Database connection properties below. |
Database connection properties
The properties object is a Javascript object that can contain the following keys. You can also define connection properties in the file moog_external_db_details.conf
.
Key | Description |
---|---|
| Database type. If you omit type you must specify the URL, jar files and JDBC class name. To use an external database other than those in the supported list, omit the |
| Database host name or IP address. Default is localhost. |
| Database name. |
| Port number. Default values: MySQL: 3306 SQL Server: 1433 DB2: 50000 Oracle: 1521 PostgreSQL: 5432 |
| Username to connect to the database. If omitted you can specify it in the URL (for some databases) or the properties. |
| Password to connect to the database. If omitted you can specify it in the URL (for some databases) or the properties. |
| Encrypted version of the password. |
| A map of key-value pairs of properties to specify the connection properties. For example, |
| The JDBC driver jar file locations. Default values: SQL Server: sqljdbc4.jar DB2: db2jcc4.jar Oracle: ojdbc6.jar PostgreSql: postgresql-9.3-1102.jdbc41.jar The assumed location is |
| The name of the JDBC class. Default values: SQL Server: com.microsoft.sqlserver.jdbc.SQLServerDriver MySQL: com.mysql.jdbc.Driver DB2: com.ibm.db2.jcc.DB2Driver Oracle: oracle.jdbc.OracleDriver PostgreSql: org.postgresql.Driver |
| JDBC-specific URL. If specified, it can override other properties. |
| A map of key-value pairs of properties of the connection pool that will be created. You can define the number of connections made available to the external database by including the
|
Response
The method returns the following parameter.
Type | Description |
---|---|
| A Java object containing the connection details. Returns |
Examples
The method can accept a single parameter with connection properties, or two parameters: one with the generic connection properties and one specific to this connection.
The following command establishes a connection using the details in the customers
object:
var customersConnection = externalDb.connect(dbTypes.customers);
The following command establishes a connection using the same details, but the username
and password
in the object are overridden by the ones provided in the command:
var customersConnection = externalDb.connect(dbTypes.customers, {user: 'myuser', password: 'mypassword'});
execute
Performs an SQL update on the external database.
Request arguments
The method takes the following arguments.
Name | Type | Required | Description |
---|---|---|---|
| String | Yes | SQL string argument containing the update. |
Response
The method returns the following parameter.
Type | Description |
---|---|
| Indicates if the operation was successful: |
Examples
The following example uses the execute
method to update the species column in a pets database.
employeesConnection.execute('update pets set species="dog" where species null');
query
Performs an SQL query on the external database.
Request arguments
The method takes the following arguments.
Name | Type | Required | Description |
---|---|---|---|
| String | Yes | SQL string argument containing the query. |
Response
The method returns the following parameter.
Type | Description |
---|---|
| A Java object containing the query results. Returns |
Response methods
The response can contain the following methods.
Name | Description |
---|---|
| Returns the number of rows. |
| Returns the next row. |
| Goes back to the first row. |
| Indicates whether the current row is the last one. |
| Returns row |
| Returns the first row. |
| Returns the type of column called |
| Returns the name of column |
| Returns |
| Returns |
Row methods
You can use the following row methods in the query.
Name | Description |
---|---|
| Returns the value for column named name as a string. |
| Returns the number of columns. |
| Goes back to the first column. |
| Indicates whether the current column is the last one. |
| Returns the value in the next column as a string. |
| Returns the value in column |
| Returns the value in the first column as a string. |
| Returns the value in the last column as a string. |
Example
The following example uses the query
method to query the customers database.
var customers = customersConnection.query('Select * from customers'); while(customers.hasNext()==true) { var customer = customers.next(); var firstName = customer.value("first_name"); var lastName = customer.value("last_name"); logger.info(firstName + " " + lastName +" is a customer"); }
prepare
Performs SQL queries and updates on the external database. You can use the prepare method for complicated operations. For example, you can reuse the same SQL statement with different arguments, and you can use external data within a statement.
Request arguments
The method takes the following arguments.
Name | Type | Required | Description |
---|---|---|---|
| String | Yes | SQL string argument containing the query or update. |
Response
The method returns the following parameter.
Type | Description |
---|---|
| A Java object containing the query results. Returns |
Response methods
The response object can contain the following methods.
Name | Description |
---|---|
| Sets parameter |
| Sets parameter 1 to value 1, parameter 2 to value 2 and so on. Returns |
| Returns the number of parameters needed to bind. Some vendors do not support this method in all cases, if not supported |
| Sets parameter 1 to value 1, parameter 2 to value 2 and so on, and then executes the prepared statement. Returns false in case of a failure in one of the stages. If values are omitted, uses the previously |
| Sets parameter 1 to value 1, parameter 2 to value 2 and so on, and then performs the query. Returns |
| Closes the prepared statement. Note: It is important to close the statement with this method when no longer needed. |
Example
The following example uses the prepare
method to set all pet species to "dog" if the breed is one of those specified:
var petsChange = employeesConnection.prepare('Update pets set species=? where breed = ?'); petsChange.set(1, 'dog'); for (var breed in ['Labrador', 'Terrier', 'Beagle', 'Boxer', 'Poodle']) { petsChange.set(2, breed); petsChange.execute(); } petsChange.close();
Database drivers and declarations
When downloading JDBC drivers:
Be sure to download the correct version of the driver for your database.
Copy or move the downloaded drivers to
$MOOGSOFT_HOME/lib/cots/
.
Microsoft SQL Server
JDBC driver: http://www.microsoft.com/en-us/download/details.aspx?displaylang=en&id=11774
Connection properties: http://technet.microsoft.com/en-us/library/ms378672(v=sql.110).aspx
Example declarations:
testdb: { type: 'sqlServer', host: '172.16.87.248', port: '1433', database: 'my_db', user: 'myuser', password: 'mypassword' } testdb: { jar_files: ["/usr/share/moogsoft/lib/cots/sqljdbc4.jar"], class_name: "com.microsoft.sqlserver.jdbc.SQLServerDriver", url: "jdbc:sqlserver://172.16.87.248:1433;databaseName=my_db", properties: { user: "myuser", password: "mypassword" } }
MySQL
JDBC driver: Already included in Moogsoft Onprem - no need to download.
Connection properties: http://dev.mysql.com/doc/connector-j/en/connector-j-reference-configuration-properties.html
Example declarations:
testdb: { type: 'mySql', host: '172.16.87.247', port: '3306', database: 'my_db', user: 'myuser', password: 'mypassword' } testdb: { jar_files: ["/usr/share/moogsoft/lib/cots/mysql-connector-java-5.1.37-bin.jar"], class_name: "com.mysql.jdbc.Driver", url: "jdbc:mysql://172.16.87.247:3306/my_db", properties: { user: "myuser", password: "mypassword" } }
IBM DB2
JDBC driver: http://www-01.ibm.com/support/docview.wss?uid=swg21363866
Connection properties: http://www-01.ibm.com/support/knowledgecenter/SSEPGG_9.1.0/com.ibm.db2.udb.apdv.java.doc/doc/tjvjcccn.htm?cp=SSEPGG_9.1.0%2F8-1-4-2-1-0
Example declarations:
testdb: { type: 'db2', host: '172.16.87.248', port: '50000', database: 'my_db', user: 'myuser', password: 'mypassword' } testdb: { jar_files: ["/usr/share/moogsoft/lib/cots/db2jcc4.jar"], class_name: "com.ibm.db2.jcc.DB2Driver", url: "jdbc:db2://172.16.87.248:50000/my_db", properties: { user: "myuser", password: "mypassword" } }
Oracle
JDBC driver: http://www.oracle.com/technetwork/database/features/jdbc/index-091264.html
Connection properties: http://docs.oracle.com/cd/B28359_01/java.111/b31224/urls.htm
Example declarations:
testdb: { type: 'oracle', host: '172.16.87.248', port: '1521', database: 'my_db', user: 'myuser', password: 'mypassword' } testdb: { jar_files: ["/usr/share/moogsoft/lib/cots/ojdbc6.jar"], class_name: "oracle.jdbc.OracleDriver", url: "jdbc:oracle:thin:System/myuser@172.16.87.248:1521:my_db" }
PostgreSql
JDBC driver: https://jdbc.postgresql.org/download.html
Connection properties: http://jdbc.postgresql.org/documentation/head/connect.html
Example declarations:
testdb: { type: 'postgresql', host: '172.16.87.248', port: '5432', database: 'my_db', user: 'myuser', password: 'mypassword' } testdb: { jar_files: ["/usr/share/moogsoft/lib/cots/postgresql-9.3-1102.jdbc41.jar"], class_name: "org.postgresql.Driver", url: "jdbc:postgresql://172.16.87.248:5432/my_db", properties: { user: "myuser", password: "mypassword" } }