X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Faccess_right.pm;h=aca8c78dbba3bd23fc20d9dc0bfc26bfa63d1850;hb=ba10db86bf541ac72be47de1e9aa5e7d43dc29b6;hp=d2a39aac862d1a1f10f11af9640108263c54c36c;hpb=685f35c0d8d08ea7bbf2ac7cf2db19cdc79fcccf;p=freeside.git diff --git a/FS/FS/access_right.pm b/FS/FS/access_right.pm index d2a39aac8..aca8c78db 100644 --- a/FS/FS/access_right.pm +++ b/FS/FS/access_right.pm @@ -2,7 +2,10 @@ package FS::access_right; use strict; 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); @@ -182,23 +185,86 @@ sub _upgrade_data { # class method my @all_groups = qsearch('access_group', {}); - ### ACL_list_all_customers - if ( !FS::upgrade_journal->is_done('ACL_list_all_customers') ) { - - # grant "List all customers" to all users who have "List customers" - for my $group (@all_groups) { - if ( $group->access_right('List customers') ) { + tie my %onetime, 'Tie::IxHash', + 'List customers' => 'List all customers', + 'List all customers' => 'Advanced customer search', + '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', + 'Post credit' => 'Credit line items', + #'View customer tax exemptions' => 'Edit customer tax exemptions', + 'Edit customer' => 'Edit customer tax exemptions', + 'Edit package definitions' => 'Bulk edit package definitions', + + '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', + ], + + 'Services: Accounts' => 'Services: Accounts: Advanced search', + 'Services: Wireless broadband services' => 'Services: Wireless broadband services: Advanced search', + 'Services: Hardware' => 'Services: Hardware: Advanced search', + 'Services: Phone numbers' => 'Services: Phone numbers: Advanced search', + + 'List rating data' => [ 'Usage: RADIUS sessions', + 'Usage: Call Detail Records (CDRs)', + 'Usage: Unrateable CDRs', + ], + + 'Edit customer' => [ 'Edit customer basics', + 'Edit customer addresses', + 'Edit customer contacts', + ], + + 'Provision customer service' => [ 'Edit password' ], + + 'Financial reports' => [ 'Employees: Commission Report', + 'Employees: Audit Report', + ], + 'Services: Accounts' => 'Services: Cable Subscribers', +; + + foreach my $old_acl ( keys %onetime ) { + + my @new_acl = ref($onetime{$old_acl}) + ? @{ $onetime{$old_acl} } + : ( $onetime{$old_acl} ); + + foreach my $new_acl ( @new_acl ) { + + ( 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) { + 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' => 'List all customers', + 'rightname' => $new_acl, } ); my $error = $access_right->insert; die $error if $error; } - } - FS::upgrade_journal->set_done('ACL_list_all_customers'); + FS::upgrade_journal->set_done($journal); + + } + } ### ACL_download_report_data @@ -212,7 +278,7 @@ sub _upgrade_data { # class method 'rightname' => 'Download report data', } ); my $error = $access_right->insert; - die $error if $error; + warn $error if $error; } FS::upgrade_journal->set_done('ACL_download_report_data');