Please use node-app-mysql-connector for managing MySQL connections.
Redis and HTTP connections are usually simple enough to not require lots of additional management logic, so just use the appropriate libraries directly. You can use the wrappers
module within node-app-base to help manage log output.
Collection of libraries to interface with external data sources. At the moment, the following sources are supported:
- MySQL
- HTTP API
- JSON REST API requests
- Redis
Add the following line to your package.json
dependencies
"node-app-data-connectors": "git+ssh://git@github.com:infinityworks/node-app-data-connectors.git[#<version>]"
You can also install specific releases or git commits in this fashion. For the syntax to do that, check the npm documentation.
Import the library and then initialise each individual connector with the desired parameters.
Initialise the module by passing it some parameters inherited from node-app-base.
const DataConnectors = require('node-app-data-connectors')(logger, timers, metrics);
Parameters:
host
: address of the MySQL serverport
: port to connect to the MySQL server onuser
: MySQL usernamepassword
: MySQL passworddatabase
: name of the database to queryconnectionOptions
: options object to override default DB pool optionsenableConnectionLogging
: log out connection lifecycle messages: creation, acquisition, release, queueing, etc.
const dbConnection = DataConnectors.dbConnection(
'sql.server',
3306,
'test',
'testpassword',
'db_name',
{ acquireTimeout: 1000 }
);
Parameters:
host
: address of the Redis serverport
: port number to establish the Redis connectiondbIndex
: Redis database indexenableInfoLogs
: enable INFO level logs to be printed from the source
const redisConnection = DataConnectors.redisConnection(
'redis.host',
6379,
1
);
Parameters:
host
: domain name of the host serving the API.port
: port to establish the HTTP connection on, namely80
or443
.protocol
: whether HTTP or HTTPS should be used. Accepted values arehttp
orhttps
.
const apiConnection = DataConnectors.apiConnection(
'service.api.com',
443,
'https'
);
const jsonApiFetch = DataConnectors.jsonApiFetch(apiConnection);
You can generate a healthcheck callback ready for consumption by the node-app-base healthcheck listener by invoking the getHealthCheckCallback
function and passing an array containing all data sources that you want to monitor.
const healthCheckCallback = DataConnectors.getHealthCheckCallback([dbConnection, redisConnection]);
healthCheck.initListener(healthCheckCallback());
MySQL database adapter.
Executes a single-statement prepared query with any number of positional parameters to substitute into the query.
Parameters:
sql
: string containing the SQL statement to run. Any query values to escape must be replaced by question marks.values
: array of value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this query
let rows = [];
try {
const params = [1];
rows = await db.query(
'SELECT * FROM `mytable` WHERE `id` = ?',
params,
'db.query',
);
} catch (e) {
// error
}
Executes any number of prepared statements using either positional or labelled parameters, within a single transaction that is automatically rolled back on failure.
Parameters:
sqls
: array of strings containing the SQL statements to run. Any query values to escape must be replaced by question marks.values
: array of array of value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this query
let result = [];
try {
const queries = [
'UPDATE user SET password = ? WHERE id = ?',
'INSERT INTO audit (type, date) VALUES ('passwordChange', NOW())',
];
const values = [
['password123', '1337'],
[],
];
result = await db.transactionQuery(
values,
'db.query',
);
// result is an array of rows
} catch (e) {
// error
}
Executes a single-statement prepared query with any number of positional parameters to substitute into the query and returns
an array with a reference to the open channel with the database and a reference to the underlying connection. Calling stream()
on the returned channel returns a stream.Readable
.
Note: this function gives the caller ownership of the underlying connection, which means the connection must be closed by the caller manually when the operation is finished.
Parameters:
sql
: string containing the SQL statement to run. Any query values to escape must be replaced by question marks.values
: array of value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this query
Returns:
Array
EventEmitter
- Connection
const params = [1];
const stream = await db.queryStream(
'SELECT * FROM `mytable` WHERE `id` = ?',
params,
'db.query',
);
stream.on('error', (err) => {
// handle error
})
.on('result', (row) => {
// process data row
})
.on('end', () => {
// all rows received
// release the connection back into the pool
connection.release();
});
Executes any number of prepared statements using either positional or labelled parameters.
Parameters:
sql
: string containing the SQL statements to run. Any query values to escape must be replaced by question marks or colon-prefixed labels, depending on whether theparamLabels
flag is set or not.values
: array/object of value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this queryoptions
paramLabels
: if set totrue
, will take a JavaScript object containing all the labelled parameters to inject into the statement (seelabelQuery
for an example). Default:false
(will use positional parameters).
const sql = 'SELECT * FROM `users` WHERE `id` = ?; SELECT * FROM `accounts` WHERE `user_id` = ?;'
let results = [];
try {
const params = [1, 10];
results = await db.multiStmtQuery(
sql,
params,
'db.query',
);
const stmtOneRows = result[0];
const stmtTwoRows = result[1];
} catch (e) {
// error
}
Executes a single prepared statement using a number of labelled parameters, provided by a parameter object.
Parameters:
sql
: string containing the SQL statement to run. Any query values to escape must be prefixed with a colon and the name of the key as passed in thevalues
object parameter.values
: object of labelled value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this query
let rows = [];
try {
const params = { id: 1, user_id: 20 };
rows = await db.labelQuery(
'SELECT * FROM `users` WHERE `id` = :id OR `user_id` = :user_id',
params,
'db.query',
);
} catch (e) {
// error
}
Executes a SQL INSERT statement with any number of value rows.
Parameters:
sql
: string containing the SQL INSERT statement to run. Any query values to escape must be replaced by question marks.values
: array of value(s) to inject into the prepared statement.label
: string containing the log key that will be used for this query
let result = null;
try {
const params = [['UserOne', 'UserOneSurname'], ['UserTwo', 'UserTwoSurname']];
result = await db.bulkInsert(
'INSERT INTO `users` (`firstname`, `surname`) VALUES ?',
params,
'db.query',
);
} catch (e) {
// error
}
The Redis adapter exposes the same public calls as the underlying Redis client. For a list of all supported Redis commands, see RedisConnection.js
.
HTTP REST API client.
Send a HTTP request to a remote REST API endpoint.
Parameters:
path
: path section of the endpoint URI (without the URI scheme and domain name)qs
: request query string object (for HTTP GET requests)transactionId
: unique request identifier
apiConnection.get('/v2/user/1', { token: 'sometoken' })
.then((response) => {
return response;
})
.catch((err) => {
return Promise.reject(err);
});
JSON wrapper around the generic ApiConnection
adapter.
Parameters:
apiPath
: path section of the endpoint URI (without the URI scheme and domain name)qsObj
: request query string object (for HTTP GET requests)transactionId
: unique request identifier
// Both Promise and ES7 async/await forms are supported
const response = await jsonApi.fetchFromJsonApi('/v2/user/1', { token: 'sometoken' });
return JSON.parse(response);