daemon/adduser2.cc
changeset 2 b3afb9f1e801
parent 1 30113bfbe723
child 3 3d1d327cfa68
equal deleted inserted replaced
1:30113bfbe723 2:b3afb9f1e801
     1 // Copyright (C) 2000 Bruce Guenter <bruceg@em.ca>
       
     2 //
       
     3 // This program is free software; you can redistribute it and/or modify
       
     4 // it under the terms of the GNU General Public License as published by
       
     5 // the Free Software Foundation; either version 2 of the License, or
       
     6 // (at your option) any later version.
       
     7 //
       
     8 // This program is distributed in the hope that it will be useful,
       
     9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
       
    10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
       
    11 // GNU General Public License for more details.
       
    12 //
       
    13 // You should have received a copy of the GNU General Public License
       
    14 // along with this program; if not, write to the Free Software
       
    15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
       
    16 
       
    17 #include <config.h>
       
    18 #include <stdlib.h>
       
    19 #include <sys/stat.h>
       
    20 #include "daemon.h"
       
    21 
       
    22 response build_forwards(const command& args, int offset,
       
    23 			vpwentry* vpw, vdomain& domain)
       
    24 {
       
    25   bool first = true;
       
    26   for(unsigned i = offset; i < args.count(); i++) {
       
    27     if(!!args[i]) {
       
    28       OK_RESPONSE(domain.validate_forward(args[i]));
       
    29       if(!first)
       
    30 	vpw->forwards = vpw->forwards + mystring::NUL + args[i];
       
    31       else {
       
    32 	vpw->forwards = args[i];
       
    33 	first = false;
       
    34       }
       
    35     }
       
    36   }
       
    37   RETURN(ok, "");
       
    38 }
       
    39 
       
    40 CMD(adduser2)
       
    41   // Usage: adduser2 baseuser-virtuser adminpass newpass dirname [forwards ...]
       
    42   // If <newpass> is empty, a null-password is used.
       
    43   // If <dirname> is empty, no user directory is created.
       
    44   // <dirname> should normally be the same as virtuser.
       
    45 {
       
    46   mystring fulluser = args[0];
       
    47   mystring adminpass = args[1];
       
    48   mystring newpass = args[2];
       
    49   mystring dirname = args[3];
       
    50   args[1] = LOG_ADMINPASS;
       
    51   args[2] = LOG_NEWPASS;
       
    52   logcommand(args);
       
    53   
       
    54   pwentry* pw;
       
    55   vpwentry* vpw;
       
    56   OK_RESPONSE(lookup_and_validate(fulluser, pw, vpw, adminpass, false));
       
    57   OK_RESPONSE(build_forwards(args, 4, vpw, state->domain));
       
    58   if(!!newpass)
       
    59     vpw->pass = pwcrypt(newpass);
       
    60   if(!!dirname)
       
    61     vpw->mailbox = "./" + state->domain.userdir(dirname);
       
    62   return state->domain.set(vpw, true, vpw->mailbox);
       
    63 }