daemon/check.cc
changeset 0 6f7a81934006
child 2 b3afb9f1e801
equal deleted inserted replaced
-1:000000000000 0:6f7a81934006
       
     1 // Copyright (C) 1999,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 "daemon.h"
       
    19 #include "misc/itoa.h"
       
    20 
       
    21 CMD(check)
       
    22   // Usage: check username-virtname password
       
    23   // Result: None
       
    24 {
       
    25   mystring fulluser = args[0];
       
    26   mystring password = args[1];
       
    27   args[1] = LOG_PASSWORD;
       
    28   logcommand(args);
       
    29 
       
    30   mystring virtname;
       
    31   pwentry* basepw;
       
    32   if(!lookup_baseuser(fulluser, basepw, virtname))
       
    33     RETURN(err, "Invalid or unknown base user or domain");
       
    34   if(!virtname) {
       
    35     if(basepw->authenticate(password))
       
    36       RETURN(ok, "");
       
    37   }
       
    38   else {
       
    39     state = new saved_state(basepw);
       
    40     vpwentry* virtpw = state->domain.lookup(virtname, false);
       
    41     if(!virtpw)
       
    42       RETURN(err, "Invalid or unknown virtual user");
       
    43     if(virtpw->authenticate(password))
       
    44       RETURN(ok, "");
       
    45   }
       
    46   RETURN(err, "Invalid or incorrect password");
       
    47 }
       
    48