Giter Site home page Giter Site logo

aondio / skill-sample-nodejs-numberguessinggame Goto Github PK

View Code? Open in Web Editor NEW

This project forked from germanviscuso/skill-sample-nodejs-numberguessinggame

1.0 3.0 0.0 4.49 MB

The number guessing game is a game where the player tries to guess the target number. After each incorrect guess, the player is informed if the target number is higher or lower than their current guess. This continues until the target number is guessed or the player gives up. This sample Alexa Skill is written in Node.js and demonstrates skill internationalization

License: Other

JavaScript 100.00%

skill-sample-nodejs-numberguessinggame's Introduction

Build An Alexa Number Guessing Game Skill

Voice User InterfaceLambda FunctionConnect VUI to CodeTestingCustomizationPublication

This Alexa sample skill is a template for a basic number guessing game skill. Guess a number, and Alexa will tell you whether the number she has in mind is higher or lower.

Let's Get Started

If this is your first time here, you're new to Alexa Skills Development, or you're looking for more detailed instructions, click the Get Started button below:

Be sure to take a look at the Additional Resources at the bottom of this page!

About

Note: The rest of this readme assumes you have your developer environment ready to go and that you have some familiarity with CLI (Command Line Interface) Tools, AWS, and the ASK Developer Portal. If not, click here for a more detailed walkthrough.

Usage

Alexa, open number guessing game
	>> ...please guess a number between 0 and 100
Five
	>> Five is too low. Try saying a larger number.
...

Repository Contents

  • /.ask - ASK CLI (Command Line Interface) Configuration
  • /lambda/custom - Back-End Logic for the Alexa Skill hosted on AWS Lambda
  • /lambda/custom/i18n - Internationalization strings used in the back-end
  • /models - Voice User Interface and Language Specific Interaction Models
  • /instructions - Step-by-Step Instructions for Getting Started
  • skill.json - Skill Manifest

Setup w/ ASK CLI

Pre-requisites

Installation

  1. Clone the repository.

    $ git clone https://github.com/germanviscuso/skill-sample-nodejs-numberguessinggame
  2. Navigating into the repository's root folder.

    $ cd skill-sample-nodejs-numberguessinggame
  3. Install npm dependencies by navigating into the lambda/custom directory and running the npm command: npm install

    $ cd lambda/custom
    $ npm install

Deployment

ASK CLI will create the skill and the lambda function for you. The Lambda function will be created in us-east-1 (Northern Virginia) by default.

  1. Deploy the skill and the lambda function in one step by running the following command:

    $ ask deploy
  2. Once deployed, additional permissions need to be added to the AWS IAM role being used by the skill since it is persisting data in Amazon DynamoDB. Navigate to the AWS IAM console.

    Note: We are adding the full access policy here for convenience. For a production skill, you should use a more targeted policy restricting access to just the required resources. Refer to the DynamoDB documentation for more details.

    1. Locate the role for your skill (by default, it is named ask-lambda-<your skill name>).
    2. Click on the role, then click Attach Policy.
    3. Search for AmazonDynamoDBFullAccess and click the check box next to it.
    4. Click Attach Policy.

Testing

  1. To test, you need to login to Alexa Developer Console, and enable the "Test" switch on your skill from the "Test" Tab.

  2. Simulate verbal interaction with your skill through the command line using the following example:

     $ ask simulate -l en-US -t "start the number guessing game"
    
     ✓ Simulation created for simulation id: 4a7a9ed8-94b2-40c0-b3bd-fb63d9887fa7
    ◡ Waiting for simulation response{
      "status": "SUCCESSFUL",
      ...

Note: if you did not add the DynamoDB permission as described in the previous step, the skill will return an error and you will see an error in your CloudWatch Logs reporting: ...Coud not read item...is not authorized to perform: dynamodb:GetItem...

  1. Once the "Test" switch is enabled, your skill can be tested on devices associated with the developer account as well. Speak to Alexa from any enabled device, from your browser at echosim.io, or through your Amazon Mobile App and say :

    Alexa, start the number guessing game
    

Customization

  1. ./skill.json

    Change the skill name, example phrase, icons, testing instructions etc ...

    Remember that some of the information is locale-specific and must be changed for each locale (en-GB and en-US)

    See the Skill Manifest Documentation for more information.

  2. ./lambda/custom/index.js

    Modify things (like e.g the number range) from the source code to customize the skill.

  3. ./lambda/custom/i18n/*.json

    Provide localized strings for the backend in each supported locale. Repeat the operation for each locale you are planning to support.

  4. ./models/*.json

    Change the model definition to replace the invocation name and, if necessary for your customization, the sample phrases for each intent. Repeat the operation for each locale you are planning to support.

Additional Resources

Community

Tutorials & Guides

  • Voice Design Guide - A great resource for learning conversational and voice user interface design.
  • CodeAcademy: Learn Alexa - Learn how to build an Alexa Skill from within your browser with this beginner friendly tutorial on CodeAcademy!

Documentation

skill-sample-nodejs-numberguessinggame's People

Contributors

germanviscuso avatar

Stargazers

 avatar

Watchers

James Cloos avatar arianna-aondio avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.