From e68e85f88922d6678a9c6fc1a7624065e38b7361 Mon Sep 17 00:00:00 2001 From: ivan Date: Fri, 9 Jan 2004 21:10:56 +0000 Subject: [PATCH] adding system_usernames config value --- FS/FS/Conf.pm | 6 ++++++ FS/FS/svc_acct.pm | 16 ++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/FS/FS/Conf.pm b/FS/FS/Conf.pm index b391fe44b..2404e5902 100644 --- a/FS/FS/Conf.pm +++ b/FS/FS/Conf.pm @@ -1151,6 +1151,12 @@ httemplate/docs/config.html 'type' => 'checkbox', }, + { + 'key' => 'system_usernames' + 'section' => 'username', + 'description' => 'A list of system usernames that cannot be edited or removed, one per line. Use a bare username to prohibit modification/deletion of the username in any domain, or username@domain to prohibit modification/deletetion of a specific username and domain.', + 'type' => 'textarea', + }, ); 1; diff --git a/FS/FS/svc_acct.pm b/FS/FS/svc_acct.pm index fce443634..3ddd70a93 100644 --- a/FS/FS/svc_acct.pm +++ b/FS/FS/svc_acct.pm @@ -427,6 +427,8 @@ The corresponding FS::cust_svc record will be deleted as well. sub delete { my $self = shift; + return "can't delete system account" if $self->_check_system; + return "Can't delete an account which is a (svc_forward) source!" if qsearch( 'svc_forward', { 'srcsvc' => $self->svcnum } ); @@ -515,6 +517,8 @@ sub replace { my $error; warn "$me replacing $old with $new\n" if $DEBUG; + return "can't modify system account" if $old->_check_system; + return "Username in use" if $old->username ne $new->username && qsearchs( 'svc_acct', { 'username' => $new->username, @@ -614,6 +618,7 @@ Called by the suspend method of FS::cust_pkg (see L). sub suspend { my $self = shift; + return "can't suspend system account" if $self->_check_system; my %hash = $self->hash; unless ( $hash{_password} =~ /^\*SUSPENDED\* / || $hash{_password} eq '*' @@ -839,6 +844,17 @@ sub check { $self->SUPER::check; } +=item _check_system + +=cut + +sub _check_system { + my $self = shift; + scalar( grep { $self->username eq $_ || $self->email eq $_ } + $conf->config('system_usernames') + ); +} + =item radius Depriciated, use radius_reply instead. -- 2.11.0