ask-sdk-postgresql-persistence-adapter
TypeScript icon, indicating that this package has built-in type declarations

1.0.5 • Public • Published

codecov npm version npm

What is ASK SDK for Node.js?

The ASK SDK v2 for Node.js is an open-source Alexa CustomSkill Development Kit. ASK SDK v2 for Node.js makes it easier for you to build highly engaging skills, by allowing you to spend more time on implementing features and less on writing boiler-plate code.

What is the ASK SDK PostgreSQL Persistence Adapter?

The ASK SDK PostgreSQL Persistence Adapter package contains implementation of the persistence adapter in Core SDK ('ask-sdk-core') based on AWS SDK. This package allows you to quickly get started in developing your custom Alexa Skill and easily manage persistence attributes throughout the skill with your own PostgreSQL database if that is your preferred database to work with.

If interested, you can find implementations for non-relational databases here instead:

Installing

ASK SDK PostgreSQL Persistence Adapter package is an addon package for the core SDK ('ask-sdk-core') and thus has peer dependency of the core SDK package. From within your NPM project, run the following commands in the terminal to install them:

npm install --save ask-sdk-postgresql-persistence-adapter

Usage and Getting Started

This package uses node-postgres to establish either a client or pool connection by importing either a PgClientConnection or PgPoolConnection along with the persistence adapter. It is recommended that you use a pool connection for your skill. You can read more about pooling and why you should use it here.

  1. Example on how to implement via pooling (recommended method):
let { PostgreSQLPersistenceAdapter, PgPoolConnection } = require('ask-sdk-postgresql-persistence-adapter');

const poolConnection = new PgPoolConnection({
  user: 'postgres_db_user',
  host: 'postgres_host',
  password: 'postgres_password',
  port: postgres_port
})

const options = {
  tableName: 'myTable',
  connection: poolConnection
}

const persistenceAdapter = new PostgreSQLPersistenceAdapter(options);

exports.handler = Alexa.SkillBuilders.custom()
  .addRequestHandlers(
    LaunchRequestHandler,
    HelloWorldIntentHandler,
    HelpIntentHandler,
    CancelAndStopIntentHandler,
    FallbackIntentHandler,
    SessionEndedRequestHandler,
  .withPersistenceAdapter(persistenceAdapter)
  .lambda();
  1. Example on how to implement via client:
let { PostgreSQLPersistenceAdapter, PgClientConnection } = require('ask-sdk-postgresql-persistence-adapter');

const clientConnection = new PgClientConnection({
  user: 'postgres_db_user',
  host: 'postgres_host',
  password: 'postgres_password',
  port: postgres_port
})

const options = {
  tableName: 'myTable',
  connection: clientConnection
}

const persistenceAdapter = new PostgreSQLPersistenceAdapter(options);

exports.handler = Alexa.SkillBuilders.custom()
  .addRequestHandlers(
    LaunchRequestHandler,
    HelloWorldIntentHandler,
    HelpIntentHandler,
    CancelAndStopIntentHandler,
    FallbackIntentHandler,
    SessionEndedRequestHandler,
  .withPersistenceAdapter(persistenceAdapter)
  .lambda();

Full PostgreSQLPersistenceAdapter parameter options:

  • tableName (string) - The name of a PostgreSQL table used. If the table is not yet created, the PostgreSQLPersistenceAdapter will create it for you in your database.
  • partitionKeyName (string) - Optional. The name of the partition key column. Default to "id" if not provided.
  • attributesName (string) - Optional. The name of the attributes column. Default to "attributes" if not provided.
  • partitionKeyGenerator (function) - Optional. The function used to generate partition key using RequestEnvelope. Default to generate the partition key using the userId.
  • connection (PostgreSQLConnection) - The desired connection to query the PostgreSQL database. Use either PgPoolConnection (recommended) or PgClientConnection.

PgPoolConnection and PgClientConnection parameter config options use pg.PoolConfig and pg.ClientConfig, you can find their detailed parameter options here:

In Node.js

To use the TypeScript definition files within a Node.js project, simply import ask-sdk-postgresql-persistence-adapter as below:

In a TypeScript file:

import * as Adapter from 'ask-sdk-postgresql-persistence-adapter';

In a JavaScript file:

const Adapter = require('ask-sdk-postgresql-persistence-adapter');

Opening Issues

For bug reports, feature requests and questions, we would like to hear about it. Search the existing issues and try to make sure your problem doesn’t already exist before opening a new issue. It’s helpful if you include the version of the SDK, Node.js or browser environment and OS you’re using. Please include a stack trace and reduced repro case when appropriate, too.

Contributions

If you would like to make a contribution, feel free to make a issue, make a pull request and link the issue.

License

This adapter is distributed under the Apache License, Version 2.0, see LICENSE for more information.

Readme

Keywords

Package Sidebar

Install

npm i ask-sdk-postgresql-persistence-adapter

Weekly Downloads

5

Version

1.0.5

License

Apache-2.0

Unpacked Size

67.2 kB

Total Files

24

Last publish

Collaborators

  • bryanleemoore