}
my $type = ref($class) || $class;
- my $self = {};
+ my $self = bless({}, $type);
syslog("LOG_DEBUG", "OILS: new OpenILS Patron(%s => %s): searching...", $key, $patron_id);
flesh_fields => {
au => [
"card",
- "standing_penalties",
"addresses",
"billing_address",
"mailing_address",
'profile',
],
- ausp => ['standing_penalty']
}
};
return undef;
}
+ # now grab the user's penalties
+
+ $self->flesh_user_penalties($user, $e) unless $args{slim_user};
+
$self->{editor} = $e;
$self->{user} = $user;
$self->{id} = ($key eq 'barcode') ? $patron_id : $user->card->barcode; # The barcode IS the ID to SIP.
syslog("LOG_DEBUG", "OILS: new OpenILS Patron(%s => %s): found patron : barred=%s, card:active=%s",
$key, $patron_id, $user->barred, $user->card->active );
- bless $self, $type;
return $self;
}
+# grab patron penalties. Only grab non-archived penalties that are for fines,
+# excessive overdues, or otherwise block circluation activity
+sub flesh_user_penalties {
+ my ($self, $user, $e) = @_;
+
+ $user->standing_penalties(
+ $e->search_actor_user_standing_penalty([
+ {
+ usr => $user->id,
+ '-or' => [
+
+ # ignore "archived" penalties
+ {stop_date => undef},
+ {stop_date => {'>' => 'now'}}
+ ],
+
+ org_unit => {
+ in => {
+ select => {
+ aou => [{
+ column => 'id',
+ transform => 'actor.org_unit_ancestors',
+ result_field => 'id'
+ }]
+ },
+ from => 'aou',
+
+ # at this point, there is no concept of "here", so fetch penalties
+ # for the patron's home lib plus ancestors
+ where => {id => $user->home_ou},
+ distinct => 1
+ }
+ },
+
+ # in addition to fines and excessive overdue penalties,
+ # we only care about penalties that result in blocks
+ standing_penalty => {
+ in => {
+ select => {csp => ['id']},
+ from => 'csp',
+ where => {
+ '-or' => [
+ {id => [1,2]}, # fines / overdues
+ {block_list => {'!=' => undef}}
+ ]
+ },
+ }
+ }
+ },
+ ])
+ );
+}
+
sub id {
my $self = shift;
return $self->{id};
sub home_library {
my $self = shift;
- my $lib = $self->{editor}->retrieve_actor_org_unit($self->{user}->home_ou)->shortname;
+ my $lib = OpenILS::SIP::shortname_from_id($self->{user}->home_ou);
syslog('LOG_DEBUG', "OILS: Patron->home_library() = $lib");
return $lib;
}
sub screen_msg {
my $self = shift;
my $u = $self->{user};
+
return 'barred' if $u->barred eq 't';
my $b = 'blocked';
return $b if $u->active eq 'f';
return $b if $u->card->active eq 'f';
- if( $u->standing_penalties ) {
- return $b if
- grep { $_->standing_penalty->name eq 'PATRON_EXCEEDS_OVERDUE_COUNT' }
- @{$u->standing_penalties};
-
- return $b if
- grep { $_->standing_penalty->name eq 'PATRON_EXCEEDS_FINES' }
- @{$u->standing_penalties};
- }
-
- my $expire = DateTime::Format::ISO8601->new->parse_datetime(
- cleanse_ISO8601($u->expire_date));
+ # if we have any penalties at this point, they are blocking penalties
+ return $b if $u->standing_penalties and @{$u->standing_penalties};
+ # has the patron account expired?
+ my $expire = DateTime::Format::ISO8601->new->parse_datetime(cleanse_ISO8601($u->expire_date));
return $b if CORE::time > $expire->epoch;
return 'OK';
return 0;
}
-sub too_many_overdue {
+sub too_many_overdue {
my $self = shift;
- if( $self->{user}->standing_penalties ) {
- return grep { $_->standing_penalty->name eq 'PATRON_EXCEEDS_OVERDUE_COUNT' }
- @{$self->{user}->standing_penalties};
- }
- return 0;
+ return scalar( # PATRON_EXCEEDS_OVERDUE_COUNT
+ grep { $_->standing_penalty == 2 } @{$self->{user}->standing_penalties}
+ );
}
# not completely sure what this means
return 0;
}
-sub excessive_fines {
+sub excessive_fines {
my $self = shift;
- syslog('LOG_DEBUG', 'OILS: Patron->excessive_fines()');
- if( $self->{user}->standing_penalties ) {
- return grep { $_->standing_penalty->name eq 'PATRON_EXCEEDS_FINES' }
- @{$self->{user}->standing_penalties};
- }
- return 0;
+ return scalar( # PATRON_EXCEEDS_FINES
+ grep { $_->standing_penalty == 1 } @{$self->{user}->standing_penalties}
+ );
}
-
# Until someone suggests otherwise, fees and fines are the same
sub excessive_fees {
my $self = shift;
- syslog('LOG_DEBUG', 'OILS: Patron->excessive_fees()');
- if( $self->{user}->standing_penalties ) {
- return grep { $_->standing_penalty->name eq 'PATRON_EXCEEDS_FINES' }
- @{$self->{user}->standing_penalties};
- }
- return 0;
+ return $self->excessive_fines;
}
# not relevant, handled by fines/fees