1 package FS::SelfService;
4 use vars qw($VERSION @ISA @EXPORT_OK $socket %autoload $tag);
10 use Storable qw(nstore_fd fd_retrieve);
14 @ISA = qw( Exporter );
16 $socket = "/usr/local/freeside/selfservice_socket";
17 $socket .= '.'.$tag if defined $tag && length($tag);
19 #maybe should ask ClientAPI for this list
21 'passwd' => 'passwd/passwd',
22 'chfn' => 'passwd/passwd',
23 'chsh' => 'passwd/passwd',
24 'login' => 'MyAccount/login',
25 'customer_info' => 'MyAccount/customer_info',
26 'invoice' => 'MyAccount/invoice',
27 'cancel' => 'MyAccount/cancel',
28 'signup_info' => 'Signup/signup_info',
29 'new_customer' => 'Signup/new_customer',
31 @EXPORT_OK = keys %autoload;
33 $ENV{'PATH'} ='/usr/bin:/usr/ucb:/bin';
34 $ENV{'SHELL'} = '/bin/sh';
35 $ENV{'IFS'} = " \t\n";
38 $ENV{'BASH_ENV'} = '';
40 my $freeside_uid = scalar(getpwnam('freeside'));
41 die "not running as the freeside user\n" if $> != $freeside_uid;
45 FS::SelfService - Freeside self-service API
51 Use this API to implement your own client "self-service" module.
53 If you just want to customize the look of the existing "self-service" module,
62 Returns the empty value on success, or an error message on errors.
66 foreach my $autoload ( keys %autoload ) {
77 $param->{_packet} = \''. $autoload{$autoload}. '\';
79 simple_packet($param);
89 socket(SOCK, PF_UNIX, SOCK_STREAM, 0) or die "socket: $!";
90 connect(SOCK, sockaddr_un($socket)) or die "connect: $!";
91 nstore_fd($packet, \*SOCK) or die "can't send packet: $!";
94 #shoudl trap: Magic number checking on storable file failed at blib/lib/Storable.pm (autosplit into blib/lib/auto/Storable/fd_retrieve.al) line 337, at /usr/local/share/perl/5.6.1/FS/SelfService.pm line 71
96 #block until there is a message on socket
97 # my $w = new IO::Select;
99 # my @wait = $w->can_read;
100 my $return = fd_retrieve(\*SOCK) or die "error reading result: $!";
101 die $return->{'_error'} if defined $return->{_error} && $return->{_error};
112 L<freeside-selfservice-clientd>, L<freeside-selfservice-server>