A highly unofficial alexa skill for google search
THIS SKILL IS FOR PERSONAL USE ONLY AND IS NOT ENDORSED BY GOOGLE OR AMAZON - DO NOT SUBMIT THIS TO AMAZON FOR CERTIFICATION AS IT WON'T PASS!
This skill is based upon the google search module created for the Adrian Smart assistant project here:-
https://github.com/TheAdrianProject/AdrianSmartAssistant/blob/master/Modules/Google/Google.js
Full credit to the Adrian team for working out the parsing routines for the google search results.
I have wrapped this module so that it can be utilised as an Alexa skill - if you host it on Lambda and call the skill "google" then you will be abe to ask Alexa queries that she does not natively know the answer to such as:-
"Alexa ask google how do I cook a chicken?"
Whilst the skill will return weather forecasts, these will default to either West virginia or Dublin, Ireland (based upon which lambda node you are hosting your skill on) unless you add a location to the search command.
Note - this skill works as a screen reader by parsing the google results page and looking for the google answers boxes at the top of the results page. This may be against the google terms of service so you use it at your own risk.
To run the skill you need to do three things:-
- download the file from github
- deploy the example code in lambda
- configure the Alexa skill to use Lambda.
- Click on the green "Clone or download" button just under the yellow bar
- Click download ZIP
- Unzip the file to a known place on your hard-drive
- Go to http://aws.amazon.com/lambda/ . You will need to set-up an AWS account if you don't have one already ** Make sure you use the same Amazon account that your Echo device is registered to**
- Go to the AWS Console and click on the Lambda link. Go to the drop down "Location" menu and ensure you select US-East(N. Virginia) if you are based in the US or EU(Ireland) if you are based in the UK or Germany. This is important as only these two regions support Alexa. NOTE: the choice of either US or EU is important as it will affect the results that you get. The EU node will provide answers in metric and will be much more UK focused, whilst the US node will be imperial and more US focused.
- Click on the Create a Lambda Function or Get Started Now button.
- Skip the Select Blueprint Tab and just click on the "Configure Triggers" Option on the left hand side
- On the Cofigure Triggers tab Click the dotted box and select "Alexa Skills Kit". Click Next
- Name the Lambda Function "google".
- Select the runtime as Node.js
- Select Code entry type as "Upload a .ZIP file", Select Archive.zip in the src folder and click open.
- Keep the Handler as index.handler (this refers to the main js file in the zip).
- Create a basic execution role and click create (or Choose use an existing role if you have deployed skills previously and then select "lambda_basic_executuion" from the existing role dropdown ).
- Under Advanced settings change the Timeout to 10 seconds
- Click "Next" and review the settings then click "Create Function". This will upload the Archive.zip file to Lambda. This may take a number of minutes depending on your connection speed
- Copy the ARN from the top right to be used later in the Alexa Skill Setup (it's the text after ARN -). Hint - Paste it into notepad or similar
-
Go to the Alexa Console (https://developer.amazon.com/edw/home.html and select Alexa on the top menu)
-
Click "Get Started" under Alexa Skills Kit
-
Click the "Add a New Skill" yellow box.
-
You will now be on the "Skill Information" page.
-
Set "Custom Interaction Model" as the Skill type
-
Select the language as English (US) or English (UK) depending on your location
-
Set "google" as the skill name and "google" as the invocation name, this is what is used to activate your skill. For example you would say: "Alexa, Ask google who is the queen of england."
-
Leave the "Audio Player" setting to "No"
-
Click Next.
-
You will now be on the "Inovation Model" page.
-
Copy the text below into the "Intent Schema" box.
{ "intents": [ { "intent": "SearchIntent", "slots": [ { "name": "search", "type": "SEARCH" } ] }, { "intent": "AMAZON.StopIntent" } ] }
-
Click on the "Add Slot Type" button.
-
Type "SEARCH" into the "Enter Type" field
-
Paste the text below into the "Enter Values" box
who is the queen why is the sky blue
-
Copy the text below amd paste them into the Sample Uterances box.
SearchIntent {search}
-
Click Next.
-
You will now be on the "Configuration" page.
-
Select "AWS Lambda ARN (Amazon Resource Name)" for the skill Endpoint Type.
-
Then pick the most appropriate geographical region (either US or EU as appropriate) and paste the ARN you copied in step 13 from the AWS Lambda setup.
-
Select no for Account Linking
-
Click Next.
-
You can test the skill by typing a query into the Service Simulator field or on your actual Alexa device. There is no need to go anyfurther through the process i.e. submitting for certification.
-
[optional] go back to the skill Information tab and copy the appId. Paste the appId into the index.js file for the variable APP_ID (IMPORTANT make sure it is in quotes).You will need to create a new zip file to upload. Open the src folder, delete Archive.zip and then select all the files in that folder (including the node_modules folder) and then create a new zip file called ARCHIVE.zip. Make sure the zip file is not just the src directory itself, otherwise Lambda function will not work.
The contents of the zip file should be as follows:
```
index.js
AlexaSkill.js
node_modules ( the folder and its contents )
```
Then update the lambda source zip file with this change and upload to lambda again, this step makes sure the lambda function only serves request from authorized source.
NOTE: if you get a lambda response saying : "The remote endpoint could not be called, or the response it returned was invalid." It is likely that you have zipped the src folder and not it's contents
-
It works in the simulator but not on my device. Make sure that the Echo device and AWS/Developer accounts are setup on the SAME Amazon account. If you use multiple users accounts on your echo device then make sure it is not switched to someone else's profile. Also make sure that the language of the skill (EN-GB or EN-US) is the same as the setting on your device
-
I am getting this error message: "The remote endpoint could not be called, or the response it returned was invalid" Sometimes AWS doesn't like the zip. Try uploading it again. If you are creating your own zip then make sure you follow the instructions in step 23
-
I am getting this error message:
{ "errorMessage": "Cannot read property 'application' of undefined", "errorType": "TypeError", "stackTrace": [ "AlexaSkill.execute (/var/task/AlexaSkill.js:86:62)", "exports.handler (/var/task/index.js:303:26)" ] }
You don't actually need to worry about this error - This because you are running the save and test option and haven't configured the test. If you want to make sure it isn't anything else then:- Next to the "test and save" button there is a "Actions" button, press this and select select Configure Test Event. Click on the Sample event template dropdown menu, scroll down and select "Alexa Start Session", then click "Save and Test". NOTE If you have setup the Application ID as per above then you will also need to paste this into the test code.
If it is successful then you should see this output:-
```
{
"version": "1.11",
"response": {
"outputSpeech": {
"type": "PlainText",
"text": "Welcome to Google Search. What are you searching for?"
},
"shouldEndSession": false
},
"sessionAttributes": {}
}
```
This means that the basics of the skill are functioning.
-
I am getting this error message
Task timed out after 3.00 seconds
You have missed one of the steps. To fix this, go to the Configuration Tab in the Lambda Console, click on Advanced settings and in the Timeout box, increase the time to 10 seconds. Then click on Save.
-
My upload to lambda takes ages and then I get a "signature expired" Your PC/Mac's clock is wrong. Turn on the automatically set time option in your control panel
-
Other errors Try uploading the zip file again, and wait a minutes or so before testing in the simulator or on a real device. This sorts out most things. If not drop me a line on this reddit thread https://www.reddit.com/r/amazonecho/comments/5md74z/a_highly_unofficial_alexa_skill_for_google_search/ or raise an issue here on github