npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

ask-sdk-postgresql-persistence-adapter

v1.0.5

Published

PostgreSQL based implementation package of PersistenceAdapter interface for Node.js

Downloads

7

Readme

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.