-
Notifications
You must be signed in to change notification settings - Fork 972
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
Hubitat smarthings merge #70
base: master
Are you sure you want to change the base?
Conversation
Remove hubUID restrictions and fix saveState error
Also, disable piston execution logging ( slowing down events page ) and change local requests to use http methods instead of sendHubCommand for faster processing.
Amazing work, thank you for moving forward with the merge. I will set this up for minions to test both sides of the integration (a few of us have Hubitat) and hopefully we'll be able to push it through in the next release within a few weeks. |
It looks like there will be a small bug fix release before this goes into testing. You're on deck for testing once that small release is deployed. |
Sounds good! There probably be another commit to this to iron out some issues I found, and to handle a fw change from Hubitat. |
I've had good results with this pattern for the HubAction and Protocol classes. May not be the most idiomatic way to accomplish it but is this something you can run with? private static Class HubActionClass() {
try {
return 'physicalgraph.device.HubAction' as Class
} catch(all) {
return 'hubitat.device.HubAction' as Class
}
} sendHubCommand(HubActionClass().newInstance(requestParams, null, [callback: localHttpRequestHandler])) Since it is used everywhere to distinguish between ST and HE I would also love to see an abstraction of the hubUID test. Is there a good way to use an alternate self-documenting name like |
Sure thing, I'll pull it in and give it a try next chance I get, along with changing hubUID references. |
This one should be ready to go. There's a lot of performance improvements here for Hubitat and for the first time I was seeing timings lower than SmartThings. Looks like the biggest slowdown in that system was the state size so I've reduced it wherever possible mostly with the stats and logs limits which are now limited to 10 and 50 with a setting that can be changed per piston if the user wants more. Also I removed atomic state loading for both systems after getRuntimeData if the piston didn't have to wait at a semaphore which helped as well. If you get a chance, let me know what you think and if you see any changes that should be made. |
Excellent! Should I include a warning when importing pistons to a Hubitat instance, something along the lines of "Unlike the computing cloud that runs pistons on SmartThings, your Hubitat Elevation hub runs all of your pistons. Please import and test in small batches to avoid overloading your hub." Perhaps if they are importing more than say 20 pistons? Not the best wording since the running pistons are what will overload the hub rather than the import, but if you have any other performance guidelines I think the import feature will be an important place for this reminder. |
I think that's a great idea as I can see users coming to Hubitat using this tool to pull in their ST pistons. I'll get together a list of performance guidelines and send them to you. |
Biggest things in Hubitat as far as performance are below:
I have some changes coming soon to fix timeToday in Hubitat. You can't create a time variable right now with something like '04:00PM'. It will just return the current time. |
Works between Hubitat and Smartthings with just an import change needed at the top of the piston source file.
Adds supports for local fuel streams for both Hubitat (enabled by default) and Smartthings (disabled by default). A container app is made for each fuel stream with a size limit of 95KB. This should eliminate reliance on the custom fuel stream servers and allow users to manage their fuel streams themselves. Import functionality can be added to pull data in from the old servers later if needed.
Add option for custom endpoint for different dashboard urls.
Add option for disabling piston logging in location events. (Significantly slows down Hubitat)
Enables command overrides/overloads. "push" in Hubitat has two methods "push()" with no button number and "push(number)" with a button number. This is also used to fix the "flash" virtual command since there is also a native "flash" command in Hubitat that conflicts with it.
If this is merged the fuel stream PR can be ignored as this supports both local and external fuel streams.