A package to help connect and work with Amazon DocumentDB (with MongoDB compatibility). You can run this package locally by disabling ssl and connecting to a compatible mongodb docker container.
The package supports two env variables
CONNECTION_URI
: Connection string to connect to the instance
DB_NAME
: The name of the Db to be configured in client.
Both the env vars are optional. You can eithr configure these or can pass them to the function.
install the package fron npm
npm install @awsmag/power-document-db
import { connectDb } from "@awsmag/power-document-db";
async function useDbWithEnvVarSet() {
return await connectDb(); // if en variables are set
}
async function useDbWithoutEnvVarSet() {
const uri = "mongodb://localhost:27017";
const dbName = "test";
const ssl = true; // Keep it true when connecting to instance. For local testing and docker container keep it false
const tlsCAFile = "./certs/global-bundle.pem"; // mandatory when it is set to true. You will get this from AWS under the steps of how to connect to AWS document Db
return await connectDb(uri, dbName, ssl, tlsCAFile); // if en variables are not set
}
The package also supports a Koa middleware to attach the client to ctx.
import { connectDb, getDbCLientMw } from "@awsmag/power-document-db";
import Koa from "koa";
const server = new Koa();
const uri = "mongodb://localhost:27017";
const dbName = "test";
const ssl = true; // Keep it true when connecting to instance. For local testing and docker container keep it false
const tlsCAFile = "./certs/global-bundle.pem"; // mandatory when it is set to true. You will get this from AWS under the steps of how to connect to AWS document Db
(async () => {
await connectDb(uri, dbName, ssl, tlsCAFile); // if en variables are not set
server.use(getDbCLientMw());
// rest of your code goes here
})();
// it will be available as `db` in ctx. In your handler use it like below.
const db = ctx.db;
// perform functions using db
To use transactions, you can start a session on the client by using the following method
import { startSession } from "@awsmag/power-document-db";
const session = await startSession();
// start transaction
session.startTransaction();
await db.insertOne({}, {session}); // use the session in options of the used command to binfd it to particular session and use transaction
// commit or abort transaction
session.commitTransaction();
session.abortTransaction();
The package is developed and maintained by S25Digital. You can also check our blog AWSMAG