LoginSignup
9
8

More than 5 years have passed since last update.

ASK CLIで作る、「ラジ○体操第一」Alexa Skill

Last updated at Posted at 2017-10-30

鍼灸院の院長に体が固いことを指摘され、ラジオ体操をすることにしました。
子供の頃は夏休みに毎日やらされていたので、音楽を聞けば画像がなくても踊れます。Alexa向けと言えましょう。
そこでAlexa Skillでラジオ体操のスキルを作ることにしました。
著作権の都合上、もちろん自分専用です。
さらに今回は、9月にリリースされたASK CLIを使ってみることにします。

用意するもの

  • Mac
  • USのAWSのアカウント
  • USのAlexa Skills Developerコンソールのアカウント
  • Alexa が動作するデバイス(echoとかFire TV Stick) あるいはテスト用のアプリ(Astraなど)

Windowsでも多分できると思います。が、ASK CLIの説明が、どう見てもLinux / Mac向けでしたので、読み替えて進むのに限界があったらVirtualBoxなどでCentOSを使うのがいいかもしれません。

Alexa Skills Developer consoleで App登録

まず、Alexa SkillのDeveloper consoleを開き、
左側の「Alexa Skills Kit」の下の「Get Started」をクリックします。

image.png

開いた画面の右肩にある「Add a new skill」を力一杯クリックします。

image.png

するとSkill Informationの設定画面がひらけます。

image.png

Skill type = Custom Interaction Model
Language = English (U.S) 

image.png
本来日本語を選びたいのですが、対応してないので仕方なしにUS英語を選びます。早く日本語対応してくれーToT

Name = Radio Taisou No.1
Invocation Name = rajio taisou dai ichi

Alexaに「〜のスキルを起動して」と呼びかける時の名前は、日本語のローマ字読みにしてみました。これで、「アレクサ、オープン ラジオ タイソウ ダイ イチィ」と、呼びかければ起動してくれるようになります。(^^;)


画面を下にスクロールすると背景が灰色の入力欄が出てきます。

image.png

Audio Player = Yes
Video App = No
Render templare = No

Nextをクリックします。

IDが生成されました。
以下のamzn1,ask.〜798の部分が、今後Application IDとかAPP IDとか呼ばれるものになります。

(このIDのアプリは、デベロッパーサイトからもう消しましたんで、ここに書いてますが、
本来はあんまり他人に教えない方が良いと思います。
理由は、悪用できないとも限らないから。)

image.png

次はIntentとかUtterancesの設定になるんですが、実はSkill Builderの使い方が未だによくわからないんですよねー。もうリリースされてから半年以上経つと思うんですが、未だにbetaですし。。

そこで新兵器のASK CLIを使います。

アマゾン公式のサンプルコード、ラジオ放送用node.jsをダウンロード

Lambda関数のサンプルコードを、Githubからダウンロードします。
https://github.com/alexa/skill-sample-nodejs-audio-player

image.png

ダウンロードしたらzipを解凍して、
single-stream」フォルダを好きな場所に移動して、好きなエディタで開きます。

以後、便宜的にローカルのパスは~/single-stream/と記載します。

なお、コードの編集はメモ帳でもいいですが、編集対象ファイルが多いので、IDEを使うことをオススメします。Node.jsに対応してるものがいいですね。私は前職のパイセンが勧めてくれたNetBeansを使っております。

image.png

さて、このファイル群を、Readmeに沿って編集してきましょう。
https://github.com/alexa/skill-sample-nodejs-audio-player/blob/mainline/single-stream/README.md

おっとその前にまず、ASK CLIをインストールします。

ASK CLIのインストール

ASK CLIとは、Alexa Skills Kit Command Line Interfaceの略で、ローカルマシンにインストールするコマンドラインツールです。

  • 以前のデバッグ時には何十回も手動でやっていた、ローカルでファイル群をzip圧縮してLambdaにアップするという作業を、deployコマンド一発でやってくれる優れもの。
  • Deployの際の認証は、AWSで発行するLambda専用のIAMのクレデンシャルを使用する。

あと実は、アプリIDも発行できるようです。
夢が膨らみますね。

インストール手順をなぞりながら進めて行きます。
まずMacでターミナルを開き、nodeが入ってるか確認コマンドを実行します。

$ node --version

「v6.11.4」のように、バージョンが表示されたのでOKです。

次に、AWSでIAMを作成して、クレデンシャルを発行し、ローカルマシンのとある場所に保存します。
実はここでハマったので、手順をこちらに書きました。よろしければご覧ください。

次にnpmを使ってASK CLIをインストールします。
Linuxの場合はsudoをつけろとあるので、Macなのでつけて実行します。

$ sudo npm install -g ask-cli

次に認証情報を初期化&書き込みをします。

$ ask init

以下のようにガイダンスが出ますので、「default」が既にあればそれを選びます。無ければ「Create new profile」を選びます。

? Please create a new profile or overwrite the existing profile.
 (Use arrow keys)
  ──────────────
❯ Create new profile 
  ──────────────
  Profile              Associated AWS Profile
  [default]                 ** NULL **

次に、lambda関数のデプロイ用に、先ほど「~/.aws/credentials」に書き込んだユーザー名を指定します。(私の場合は 「default」でした

-------------------- Initialize CLI --------------------
Setting up ask profile: [default]
? Please choose one from the following AWS profiles for skill's Lambda function deployment.
 (Use arrow keys)
❯ default 
  ──────────────
  skip AWS credential for ask-cli 
  ──────────────

すると自動的にブラウザに遷移し、Amazon Loginが走ります。
image.png

「Sign in was successful. Close this browser and return to the command line interface.」というメッセージが出たら、ブラウザは閉じてOKです。

ターミナル側のジョブも同時に完了してます。
image.png

さて、先ほどGithubからダウンロードした「single-stream」を置いたディレクトリに移動します。
便宜上、「~/single-stream/」とします。
移動したらnpmをインストールします。

$ cd ~/single-stream/
$ (cd lambda && npm install)
$ (cd lambda/src && npm install)

ライセンス関連のワーニングが出ますが、動作には影響ないようです。

ラ。。。の音源のMP3ファイルをゲットする

ここは詳しく書きません!(^^;)(^^;)(^^;)
- MP3ファイル
- httpsアクセスできる状態にしておく
例)https://s3.amazonaws.com/***自分のバケット***/radioTaisou_1.mp4

Alexa公式サンプルの、ラジオ放送用node.jsをカスタマイズ

ここからがついにSKill本体の編集です。

1. ./skill.json

image.png
(実際はもっと長いけど省略)

以下の箇所を自分のSkillの設定に合わせて書き換え。

17行目、34行目
"name": "My Radio",

"name": "Radio Taisou No.1",
6行目、23行目
"summary": "Listen to My Radio, less bla bla bla, more la la la.",

"summary": "Japanese most famous workout dance.",

8〜10行目、25〜27行目
"Alexa, open My Radio",
"Alexa, play My Radio",
"Alexa, ask My Radio to play"

"Alexa, open Rajio taisou dai ichi",
"Alexa, play Rajio taisou dai ichi",
"Alexa, ask Rajio taisou dai ichi to play"

18行目、35行目
"description": "Listen to My Radio, with less bla bla bla, and more la la la.\n\nMy Radio provides a high quality sound 24/7 with the best music.\n\nTo start, just say \"Alexa, launch My Radio\" or \"Alexa, play my radio\" to start the radio\".\n\nAt anytime, you can stop the radio by saying \"Alexa, stop\"",

"description": "Let's play japanese most famous workout dance.\n\nTo start, just say \"Alexa, launch My Rajio taisou dai ichi\" or \"Alexa, play my Rajio taisou dai ichi\" to start the radio\".\n\nAt anytime, you can stop the radio by saying \"Alexa, stop\"",

書き換えたら保存。(^^)

2. ./lambda/src/audioAssets.js

image.png

4〜7行目
title: 'My Radio',
subtitle: 'Less bla bla, more la la',
cardContent: "Visit our web site https://www.myradio.com",
url: 'https://audio1.maxi80.com',

title: 'Radio Taisou No.1',
subtitle: 'Less bla bla, more la la',
cardContent: "this skill plays only music. If you're Japanese, you'ld know the dance.",
url: (音源ファイルのURLをここに書く),
largeImageUrl:(個人用なので特に差し替えない)
smallImageUrl:(個人用なので特に差し替えない)

保存!(^^)

3. ./models/*.json

my radio

rajio taisou dai ichi

保存!(^^)

ローカルでテストする

$ cd ~/single-stream/
$ (cd lambda && npm test)

スクリーンショット 2017-10-26 1.24.22.png

盛大なワーニングが。。
「Warning: Application ID is not set」
うーん、おっしゃる通りセットしてないです。手順にもなかったですしね!
App IDとかappIDとかで検索して、どうやらデフォルトが「amzn1.ask.skill.123」らしいことがわかったので、「amzn1.ask.skill.123」でプロジェクト内を検索し、ヒットした箇所を片っ端から直していきます。ここら辺はGithub上の手順書に記載がないので、正しいかどうかわからず、手探りです。

4. ./lambda/src/constants.js

7行目に追加
appId : '自分のスキルのapplication id',
例)
appId : 'amzn1.ask.skill.3696b9a6-a826-472d-944c-b96c364cd798',

「自分のスキルのapplication id」は、Alexa SkillのDeveloper consoleで確認できます。

5. ./lambda/test/launch_request.json

7行目と19行目を
"applicationId": "amzn1.ask.skill.123"

"applicationId": "自分のスキルのapplication id"

6. ./lambda/test/next_intent.json

7行目と21行目を
"applicationId": "amzn1.ask.skill.123"

"applicationId": "自分のスキルのapplication id"

7. ./lambda/test/play_intent.json

7行目と21行目を
"applicationId": "amzn1.ask.skill.123"

"applicationId": "自分のスキルのapplication id"

8. ./lambda/test/playback_stopped.json

12行目を
"applicationId": "amzn1.ask.skill.123"

"applicationId": "自分のスキルのapplication id"

9. ./lambda/test/system_exception.json

6行目を同様に修正。
"applicationId": "amzn1.ask.skill.123"

"applicationId": "自分のスキルのapplication id"

ローカルでテストする(2回目)

$ cd ~/single-stream/
$ (cd lambda && npm test)

image.png

今度はうまくいきました!!
だいぶ疲れたぞー。。

デプロイ

ついにこの時がきました!
Macのターミナルから実行します。

ask deploy

スクリーンショット 2017-10-27 0.36.35.png

エラーが1箇所出たんですが、ジョブは実行を続けて、deployまで完了しました。
そのエラーっていうのはこれ。
- 1行目、「 Error: Cannot find module'./build/Release/DTraceProviderBindings'」

DTraceProviderBindingsって何?

ググったんですが、ちゃんと解決してる例が見当たらず。。
中にはNode.jsのバージョンダウンでなおったという噂もあったり、まだこのCLI自体が出たばっかりなのでバグってるんじゃないか疑惑もあり。後日調べます。。

Alexa Skills開発用コンソールとAWSのLambdaをチェック

まず、開発用コンソールから。
スクリーンショット 2017-10-27 0.39.22.png
あれっ、deploy成功したはずなのに、Interaction Modelの中に入ってない。。 ToT
どういうこと?!

慌てつつ「Back to All skills」リンクを踏んで一覧画面に戻ると、同じアプリ名のものが2個ありました。。。
10月24日と
10月27日。
スクリーンショット 2017-10-27 0.43.12.png

どうやら、ASK CLIでアップしたときに、上書きではなく、新しいAppとして生成してしまったようです。全くそんなつもりは無かったのですが。。
何かパラメタの指定を間違えたのかもしれません。
デバッグで何回もdeployすると思いますが、次回deployするときにも、また新しいIDで生成されたら厄介なので、あとで上書きの方法を調べることにします。が、今は先へ進みます。

次にAWSのダッシュボードでLambda関数ができたかチェックします。
無事にできていました!よかったー(^^)
スクリーンショット 2017-10-27 0.42.00.png

Lambda関数のテスト

上のキャプチャの画面で、「ask-custom-myradio-default」の字のところをクリックします。

「テストイベントの選択..▼」というプルダウンリストで、「テストイベントの設定」を選ぶと、ポップアップが開きます。

「新しいテストイベントの作成」ラジオボタンを選んだ状態で、「イベントテンプレート」のプルダウンリストから、「Alexa Start Session」を選択します。

スクリーンショット 2017-10-27 0.52.05.png

すると自動的にテストコードが生成されます。
「イベント名」に、適当な名前を入力します。
例)start1
スクリーンショット 2017-10-27 0.57.51.png

下までスクロールし、「作成」をクリックします。
元の画面に戻ったら、「テスト」ボタンをクリックします。

すると。。
失敗してしまいました orz

「ログ」のところをクリックすると、Cloud Watchのロググループに遷移します。

The applicationIds don't match: amzn1.ask.skill.[unique-value-here]〜
というメッセージが表示されています。

そりゃそうだ、app IDは新しく発行されたから、さっき書いたものと違って当然です。

Deployするたびに新しく生成せず、上書きするようにしなければ、テストもできないことになっちゃうー

とほほほ

もうこのスキルを作り始めてから6日ほど経っており、その間にわがアーセナルはリーグカップでノリッヂにホームで2-1で勝ち、プレミアリーグでもスウォンジーに2-1で勝っており、その前も含めるとなんと9日間で4勝もしており、、、

ジルーがプシュカシュ賞をとりましたね!おめでとう!おめでとうござりまする!(^^)

自分も早く結果を出さなければ!

ええい、こうなったら。。
新しくできたスキルから元のスキルにInteraction Modelをコピペしてやるのです!

新しく生成されてたスキルから、必要な分をコピー

Alexa skills kitのデベロッパーコンソールに行き、
スキル一覧から、新旧二つのスキルをブラウザ2面で開き、「Interaction Model」で、以下の2箇所の内容をコピーしました。

  • Built-in intents for playback control
     スクリーンショット 2017-10-30 3.14.29.png
     

  • Sample Utterances
     スクリーンショット 2017-10-30 3.19.04.png

そして、「Test」>「Service Simulator」>「Enter Utterance」に「Alexa, open radio taisou day ichi」と入力し、「Ask Radio taisou No.1」ボタンをクリック!

スクリーンショット 2017-10-30 3.23.21.png

JSONが返ってきました!!うおおおお!でけたー!
スクリーンショット 2017-10-30 3.24.38.png

実機テスト

ここまでくればもう実機でも動くはず。そこでMacを離れ、iPhoneを手に持ちます。

Alexa AppでEnableにする

iPhoneのAlexa Appを開く>Skill>your skillを開くと、
開発中でも、同じAmazonアカウントに紐づくものなら一覧に表示されます。

6831C7C1-F262-4571-8D85-A4EDF19E4EB8.png

ただし初期値は「Disable」状態なので、Skillの詳細画面で「Enable」にしてやる必要があります。
以下は変更後。

Amazon Echo dotみたいなアレに呼びかけて鳴らす

ここは日本ですので大人の事情でアレと呼んでいます。そのアレに呼びかけると、ちゃんと答えてくれました。

長かった。。
ASK CLIに関しては釈然としない気持ちでいっぱいです。
が、当初の目的は健康増進のためのスキル作りでしたので、達成と言えるでしょう!
お疲れさまっしたー(^^)

残課題

  • ASK CLIでdeployするたびに新しいApp IDを生成してしまう不具合の回避方法を調べる。
  • DTraceProviderBindingsのエラーの原因を調べる。
  • 「体操したよ」とSNSに報告すると、うっすら承認欲求が満たされてモチベーションがわくかもしんない。

今日のところは以上でーす!

9
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
8