jobisoft / EAS-4-TbSync

[Thunderbird Add-On] The Exchange ActiveSync provider for TbSync to sync contacts, tasks and calendars to Thunderbird.
https://github.com/jobisoft/EAS-4-TbSync/wiki/About:-Provider-for-Exchange-ActiveSync
Mozilla Public License 2.0
192 stars 29 forks source link

attendee.commonName.replace is not a function #248

Closed andreagobetti closed 5 months ago

andreagobetti commented 11 months ago

Your environment

TbSync version: 4.7 EAS-4-TbSync version: 4.7 Thunderbird version: 115.2.3

Expected behavior

Syncing process to work smoothly

Actual behavior

Got a js error while syncing an EAS account, causing "BadItemSkipped::JavaScriptError":

[EventLog] : JavaScriptError
attendee.commonName.replace is not a function

addAttendee@resource:///components/calItemBase.js:643:46
setThunderbirdItemFromWbxml@chrome://eas4tbsync/content/includes/calendarsync.js:155:26
processCommands@chrome://eas4tbsync/content/includes/sync.js:915:49

Steps to reproduce

Sync an event in a calendar via EAS, here is the event that caused the error:

BEGIN:VCALENDAR
PRODID:-//Mozilla.org/NONSGML Mozilla Calendar V1.1//EN
VERSION:2.0
BEGIN:VTIMEZONE
TZID:Europe/Rome
X-TZINFO:Europe/Rome[2023c]
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+004956
TZNAME:Europe/Rome(STD)
DTSTART:18931031T234956
RDATE:18931031T234956
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19160604T000000
RDATE:19160604T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19161001T000000
RDATE:19161001T000000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19170401T000000
RDATE:19170401T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19180310T000000
RDATE:19180310T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19171001T000000
RRULE:FREQ=YEARLY;BYMONTH=10;BYDAY=1MO;UNTIL=19181007T000000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19190302T000000
RDATE:19190302T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19191005T000000
RDATE:19191005T000000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19200321T000000
RDATE:19200321T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19200919T000000
RDATE:19200919T000000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19400615T000000
RDATE:19400615T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19421102T030000
RDATE:19421102T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19430329T020000
RDATE:19430329T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19431004T030000
RDATE:19431004T030000
END:STANDARD
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19440917T030000
RDATE:19440917T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19440403T020000
RRULE:FREQ=YEARLY;BYMONTH=4;BYDAY=1MO;UNTIL=19450402T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19450915T010000
RDATE:19450915T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19460317T020000
RDATE:19460317T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19461006T030000
RDATE:19461006T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19470316T000000
RDATE:19470316T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19471005T010000
RDATE:19471005T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19480229T020000
RDATE:19480229T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19481003T030000
RDATE:19481003T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19660522T000000
RDATE:19660522T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19660925T000000
RDATE:19660925T000000
END:STANDARD
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19670924T010000
RDATE:19670924T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19670528T000000
RRULE:FREQ=YEARLY;BYMONTH=5;BYDAY=-1SU;UNTIL=19680526T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19680922T010000
RDATE:19680922T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19690601T000000
RDATE:19690601T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19700531T000000
RDATE:19700531T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19710523T000000
RDATE:19710523T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19690928T010000
RRULE:FREQ=YEARLY;BYMONTH=9;BYDAY=-1SU;UNTIL=19710926T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19720528T000000
RDATE:19720528T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19721001T010000
RDATE:19721001T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19730603T000000
RDATE:19730603T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19740526T000000
RDATE:19740526T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19750601T000000
RDATE:19750601T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19760530T000000
RDATE:19760530T000000
END:DAYLIGHT
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19770522T000000
RDATE:19770522T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19730930T010000
RRULE:FREQ=YEARLY;BYMONTH=9;BYDAY=-1SU;UNTIL=19770925T010000
END:STANDARD
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19781001T010000
RDATE:19781001T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19780528T000000
RRULE:FREQ=YEARLY;BYMONTH=5;BYDAY=-1SU;UNTIL=19790527T000000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19790930T010000
RDATE:19790930T010000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19800406T020000
RDATE:19800406T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19800928T030000
RRULE:FREQ=YEARLY;BYMONTH=9;BYDAY=-1SU;UNTIL=19950924T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:Europe/Rome(DST)
DTSTART:19810329T020000
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=-1SU;UNTIL=19960331T020000
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:Europe/Rome(STD)
DTSTART:19961027T030000
RDATE:19961027T030000
END:STANDARD
BEGIN:DAYLIGHT
TZOFFSETTO:+020000
TZOFFSETFROM:+010000
TZNAME:(DST)
DTSTART:19970330T020000
RRULE:FREQ=YEARLY;BYMONTH=3;BYDAY=-1SU
END:DAYLIGHT
BEGIN:STANDARD
TZOFFSETTO:+010000
TZOFFSETFROM:+020000
TZNAME:(STD)
DTSTART:19971026T030000
RRULE:FREQ=YEARLY;BYMONTH=10;BYDAY=-1SU
END:STANDARD
END:VTIMEZONE
BEGIN:VEVENT
CREATED:20230921T132903Z
LAST-MODIFIED:20230921T132903Z
DTSTAMP:20230921T132903Z
UID:44201
SUMMARY:Lanciamo i piccioni nel lago
ATTENDEE;RSVP=FALSE;CN=other user;PARTSTAT=NEEDS-ACTION;CUTYPE=INDIVIDU
 AL;ROLE=REQ-PARTICIPANT:mailto:other.user@company.name
DTSTART;TZID=Europe/Rome:20230921T200000
DTEND;TZID=Europe/Rome:20230921T203000
DESCRIPTION:Nuova richiesta di riunione:\n\nOggetto: Lanciamo i piccioni ne
 l lago \nOrganizzatore: "User Name" <user.name@company.name> \n\nOra: 
 Giovedì\, 21 settembre 2023\, 20:00:00 - 20:30:00 GMT +01:00 Amsterdam\, B
 erlino\, Berna\, Roma\, Stoccolma\, Vienna\n \nInvitati: other.user@company
 .name\; user.name@company.name \n\n\n*~*~*~*~*~*~*~*~*~*
X-EAS-BUSYSTATUS:2
TRANSP:OPAQUE
X-EAS-SENSITIVITY:0
CLASS:PUBLIC
X-EAS-RESPONSETYPE:1
BEGIN:VALARM
ACTION:DISPLAY
TRIGGER:-PT5M
DESCRIPTION:Descrizione personalizzata Mozilla
END:VALARM
END:VEVENT
END:VCALENDAR
jobisoft commented 9 months ago

Unable to reproduce. I used this ics file from your data, used Thunderbirds import function to add it to my outlook.com calendar and it synced fine. test.ics.txt

Thunderbird 115.5.1