summaryrefslogtreecommitdiff
path: root/perl
diff options
context:
space:
mode:
authorRuss Allbery <eagle@eyrie.org>2014-07-15 20:46:57 -0700
committerRuss Allbery <rra@stanford.edu>2014-07-15 21:10:57 -0700
commitc2112bf049d193c677335c94b477eb5cadb403ed (patch)
tree2cd6c0d08fe77f1a95949d09a535fb3843a1bd2b /perl
parent443c2c7ac38672f18a14a84e7a220d1a3b1cd545 (diff)
Use DateTime objects uniformly, improve expires parsing
Always use DateTime objects for every date field in the database, and translate them into the local time zone for display when pulling them out of the database. This should provide better portability to different database backends. Change the parsing of expires arguments to use Date::Parse, thus supporting a much broader variety of possible date and time formats and allowing easy conversion to a DateTime object. Document the new dependency. Change-Id: I2ee8eaa6aa6ae9925ac419e49234ec9880d4fe95 Reviewed-on: https://gerrit.stanford.edu/1555 Reviewed-by: Russ Allbery <rra@stanford.edu> Tested-by: Russ Allbery <rra@stanford.edu>
Diffstat (limited to 'perl')
-rw-r--r--perl/lib/Wallet/ACL.pm5
-rw-r--r--perl/lib/Wallet/Object/Base.pm54
2 files changed, 41 insertions, 18 deletions
diff --git a/perl/lib/Wallet/ACL.pm b/perl/lib/Wallet/ACL.pm
index b488b43..a3b0146 100644
--- a/perl/lib/Wallet/ACL.pm
+++ b/perl/lib/Wallet/ACL.pm
@@ -378,8 +378,9 @@ sub history {
my @data = $self->{schema}->resultset('AclHistory')
->search (\%search, \%options);
for my $data (@data) {
- $output .= sprintf ("%s %s ", $data->ah_on->ymd,
- $data->ah_on->hms);
+ my $date = $data->ah_on;
+ $date->set_time_zone ('local');
+ $output .= sprintf ("%s %s ", $date->ymd, $date->hms);
if ($data->ah_action eq 'add' || $data->ah_action eq 'remove') {
$output .= sprintf ("%s %s %s", $data->ah_action,
$data->ah_scheme, $data->ah_identifier);
diff --git a/perl/lib/Wallet/Object/Base.pm b/perl/lib/Wallet/Object/Base.pm
index f1b8b72..4939bf5 100644
--- a/perl/lib/Wallet/Object/Base.pm
+++ b/perl/lib/Wallet/Object/Base.pm
@@ -18,6 +18,7 @@ use warnings;
use vars qw($VERSION);
use DateTime;
+use Date::Parse qw(str2time);
use DBI;
use Text::Wrap qw(wrap);
use Wallet::ACL;
@@ -230,10 +231,20 @@ sub _set_internal {
my %search = (ob_type => $type,
ob_name => $name);
my $object = $self->{schema}->resultset('Object')->find (\%search);
- my $old = $object->get_column ("ob_$attr");
-
- $object->update ({ "ob_$attr" => $value });
- $self->log_set ($attr, $old, $value, $user, $host, $time);
+ my $column = "ob_$attr";
+ my $old = $object->$column;
+ my $new = $value;
+ $object->update ({ $column => $value });
+
+ if (ref ($old) && $old->isa ('DateTime')) {
+ $old->set_time_zone ('local');
+ $old = $old->ymd . q{ } . $old->hms;
+ }
+ if (ref ($new) && $new->isa ('DateTime')) {
+ $new->set_time_zone ('local');
+ $new = $new->ymd . q{ } . $new->hms;
+ }
+ $self->log_set ($attr, $old, $new, $user, $host, $time);
$guard->commit;
};
if ($@) {
@@ -262,7 +273,7 @@ sub _get_internal {
my %search = (ob_type => $type,
ob_name => $name);
my $object = $self->{schema}->resultset('Object')->find (\%search);
- $value = $object->get_column ($attr);
+ $value = $object->$attr;
};
if ($@) {
$self->error ($@);
@@ -334,15 +345,23 @@ sub comment {
sub expires {
my ($self, $expires, $user, $host, $time) = @_;
if ($expires) {
- if ($expires !~ /^\d{4}-\d\d-\d\d( \d\d:\d\d:\d\d)?\z/) {
+ my $seconds = str2time ($expires);
+ unless (defined $seconds) {
$self->error ("malformed expiration time $expires");
return;
}
- return $self->_set_internal ('expires', $expires, $user, $host, $time);
+ my $date = DateTime->from_epoch (epoch => $seconds);
+ return $self->_set_internal ('expires', $date, $user, $host, $time);
} elsif (defined $expires) {
return $self->_set_internal ('expires', undef, $user, $host, $time);
} else {
- return $self->_get_internal ('expires');
+ my $date = $self->_get_internal ('expires');
+ if (defined $date) {
+ $date->set_time_zone ('local');
+ return $date->ymd . q{ } . $date->hms;
+ } else {
+ return;
+ }
}
}
@@ -506,13 +525,14 @@ sub history {
eval {
my %search = (oh_type => $self->{type},
oh_name => $self->{name});
- my %attrs = (order_by => 'oh_on');
+ my %attrs = (order_by => 'oh_id');
my @history = $self->{schema}->resultset('ObjectHistory')
->search (\%search, \%attrs);
for my $history_rs (@history) {
- $output .= sprintf ("%s %s ", $history_rs->oh_on->ymd,
- $history_rs->oh_on->hms);
+ my $date = $history_rs->oh_on;
+ $date->set_time_zone ('local');
+ $output .= sprintf ("%s %s ", $date->ymd, $date->hms);
my $old = $history_rs->oh_old;
my $new = $history_rs->oh_new;
@@ -635,15 +655,15 @@ sub show {
for my $i (0 .. $#attrs) {
my $field = $attrs[$i][0];
my $fieldtext = $attrs[$i][1];
- next unless my $value = $object_rs->get_column ($field);
+ my $value = $object_rs->$field;
+ next unless defined($value);
if ($field eq 'ob_comment' && length ($value) > 79 - 17) {
local $Text::Wrap::columns = 80;
local $Text::Wrap::unexpand = 0;
$value = wrap (' ' x 17, ' ' x 17, $value);
$value =~ s/^ {17}//;
- }
- if ($field eq 'ob_created_by') {
+ } elsif ($field eq 'ob_created_by') {
my @flags = $self->flag_list;
if (not @flags and $self->error) {
return;
@@ -656,8 +676,10 @@ sub show {
return;
}
$output .= $attr_output;
- }
- if ($field =~ /^ob_(owner|acl_)/) {
+ } elsif (ref ($value) && $value->isa ('DateTime')) {
+ $value->set_time_zone ('local');
+ $value = sprintf ("%s %s", $value->ymd, $value->hms);
+ } elsif ($field =~ /^ob_(owner|acl_)/) {
my $acl = eval { Wallet::ACL->new ($value, $self->{schema}) };
if ($acl and not $@) {
$value = $acl->name || $value;