App-Dochazka-REST
view release on metacpan or search on metacpan
lib/App/Dochazka/REST/Fillup.pm view on Meta::CPAN
Add_Delta_Days
Date_to_Days
Day_of_Week
check_date
);
use JSON qw( decode_json );
use Params::Validate qw( :all );
use Try::Tiny;
BEGIN {
no strict 'refs';
our %attr= (
act_obj => {
type => HASHREF,
isa => 'App::Dochazka::REST::Model::Activity',
optional => 1
},
clobber => { type => BOOLEAN, optional => 1 },
constructor_status => {
type => HASHREF,
isa => 'App::CELL::Status',
optional => 1
},
context => { type => HASHREF, optional => 1 },
date_list => { type => ARRAYREF, optional => 1 },
dry_run => { type => BOOLEAN, optional => 1 },
emp_obj => {
type => HASHREF,
isa => 'App::Dochazka::REST::Model::Employee',
optional => 1
},
intervals => { type => ARRAYREF, optional => 1 },
long_desc => { type => SCALAR, optional => 1 },
remark => { type => SCALAR, optional => 1 },
tiid => { type => SCALAR, optional => 1 },
tsrange => { type => HASHREF, optional => 1 },
tsranges => { type => ARRAYREF, optional => 1 },
);
map {
my $fn = __PACKAGE__ . "::$_";
$log->debug( "BEGIN BLOCK: $_ $fn" );
*{ $fn } =
App::Dochazka::Common::Model::make_accessor( $_, $attr{ $_ } );
} keys %attr;
*{ 'reset' } = sub {
# process arguments
my $self = shift;
my %ARGS = validate( @_, \%attr ) if @_ and defined $_[0];
# Wipe out current TIID
$self->DESTROY;
# Set attributes to run-time values sent in argument list.
# Attributes that are not in the argument list will get set to undef.
map { $self->{$_} = $ARGS{$_}; } keys %attr;
# run the populate function, if any
$self->populate() if $self->can( 'populate' );
# return an appropriate throw-away value
return;
};
*{ 'TO_JSON' } = sub {
my $self = shift;
my $unblessed_copy;
map { $unblessed_copy->{$_} = $self->{$_}; } keys %attr;
return $unblessed_copy;
};
}
my %dow_to_num = (
'MON' => 1,
'TUE' => 2,
'WED' => 3,
'THU' => 4,
'FRI' => 5,
'SAT' => 6,
'SUN' => 7,
);
my %num_to_dow = reverse %dow_to_num;
=head1 NAME
App::Dochazka::REST::Fillup - fillup routines
=head1 SYNOPSIS
use App::Dochazka::REST::Fillup;
...
=head1 METHODS
=head2 populate
Get the next TIID and store in the object
=cut
sub populate {
my $self = shift;
if ( ! exists( $self->{tiid} ) or ! defined( $self->{tiid} ) or $self->{tiid} == 0 ) {
my $ss = _next_tiid();
$log->info( "Got next TIID: $ss" );
$self->{tiid} = $ss;
}
return;
}
( run in 0.562 second using v1.01-cache-2.11-cpan-cdf2f3d4e48 )