Skip to content
This repository has been archived by the owner on May 7, 2020. It is now read-only.

[Feature Request - Rules Engine] Add time condition module #6465

Open
Eseraz opened this issue Nov 5, 2018 · 5 comments
Open

[Feature Request - Rules Engine] Add time condition module #6465

Eseraz opened this issue Nov 5, 2018 · 5 comments

Comments

@Eseraz
Copy link
Contributor

Eseraz commented Nov 5, 2018

When generating rules with Paper UI, I was unable to check if the time was later or earlier than a specific value through the UI. I want to add a module, which makes that possible.

I am guessing that this module would go in the org.eclipse.smarthome.automation.module.timer package?

@maggu2810
Copy link
Contributor

@adimova WDYT?

@Eseraz
Copy link
Contributor Author

Eseraz commented Nov 6, 2018

So the feature seems to work already, but when thinking a bit more about it, maybe it would be better if you could just set two time values without any comparator. So if the first time value is before the second value, it checks if the time is between those two values and if the first time is set after the second value it will check if the time is between 00:00 and the first time value, or the second value and 00:00.

I think i will try that and then I'll figure out how to put this in a pull request, if you think that would be a nice feature :)

Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 7, 2018
This condition checks if the current time is before,
after, or equals to a time, which may be entered by
the user. This is part of eclipse-archived#6465.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 7, 2018
The time of day condition now compares if the current time is
between a start and end time. Also supports wrapping around midnight,
if the end time is before the start time.

This is part of the issue eclipse-archived#6465.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
@Eseraz
Copy link
Contributor Author

Eseraz commented Nov 7, 2018

If you want to have a look, the feature is implemented on this branch.
I will most likely add some tests tomorrow and then make a pull request.

@5iver
Copy link
Contributor

5iver commented Nov 7, 2018

I have a few thoughts...

  1. The end time should be excluded from the interval, to avoid overlaps. One condition ending at 5AM and another starting at 5AM, should not both be true at 5AM.

  2. ZonedDateTime should be used instead of LocalTime, in order to handle Daylight Saving Time transitions. For example, a LocalTime interval from 1:15AM-1:45AM would occur twice on a transition day.

  3. There are several other temporal conditions that could be combined, including what you've done with TimeOfDay. Each condition has a start and end date, but the user input fields could be a free-form manual time, or a DateTime Item with an optional duration offset. I think this would cover most use cases for a Date/Time condition. This might be better as a future feature request, but since the TimeOfDay functionality would be included, implementing it now would save some rework. However, I do not know if any of this is something that would be approved, but it seems like a good addition to me!

Start End
Item1 Item2
Item1 Item1 plus duration
Item1 minus duration Item1
05:00:00 PM (before Item1) Item1
Item1 05:00:00 PM (after Item1)
05:00:00 PM 09:00:00 PM

@Eseraz
Copy link
Contributor Author

Eseraz commented Nov 8, 2018

  1. Good point, I will change that!

  2. True, that is a problem. But would that be solved if i changed that to ZonedDateTime?
    The form only takes hours and minutes as parameters, so if I want to transform start and end time to ZonedDateTime it would probably look like this:

        LocalTime startTime = LocalTime.parse(startTimeConfig).truncatedTo(ChronoUnit.MINUTES);
        LocalTime endTime = LocalTime.parse(endTimeConfig).truncatedTo(ChronoUnit.MINUTES);

        ZonedDateTime currentZonedDateTime = ZonedDateTime.now();
        ZonedDateTime zonedStartTime = ZonedDateTime.of(LocalDate.now(), startTime, ZoneId.systemDefault());
        ZonedDateTime zonedEndTime = ZonedDateTime.of(LocalDate.now(), endTime, ZoneId.systemDefault());

Since I don't have any information about the time zone of start and end time, they always stay the same as the current times time zone. Therefore even with these changes (if I am correct), it would happen twice again, but once it would be 1:15AM-1:45AM in the BST Time Zone and once in the GMT Time Zone. Or am I missing something obvious?

An option might be to check the rules of the time transition using the ZoneRules and ZoneOffsetTransition classes to detect if the condition is affected by daylight savings. So if the check says the time exists twice on this day, the condition will return false the second time it occurs. Or if the check says the condition will not be true at all, since the hour between 1 and 2 AM is missing, the condition will return true from 2 AM to 3 AM instead.
Although I'm afraid this option might be a little complicated...

  1. I think I would like it too, if it had more options in general, but my aim making this was to provide a simple solution for inexperienced users. I want the form to provide a format, so you can not enter an invalid time. Making this a free form would therefore oppose my original intention.

I could easily create a separate condition, that compares a time item with another time item, or a time item to a time in hh:mm format. But I don't want to clutter the available options with too many time conditions.

Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 8, 2018
In order to avoid overlapping of time conditions intervals
the condition will no longer return true, if the current time
is equals to the end of the time interval.

This references eclipse-archived#6465 and was implemented due to a suggestion
of @openhab-5iver.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 18, 2018
The DayOfWeekConditionHandlerTest provides a lot of functionality that may
be used in the TimeOfDayConditionHandlerTest to test feature eclipse-archived#6465. In order to avoid duplicate code, a base class has been extracted.

Also-by: Kai Kreuzer <kai@openhab.org>
Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 18, 2018
This is a test that is based on the previously created
BaseConditionHandlerTest. It is used to test the TimeOfDayConditionHandler
which is part of feature eclipse-archived#6465.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
Eseraz added a commit to Eseraz/smarthome that referenced this issue Nov 20, 2018
Improves eclipse-archived#6465.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
kaikreuzer pushed a commit that referenced this issue Nov 29, 2018
* Added first version of a time of day condition.

Signed-off-by: Dominik Schlierf <dominik.schlierf.esh@web.de>
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

3 participants