-
Notifications
You must be signed in to change notification settings - Fork 293
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
Server 500 if no valid instances #1053
Comments
I can confirm this issue. I already did some research about it a few weeks ago and found the following: The only way to "fix" it is by identifying the "defective" calendar entries who have a recurrence rule set which doesn't create any instances. Then just delete it on client or on server side and restart the sync. The sync fails because the entry is already available on the server and on the client. Because neither the one on the server nor the one on the client gets automatically deleted it blocks the whole sync process with error 500. As we are using Baikal and the calendar apps for years now I conclude this "issue" got intoduced by some Baikal update or by some changes in Androids calendar app (or some of the third-party ones). I don't think its about the apps but I don''t know for sure. The problem did not happen before I updated to 0.80 of Baikal which I did on 05/31/2021. Maybe we can find the cause together as I need to dig deeper into it because it currently happens again on customer side. |
Some more details on the problem: An example for such an "defective" calendar entry which produces error 500 is as follows:
I think the recurrence rule doesn't make any sense. The event takes place on Monday and the repetition already ends after three days on Thursday but should be repeated weekly on Tuesday, Thursday and Saturday. So the "Saturday" would never match and neither would the weekly. The calendar app which produces those entries is Business Calendar 2 (com.appgenix.bizcal) EDIT: After some more research its more clear to me now. The "weekly" can't be the problem because its the only way to only repeat the event on different days of a week. So the main problem seems to be that the repetition already ends on Thursday but theres also a recurrence set for Saturday which would never match (and therefore produce no valid entry). I will dig deeper into this as this could also point out some "server side problem" with handling such events. EDIT2: Now I digged deeper into it and got the issue: The event date is set to Monday the 4th with a weekly recurrence rule for Tuesday, Thursday and Saturday. But Monday (which is the events date) is explicit excluded from this rule (first thing which is strange) and the recurrence rule ends before the event would be created on Thursday and Saturday (20211007T102959Z). So the only instance which got created by the recurrence rule is the event on Tuesday. Therefore the whole recurrence rule doesn't make any sense. It would be easier to just create the event on Tuesday without any recurrence rule. I also simulated the same setting with an iOS device. But iOS handles recurrences differently and creates own events out of the set recurrence rule and references them between all instances. So this can't be compared to Androids behaviour and therefore it seems to be an Android only issue which originates totally on the user side. |
Ah and the software stack we use is: Baikal 0.80 |
I have the same problem. Luckily I could identify the problem-events from the notification by davx5 (by opening the details in browser). I would be very lucky, if this bug would get fixed! |
Can confirm this issue still present in version 0.10.1 of baikal. In my case this happens often when syncing my work Google Calendar events to my personal Baikal using vdirsyncer. Here are some examples that cause 500 error:
Not expert in VCALENDAR format but when using the DTSTART, DTEND, and RRULE in this test tool these entries do generate events. Which makes me believe baikal implementation that checks for valid instances in recurence rules is not working properly. Would be great if baikal could gracefully handle these cases in future versions. |
Baikal version: 0.6.1
I am using a mixture of software to access a CalDav. Mostly it works very well. However, I have found one issue which I'm not sure where the correct place is to report it - so please advise me if this is not an error in Baikal where you think the error lies.
The software stack for the error is Android 9 with DAVx5 3.3.12-ose and aCalendar+ 2.5.3
It appears slightly hard to reproduce - partly because it relies on syncing and I'm too impatient when testing. However, essentially if I create a recurring event, then change one of the dates so that it is a separate event (edit only this occurence), then delete the recurring portion and the stand-alone portion, (all within aCalendar+) Baikal issues a 500 server error.
The biggest issue is that I now have no event on Android, and DAVx5 will keep trying to delete the event indefinitely. The only way to get out of the loop is to go into another device, and change the event (which hasn't been deleted due to the server error) so that the server version is now newer than the original android version and a sync forces an update of the original device.
I don't know if it is related, but the standalone event seems to retain a RRule (though it not longer repeats) and the repeat is no longer editable in aCalendar+.
The 500 seems to be generated as there are "no valid instances". However, it seems strange to me that this generates a 500, rather than simply deleting the event. Am I missing something. Surely "no valid instances" = "event deleted". It would appear not in Baikal.
Baikal Stack Trace:
[27-Aug-2021 23:44:21 Europe/London] Sabre\VObject\Recur\NoInstancesException: This recurrence rule does not generate any valid instances in PATH\baikal\vendor\sabre\vobject\lib\Recur\EventIterator.php:192
Stack trace:
#0 PATH\baikal\vendor\sabre\dav\lib\CalDAV\Backend\PDO.php(657): Sabre\VObject\Recur\EventIterator->__construct(Object(Sabre\VObject\Component\VCalendar), '53ad89ae-082c-4...')
#1 PATH\baikal\vendor\sabre\dav\lib\CalDAV\Backend\PDO.php(595): Sabre\CalDAV\Backend\PDO->getDenormalizedData('BEGIN:VCALENDAR...')
#2 PATH\baikal\vendor\sabre\dav\lib\CalDAV\CalendarObject.php(107): Sabre\CalDAV\Backend\PDO->updateCalendarObject(3, '53ad89ae-082c-4...', 'BEGIN:VCALENDAR...')
#3 PATH\baikal\vendor\sabre\dav\lib\DAV\Server.php(1133): Sabre\CalDAV\CalendarObject->put('BEGIN:VCALENDAR...')
#4 PATH\baikal\vendor\sabre\dav\lib\DAV\CorePlugin.php(515): Sabre\DAV\Server->updateFile('calendars/MyCal...', 'BEGIN:VCALENDAR...', NULL)
#5 PATH\baikal\vendor\sabre\event\lib\WildcardEmitterTrait.php(96): Sabre\DAV\CorePlugin->httpPut(Object(Sabre\HTTP\Request), Object(Sabre\HTTP\Response))
#6 PATH\baikal\vendor\sabre\dav\lib\DAV\Server.php(464): Sabre\DAV\Server->emit('method:PUT', Array)
#7 PATH\baikal\vendor\sabre\dav\lib\DAV\Server.php(241): Sabre\DAV\Server->invokeMethod(Object(Sabre\HTTP\Request), Object(Sabre\HTTP\Response))
#8 PATH\baikal\vendor\sabre\dav\lib\DAV\Server.php(309): Sabre\DAV\Server->start()
#9 PATH\baikal\Core\Frameworks\Baikal\Core\Server.php(123): Sabre\DAV\Server->exec()
#10 PATH\baikal\html\dav.php(61): Baikal\Core\Server->start()
Really appreciate your pointers and thoughts.
Many thanks.
The text was updated successfully, but these errors were encountered: