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,
21 'MyAccount/cancel' => \&cancel,
25 my $cache = new Cache::SharedMemoryCache();
27 #false laziness w/FS::ClientAPI::passwd::passwd (needs to handle encrypted pw)
31 my $svc_domain = qsearchs('svc_domain', { 'domain' => $p->{'domain'} } )
32 or return { error => "Domain not found" };
35 ( length($p->{'password'}) < 13
36 && qsearchs( 'svc_acct', { 'username' => $p->{'username'},
37 'domsvc' => $svc_domain->svcnum,
38 '_password' => $p->{'password'} } )
40 || qsearchs( 'svc_acct', { 'username' => $p->{'username'},
41 'domsvc' => $svc_domain->svcnum,
42 '_password' => $p->{'password'} } );
44 unless ( $svc_acct ) { return { error => 'Incorrect password.' } }
47 'svcnum' => $svc_acct->svcnum,
50 my $cust_pkg = $svc_acct->cust_svc->cust_pkg;
52 my $cust_main = $cust_pkg->cust_main;
53 $session->{'custnum'} = $cust_main->custnum;
58 $session_id = md5_hex(md5_hex(time(). {}. rand(). $$))
59 } until ( ! defined $cache->get($session_id) ); #just in case
61 $cache->set( $session_id, $session, '1 hour' );
63 return { 'error' => '',
64 'session_id' => $session_id,
70 my $session = $cache->get($p->{'session_id'})
71 or return { 'error' => "Can't resume session" }; #better error message
75 my $custnum = $session->{'custnum'};
77 if ( $custnum ) { #customer record
79 my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
80 or return { 'error' => "unknown custnum $custnum" };
82 $return{balance} = $cust_main->balance;
87 date => time2str("%b %o, %Y", $_->_date),
90 } $cust_main->open_cust_bill;
91 $return{open_invoices} = \@open;
93 my $conf = new FS::Conf;
94 $return{small_custview} =
95 small_custview( $cust_main, $conf->config('defaultcountry') );
97 $return{name} = $cust_main->first. ' '. $cust_main->get('last');
99 } else { #no customer record
101 my $svc_acct = qsearchs('svc_acct', { 'svcnum' => $session->{'svcnum'} } )
102 or die "unknown svcnum";
103 $return{name} = $svc_acct->email;
108 return { 'error' => '',
109 'custnum' => $custnum,
117 my $session = $cache->get($p->{'session_id'})
118 or return { 'error' => "Can't resume session" }; #better error message
120 my $custnum = $session->{'custnum'};
122 my $invnum = $p->{'invnum'};
124 my $cust_bill = qsearchs('cust_bill', { 'invnum' => $invnum,
125 'custnum' => $custnum } )
126 or return { 'error' => "Can't find invnum" };
130 return { 'error' => '',
132 'invoice_text' => join('', $cust_bill->print_text ),
139 my $session = $cache->get($p->{'session_id'})
140 or return { 'error' => "Can't resume session" }; #better error message
142 my $custnum = $session->{'custnum'};
144 my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
145 or return { 'error' => "unknown custnum $custnum" };
147 my @errors = $cust_main->cancel;
149 my $error = scalar(@errors) ? join(' / ', @errors) : '';
151 return { 'error' => $error };