-
Notifications
You must be signed in to change notification settings - Fork 71.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
DialogFlow APIv2 Integration (GoogleHome) - dev #4035
Conversation
Revert "Update language.js" (nightscout#3406)
Release/0.10.3
German language change. Name too long, please switch back to BWP
Create issue templates for NS repo
, intentHandler: googleHomeCurrentBasalhandler | ||
}] | ||
}; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What API call changes are needed to have this live in the Home plugin? basalprofile.js should only contain basalprofile code.
, slots: ['iob', 'insulin on board', 'insulin'] | ||
, intentHandler: googleHomeIOBIntentHandler | ||
}] | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same here let's aim to restructure both Home and Alexa so the IOB reporting code is in the plugin, not in iob.js
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alternatively, would it be possible to add a single method that output a string for speech and reuse that in both Home and Alexa? That'd maybe be the cleanest solution?
|
||
if (env.settings.isEnabled('googlehome')) { | ||
ctx.googleHome = require('../plugins/googlehome')(env, ctx); | ||
} | ||
|
||
next( ); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@PieterGit let's try to figure out if there's a way to reduce plugin-specific code in this section
intent: 'LastLoop' | ||
, intentHandler: googleHomeLastLoopHandler | ||
}] | ||
}; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And same here - Home and Alexa code for creating the speech user interface should be in the plugin itself. What'd be acceptable for this file is a generic API method that returns a string for speech, which is reused in both Home and Alexa speech implementations, but custom method for both adds a lot of maintenance burden
@mdomox can you fix @sulkaharo requested changes in the coming days or weeks. These changes should be made before the feature freeze for the 0.11 release. I'm thinking of postponing the freeze to beginning of december, so that we can release 0.11 before xmas. Perhaps @rickfriele can give you some help. The issues raised by @sulkaharo must be resolved before we can merge this to dev. I also would like another Google Home user to confirm it works after you made the changes. |
The issues raised are common with Alexa code. As I understood a restructure is needed. I will try, but I am not 100% confident I can manage it in the timeframe required (I am new to this ). Is there documentation regarding all the variables, objects and functions declared in this project? @PieterGit This is a DialogFlow integration. It can interface to a number of endpoints (Telegram, Viber, Skype, Facebook Messenger, Siri, Google Assistant). GoogleHome in fact, is just another Google Assistant player (as your WearOS smartwatch and Android phone). |
Really can't help with programming, but would like to try to help testing with Google assistant. I don't quite understand if there some code ready to be tested, but if somebody could confirm and help with merging this pull request in my ns, I'm all in. |
@mdomox I postponed this to 0.12 release. This needs better integration. Please ask @sulkaharo for help if you need help. See https://gitter.im/nightscout/public?at=5c093bdf178d7860a194d359 |
@mdomox can you give an update if you have time to work on better Google Home (and maybe also Alexa ) integration? See also this discussion which is relevant for Google Home integration as well: #4168 (comment) |
|
@PieterGit , moreover, now it runs independently, having the speech plugin disabled, since it constantly produces output on every new BG value (something that is not necessary or even annoying). The current implementation is not intrusive, meaning that it does not produce output unless called by the user. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mdomox I did a code review. Thanks for making it more run independently. I found the following issues with this PR:
- There are two codacy issues open on: https://app.codacy.com/app/Nightscout/cgm-remote-monitor/pullRequest?prid=2467222
lib/api/googlehome/index.js
line 10: 'translate' is assigned a value but never used. (no-unused-vars)
var translate = ctx.language.translate;
lib/plugins/googlehome.js
line 2: 'ctx' is defined but never used. (no-unused-vars)
- can't you move the intentHandlers to
lib/plugins/googlehome.js
somehow, e.g. here
https://github.com/nightscout/cgm-remote-monitor/pull/4035/files#diff-5f9a8d56c561357217c992f218e4a7c7R12
you still have quite some plugin specific changes to other core plugins, these should not be added in the core plugin but inside the google home plugin. Your plugin should not touch these files:
lib/plugins/basalprofile.js
lib/plugins/cob.js
lib/plugins/iob.js
lib/plugins/openaps.js
See https://github.com/nightscout/cgm-remote-monitor/pull/4035/files for details.
- Can you add unit tests for the plugin?
- Can you add swagger docs for the
/googlehome
api?
@PieterGit 2nd comment: intentHandlers in those core plugins already exist for Alexa . Why not for DialogFlow? Why is this a show-stopper? 3rd comment: How is this done? Is there a documentation on how to perform those tests? 4rd comment: A doc is in the /doc folder. I wil review it and maybe update it. |
I have tested the mdomox googlehome on Dialogflow and my Googlehome. |
Are we any closer to getting this merged into the master? |
Probably not, given lack of activity in the last few months to address the improvement requests above |
For what it's worth: I may have an alternative to this. I don't mean to diminish the great work @mdomox has been doing and I realize this is not a full alternative. There will always be people who prefer to set up their own DialogFlow Actions. But for those of us who don't feel comfortable doing that, I thought a SaaS might be useful. |
@sulkaharo @PieterGit I'm willing to take a stab at updating this PR (as I have time) to resolve the issues brought up. I'm a full-stack web developer, but unfortunately Node is not a platform I have experience with, so any pointers you can give to help me get started would be great! |
Closing this PR. It will be integrated with the product with #4980 |
No description provided.