Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@jargon/alexa-skill-sdk
Advanced tools
The Jargon Alexa Skill SDK makes it easy to manage the content of your custom Alexa skill
The Jargon SDK makes it easy for skill developers to manage their runtime content, and to support multiple languages from within their skill.
Need help localizing your skills to new languages and locales? Contact Jargon at localization@jargon.com.
This version of the SDK works with Amazon Alexa skills that are built using the ASK SDK v2 for Node.js.
Like the ASK SDK, the Jargon SDK is built using TypeScript, and includes typing information in the distribution package (but you're under no obligation to use TypeScript to build your skill).
Your Lambda function should be using the nodejs8.10 runtime, or a later version (when available).
Content resources define the text that your skill outputs to users, via Alexa's voice, card content, or screen content. It's important that these resources live outside of your skill's source code to make it possible to localize them into other languages.
The Jargon SDK expects resource files to live in the "resources" subdirectory within your lambda code (i.e., skill_root/lambda/custom/resources). Each locale has a single resource file, named for that locale (e.g., "en-US.json").
Resource files are JSON, with a single top-level object (similar to package.json). The keys within that object are the identifiers you'll use to refer to specific resources within your source code. Nested objects are supported to help you organize your resources.
{
"key1":"Text for key 1",
"key2":"Text for key 2",
"nestedObjects":{
"are":{
"supported":"Use the key 'nestedObjects.are.supported' to refer to this resource"
}
}
}
Resource values are in ICU MessageFormat. This format supports constructing text at runtime based on parameters passed in from your code, and selecting alternative forms to handle things like pluralization and gender.
{
"sayHello":"Hello {name}"
}
{
"itemCount":"{count, plural, =0 {You have zero items} =1 {You have one item} other {You have # items}}"
}
{
"pronounSelection":"{gender, select, female {She did it!} male {He did it!} other {It did it!}"
}
It's important for Alexa skills to vary the words they use in response to users, lest they sound robotic. The Jargon SDK makes ths simple with built-in variation support. Variations are defined using nested objects:
{
"resourceWithVariations":{
"v1":"First variation",
"v2":"Second variation",
"v3":"Third variation"
}
}
When rendering the key resourceWithVariations
the Jargon SDK will choose a variation at random (with other more complex
methods coming in future versions). If you render the same resource multiple times within a single request (e.g., for spoken
content and for card or screen content) the SDK will by default consistently choose the same variation.
Note that you can always select a specific variation using its fully-qualified key (e.g., resourceWithVariations.v1
)
You can determine which variation the SDK chose via the ResourceManager's selectedVariation(s) routines.
The core class you'll work with. JargonResponseBuilder
mirrors the ASK SDK response builder, but changes string
parameters containing content presented to users to RenderItem
s (see below).
By default the speak
and reprompt
methods replace the content from previous calls to those methods; this behavior mirrors
that of corresponding ASK SDK methods. There are two ways to change this behavior such to multiple calls to result in content
getting merged (with a space in between) instead of replaced:
JargonSkillBuilder
(described below) pass in an options object with mergeSpeakAndReprompt
set to trueResponseGenerationOptions
object to the speak
or reprompt
method with merge
set to trueWhen mergeSpeakAndReprompt
is true the default replace behavior can be used for specific calls to speak
or reprompt
by
providing a ResponseGenerationOptions
object with merge
set to false
Note that each individual call to speak
or reprompt
should contain content that can stand alone (e.g., a full sentence or
paragraph) to minimize the chances that the order of the content would change across languages.
/**
* Options that modify the default response builder behavior for a specific call.
* These flags may be Jargon-specific (such as merge) or come from the ASK response
* builder (playBehavior).
*/
export interface ResponseGenerationOptions {
/**
* If provided, overrides the mergeSpeakAndReprompt setting in the response builder's options.
* True merges the rendered content with previously rendered content; false replaces any previous content
*/
merge?: boolean
/** Optional playBehavior parameter for speak and reprompt (for ASK v2.4.0 and greater) */
playBehavior?: ui.PlayBehavior
}
/**
* Type alias for response builder parameters that were previously optional
* booleans (for merge), but that can now also take a ResponseGenerationOptions instance
*/
export type RGOParam = ResponseGenerationOptions | boolean
/**
* JargonResponseBuilder mirrors the ASK response builder, but takes RenderItems instead
* of raw strings for parameters that end up being spoken or displayed to the end user.
*/
export interface JargonResponseBuilder {
/**
* Has Alexa say the provided speech to the user
* @param {RenderItem} speechOutput The item to render for the speech content
* @param {RGOParam} optionsOrMerge Options to control response generation behavior. A boolean value
* is treated as ResponseGenerationOptions.merge (for backwards compatibility)
* @returns {ResponseBuilder}
*/
speak (speechOutput: RenderItem, optionsOrMerge?: RGOParam): this
/**
* Has alexa listen for speech from the user. If the user doesn't respond within 8 seconds
* then has alexa reprompt with the provided reprompt speech
* @param {RenderItem} repromptSpeechOutput The item to render for the reprompt content
* @param {RGOParam} optionsOrMerge Options to control response generation behavior. A boolean value
* is treated as ResponseGenerationOptions.merge (for backwards compatibility)
* @returns {ResponseBuilder}
*/
reprompt (repromptSpeechOutput: RenderItem, optionsOrMerge?: RGOParam): this
/**
* Renders a simple card with the following title and content
* @param {RenderItem} cardTitle
* @param {RenderItem} cardContent
* @returns {JargonResponseBuilder}
*/
withSimpleCard (cardTitle: RenderItem, cardContent: RenderItem): this
/**
* Renders a standard card with the following title, content and image
* @param {RenderItem} cardTitle
* @param {RenderItem} cardContent
* @param {string} smallImageUrl
* @param {string} largeImageUrl
* @returns {JargonResponseBuilder}
*/
withStandardCard (cardTitle: RenderItem, cardContent: RenderItem, smallImageUrl?: string, largeImageUrl?: string): this
/**
* Adds a hint directive - show a hint on the screen of the echo show
* @param {RenderItem} text plain text to show on the hint
* @returns {JargonResponseBuilder}
*/
addHintDirective (text: RenderItem): this
/**
* Adds a VideoApp play directive to play a video
*
* @param {string} source Identifies the location of video content at a remote HTTPS location.
* The video file must be hosted at an Internet-accessible HTTPS endpoint.
* @param {RenderItem} title (optional) title that can be displayed on VideoApp.
* @param {RenderItem} subtitle (optional) subtitle that can be displayed on VideoApp.
* @returns {JargonResponseBuilder}
*/
addVideoAppLaunchDirective (source: string, title?: RenderItem, subtitle?: RenderItem): this
// Additional methods are identical to ResponseBuilder in the ASK SDK
A RenderItem specifies a resource key, optional parameters, and options to control details of the rendering (which are themselves optional).
interface RenderItem {
/** The resource key to render */
key: string
/** Params to use during rendering (optional) */
params?: RenderParams
/** Render options (optional) */
options?: RenderOptions
}
RenderParams
are a map from parameter name to a string, number, or RenderItem
instance.
interface RenderParams {
[param: string]: string | number | RenderItem
}
The use of a RenderItem
instance as a parameter value makes it easy to compose multiple
resource together at runtime. This is useful when a parameter value varies across locales,
or when you want the SDK to select across multiple variations for a parameter value, and reduces
the need to chain together multiple calls into the ResourceManager
.
The ri
helper function simplifies constructing a RenderItem
:
function ri (key: string, params?: RenderParams, options?: RenderOptions): RenderItem
handlerInput.jrb.speak(ri('sayHello', { 'name': 'World' }))
RenderOptions
allows fine-grained control of rendering behavior for a specific call, overriding
the configuration set at the ResourceManager
level.
interface RenderOptions {
/** When true, forces the use of a new random value for selecting variations,
* overriding consistentRandom
*/
readonly forceNewRandom?: boolean
}
JargonSkillBuilder
installs onto the ASK skill builder, and handles all details of initializing the Jargon SDK,
installing request and response interceptors, and so on.
const skillBuilder = new Jargon.JargonSkillBuilder().installOnto(Alexa.SkillBuilders.custom())
Internally JargonResponseBuilder
uses a ResourceManager
to render strings and objects. You
can directly access the resource manager if desired, for use cases such as:
You can access the resource manager through any of the following methods:
handlerInput.jrm
handlerInput.jargonResourceManager
handlerInput.attributesManager.getRequestAttributes().jrm
handlerInput.attributesManager.getRequestAttributes().jargonResourceManager
export interface ResourceManager {
/** Renders a string in the current locale
* @param {RenderItem} item The item to render
* @returns {Promise<string>} A promise to the rendered string
*/
render (item: RenderItem): Promise<string>
/** Renders multiple item
* @param {RenderItem[]} items The items to render
* @returns {Promise<string[]} A promise to the rendered strings
*/
renderBatch (items: RenderItem[]): Promise<string[]>
/** Renders an object in the current locale. This also supports returning
* strings, numbers, or booleans
* @param {RenderItem} item The item to render
* @returns {Promise<T>} A promise to the rendered object
*/
renderObject<T> (item: RenderItem): Promise<T>
/** Retrieves information about the selected variant for a rendered item. This
* will only return a result when rendering the item required a variation
* selection. If item has been used for multiple calls to a render routine
* the result of the first operation will be returned; use selectedVariations
* to see all results.
* @param {RenderItem} item The item to retrieve the selected variant for
* @return {Promise<SelectedVariation>} A promise to the selected variation
*/
selectedVariation (item: RenderItem): Promise<SelectedVariation>
/** Retrieves information about all selected variations for rendered item. This
* will only return a result for items that required a variation selection
* during rendering. Results are ordered by the ordering of the calls to render
* routines.
* @return {Promise<SelectedVariation[]>} A promise to the selected variations
*/
selectedVariations (): Promise<SelectedVariation[]>
/** The locale the resource manager uses */
readonly locale: string
}
Note that the render routines return Promise
s to the rendered content, not the content directly.
ResourceManager
is part of the package @jargon/sdk-core,
and can be used directly from code that isn't based on ASKv2.
This SDK includes default responses for some common scenarios. These responses are available using the following RenderItem
keys:
Jargon.unhandledResponse
-- provides a response for when you can't otherwise process an intentJargon.defaultReprompt
-- provides a generic repromptYou can render these resources as you would any of your own. You can also define your own version for these keys in your resource file to override the Jargon-provided responses.
Currently the SDK includes variants of these resources for English, with other languages coming soon.
First add the Jargon SDK as a dependency of your lambda code (skill_root/lambda/custom)
Next, install Jargon's skill builder onto the Alexa skill builder:
// Import the Jargon SDK
const Jargon = require('@jargon/alexa-skill-sdk')
// Installation
const skillBuilder = new Jargon.JargonSkillBuilder().installOnto(Alexa.SkillBuilders.custom())
The content that your skill outputs via speak(), reprompt(), etc., needs to move from wherever it currently lives in to Jargon resource files. That's currently a manual step, but in the future we'll have tools to help automate portions of the process.
Resource files go under skill_root/lambda/custom/resources, and are named by the locale they contain content for (e.g., "en-US.json").
In your skill handlers access the Jargon response builder via one of the following methods:
handlerInput.jrb
handlerInput.jargonResourceManager
handlerInput.attributesManager.getRequestAttributes().jrb
handlerInput.attributesManager.getRequestAttributes().jargonResourceManager
Feel free to move to the Jargon response builder incrementally; however, you shouldn't mix the use of
the ASK response builder and the Jargon response builder in a single request due to the last-write-wins
behavior of speak()
and reprompt()
in the ASK response builder.
We've "Jargonized" some of the ASK starter templates to simplify creating a new skill. To make use of these templates:
npm update -g ask-cli
ask init
to configure everythingask new --url https://s3.amazonaws.com/jargon-templates/ask-nodejs.json
Please note that you'll receive a warning message that the template isn't from an official source; in order to create the skill from the template answer "yes" when prompted. The templates include the same hook scripts as the original Amazon templates; these scripts ensure that the necessary dependencies are installed (via npm) after creating a new project, and prior to deployment.
If you know which template you'd like to use, in step 2 above you can directly provide its URL:
Alternatively, you can clone the template repository instead of using the ASK CLI.
Please file an issue if you're interested in seeing a template for a different use case, or contact us at sdk@jargon.com with any suggestions or feedback you might have.
FAQs
The Jargon Alexa Skill SDK makes it easy to manage the content of your custom Alexa skill
We found that @jargon/alexa-skill-sdk demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.