Skip to main content

A Python package for building Alexa skills.

Project description

skillful
========

`|PyPI Version| <https://pypi.python.org/pypi/skillful>`_ `|PyPI
Downloads| <https://pypi.python.org/pypi/skillful>`_ `|Build
Status| <https://travis-ci.org/bmweiner/skillful>`_
`|Coverage| <https://coveralls.io/github/bmweiner/skillful?branch=master>`_

*A Python package for building Amazon Alexa skills.*

Features
--------

- Request and response objects for `custom
skills <https://goo.gl/JpVGm4>`_
- Simple definition of response logic for each request type
- Built-in request parsing/validation, intent dispatch, and response
construction

Installation
------------

::

pip install skillful

Example
-------

::

import skillful
from skillful.tests import data

application_id = 'amzn1.echo-sdk-ams.app.000000-d0ed-0000-ad00-000000d00ebe'
skill = skillful.Skill(application_id)

@skill.launch
def on_launch():
print('Launched: {}'.format(skill.request.session.session_id))
text = 'Welcome to skillful. Would you like to build an Alexa skill?'
skill.response.set_output_speech_plain_text(text)
ssml = ('<speak>Please tell me if you would like to build an Alexa '
'skill.</speak>')
skill.response.set_reprompt_output_speech_ssml(ssml)

@skill.intent('yes')
def on_intent_yes():
text = ('Great! Building Alexa skills is easy with skillful. Open '
'the Alexa app to see more information on skillful, a '
'Python package for building Alexa skills.')
skill.response.set_output_speech_plain_text(text)
title = 'skillful'
content = ('A Python package for building Alexa skills.\n\n'
'Visit: https://github.com/bmweiner/skillful')
skill.response.set_card_type_simple(title, content)
skill.terminate()

@skill.intent('no')
def on_intent_no():
text = ('Well, if you change your mind, open the Alexa app to see '
'more information on skillful, a Python package for '
'building Alexa skills.')
skill.response.set_output_speech_plain_text(text)
title = 'skillful'
content = ('A Python package for building Alexa skills.\n\n'
'Visit: https://github.com/bmweiner/skillful')
skill.response.set_card_type_simple(title, content)
skill.terminate()

@skill.session_ended
def on_session_ended():
print('Ended: {}'.format(skill.request.session.session_id))
skill.terminate()

# simulate request body
body = data.SAMPLE_LAUNCH_REQUEST
skill.process(body)

Output:

::

Launched: amzn1.echo-api.session.0000000-0000-0000-0000-00000000000

{
"version": "1.0",
"response": {
"outputSpeech": {
"text": "Welcome to skillful. Would you like to build an Alexa skill?",
"type": "PlainText"
},
"shouldEndSession": false,
"reprompt": {
"outputSpeech": {
"ssml": "<speak>Please tell me if you would like to build an Alexa skill.</speak>",
"type": "SSML"
}
}
}
}

.. |PyPI Version| image:: https://img.shields.io/pypi/v/skillful.svg
.. |PyPI Downloads| image:: https://img.shields.io/pypi/dm/skillful.svg
.. |Build
Status| image:: https://travis-ci.org/bmweiner/skillful.svg?branch=master
.. |Coverage| image:: https://coveralls.io/repos/github/bmweiner/skillful/badge.svg?branch=master

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

skillful-0.3.2.tar.gz (8.5 kB view details)

Uploaded Source

File details

Details for the file skillful-0.3.2.tar.gz.

File metadata

  • Download URL: skillful-0.3.2.tar.gz
  • Upload date:
  • Size: 8.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for skillful-0.3.2.tar.gz
Algorithm Hash digest
SHA256 f2832f38b07b611314f6648bb9c6e9f61ba42c911dc4cb92048198af7a36393f
MD5 fe1a98fdee7dffa46adc79d2a97a54f1
BLAKE2b-256 1d30c73d3ef393f52e4156ec71ead94c2269ea26c5d6d79651a0caa936ca4eab

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page