diff -r 000000000000 -r 6f7a81934006 daemon/adduser2.cc --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/daemon/adduser2.cc Wed Jan 16 22:39:43 2008 +0100 @@ -0,0 +1,63 @@ +// Copyright (C) 2000 Bruce Guenter +// +// This program is free software; you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + +#include +#include +#include +#include "daemon.h" + +response build_forwards(const command& args, int offset, + vpwentry* vpw, vdomain& domain) +{ + bool first = true; + for(unsigned i = offset; i < args.count(); i++) { + if(!!args[i]) { + OK_RESPONSE(domain.validate_forward(args[i])); + if(!first) + vpw->forwards = vpw->forwards + mystring::NUL + args[i]; + else { + vpw->forwards = args[i]; + first = false; + } + } + } + RETURN(ok, ""); +} + +CMD(adduser2) + // Usage: adduser2 baseuser-virtuser adminpass newpass dirname [forwards ...] + // If is empty, a null-password is used. + // If is empty, no user directory is created. + // should normally be the same as virtuser. +{ + mystring fulluser = args[0]; + mystring adminpass = args[1]; + mystring newpass = args[2]; + mystring dirname = args[3]; + args[1] = LOG_ADMINPASS; + args[2] = LOG_NEWPASS; + logcommand(args); + + pwentry* pw; + vpwentry* vpw; + OK_RESPONSE(lookup_and_validate(fulluser, pw, vpw, adminpass, false)); + OK_RESPONSE(build_forwards(args, 4, vpw, state->domain)); + if(!!newpass) + vpw->pass = pwcrypt(newpass); + if(!!dirname) + vpw->mailbox = "./" + state->domain.userdir(dirname); + return state->domain.set(vpw, true, vpw->mailbox); +}