Fully added working import and API
This commit is contained in:
parent
975c348299
commit
95042d7359
3 changed files with 34 additions and 22 deletions
|
@ -18,27 +18,29 @@ sub post_lcc_transactions {
|
||||||
|
|
||||||
return $c->api_validation_error if $validation->has_error;
|
return $c->api_validation_error if $validation->has_error;
|
||||||
|
|
||||||
my $lcc_import_ext_ref = $self->schema->resultset('ExternalReference')->find_or_create({ name => 'LCC CSV' });
|
my $lcc_import_ext_ref = $c->schema->resultset('ExternalReference')->find({ name => 'LCC CSV' });
|
||||||
|
|
||||||
my $lcc_transactions = $lcc_import_ext_ref->search_related('transactions',
|
return 0 unless $lcc_import_ext_ref;
|
||||||
|
|
||||||
|
my $lcc_transactions = $lcc_import_ext_ref->transactions->search(
|
||||||
undef,
|
undef,
|
||||||
{
|
{
|
||||||
page => $validation->param('page') || 1,
|
page => $validation->param('page') || 1,
|
||||||
rows => 10,
|
rows => 10,
|
||||||
order_by => { -desc => 'purchase_time' },
|
join => 'transaction',
|
||||||
},
|
order_by => { -desc => 'transaction.purchase_time' },
|
||||||
);
|
});
|
||||||
|
|
||||||
# purchase_time needs timezone attached to it
|
# purchase_time needs timezone attached to it
|
||||||
my @transaction_list = (
|
my @transaction_list = (
|
||||||
map {{
|
map {{
|
||||||
transaction_external_id => $_->external_id,
|
transaction_external_id => $_->external_id,
|
||||||
seller => $_->transaction->seller->name,
|
seller => $_->transaction->seller->name,
|
||||||
net_value => $_->transaction->value,
|
net_value => $_->transaction->meta->net_value,
|
||||||
gross_value => $_->transaction->meta->gross_value,
|
gross_value => $_->transaction->meta->gross_value,
|
||||||
sales_tax_value => $_->transaction->meta->sales_tax_value,
|
sales_tax_value => $_->transaction->meta->sales_tax_value,
|
||||||
purchase_time => $c->transaction->format_iso_datetime($_->purchase_time),
|
purchase_time => $c->format_iso_datetime($_->transaction->purchase_time),
|
||||||
}} $transactions->all
|
}} $lcc_transactions->all
|
||||||
);
|
);
|
||||||
|
|
||||||
return $c->render( json => {
|
return $c->render( json => {
|
||||||
|
@ -55,7 +57,7 @@ sub post_lcc_suppliers {
|
||||||
|
|
||||||
# TODO give an error if user is not of Lancashire County Council
|
# TODO give an error if user is not of Lancashire County Council
|
||||||
|
|
||||||
my $is_lcc = $self->entity->organisation->count({ name => "Lancashire County Council" });
|
my $is_lcc = $user->entity->organisation->count({ name => "Lancashire County Council" });
|
||||||
|
|
||||||
my $validation = $c->validation;
|
my $validation = $c->validation;
|
||||||
$validation->input( $c->stash->{api_json} );
|
$validation->input( $c->stash->{api_json} );
|
||||||
|
@ -63,7 +65,7 @@ sub post_lcc_suppliers {
|
||||||
|
|
||||||
return $c->api_validation_error if $validation->has_error;
|
return $c->api_validation_error if $validation->has_error;
|
||||||
|
|
||||||
my $lcc_import_ext_ref = $self->schema->resultset('ExternalReference')->find_or_create({ name => 'LCC CSV' });
|
my $lcc_import_ext_ref = $c->schema->resultset('ExternalReference')->find_or_create({ name => 'LCC CSV' });
|
||||||
|
|
||||||
my $lcc_suppliers = $lcc_import_ext_ref->search_related('organisations',
|
my $lcc_suppliers = $lcc_import_ext_ref->search_related('organisations',
|
||||||
undef,
|
undef,
|
||||||
|
@ -74,7 +76,6 @@ sub post_lcc_suppliers {
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
# purchase_time needs timezone attached to it
|
|
||||||
my @supplier_list = (
|
my @supplier_list = (
|
||||||
map {{
|
map {{
|
||||||
supplier_external_id => $_->external_id,
|
supplier_external_id => $_->external_id,
|
||||||
|
|
|
@ -27,15 +27,17 @@ sub _row_to_result {
|
||||||
|
|
||||||
my $address = ( defined $addr2 ? ( $row->{"address line 2"} . ' ' . $addr2) : $row->{"address line 2"} );
|
my $address = ( defined $addr2 ? ( $row->{"address line 2"} . ' ' . $addr2) : $row->{"address line 2"} );
|
||||||
|
|
||||||
$self->external_result->find_or_create_related('organisations', {
|
return if $self->external_result->organisations->find({external_id => $row->{supplier_id}});
|
||||||
external_id => $row->{supplier_id},
|
|
||||||
|
$self->schema->resultset('Entity')->create({
|
||||||
|
type => 'organisation',
|
||||||
organisation => {
|
organisation => {
|
||||||
name => $row->{name},
|
name => $row->{name},
|
||||||
street_name => $row->{"address line 1"},
|
street_name => $row->{"address line 1"},
|
||||||
town => $address,
|
town => $address,
|
||||||
postcode => $row->{post_code},
|
postcode => $row->{post_code},
|
||||||
country => $row->{country_code},
|
country => $row->{country_code},
|
||||||
entity => { type => 'organisation' },
|
external_reference => [ { external_reference => $self->external_result, external_id => $row->{supplier_id} } ],
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,9 +19,15 @@ sub import_csv {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
my $rows = $self->csv_data;
|
my $rows = $self->csv_data;
|
||||||
# my $lcc_org = $self->schema->resultset('Organisation')->find({ name => "Lancashire County Council" });
|
my $lcc_org = $self->schema->resultset('Organisation')->find({
|
||||||
|
name => "Lancashire County Council",
|
||||||
|
street_name => "County Hall"
|
||||||
|
});
|
||||||
|
unless ($lcc_org) {
|
||||||
|
Pear::LocalLoop::Error->throw("Cannot find LCC Organisation, please contact an admin");
|
||||||
|
}
|
||||||
foreach my $row ( @{$rows} ) {
|
foreach my $row ( @{$rows} ) {
|
||||||
$self->_row_to_result($row);
|
$self->_row_to_result($row, $lcc_org);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,6 +44,9 @@ sub _row_to_result {
|
||||||
Pear::LocalLoop::Error->throw("Cannot find an organisation with supplier_id $supplier_id");
|
Pear::LocalLoop::Error->throw("Cannot find an organisation with supplier_id $supplier_id");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
use Devel::Dwarn;
|
||||||
|
Dwarn $organisation->entity->id;
|
||||||
|
|
||||||
my $date_formatter = DateTime::Format::Strptime->new(
|
my $date_formatter = DateTime::Format::Strptime->new(
|
||||||
pattern => '%Y/%m/%d'
|
pattern => '%Y/%m/%d'
|
||||||
);
|
);
|
||||||
|
@ -56,9 +65,9 @@ sub _row_to_result {
|
||||||
external_id => $row->{transaction_id},
|
external_id => $row->{transaction_id},
|
||||||
transaction => {
|
transaction => {
|
||||||
seller => $organisation->entity,
|
seller => $organisation->entity,
|
||||||
buyer => $lcc_org,
|
buyer => $lcc_org->entity,
|
||||||
purchase_time => $paid_date,
|
purchase_time => $paid_date,
|
||||||
value => $row->{net_amount},
|
value => $gross_value * 100000,
|
||||||
meta => {
|
meta => {
|
||||||
gross_value => $gross_value * 100000,
|
gross_value => $gross_value * 100000,
|
||||||
sales_tax_value => $sales_tax_value * 100000,
|
sales_tax_value => $sales_tax_value * 100000,
|
||||||
|
|
Reference in a new issue