-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;
- size_t bytes = 0;
- size_t thisblock = 0;
struct vCard *v;
int i;
char *key, *value;
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);
+ output_headers(3);
strcpy(whatuser, "");
- sprintf(buf, "MSG0 %s|1", bstr("msgnum") );
+ sprintf(buf, "MSG0 %ld|1", msgnum);
serv_puts(buf);
serv_gets(buf);
if (buf[0] != '1') {
}
}
- total_len = atoi(&buf[4]);
-
-
- sprintf(buf, "OPNA %s|%s", bstr("msgnum"), bstr("partnum") );
+ sprintf(buf, "OPNA %ld|%s", msgnum, partnum);
serv_puts(buf);
serv_gets(buf);
if (buf[0] != '2') {
total_len = atoi(&buf[4]);
serialized_vcard = malloc(total_len + 1);
- while (bytes < total_len) {
- thisblock = 4000;
- if ((total_len - bytes) < thisblock) thisblock = total_len - bytes;
- sprintf(buf, "READ %d|%d", bytes, thisblock);
- serv_puts(buf);
- serv_gets(buf);
- if (buf[0] == '6') {
- thisblock = atoi(&buf[4]);
- serv_read(&serialized_vcard[bytes], thisblock);
- bytes += thisblock;
- }
- else {
- wprintf("Error: %s<BR>\n", &buf[4]);
- }
- }
+
+ read_server_binary(serialized_vcard, total_len);
serv_puts("CLOS");
serv_gets(buf);
extract_token(worktel, value, 0, ';');
}
+ else if (!strcasecmp(key, "email;internet")) {
+ if (inetemail[0] != 0) {
+ strcat(inetemail, "\n");
+ }
+ strcat(inetemail, value);
+ }
+
else {
strcat(extrafields, key);
strcat(extrafields, ":");
vcard_free(v);
/* Display the form */
+ do_template("beginbox_nt");
wprintf("<FORM METHOD=\"POST\" ACTION=\"/submit_vcard\">\n");
- wprintf("<H2><IMG VALIGN=CENTER SRC=\"/static/vcard.gif\">"
+ wprintf("<H2><IMG ALIGN=CENTER SRC=\"/static/vcard.gif\">"
"Contact information for ");
escputs(whatuser);
wprintf("</H2>\n");
"VALUE=\"%s\" MAXLENGTH=\"29\"></TD></TR></TABLE>\n",
worktel);
+ 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("\">\n");
- wprintf("<CENTER>\n");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">");
- wprintf("<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">");
- wprintf("</CENTER></FORM>\n");
+ wprintf("<INPUT TYPE=\"hidden\" NAME=\"return_to\" VALUE=\"");
+ urlescputs(return_to);
+ wprintf("\">\n");
-
+ wprintf("<CENTER>\n"
+ "<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"OK\">"
+ " "
+ "<INPUT TYPE=\"submit\" NAME=\"sc\" VALUE=\"Cancel\">"
+ "</CENTER></FORM>\n"
+ );
+
+ do_template("endbox");
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");
}
sprintf(buf, "ENT0 1|||4||");
- fprintf(stderr, "%s\n", buf);
serv_puts(buf);
serv_gets(buf);
- fprintf(stderr, "%s\n", buf);
if (buf[0] != '4') {
edit_vcard();
return;
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");
- readloop("readnew");
+ if (!strcmp(bstr("return_to"), "/select_user_to_edit")) {
+ select_user_to_edit(NULL, NULL);
+ }
+ else if (!strcmp(bstr("return_to"), "/do_welcome")) {
+ do_welcome();
+ }
+ else {
+ readloop("readnew");
+ }
}