Skip to content

Latest commit

 

History

History
102 lines (85 loc) · 7.42 KB

README.md

File metadata and controls

102 lines (85 loc) · 7.42 KB

Audio Player Sample Project

The Alexa Skills Kit now allows developers to build skills that play long-form audio content on Alexa devices. This sample project demonstrates how to use the new interfaces for triggering playback of audio and handling audio player input events.

How to Run the Sample

  1. Clone the project and package the skill:
git clone https://github.com/thekozak/lambda-alexa-nodejs-nightfly.git
cd lambda-alexa-nodejs-nightfly/js
npm install
zip -r ../audio-player.zip *
  1. Create or login to an AWS account. In the AWS Console:

    1. Create an AWS Role in IAM with access to Lambda, CloudWatch Logs and DynamoDB. create_role_1 create_role_2 create_role_3

    2. Create an AWS Lambda function named AudioPlayerLambdaFunction being sure to select the role created above, configuring "Alexa Skills Kit" as the "Trigger" and using the zip file created above as the source. alt text alt text

    3. After creation, take note of the ARN on the upper right, which you'll configure in the Developer Console below.

  2. Create or login to an Amazon Developer account. In the Developer Console:

    1. Create an Alexa Skill named MySkill and using the invocation name "my skill" and select 'Yes' for Audio Player support. alt text
    2. Copy the contents of speechAssets/intentSchema.json and speechAssets/Utterances.txt into the intent schema and sample utterances fields on the Interaction Model tab. alt text
    3. Copy the Lambda ARN from above in the Configuration tab. alt text
  3. You can start using the skill on your device or in the simulator using the invocation phrase "Alexa, ask my skill to play".

How it Works

Alexa Skills Kit now includes a set of output directives and input events that allow you to control the playback of audio files or streams. There are a few important concepts to get familiar with:

  • AudioPlayer directives are used by your skill to start and stop audio playback from content hosted at a publicly accessible secure URL. You send AudioPlayer directives in response to the intents you've configured for your skill, or new events you'll receive when a user controls their device with a dedicated controller (see PlaybackController events below).
  • PlaybackController events are sent to your skill when a user selects play/next/prev/pause on dedicated hardware controls on the Alexa device, such as on the Amazon Tap or the Voice Remote for Amazon Echo and Echo Dot. Your skill receives these events if your skill is currently controlling audio on the device (i.e., you were the last to send an AudioPlayer directive).
  • AudioPlayer events are sent to your skill at key changes in the status of audio playback, such as when audio has begun playing, been stopped or has finished. You can use them to track what's currently playing or queue up more content. Unlike intents, when you receive an AudioPlayer event, you may only respond with appropriate AudioPlayer directives to control playback.

The sample project plays a pre-defined list of audio content defined in js/audioAssets.js, allowing the user to control playback with a range of custom and built-in intents. It's organized into several modules:

  • index.js is the main module that handles events from Alexa. In the sample project, we setup the skill and register handlers defined in seperate modules.
  • constants.js holds a few constants like the Application ID of the skill and the name of a table in DynamoDB the skill will use to store details about what each user has played.
  • audioAssets.js is a list of audio content the skill will play from.
  • stateHandlers.js is where the skill handles voice intent and playback control commands. It registers handlers for each of the input events in different states the skill can be in, and defines a controller that centralizes the handler code since we perform the same action for several different input events (e.g., we do the same thing when the user tells the skill to stop or if the stop button is pressed on the device). The sample project define three states:
    • START_MODE is the default state of the skill, such as when it's invoked without an intent for the first time.
    • PLAY_MODE is used when audio is currently being played by the skill.
    • RESUME_DECISION_MODE is used to handle the response from the user when they're asked to confirm they'd like to resume playback from a prior use of the skill.
  • audioEventHandlers.js is where the skill handles AudioPlayer events. These events are only expected in the PLAY_MODE state and are used to track the user's progress through the content.

You can learn more about the new AudioPlayer interface and PlaybackController interface.

Test Lambda

{
  "session": {
    "new": true,
    "sessionId": "SessionId.7a00fa10-2bbc-4bc1-9599-4d149c2d572f",
    "application": {
      "applicationId": "amzn1.ask.skill.ca116d16-c7da-4513-bcbe-b78b35e75d25"
    },
    "attributes": {},
    "user": {
      "userId": "amzn1.ask.account.AHWNRCXK46RQ27LHZNUCB5N3HZRLAP2ZGNWU45OFE7DLPS6BGNXSJDMELSJWCSN34SUX5XTMBQMY7RUBELJFQ2CVNW4CWJ4PGIOHX5GAEC5Q2QJQAMMIA6N2RKZOF5ZY4IGSXJEWJ6QAWGWRBMXDOSLLJQAXHQUXYCIKD6SOMUEZNXBFBMRYQ44GBT4DQLD24VZ4YKDDYCO3QII"
    }
  },
  "request": {
    "type": "IntentRequest",
    "requestId": "EdwRequestId.6aea1e0a-722e-4617-b6bd-3424bd6542bf",
    "intent": {
      "name": "PlayAudio",
      "slots": {}
    },
    "locale": "en-US",
    "timestamp": "2017-08-22T02:18:34Z"
  },
  "context": {
    "AudioPlayer": {
      "playerActivity": "IDLE"
    },
    "System": {
      "application": {
        "applicationId": "amzn1.ask.skill.ca116d16-c7da-4513-bcbe-b78b35e75d25"
      },
      "user": {
        "userId": "amzn1.ask.account.AHWNRCXK46RQ27LHZNUCB5N3HZRLAP2ZGNWU45OFE7DLPS6BGNXSJDMELSJWCSN34SUX5XTMBQMY7RUBELJFQ2CVNW4CWJ4PGIOHX5GAEC5Q2QJQAMMIA6N2RKZOF5ZY4IGSXJEWJ6QAWGWRBMXDOSLLJQAXHQUXYCIKD6SOMUEZNXBFBMRYQ44GBT4DQLD24VZ4YKDDYCO3QII"
      },
      "device": {
        "supportedInterfaces": {}
      }
    }
  },
  "version": "1.0"
}