-void edit_vcard(void) {
+void do_edit_vcard(long msgnum, char *partnum, char *return_to) {
char buf[SIZ];
char *serialized_vcard = NULL;
size_t total_len = 0;
struct vCard *v;
int i;
char *key, *value;
+ char whatuser[SIZ];
char lastname[SIZ];
char firstname[SIZ];
char country[SIZ];
char hometel[SIZ];
char worktel[SIZ];
+ char inetemail[SIZ];
char extrafields[SIZ];
lastname[0] = 0;
country[0] = 0;
hometel[0] = 0;
worktel[0] = 0;
+ inetemail[0] = 0;
extrafields[0] = 0;
- output_headers(1);
- sprintf(buf, "OPNA %s|%s", bstr("msgnum"), bstr("partnum") );
+ output_headers(3);
+
+ strcpy(whatuser, "");
+ sprintf(buf, "MSG0 %ld|1", msgnum);
+ serv_puts(buf);
+ serv_gets(buf);
+ if (buf[0] != '1') {
+ wDumpContent(1);
+ return;
+ }
+ while (serv_gets(buf), strcmp(buf, "000")) {
+ if (!strncasecmp(buf, "from=", 5)) {
+ strcpy(whatuser, &buf[5]);
+ }
+ else if (!strncasecmp(buf, "node=", 5)) {
+ strcat(whatuser, " @ ");
+ strcat(whatuser, &buf[5]);
+ }
+ }
+
+ total_len = atoi(&buf[4]);
+
+
+ sprintf(buf, "OPNA %ld|%s", msgnum, partnum);
serv_puts(buf);
serv_gets(buf);
if (buf[0] != '2') {
}
else if (!strcasecmp(key, "tel;work")) {
- extract_token(hometel, value, 0, ';');
+ extract_token(worktel, value, 0, ';');
+ }
+
+ else if (!strcasecmp(key, "email;internet")) {
+ if (inetemail[0] != 0) {
+ strcat(inetemail, "\n");
+ }
+ strcat(inetemail, value);
}
else {
vcard_free(v);
/* Display the form */
- wprintf("<FORM METHOD=\"POST\" ACTION=\"/do_FIXME_stuff\">\n");
- wprintf("<H2><IMG VALIGN=CENTER SRC=\"/static/vcard.gif\">"
- "Contact information for FIXME</H2>\n");
+ wprintf("<FORM METHOD=\"POST\" ACTION=\"/submit_vcard\">\n");
+ wprintf("<H2><IMG ALIGN=CENTER SRC=\"/static/vcard.gif\">"
+ "Contact information for ");
+ escputs(whatuser);
+ wprintf("</H2>\n");
- wprintf("Last name: "
- "<INPUT TYPE=\"text\" NAME=\"lastname\" "
- "VALUE=\"%s\" MAXLENGTH=\"29\"><BR>\n",
- lastname);
- wprintf("First name: "
- "<INPUT TYPE=\"text\" NAME=\"firstname\" "
- "VALUE=\"%s\" MAXLENGTH=\"29\"><BR>\n",
- firstname);
- wprintf("Prefix: "
- "<INPUT TYPE=\"text\" NAME=\"prefix\" "
- "VALUE=\"%s\" MAXLENGTH=\"5\"><BR>\n",
+ wprintf("<TABLE border=0><TR>"
+ "<TD>Prefix</TD>"
+ "<TD>First</TD>"
+ "<TD>Middle</TD>"
+ "<TD>Last</TD>"
+ "<TD>Suffix</TD></TR>\n");
+ wprintf("<TR><TD><INPUT TYPE=\"text\" NAME=\"prefix\" "
+ "VALUE=\"%s\" MAXLENGTH=\"5\"></TD>",
prefix);
- wprintf("Suffix: "
- "<INPUT TYPE=\"text\" NAME=\"suffix\" "
- "VALUE=\"%s\" MAXLENGTH=\"10\"><BR><BR>\n",
+ wprintf("<TD><INPUT TYPE=\"text\" NAME=\"firstname\" "
+ "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+ firstname);
+ wprintf("<TD><INPUT TYPE=\"text\" NAME=\"middlename\" "
+ "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+ middlename);
+ wprintf("<TD><INPUT TYPE=\"text\" NAME=\"lastname\" "
+ "VALUE=\"%s\" MAXLENGTH=\"29\"></TD>",
+ lastname);
+ wprintf("<TD><INPUT TYPE=\"text\" NAME=\"suffix\" "
+ "VALUE=\"%s\" MAXLENGTH=\"10\"></TD></TR></TABLE>\n",
suffix);
- wprintf("<TABLE border=0><TR><TD>Address - PO box; optional:</TD>"
+ wprintf("<TABLE border=0><TR><TD>PO box (optional):</TD>"
"<TD><INPUT TYPE=\"text\" NAME=\"pobox\" "
"VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
pobox);
- wprintf("<TR><TD>Street:</TD>"
+ wprintf("<TR><TD>Address line 1:</TD>"
"<TD><INPUT TYPE=\"text\" NAME=\"extadr\" "
"VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
extadr);
- wprintf("<TR><TD> </TD>"
+ wprintf("<TR><TD>Address line 2:</TD>"
"<TD><INPUT TYPE=\"text\" NAME=\"street\" "
"VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR>\n",
street);
"VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR></TABLE>\n",
worktel);
- wprintf("<TEXTAREA NAME=\"extrafields\" ROWS=10 COLS=80 WIDTH=80>");
+ wprintf("<TABLE border=0><TR><TD>Internet e-mail addresses:<BR>"
+ "<FONT size=-2>For addresses in the Citadel directory, "
+ "the topmost address will be used in outgoing mail."
+ "</FONT></TD><TD>"
+ "<TEXTAREA NAME=\"inetemail\" ROWS=5 COLS=40 WIDTH=40>");
+ escputs(inetemail);
+ wprintf("</TEXTAREA></TD></TR></TABLE><BR>\n");
+
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"extrafields\" VALUE=\"");
escputs(extrafields);
- wprintf("</TEXTAREA><BR>\n");
+ wprintf("\">\n");
+
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"return_to\" VALUE=\"");
+ urlescputs(return_to);
+ wprintf("\">\n");
+
+ wprintf("<CENTER>\n");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
+ wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
+ wprintf("</CENTER></FORM>\n");
wDumpContent(1);
}
+
+
+
+void edit_vcard(void) {
+ long msgnum;
+ char *partnum;
+
+ msgnum = atol(bstr("msgnum"));
+ partnum = bstr("partnum");
+ do_edit_vcard(msgnum, partnum, "");
+}
+
+
+
+
+void submit_vcard(void) {
+ char buf[SIZ];
+ int i;
+
+ if (strcmp(bstr("sc"), "OK")) {
+ readloop("readnew");
+ return;
+ }
+
+ sprintf(buf, "ENT0 1|||4||");
+ serv_puts(buf);
+ serv_gets(buf);
+ if (buf[0] != '4') {
+ edit_vcard();
+ return;
+ }
+
+ serv_puts("Content-type: text/x-vcard");
+ serv_puts("");
+ serv_puts("begin:vcard");
+ serv_printf("n:%s;%s;%s;%s;%s",
+ bstr("lastname"),
+ bstr("firstname"),
+ bstr("middlename"),
+ bstr("prefix"),
+ bstr("suffix") );
+ serv_printf("adr:%s;%s;%s;%s;%s;%s;%s",
+ bstr("pobox"),
+ bstr("extadr"),
+ bstr("street"),
+ bstr("city"),
+ bstr("state"),
+ bstr("zipcode"),
+ bstr("country") );
+ serv_printf("tel;home:%s", bstr("hometel") );
+ serv_printf("tel;work:%s", bstr("worktel") );
+
+ for (i=0; i<num_tokens(bstr("inetemail"), '\n'); ++i) {
+ extract_token(buf, bstr("inetemail"), i, '\n');
+ if (strlen(buf) > 0) {
+ serv_printf("email;internet:%s", buf);
+ }
+ }
+
+ serv_printf("%s", bstr("extrafields") );
+ serv_puts("end:vcard");
+ serv_puts("000");
+
+ if (!strcmp(bstr("return_to"), "/select_user_to_edit")) {
+ select_user_to_edit(NULL, NULL);
+ }
+ else {
+ readloop("readnew");
+ }
+}