* Finished the thing to edit other users' vCards.
authorArt Cancro <ajc@citadel.org>
Mon, 17 Jun 2002 03:48:44 +0000 (03:48 +0000)
committerArt Cancro <ajc@citadel.org>
Mon, 17 Jun 2002 03:48:44 +0000 (03:48 +0000)
webcit/ChangeLog
webcit/useredit.c
webcit/vcard_edit.c
webcit/webcit.h

index 1e4801c875a569173f64e2dacc88e46a280a7737..47bb566f458d5133a44c9d81b4f29b8989673d01 100644 (file)
@@ -1,4 +1,7 @@
 $Log$
+Revision 323.41  2002/06/17 03:48:44  ajc
+* Finished the thing to edit other users' vCards.
+
 Revision 323.40  2002/06/16 21:49:02  ajc
 * Administratively edit other users' vCards.  Still needs a couple of lines
   of glue code to make it work.
@@ -839,4 +842,3 @@ Sun Dec  6 19:50:55 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
 
 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
        * webserver.c: warning fix
-
index e47ed8dbb6c4ee40a17f3a19d3bd38a91f3b8331..540999254e5f75ed6a9259abceb2b8843b57f557 100644 (file)
@@ -180,7 +180,7 @@ TRYAGAIN:
                return;
        }
 
-       display_addressbook(vcard_msgnum, 0);
+       do_edit_vcard(vcard_msgnum, "1", "/select_user_to_edit");
 }
 
 
index f497730b913a34c58f18e199bb5fd5d3b9692810..1c156cce461e5ac82f252508ab51ebb81479db6f 100644 (file)
@@ -30,7 +30,7 @@
 
 
 
-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;
@@ -78,7 +78,7 @@ void edit_vcard(void) {
        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') {
@@ -98,7 +98,7 @@ void edit_vcard(void) {
        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') {
@@ -259,6 +259,10 @@ void edit_vcard(void) {
        escputs(extrafields);
        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\">");
@@ -270,6 +274,18 @@ void edit_vcard(void) {
 
 
 
+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;
@@ -318,5 +334,10 @@ void submit_vcard(void) {
        serv_puts("end:vcard");
        serv_puts("000");
 
-       readloop("readnew");
+       if (!strcmp(bstr("return_to"), "/select_user_to_edit")) {
+               select_user_to_edit(NULL);
+       }
+       else {
+               readloop("readnew");
+       }
 }
index a3c6f4cb65f9ff5aa753cb7691d18121b1df39c8..b462c3c86ea3850f8cb4d7e3fbac8088b5b905ff 100644 (file)
@@ -292,6 +292,7 @@ void remove_token(char *source, int parmnum, char separator);
 int decode_base64(char *dest, char *source, size_t length);
 char *load_mimepart(long msgnum, char *partnum);
 int pattern2(char *search, char *patn);
+void do_edit_vcard(long, char *, char *);
 void edit_vcard(void);
 void submit_vcard(void);
 void striplt(char *);