Make google actions development project preview persist longer

最后都变了- 提交于 2019-11-27 17:38:06

You can extend the time the development action can be previewed on the web simulator or Google Home device. After you preview the action from API.AI, click on the list of action packages in the web simulator. Then select the "Preview for 24 hours" link for your action package.

Brady Holt

I have found a way to create the Action on API.ai and then preview it indefinitely.

From API.ai:

  1. Open browser dev console (Network tab)
  2. Go to Integrations
  3. Turn on "Actions on Google" integration
  4. Click "Authorize"
  5. Click "Preview"
  6. Inspect the XHR response from https://console.api.ai/api/agent/googleassistant/preview in the Network dev console

    {  
      "status":{  
      "code":401,
      "errorType":"unauthorized",
      "errorDetails":"You are not authorized for this operation. ",
      "webhookTimedOut":false
       }
    }
    
  7. Copy/paste the content of the response into a file called action.json

Then, download and install the gactions CLI from here - gactions CLI and then run this command:

gactions preview --action_package action.json --preview_mins 9999999 \
  --invocation_name [your_own_invocation_name_here] 

The preview_mins value of 9999999 makes the preview effectively indefinite.

Here is a video demonstrating it:

As of today, May 17 2017, the highest voted answer to this question no longer works for new API.ai projects due to the upgrading of the Actions on Google SDK to v2. A similar methodology to @Brady's answer does work still, but they've made it more difficult in some ways (more information needs to be provided to Google, globally unique invocation name despite being a local only test), and better in others (gactions CLI docs now explicitly state that indefinitely timed previews are accepted, and actually is the default if not provided as a argument to the gactions test call).

  1. Create your API.ai agent as normal.
  2. Under the "Integrations" side menu, open the "Actions on Google" settings.
  3. Select "Test" from the bottom of the dialog box that appears (you may need to jump through a few hoops here, signing in, authorizing account access, etc.)
  4. This is where it gets a little different. You now need to create a project on the Actions on Google console. Create or import a project to the console.
  5. The first required step is to supply an action package, which can come from either API.ai or the SDK directly. For API.ai, you have to go back to the Integrations page we were at and press "Update" on your Actions on Google settings. (On the previous version of the SDK, this was labeled "Deploy" and would have made your app public, but don't worry - all this does now is update the AoG console. You publish publicly from the AoG console later if desired).
  6. This new console requires more information outright than was necessary before. I found that the "Assistant app name" can be whatever you want, but the "Pronunciation" is strictly limited to a few conditions (globally unique, reserved keywords, non-brand violating). I also found that I could still invoke using the app name and not just the pronunciation, but I suspect that will be fixed.
  7. Once you've filled out all the necessary information, you can test from API.ai. Return to the AoG settings menu in API.ai and retrieve the response content from the HTTP request preview (just like in @Brady's answer above). Here we hit another difference. The content of the request response can't be used directly in the action.json file as it is wrapped in another object. You want to use only the object from the property actionPackage. (i.e. remove

    {
      "actionPackage": 
    

    from the beginning of the content and

    }
    

    from the end). You should end up with a object of a structure similar to this (but maybe not exactly, it depends on the content of your API.ai agent):

    {
      "actions": [...],
      "types": [...],
      "manifest": {...},
      "conversations": {...}
    }
    
  8. Put this into your action.json file.

  9. Execute the new gactions CLI command:

    gactions test --project <your_project_name_from_aog_console> --action-package action.json
    
  10. Enjoy your local v2 Actions on Google SDK project! And pray Google does not alter the deal any further...

I tried my best to recall what I had to do from memory, so there may be some mistakes in this write up. Hopefully this helps someone.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!