X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Faccess_right.pm;h=52cae3484297a69d435084525b32a4d890231f30;hb=17b4664d50ba04809cb8b68fa0f3b6146b0c8ff3;hp=719577f50483c3b9d276345678c80a1643e5bd0e;hpb=b3f48204012dd722912dcb3703908bd1eaf6df7b;p=freeside.git diff --git a/FS/FS/access_right.pm b/FS/FS/access_right.pm index 719577f50..52cae3484 100644 --- a/FS/FS/access_right.pm +++ b/FS/FS/access_right.pm @@ -3,6 +3,7 @@ package FS::access_right; use strict; use vars qw( @ISA ); use FS::Record qw( qsearch qsearchs ); +use FS::upgrade_journal; @ISA = qw(FS::Record); @@ -183,9 +184,32 @@ sub _upgrade_data { # class method my @all_groups = qsearch('access_group', {}); my %onetime = ( - 'List customers' => 'List all customers', - 'List packages' => 'Summarize packages', - 'Post payment' => 'Backdate payment', + 'List customers' => 'List all customers', + 'List packages' => 'Summarize packages', + 'Post payment' => 'Backdate payment', + 'Cancel customer package immediately' => 'Un-cancel customer package', + 'Suspend customer package' => 'Suspend customer', + 'Unsuspend customer package' => 'Unsuspend customer', + + 'List services' => [ 'Services: Accounts', + 'Services: Domains', + 'Services: Certificates', + 'Services: Mail forwards', + 'Services: Virtual hosting services', + 'Services: Wireless broadband services', + 'Services: DSLs', + 'Services: Dish services', + 'Services: Hardware', + 'Services: Phone numbers', + 'Services: PBXs', + 'Services: Ports', + 'Services: Mailing lists', + 'Services: External services', + ], + 'List rating data' => [ 'Usage: RADIUS sessions', + 'Usage: Call Detail Records (CDRs)', + 'Usage: Unrateable CDRs', + ], ); foreach my $old_acl ( keys %onetime ) { @@ -196,20 +220,20 @@ sub _upgrade_data { # class method foreach my $new_acl ( @new_acl ) { - ( my $journal = 'ACL_'.lc($new_acl) ) =~ s/ /_/g; + ( my $journal = 'ACL_'.lc($new_acl) ) =~ s/\W/_/g; next if FS::upgrade_journal->is_done($journal); # grant $new_acl to all groups who have $old_acl for my $group (@all_groups) { - if ( $group->access_right($old_acl) ) { - my $access_right = FS::access_right->new( { - 'righttype' => 'FS::access_group', - 'rightobjnum' => $group->groupnum, - 'rightname' => $new_acl, - } ); - my $error = $access_right->insert; - die $error if $error; - } + next unless $group->access_right($old_acl); + next if $group->access_right($new_acl); + my $access_right = FS::access_right->new( { + 'righttype' => 'FS::access_group', + 'rightobjnum' => $group->groupnum, + 'rightname' => $new_acl, + } ); + my $error = $access_right->insert; + die $error if $error; } FS::upgrade_journal->set_done($journal);