2017-06-12 22:22:34 +00:00
|
|
|
package Pear::LocalLoop::Command::dev_transactions;
|
|
|
|
use Mojo::Base 'Mojolicious::Command';
|
|
|
|
|
|
|
|
use Mojo::Util 'getopt';
|
|
|
|
|
|
|
|
use DateTime;
|
|
|
|
use DateTime::Format::Strptime;
|
|
|
|
|
|
|
|
has description => 'Input Dev Transaction';
|
|
|
|
|
|
|
|
has usage => sub { shift->extract_usage };
|
|
|
|
|
|
|
|
sub run {
|
|
|
|
my ( $self, @args ) = @_;
|
|
|
|
|
|
|
|
getopt \@args,
|
|
|
|
'f|force' => \my $force,
|
|
|
|
'd|date=s' => \my $date,
|
|
|
|
'n|number=i' => \my $number,
|
|
|
|
'c|count=i' => \my $count;
|
|
|
|
|
|
|
|
unless ( defined $force ) {
|
|
|
|
say "Will not do anything without force option";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-06-12 22:30:40 +00:00
|
|
|
if ( ( defined( $ENV{MOJO_MODE} ) && $ENV{MOJO_MODE} eq 'production' ) || $self->app->mode eq 'production' ) {
|
2017-06-12 22:22:34 +00:00
|
|
|
say "Will not run dev data fixtures in production!";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $date_formatter = DateTime::Format::Strptime->new(
|
|
|
|
pattern => '%Y-%m-%d'
|
|
|
|
);
|
|
|
|
|
|
|
|
my $datetime;
|
|
|
|
|
|
|
|
if ( defined $date ) {
|
|
|
|
|
|
|
|
$datetime = $date_formatter->parse_datetime($date);
|
|
|
|
|
|
|
|
unless ( defined $datetime ) {
|
|
|
|
say "Unrecognised date format, please use 'YYYY-MM-DD' Format";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$datetime = DateTime->today;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $schema = $self->app->schema;
|
|
|
|
|
|
|
|
my $user_rs = $schema->resultset('User');
|
|
|
|
|
|
|
|
my $organisation_rs = $user_rs->search({ customer_id => undef });
|
|
|
|
|
|
|
|
my $dtf = $schema->storage->datetime_parser;
|
|
|
|
|
|
|
|
my @organisations = $organisation_rs->all;
|
|
|
|
|
|
|
|
unless ( defined $number ) {
|
|
|
|
$number = 1;
|
|
|
|
}
|
|
|
|
|
2017-06-12 22:30:40 +00:00
|
|
|
unless ( defined $count ) {
|
|
|
|
$count = 0;
|
|
|
|
}
|
|
|
|
|
2017-06-12 22:22:34 +00:00
|
|
|
for my $day_sub ( 0 .. $count ) {
|
2017-06-12 22:30:40 +00:00
|
|
|
$datetime->subtract( days => 1 );
|
2017-06-12 22:22:34 +00:00
|
|
|
for ( 1 .. $number ) {
|
|
|
|
for my $user_result ( $user_rs->all ) {
|
|
|
|
$user_result->create_related( 'transactions', {
|
2017-06-13 21:01:22 +00:00
|
|
|
seller_id => $organisations[int(rand($#organisations))]->organisation_id,
|
2017-06-12 22:22:34 +00:00
|
|
|
value => int(rand(9999)) / 100,
|
|
|
|
proof_image => 'a',
|
|
|
|
submitted_at => $dtf->format_datetime($datetime->clone->add( minutes => int(rand(1440)) )),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
Usage: APPLICATION dev_transactions [OPTIONS]
|
|
|
|
|
|
|
|
Options:
|
|
|
|
|
|
|
|
-f, --force Actually insert the data
|
|
|
|
-d, --date Date to create the transactions on
|
|
|
|
|
|
|
|
=cut
|
|
|
|
|
|
|
|
1;
|