X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Faccess_right.pm;h=13a826f29a82f689c8d31eb0f8e5b1e9835bb961;hp=f8e30d0d24cc5ade7dbc82f1110112df4c80a202;hb=990d718978480aa02b0031a2ec6753e64975fd34;hpb=05eb6fd62056682d8760b85ced91dabd33357a3b diff --git a/FS/FS/access_right.pm b/FS/FS/access_right.pm index f8e30d0d2..13a826f29 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', @@ -235,13 +239,36 @@ sub _upgrade_data { # class method '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', + 'Configuration' => 'Edit global fee definitions', + 'Edit package definition costs' => 'View package definition costs', + 'List prospects' => 'List contacts', + 'List customers' => 'List contacts', + 'Backdate payment' => 'Backdate credit', + 'Generate quotation' => 'Disable quotation', + 'Add on-the-fly void credit reason' => 'Add on-the-fly void reason', + '_ALL' => 'Employee preference telephony integration', + 'Edit customer package dates' => [ 'Change package start date', #4.x + 'Change package contract end date', + ], + 'Resend invoices' => 'Print and mail invoices', + ); + +# 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 ) { @@ -250,7 +277,7 @@ sub _upgrade_data { # class method # grant $new_acl to all groups who have $old_acl for my $group (@all_groups) { - next unless $group->access_right($old_acl); + next unless $old_acl eq '_ALL' || $group->access_right($old_acl); next if $group->access_right($new_acl); my $access_right = FS::access_right->new( { 'righttype' => 'FS::access_group', @@ -267,11 +294,39 @@ sub _upgrade_data { # class method } + # some false laziness with @onetime above, + # but for use when multiple old acls trigger a single new acl + # (keys/values reversed from @onetime, expects arrayref value) + my @onetime_bynew = ( + 'Customize billing during suspension' => [ 'Suspend customer package', 'Suspend customer package later' ], + ); + while ( @onetime_bynew ) { + my( $new_acl, $old_acl ) = splice(@onetime_bynew, 0, 2); + ( 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 one of @old_acl + for my $group (@all_groups) { + next unless grep { $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); + + } + ### ACL_download_report_data if ( !FS::upgrade_journal->is_done('ACL_download_report_data') ) { # grant to everyone for my $group (@all_groups) { + next if $group->access_right('Download report data'); my $access_right = FS::access_right->new( { 'righttype' => 'FS::access_group', 'rightobjnum' => $group->groupnum,