moved the user stage out to it's own module since there will be a number of support...
authorerickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 23 Jun 2009 14:37:41 +0000 (14:37 +0000)
committererickson <erickson@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 23 Jun 2009 14:37:41 +0000 (14:37 +0000)
git-svn-id: svn://svn.open-ils.org/ILS/trunk@13443 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/src/perlmods/OpenILS/Application/Actor.pm
Open-ILS/src/perlmods/OpenILS/Application/Actor/Stage.pm [new file with mode: 0644]

index 8930779..87ac173 100644 (file)
@@ -3314,43 +3314,5 @@ sub update_events {
     return {complete => 1};
 }
 
-
-
-__PACKAGE__->register_method (
-       method          => 'create_user_stage',
-       api_name    => 'open-ils.actor.user.stage.create',
-);
-
-sub create_user_stage {
-    my($self, $conn, $user, $mail_addr, $bill_addr) = @_; # more?
-
-    return 0 unless $U->ou_ancestor_setting_value('opac.allow_pending_user');
-    return OpenILS::Event->new('BAD_PARAMS') unless $user;
-
-    my $e = new_editor(xact => 1);
-
-    my $uname = $U->create_uuid_string;
-    $user->usrname($uname);
-
-    $e->create_staging_user_stage($user) or return $e->die_event;
-
-    if($mail_addr) {
-        $mail_addr->usrname($uname);
-        $e->create_staging_mailing_address_stage($mail_addr) or return $e->die_event;
-    }
-
-    if($bill_addr) {
-        $bill_addr->usrname($uname);
-        $e->create_staging_billing_address_stage($bill_addr) or return $e->die_event;
-    }
-
-    $e->commit;
-    $conn->respond_complete($uname);
-
-    $U->create_trigger_event('stgu.create', $user, $user->home_ou);
-    return undef;
-}
-
-
 1;
 
diff --git a/Open-ILS/src/perlmods/OpenILS/Application/Actor/Stage.pm b/Open-ILS/src/perlmods/OpenILS/Application/Actor/Stage.pm
new file mode 100644 (file)
index 0000000..0bb415f
--- /dev/null
@@ -0,0 +1,93 @@
+package OpenILS::Application::Actor::Stage;
+use strict; use warnings;
+use base 'OpenILS::Application';
+use OpenILS::Application::AppUtils;
+use OpenILS::Utils::CStoreEditor q/:funcs/;
+use OpenSRF::Utils::Logger q/$logger/;
+use OpenILS::Utils::Fieldmapper;
+my $U = "OpenILS::Application::AppUtils";
+
+
+__PACKAGE__->register_method (
+       method          => 'create_user_stage',
+       api_name    => 'open-ils.actor.user.stage.create',
+);
+
+sub create_user_stage {
+    my($self, $conn, $user, $mail_addr, $bill_addr) = @_; # more?
+
+    return 0 unless $U->ou_ancestor_setting_value('opac.allow_pending_user');
+    return OpenILS::Event->new('BAD_PARAMS') unless $user;
+
+    my $e = new_editor(xact => 1);
+
+    my $uname = $U->create_uuid_string;
+    $user->usrname($uname);
+
+    $e->create_staging_user_stage($user) or return $e->die_event;
+
+    if($mail_addr) {
+        $mail_addr->usrname($uname);
+        $e->create_staging_mailing_address_stage($mail_addr) or return $e->die_event;
+    }
+
+    if($bill_addr) {
+        $bill_addr->usrname($uname);
+        $e->create_staging_billing_address_stage($bill_addr) or return $e->die_event;
+    }
+
+    $e->commit;
+    $conn->respond_complete($uname);
+
+    $U->create_trigger_event('stgu.create', $user, $user->home_ou);
+    return undef;
+}
+
+__PACKAGE__->register_method (
+       method          => 'user_stage_by_org',
+       api_name    => 'open-ils.actor.user.stage.retrieve.by_org',
+    stream      => 1
+);
+
+sub user_stage_by_org {
+    my($self, $conn, $auth, $org_id, $limit, $offset) = @_;
+
+    my $e = new_editor(authtoken => $auth);
+    return $e->event unless $e->checkauth;
+    $org_id ||= $e->requestor->ws_ou;
+    return $e->event unless $e->allowed('VIEW_USER_STAGE', $org_id);
+
+    $limit ||= 100;
+    $offset ||= 0;
+
+    my $stage_ids = $e->search_staging_user_stage(
+        [
+            {   home_ou => $org_id}, 
+            {   limit => $limit, 
+                offset => $offset, 
+                order_by => {stgu => 'row_id'}
+            }
+        ],
+        {idlist => 1}
+    );
+
+    $conn->respond(flesh_user_stage($e, $_)) for @$stage_ids;
+    return undef;
+}
+
+sub flesh_user_stage {
+    my($e, $row_id) = @_;
+    my $user = $e->retrieve_staging_user_stage($row_id);
+    return {
+        user => $user,
+        billing_address => $e->search_staging_billing_address_stage({usrname => $user->usrname})->[0],
+        mailing_address => $e->search_staging_mailing_address_stage({usrname => $user->usrname})->[0],
+        card => $e->search_staging_card_stage({usrname => $user->usrname})->[0],
+        statcat => $e->search_staging_statcat_stage({usrname => $user->usrname})->[0],
+    };
+}
+
+1;
+
+
+