1 package OpenILS::Application::Actor::UserGroups;
2 use base 'OpenILS::Application';
3 use strict; use warnings;
4 use OpenILS::Application::AppUtils;
5 use OpenILS::Utils::CStoreEditor q/:funcs/;
6 use OpenSRF::Utils::Logger q/$logger/;
7 use OpenSRF::EX qw(:try);
8 my $U = "OpenILS::Application::AppUtils";
10 sub initialize { return 1; }
14 __PACKAGE__->register_method(
15 method => 'group_money_summary',
16 api_name => 'open-ils.actor.usergroup.members.balance_owed',
22 sub group_money_summary {
23 my($self, $conn, $auth, $group_id) = @_;
24 my $e = new_editor(authtoken=>$auth);
25 return $e->event unless $e->checkauth;
26 return $e->event unless $e->allowed('VIEW_USER');
28 my $users = $e->search_actor_user({usrgroup => $group_id}, {idlist => 1});
31 for my $uid ( @$users ) {
32 push @mous, @{$e->json_query(
34 select => {mous => ['usr', 'balance_owed']},
36 where => { usr => $uid }
45 __PACKAGE__->register_method(
46 method => 'get_users_from_usergroup',
47 api_name => 'open-ils.actor.usergroup.members.retrieve',
50 Returns a list of ids for users that are in the given usergroup
54 sub get_users_from_usergroup {
55 my( $self, $conn, $auth, $usergroup ) = @_;
56 my $e = new_editor(authtoken=>$auth);
57 return $e->event unless $e->checkauth;
58 return $e->event unless $e->allowed('VIEW_USER'); # XXX reley on editor perm
59 return $e->search_actor_user({usrgroup => $usergroup}, {idlist => 1});
64 __PACKAGE__->register_method(
65 method => 'get_leaders_from_usergroup',
66 api_name => 'open-ils.actor.usergroup.leaders.retrieve',
68 Returns a list of ids for users that are leaders of the given usergroup
72 sub get_leaders_from_usergroup {
73 my( $self, $conn, $auth, $usergroup ) = @_;
74 my $e = new_editor(authtoken=>$auth);
75 return $e->event unless $e->checkauth;
76 return $e->event unless $e->allowed('VIEW_USER'); # XXX reley on editor perm
77 my $users = $e->search_actor_user({usrgroup => $usergroup})
82 push( @res, $u->id ) if $u->master_account;
90 __PACKAGE__->register_method(
91 method => 'get_address_members',
92 api_name => 'open-ils.actor.address.members',
94 Returns a list of ids for users that link to the given address
96 @param addrid The address id
100 sub get_address_members {
101 my( $self, $conn, $auth, $addrid ) = @_;
103 my $e = new_editor(authtoken=>$auth);
104 return $e->event unless $e->checkauth;
105 return $e->event unless $e->allowed('VIEW_USER'); # XXX reley on editor perm
107 my $ad = $e->retrieve_actor_user_address($addrid) or return $e->event;
108 my $ma = $e->search_actor_user({mailing_address => $addrid}, {idlist => 1});
109 my $ba = $e->search_actor_user({billing_address => $addrid}, {idlist => 1});
111 my @list = (@$ma, @$ba, $ad->usr);
112 my %dedup = map { $_ => 1 } @list;
113 return [ keys %dedup ];
118 __PACKAGE__->register_method(
119 method => 'reset_group',
120 api_name => 'open-ils.actor.usergroup.new',
122 Gives the requested user a new empty usergroup.
123 @param auth The auth token
124 @param userid The id of the user who needs the new usergroup
125 @param leader If true, this user will be marked as the group leader
130 my( $self, $conn, $auth, $userid, $leader ) = @_;
132 my $e = new_editor(authtoken=>$auth, xact=>1);
133 return $e->die_event unless $e->checkauth;
134 return $e->die_event unless $e->allowed('UPDATE_USER'); # XXX reley on editor perm
136 my $user = $e->retrieve_actor_user($userid) or return $e->die_event;
138 # ask for a new group id
139 my $groupid = $U->storagereq('open-ils.storage.actor.user.group_id.new');
141 $user->usrgroup($groupid);
142 $user->master_account('t') if $leader;
144 $e->update_actor_user($user) or return $e->die_event;