\n");
serv_printf("ICAL respond|%s|%s|%s|",
bstr("msgnum"),
@@ -394,7 +396,7 @@ void respond_to_request(void) {
wprintf("
\n");
wDumpContent(1);
}
@@ -407,12 +409,14 @@ void respond_to_request(void) {
void handle_rsvp(void) {
char buf[SIZ];
- output_headers(3);
+ output_headers(1, 1, 2, 0, 0, 0, 0);
+ wprintf("
\n"
);
serv_printf("ICAL handle_rsvp|%s|%s|%s|",
@@ -445,7 +449,7 @@ void handle_rsvp(void) {
wprintf("
wc_roomname);
- wprintf("\">
Return to messages\n");
+ wprintf("\">
Return to messages
\n");
wDumpContent(1);
}
@@ -517,14 +521,17 @@ void display_edit_individual_task(icalcomponent *supplied_vtodo, long msgnum) {
created_new_vtodo = 1;
}
- output_headers(3);
- wprintf("
"
+ output_headers(1, 1, 2, 0, 0, 0, 0);
+ wprintf(" |
\n"
+ "
\n"
);
-
- do_template("beginbox_nt");
+ wprintf("
\n");
wDumpContent(1);
if (created_new_vtodo) {
@@ -598,8 +605,10 @@ void save_individual_task(icalcomponent *supplied_vtodo, long msgnum) {
char buf[SIZ];
int delete_existing = 0;
icalproperty *prop;
- icalcomponent *vtodo;
+ icalcomponent *vtodo, *encaps;
int created_new_vtodo = 0;
+ int i;
+ int sequence = 0;
if (supplied_vtodo != NULL) {
vtodo = supplied_vtodo;
@@ -665,14 +674,50 @@ void save_individual_task(icalcomponent *supplied_vtodo, long msgnum) {
icaltime_from_webform("due")
)
);
-
+
+ /* Give this task a UID if it doesn't have one. */
+ lprintf(9, "Give this task a UID if it doesn't have one.\n");
+ if (icalcomponent_get_first_property(vtodo,
+ ICAL_UID_PROPERTY) == NULL) {
+ generate_uuid(buf);
+ icalcomponent_add_property(vtodo,
+ icalproperty_new_uid(buf)
+ );
+ }
+
+ /* Increment the sequence ID */
+ lprintf(9, "Increment the sequence ID\n");
+ while (prop = icalcomponent_get_first_property(vtodo,
+ ICAL_SEQUENCE_PROPERTY), (prop != NULL) ) {
+ i = icalproperty_get_sequence(prop);
+ lprintf(9, "Sequence was %d\n", i);
+ if (i > sequence) sequence = i;
+ icalcomponent_remove_property(vtodo, prop);
+ icalproperty_free(prop);
+ }
+ ++sequence;
+ lprintf(9, "New sequence is %d. Adding...\n", sequence);
+ icalcomponent_add_property(vtodo,
+ icalproperty_new_sequence(sequence)
+ );
+
+ /*
+ * Encapsulate event into full VCALENDAR component. Clone it first,
+ * for two reasons: one, it's easier to just free the whole thing
+ * when we're done instead of unbundling, but more importantly, we
+ * can't encapsulate something that may already be encapsulated
+ * somewhere else.
+ */
+ lprintf(9, "Encapsulating into full VCALENDAR component\n");
+ encaps = ical_encapsulate_subcomponent(icalcomponent_new_clone(vtodo));
+
/* Serialize it and save it to the message base */
serv_puts("ENT0 1|||4");
serv_gets(buf);
if (buf[0] == '4') {
serv_puts("Content-type: text/calendar");
serv_puts("");
- serv_puts(icalcomponent_as_ical_string(vtodo));
+ serv_puts(icalcomponent_as_ical_string(encaps));
serv_puts("000");
/* Probably not necessary; the server will see the UID
@@ -681,6 +726,7 @@ void save_individual_task(icalcomponent *supplied_vtodo, long msgnum) {
*/
delete_existing = 1;
}
+ icalcomponent_free(encaps);
}
/*
@@ -794,7 +840,7 @@ void display_edit_task(void) {
/* Force change the room if we have to */
if (strlen(bstr("taskrm")) > 0) {
- gotoroom(bstr("taskrm"), 0);
+ gotoroom(bstr("taskrm"));
}
msgnum = atol(bstr("msgnum"));
@@ -884,7 +930,7 @@ void do_freebusy(char *req) {
if (buf[0] != '1') {
wprintf("HTTP/1.0 404 %s\n", &buf[4]);
- output_headers(0);
+ output_headers(0, 0, 0, 0, 0, 0, 0);
wprintf("Content-Type: text/plain\n");
wprintf("\n");
wprintf("%s\n", &buf[4]);