X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2Fbin%2Ffreeside-adduser;h=3976caece193fbc6ddedd419e5444237f8f9dd4e;hb=65fc97717e093e8ff35d6f4c0efd04e3af334c8d;hp=424123226c29356512809635d8f0f0b9b4a030df;hpb=3dc9eeed220e7f7adbf08526f109a190deb3f552;p=freeside.git diff --git a/FS/bin/freeside-adduser b/FS/bin/freeside-adduser index 424123226..3976caece 100644 --- a/FS/bin/freeside-adduser +++ b/FS/bin/freeside-adduser @@ -1,35 +1,83 @@ #!/usr/bin/perl -w -# -# $Id: freeside-adduser,v 1.7 2002-08-25 01:16:30 ivan Exp $ use strict; -use vars qw($opt_h $opt_b $opt_c $opt_s); +use vars qw($opt_s $opt_h $opt_b $opt_c $opt_g $opt_n); +use Fcntl qw(:flock); use Getopt::Std; my $FREESIDE_CONF = "/usr/local/etc/freeside"; -getopts("bch:s:"); +getopts("s:bch:g:n"); die &usage if $opt_c && ! $opt_h; my $user = shift or die &usage; +#if ( -e "$FREESIDE_CONF/mapsecrets" ) { +# open(MAPSECRETS,"<$FREESIDE_CONF/mapsecrets") +# or die "can't open $FREESIDE_CONF/mapsecrets: $!"; +# while () { +# /^(\S+) / or die "unparsable line in mapsecrets: $_"; +# die "user $user already exists\n" if $user eq $1; +# } +# close MAPSECRETS; +#} + if ( $opt_h ) { my @args = ( 'htpasswd' ); push @args, '-b' if $opt_b; push @args, '-c' if $opt_c; push @args, $opt_h, $user; push @args, shift if $opt_b; + warn join(', ', 'htpasswd', @args)."\n"; system(@args) == 0 or die "htpasswd failed: $?"; } -my $secretfile = $opt_s || 'secrets'; +if ( $opt_s ) { + open(MAPSECRETS,">>$FREESIDE_CONF/mapsecrets") + and flock(MAPSECRETS,LOCK_EX) + or die "can't open $FREESIDE_CONF/mapsecrets: $!"; + print MAPSECRETS "$user $opt_s\n"; + close MAPSECRETS or die "can't close $FREESIDE_CONF/mapsecrets: $!"; +} + +### + +exit if $opt_n; + +### + +use FS::UID qw(adminsuidsetup); +use FS::CurrentUser; +use FS::access_user; +use FS::access_usergroup; + +$FS::CurrentUser::upgrade_hack = 1; +#adminsuidsetup $rootuser; +adminsuidsetup $user; + +my $access_user = new FS::access_user { + 'username' => $user, + '_password' => 'notyet', + 'first' => 'Firstname', # $opt_f || + 'last' => 'Lastname', # $opt_l || +}; +my $au_error = $access_user->insert; +die $au_error if $au_error; + +if ( $opt_g ) { -open(MAPSECRETS,">>$FREESIDE_CONF/mapsecrets") - or die "can't open $FREESIDE_CONF/mapsecrets: $!"; -print MAPSECRETS "$user $secretfile\n"; -close MAPSECRETS or die "can't close $FREESIDE_CONF/mapsecrets: $!"; + my $access_usergroup = new FS::access_usergroup { + 'usernum' => $access_user->usernum, + 'groupnum' => $opt_g, + }; + my $aug_error = $access_usergroup->insert; + die $aug_error if $aug_error; + +} + +### sub usage { - die "Usage:\n\n freeside-adduser [ -h htpasswd_file [ -c ] [ -b ] ] [ -s secretfile ] username" + die "Usage:\n\n freeside-adduser [ -h htpasswd_file [ -c ] [ -b ] ] [ -g groupnum ] username [ password ]" } =head1 NAME @@ -38,7 +86,7 @@ freeside-adduser - Command line interface to add (freeside) users. =head1 SYNOPSIS - freeside-adduser [ -h htpasswd_file [ -c ] ] [ -s secretfile ] username + freeside-adduser [ -n ] [ -h htpasswd_file [ -c ] [ -b ] ] [ -g groupnum ] username [ password ] =head1 DESCRIPTION @@ -49,10 +97,16 @@ sales/tech folks) to the web interface, not for adding customer accounts. -c: Passed to htpasswd(1) - -s: Specify an alternate secret file - -b: same as htpasswd(1), probably insecure, not recommended + -g: initial groupnum + + Development/multi-DB options: + + -s: alternate secrets file + + -n: no ACL added, for bootstrapping + =head1 SEE ALSO L(1), base Freeside documentation