diff --git a/src/elogd.c b/src/elogd.c index c920df5a..29d24d9f 100755 --- a/src/elogd.c +++ b/src/elogd.c @@ -6,6 +6,9 @@ Contents: Web server program for Electronic Logbook ELOG $Log$ + Revision 1.578 2005/03/02 21:03:16 ritt + Implemented email subscriptions for individual logbooks + Revision 1.577 2005/03/02 17:13:24 ritt Implemented central load_password_file() @@ -1218,7 +1221,7 @@ int run_service(void); void show_error(char *error); BOOL enum_user_line(LOGBOOK * lbs, int n, char *user, int size); int get_user_line(char *logbook_name, char *user, char *password, char *full_name, - char *email, char *email_notify); + char *email, BOOL email_notify[1000]); int strbreak(char *str, char list[][NAME_LENGTH], int size, char *brk); int execute_shell(LOGBOOK * lbs, int message_id, char attrib[MAX_N_ATTR][NAME_LENGTH], char att_file[MAX_ATTACHMENTS][256], char *sh_cmd); @@ -9899,8 +9902,8 @@ int save_user_config(LOGBOOK * lbs, char *user, BOOL new_user, BOOL activate) char file_name[256], str[256], *pl, new_pwd[80], new_pwd2[80]; char smtp_host[256], email_addr[256], mail_from[256], subject[256], mail_text[2000]; char admin_user[80], enc_pwd[80], url[256]; - int self_register; - PMXML_NODE xml_tree, node; + int i, self_register; + PMXML_NODE xml_tree, node, subnode; /* check for full name */ if (!isparam("new_full_name") || *getparam("new_full_name") == 0) { @@ -9961,27 +9964,31 @@ int save_user_config(LOGBOOK * lbs, char *user, BOOL new_user, BOOL activate) if (new_user) { node = mxml_add_node(xml_tree, "user", NULL); - if (activate) { - mxml_add_node(node, "name", getparam("new_user_name")); - mxml_add_node(node, "password", getparam("encpwd")); - mxml_add_node(node, "full_name", getparam("new_full_name")); - mxml_add_node(node, "email", getparam("new_user_email")); - mxml_add_node(node, "email_notify", getparam("email_notify")); - } else { - mxml_add_node(node, "name", getparam("new_user_name")); - mxml_add_node(node, "password", new_pwd); - mxml_add_node(node, "full_name", getparam("new_full_name")); - mxml_add_node(node, "email", getparam("new_user_email")); - mxml_add_node(node, "email_notify", getparam("email_notify")); - } + mxml_add_node(node, "full_name", getparam("new_full_name")); + mxml_add_node(node, "name", getparam("new_user_name")); + mxml_add_node(node, "email", getparam("new_user_email")); + if (activate) + mxml_add_node(node, "password", getparam("encpwd")); + else + mxml_add_node(node, "password", new_pwd); + } else { /* replace record */ mxml_replace_subvalue(node, "name", getparam("new_user_name")); mxml_replace_subvalue(node, "password", new_pwd); mxml_replace_subvalue(node, "full_name", getparam("new_full_name")); mxml_replace_subvalue(node, "email", getparam("new_user_email")); - mxml_replace_subvalue(node, "email_notify", getparam("email_notify")); + } + + subnode = mxml_find_node(node, "email_notify"); + if (subnode) + mxml_delete_node(subnode); + mxml_add_node(node, "email_notify", NULL); + for (i=0 ; lb_list[i].name[0] ; i++) { + sprintf(str, "sub_lb%d", i); + if (getparam(str) && atoi(getparam(str))) + mxml_add_node(subnode, "logbook", lb_list[i].name); } getcfg(lbs->name, "Password file", str, sizeof(str)); @@ -10164,9 +10171,10 @@ int ascii_compare(const void *s1, const void *s2) void show_config_page(LOGBOOK * lbs) { - char str[256], user[80], password[80], full_name[80], user_email[80], email_notify[256], logbook[256]; + char str[256], user[80], password[80], full_name[80], user_email[80], logbook[256]; char **user_list; int i, n; + BOOL email_notify[1000]; if (lbs) strcpy(logbook, lbs->name); @@ -10246,7 +10254,7 @@ void show_config_page(LOGBOOK * lbs) /*---- entry form ----*/ - rsprintf("