0

我正在运行一个 sabre CalDAV 服务器,并且我在 Yosemite 上使用 iCal 作为客户端。现在,我在 iCal 中创建了一个全天重复事件,并使用 Charles Proxy 检查从 iCal 发送的请求正文。创建它发送正确数据的事件:

BEGIN:VCALENDAR
VERSION:2.0
PRODID:-//Apple Inc.//Mac OS X 10.10.1//EN
CALSCALE:GREGORIAN
BEGIN:VEVENT
CREATED:20160404T203206Z
UID:14C144D6-A872-4D24-91C0-783A9979BB9E
RRULE:FREQ=WEEKLY;INTERVAL=1;COUNT=1
DTEND;VALUE=DATE:20160409
TRANSP:TRANSPARENT
SUMMARY:Repeat
DTSTART;VALUE=DATE:20160404
DTSTAMP:20160404T203206Z
SEQUENCE:0
BEGIN:VALARM
X-WR-ALARMUID:A807798B-DE16-4E62-86E9-C204A2B80F76
UID:A807798B-DE16-4E62-86E9-C204A2B80F76
TRIGGER;VALUE=DATE-TIME:19760401T005545Z
ACTION:NONE
END:VALARM
END:VEVENT
END:VCALENDAR

响应:

HTTP/1.1 201 Created
Date: Mon, 04 Apr 2016 20:32:19 GMT
Server: Apache/2.4.10 (Unix) OpenSSL/1.0.1j PHP/5.6.3 mod_perl/2.0.8-dev Perl/v5.16.3
X-Powered-By: PHP/5.6.3
X-Sabre-Version: 3.0.8
Content-Length: 0
ETag: "55c6a353f278653fdd61387395c274df"
Keep-Alive: timeout=5, max=100
Connection: Keep-Alive
Content-Type: text/html; charset=UTF-8

但是,如果我更改重复事件的单个事件并选择仅将更改应用于此事件,iCal 会将旧日历数据发送回服务器而不进行任何更改。如果我将更改应用于所有事件,则会发送正确的数据。如果我选择仅将更改应用于未来事件,它会正确更改旧事件并为未来发生的事件创建新事件。但是话又说回来,一次发生的任何更改都不会发送到服务器。

这只发生在全天活动中。定时事件工作得很好。我是用“count”还是“until”创建规则也没关系。

如果我更改单个事件并从 iCal 导出我的日历,我也会得到正确的日历数据,尽管此数据不会发送到服务器(不同的事件):

BEGIN:VCALENDAR
METHOD:PUBLISH
VERSION:2.0
X-WR-CALNAME:XXX
X-WR-CALDESC:
X-APPLE-CALENDAR-COLOR:#FF9500
X-WR-TIMEZONE:Europe/Berlin
CALSCALE:GREGORIAN
BEGIN:VEVENT
CREATED:20160405T063102Z
UID:68C23C1E-371C-4799-9139-04F0F8FE6F88
RRULE:FREQ=WEEKLY;INTERVAL=1;COUNT=4
DTEND;VALUE=DATE:20160409
TRANSP:TRANSPARENTSUMMARY:hhhhh
DTSTART;VALUE=DATE:20160404
DTSTAMP:20160405T063102Z
SEQUENCE:0
END:VEVENT
BEGIN:VEVENT
CREATED:20160405T063102Z
UID:68C23C1E-371C-4799-9139-04F0F8FE6F88
DTEND;VALUE=DATE:20160421
TRANSP:TRANSPARENT
SUMMARY:hhhhh
DTSTART;VALUE=DATE:20160418
DTSTAMP:20160405T063102Z
SEQUENCE:0
RECURRENCE-ID;VALUE=DATE:20160418
END:VEVENT
END:VCALENDAR

在那里,我终于可以看到带有正确重复 ID 的事件。

有任何想法吗?还有其他人遇到过类似的问题吗?我不知道,这可能是什么原因造成的......

提前致谢!

4

1 回答 1

0

好的,这一定是日历错误。启用调试后,我发现此错误:

Apr  6 12:20:11 XXX.local CalendarAgent[229]: [com.apple.calendar.store.log.ICS] [CaliCalTranslator: Event 97323C3B-753D-46E5-830E-E182BEAA5E0D has invalid instance on date 2016-04-11 00:00:00 +0000.  Filtering]

我将日历从版本 8.0 (2026) 更新到版本 8.0 (2034.9),现在一切都按预期工作。

于 2016-04-06T13:16:15.033 回答