SmartApp replacement for Shabbat-and-Holiday-Modes!

Unfortunately, since groovy is supposed to stop working, my personal favorite smartapp, shabbat-and-holiday-modes (pretty much a must have for any shabbos-keeping smarthome) will stop working. To combat this, I’ve created an open-source replacement! It’s called smartthings-shabbos-mode and it’s on github. It is significantly harder to implement then the old app, but it’s my only option. Setup instructions are on github. Feel free to check it out!

As noted in the replies to this thread, the exact instructions are liable to change. As smartthings is going through a transition phase, what works an what doesn’t can be different every day. I’m just trying to get an implementation out for all the people who’d otherwise be left hung to dry by the lack of any replacement for the groovy smartapp.

1 Like

An excellent idea, but unfortunately your GitHub instructions tell people to go to the IDE and create a virtual switch there. That is no longer an option in the new architecture. And the IDE itself will be going away soon. :disappointed_relieved:

There are two different options that can be used instead.

First, those who have a smartthings/Aeotec hub can use one of the community-created edge Drivers for virtual devices. You can find those on the quick browse lists in the community – created wiki.

https://thingsthataresmart.wiki/index.php?title=Quick_Browse_Lists_for_Edge_Drivers

Those who don’t have a hub would have to create a virtual device using the API, which is more complicated. And then I’m not sure your new smartapp is going to work for them. So I’m just going to mention that, but not go into the details at this time.

Also note that once the IDE goes away, there will no longer be an official method for adding custom modes like one for Shabbat. You will still be able to do this through the CLI, but again, that’s more complicated. Of course, if someone already had the mode from before, they should be OK.

Thanks! I’ll have to look into updating the instructions. However, I checked today, and I was still able to sign into the IDE and the option to create a simulated switch was still there.

For the moment, yes. But that’s only during this transition phase, and you are trying to provide an after groovy solution, so you need something more long-term.

Importantly, changing the mode is technically not necessary in my implementation. I’ll have to update the exact instructions for the final version of smartthings. But I want to get a working version as soon as possible.

1 Like

Understood, and I think that it’s great that you’ve done this. Not only will it help people looking to solve this specific use case, I think it’s also a very good example of how groovy smart apps might be migrated to the new architecture.

Here’s the announcement about the IDE being shut down. That could happen at any time now.

[quote=“SmartThings, post:1, topic:246280”]
Q1 of 2023
.
· Complete 1st Party DTH migrations
.
· Shutdown Graph IDE
[/quote]

The End of Groovy Has Arrived

Don’t forget that the API browser from @TAustin allows you to create virtual devices and location modes via the browser vs having to use the CLI or the APIs.

3 Likes

I tried using that app a few years ago and never got it working reliably. For years, I now use IFTTT. What I do (in short) is use Hebcal to add a new calendar to my Google account with customized local candle Lighting and havdallah times. Then I use an IFTTT routine to turn on and off a virtual switch when it sees those events start. From there, I trigger the automations, etc.

Step 1
Hebcal to Google calendar

Step 2
Ifttt routine controlling a smartthings device

The only thing to note is that IFTTT no longer guarantees immediate responses for these type of routines, unless you pay for their service.

Step 3. Optional, if you want precise control.
As a workaround, I use this method to find the candle Lighting and havdallah times much earlier than I want them to be controlled. Then, I use the new edge drivers “Virtual Calendar”, to get accurate automations to the minute. For instance, ifttt would trigger a virtual device called “IFTTT Shabbas apx start/end”. Then l would have a routine which triggers a sabbath mode Prep 44 minutes before candle Lighting, another routine at candle Lighting, and a third at the 18 minutes. Then another routine at havdallah.




(misspelling for the speaker notification was intentional, to try to get the most accurate pronunciation.

Have you checked it lately? A number of people have reported that the Ifttt/SmartThings integration is currently broken. IFTTT is working on a new version to work with the new architecture and they rolled it out for a couple of days, but then withdrew it again because they needed to do more work on it.

SmartThings and IFTTT not linking DO NOT UNLINK!

It worked this weekend. I just tested one of my other ifttt routines and they work as well. I did rebuild my ifttt routines last Tuesday or so. Maybe those newer ones work?

1 Like

I recall also having some trouble. I had to add devices via linked services in the smartthings app, and not by creating a new connection in ifttt.
I agree that it may not work well for new ifttt accounts. Hopefully it won’t break.

1 Like

They definitely seem to be working on it, so I expect this just to be a transition glitch and to get straightened out pretty soon. Hopefully.

1 Like

BTW, it appears my current ifttt routines still work, but I can’t edit them. The device menu shows empty. Hopefully they migrate soon to the new system.

1 Like

Nice solution. The best solution is the one that works! I actually tried to replace shabbat-and-holiday-modes with a google calendar/ifttt integration, but I couldn’t quite figure out how to get it to work. That was actually one of the reasons that I coded a replacement. I personally am not a huge fan of IFTTT due to their limitations on their free tier and long latencies. My code actually does not rely on hebcal, and instead calculates all the calendar information locally. The only two points of failure are AWS and smartthings. If we ever become able to run apps directly on the hub, then a local version of this would be the ultimate solution.

2 Likes

Thank you so much for your work on this SmartApp replacement for Shabbat-and-Holiday-Modes. I am attempting to follow your AWS instructions as I too don’t have a linux server available. I am stuck on the instruction:

“In Amazon EventBridge, create a trigger called ‘Run_Shabbos_Mode’ (it must be called exactly that), and schedule it with any valid cron() expression. Set it to run the lambda function ‘Shabbos_Mode_Activator’.”

I just was unsure about when it should be scheduled to run via cron. Can you offer a more specific schedule like you did in your next instruction:

“run the function ‘Get_Sunset_Time’ before the earliest sunset of the year in your location every day.”

Thank you again for posting your work on this as it will truly be helpful!

1 Like

‘Run_Shabbos_Mode’ can be set to literally any valid cron expression, because it’s overwritten everyday anyways by the ‘Get_Sunset_Time’ lambda function. The program works in two steps; at the same time everyday ‘Get_Sunset_Time’ runs, and as implied, calculates the time of sunset in your area. It then schedules ‘Run_Shabbos_Mode’ to run at sunset (through amazon eventbridge), which calculates if the next day is shabbos or yom tov and chooses what to do accordingly.

Therefore, ‘Get_Sunset_Time’ must be set to run before sunset everyday (it could honestly be set to run at 8 in the morning, but I felt that an hour before sunset was a good time), and it will automatically schedule ‘Run_Shabbos_Mode’ to run at sunset. The reason why you need to set a trigger at all for ‘Run_Shabbos_Mode’ is because even though I could create an eventbridge schedule through amazon’s API, I couldn’t figure out how to set ‘Run_Shabbos_Mode’ as the target.

Thank you for your work.

Interesting, did you use someone else’s calculations? Does this account for those located in Israel and the diaspora?

It would be nice if we could customize the end of shabbat times.

I used the excellent python zmanim library, to do completely local calculations for both the sunset time as well as the jewish date. The library natively supports Israel, so I’ve updated it to support that just now. More importantly, in doing so I discovered a critical bug that would cause it to fail whenever shabbos falls out on rosh chodesh (!). I’ve since fixed that, but anyone who has already downloaded the old version should replace it immediately with the updated version!!

As for changing the end time of shabbos, the library only has a built in mode for 72 minutes. With a little bit more work, it should be possible to put in a custom time, so perhaps I’ll do that in the future.

1 Like

@Rafael_M I tried to install this today. After I installed it I wanted to test it so I ran python3 Self_Hosting.py and expected it to switch the Shabbos Mode Switch off but it didn’t. Not sure exactly it is designed to work. I created the virtual device with an edge driver since rather than the IDE, not sure if that has anything to do with it.

The self_hosting.py file only triggers the switch under 2 conditions: When today is a weekday and tomorrow is shabbos (or yom tov), and vice versa. Even then it waits until sunset first. If you’d like to test at least its ability to change the switch from on to off, then you can add main('off') or main('on') (depending on whether you want the switch off or on) to the bottom of the code, and then run it. Note that this test will only work where none of the two conditions delineated above apply.

1 Like