X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Faccess_right.pm;h=d26db4895bef558dedf6c7a7d55a3f98210ec9ec;hp=d370ba5d14cbdcc816d68eda5091d95b0120a725;hb=e9e0cf0989259b94d9758eceff448666a2e5a5cc;hpb=ded0ab5cac02f099b387de360fb6dd6bd8cbb6b4 diff --git a/FS/FS/access_right.pm b/FS/FS/access_right.pm index d370ba5d1..d26db4895 100644 --- a/FS/FS/access_right.pm +++ b/FS/FS/access_right.pm @@ -5,6 +5,7 @@ use vars qw( @ISA ); use Tie::IxHash; use FS::Record qw( qsearch qsearchs ); use FS::upgrade_journal; +use FS::access_group; @ISA = qw(FS::Record); @@ -187,7 +188,8 @@ sub _upgrade_data { # class method my @all_groups = qsearch('access_group', {}); - tie my %onetime, 'Tie::IxHash', + #tie my %onetime, 'Tie::IxHash', + my @onetime = ( 'List customers' => 'List all customers', 'List all customers' => 'Advanced customer search', 'List packages' => 'Summarize packages', @@ -224,6 +226,8 @@ sub _upgrade_data { # class method 'Services: Hardware' => 'Services: Hardware: Advanced search', 'Services: Phone numbers' => 'Services: Phone numbers: Advanced search', + 'Services: Accounts' => 'Services: Alarm services', + 'List rating data' => [ 'Usage: RADIUS sessions', 'Usage: Call Detail Records (CDRs)', 'Usage: Unrateable CDRs', @@ -232,13 +236,27 @@ sub _upgrade_data { # class method 'Financial reports' => [ 'Employees: Commission Report', 'Employees: Audit Report', ], -; + 'Change customer package' => 'Detach customer package', + 'Services: Accounts' => 'Services: Cable Subscribers', + 'Bulk change customer packages' => 'Bulk move customer services', + 'Configuration' => 'Edit sales people', + 'Configuration' => 'Alarm global configuration', + 'Services: Accounts' => 'Services: Conferencing', + 'Services: Accounts' => 'Services: Video', + 'Edit global package definitions' => 'Edit package definition costs', + 'Add on-the-fly credit reason' => 'Add on-the-fly refund reason', + ); + +# foreach my $old_acl ( keys %onetime ) { +# +# my @new_acl = ref($onetime{$old_acl}) +# ? @{ $onetime{$old_acl} } +# : ( $onetime{$old_acl} ); - foreach my $old_acl ( keys %onetime ) { + while ( @onetime ) { - my @new_acl = ref($onetime{$old_acl}) - ? @{ $onetime{$old_acl} } - : ( $onetime{$old_acl} ); + my( $old_acl, $new_acl ) = splice(@onetime, 0, 2); + my @new_acl = ref($new_acl) ? @$new_acl : ( $new_acl ); foreach my $new_acl ( @new_acl ) {