1 package FS::ClientAPI::MyAccount;
5 use Digest::MD5 qw(md5_hex);
7 use Cache::SharedMemoryCache; #store in db?
8 use FS::CGI qw(small_custview); #doh
10 use FS::Record qw(qsearchs);
16 use FS::ClientAPI; #hmm
17 FS::ClientAPI->register_handlers(
18 'MyAccount/login' => \&login,
19 'MyAccount/customer_info' => \&customer_info,
20 'MyAccount/invoice' => \&invoice,
24 my $cache = new Cache::SharedMemoryCache();
26 #false laziness w/FS::ClientAPI::passwd::passwd (needs to handle encrypted pw)
30 my $svc_domain = qsearchs('svc_domain', { 'domain' => $p->{'domain'} } )
31 or return { error => "Domain not found" };
34 ( length($p->{'password'}) < 13
35 && qsearchs( 'svc_acct', { 'username' => $p->{'username'},
36 'domsvc' => $svc_domain->svcnum,
37 '_password' => $p->{'password'} } )
39 || qsearchs( 'svc_acct', { 'username' => $p->{'username'},
40 'domsvc' => $svc_domain->svcnum,
41 '_password' => $p->{'password'} } );
43 unless ( $svc_acct ) { return { error => 'Incorrect password.' } }
46 'svcnum' => $svc_acct->svcnum,
49 my $cust_pkg = $svc_acct->cust_svc->cust_pkg;
51 my $cust_main = $cust_pkg->cust_main;
52 $session->{'custnum'} = $cust_main->custnum;
57 $session_id = md5_hex(md5_hex(time(). {}. rand(). $$))
58 } until ( ! defined $cache->get($session_id) ); #just in case
60 $cache->set( $session_id, $session, '1 hour' );
62 return { 'error' => '',
63 'session_id' => $session_id,
69 my $session = $cache->get($p->{'session_id'})
70 or return { 'error' => "Can't resume session" }; #better error message
74 my $custnum = $session->{'custnum'};
76 if ( $custnum ) { #customer record
78 my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
79 or return { 'error' => "unknown custnum $custnum" };
81 $return{balance} = $cust_main->balance;
86 date => time2str("%b %o, %Y", $_->_date),
89 } $cust_main->open_cust_bill;
90 $return{open_invoices} = \@open;
92 my $conf = new FS::Conf;
93 $return{small_custview} =
94 small_custview( $cust_main, $conf->config('defaultcountry') );
96 $return{name} = $cust_main->first. ' '. $cust_main->get('last');
98 } else { #no customer record
100 my $svc_acct = qsearchs('svc_acct', { 'svcnum' => $session->{'svcnum'} } )
101 or die "unknown svcnum";
102 $return{name} = $svc_acct->email;
107 return { 'error' => '',
108 'custnum' => $custnum,
116 my $session = $cache->get($p->{'session_id'})
117 or return { 'error' => "Can't resume session" }; #better error message
119 my $custnum = $session->{'custnum'};
121 my $invnum = $p->{'invnum'};
123 my $cust_bill = qsearchs('cust_bill', { 'invnum' => $invnum,
124 'custnum' => $custnum } )
125 or return { 'error' => "Can't find invnum" };
129 return { 'error' => '',
131 'invoice_text' => join('', $cust_bill->print_text ),