From: Ivan Kohler Date: Tue, 25 Jul 2017 06:59:52 +0000 (-0700) Subject: new backoffice API call customer_list_svcs X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=commitdiff_plain;h=e3c22ef5216a090529e99209409a9cc6ff11a1d3 new backoffice API call customer_list_svcs --- diff --git a/FS/FS/API.pm b/FS/FS/API.pm index 6ca2b553b..fd3793d4f 100644 --- a/FS/FS/API.pm +++ b/FS/FS/API.pm @@ -537,6 +537,41 @@ sub customer_info { $cust_main->API_getinfo; } +=item customer_list_svcs OPTION => VALUE, ... + +Returns customer service information. Takes a list of keys and values as +parameters with the following keys: custnum, secret + +=cut + +sub customer_list_svcs { + my( $class, %opt ) = @_; + return _shared_secret_error() unless _check_shared_secret($opt{secret}); + + my $cust_main = qsearchs('cust_main', { 'custnum' => $opt{custnum} }) + or return { 'error' => 'Unknown custnum' }; + + #$cust_main->API_list_svcs; + + #false laziness w/ClientAPI/list_svcs + + my @cust_svc = (); + #my @cust_pkg_usage = (); + #foreach my $cust_pkg ( $p->{'ncancelled'} + # ? $cust_main->ncancelled_pkgs + # : $cust_main->unsuspended_pkgs ) { + foreach my $cust_pkg ( $cust_main->all_pkgs ) { + #next if $pkgnum && $cust_pkg->pkgnum != $pkgnum; + push @cust_svc, @{[ $cust_pkg->cust_svc ]}; #@{[ ]} to force array context + #push @cust_pkg_usage, $cust_pkg->cust_pkg_usage; + } + + return { + 'cust_svc' => [ map $_->API_getinfo, @cust_svc ], + }; + +} + =item location_info Returns location specific information for the customer. Takes a list of keys diff --git a/FS/FS/cust_svc.pm b/FS/FS/cust_svc.pm index 08183b46c..4aa7504f7 100644 --- a/FS/FS/cust_svc.pm +++ b/FS/FS/cust_svc.pm @@ -1197,7 +1197,7 @@ sub API_getinfo { my $self = shift; my $svc_x = $self->svc_x; +{ ( map { $_=>$self->$_ } $self->fields ), - ( map { $svc_x=>$svc_x->$_ } $svc_x->fields ), + ( map { $_=>$svc_x->$_ } $svc_x->fields ), }; } diff --git a/bin/xmlrpc-customer_list_svcs b/bin/xmlrpc-customer_list_svcs new file mode 100755 index 000000000..cdfb51ebf --- /dev/null +++ b/bin/xmlrpc-customer_list_svcs @@ -0,0 +1,26 @@ +#!/usr/bin/perl + +use strict; +use Frontier::Client; +use Data::Dumper; + +my $uri = new URI 'http://localhost:8008/'; + +my $server = new Frontier::Client ( 'url' => $uri ); + +my $result = $server->call( + 'FS.API.customer_list_svcs', + 'secret' => 'sharingiscaring', + 'custnum' => 181318, +); + +#die $result->{'error'} if $result->{'error'}; + +#print Dumper($result); + +foreach my $cust_svc ( @{ $result->{'cust_svc'} } ) { + #print $cust_svc->{mac_addr}."\n" if exists $cust_svc->{mac_addr}; + print $cust_svc->{circuit_id}."\n" if exists $cust_svc->{circuit_id}; +} + +1;