1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/usr/bin/perl -Tw
#
# fs_passwdd
#
# This is run REMOTELY over ssh by fs_passwd_server.
#
# ivan@sisd.com 98-mar-9
use strict;
use Socket;
my $fs_passwdd_socket = "/usr/local/freeside/fs_passwdd_socket";
my $pid_file = "$fs_passwdd_socket.pid";
$ENV{'PATH'} ='/usr/local/bin:/usr/bin:/usr/ucb:/bin';
$ENV{'SHELL'} = '/bin/sh';
$ENV{'IFS'} = " \t\n";
$ENV{'CDPATH'} = '';
$ENV{'ENV'} = '';
$ENV{'BASH_ENV'} = '';
$|=1;
my $uaddr = sockaddr_un($fs_passwdd_socket);
my $proto = getprotobyname('tcp');
socket(Server,PF_UNIX,SOCK_STREAM,0) or die "socket: $!";
unlink($fs_passwdd_socket);
bind(Server, $uaddr) or die "bind: $!";
listen(Server,SOMAXCONN) or die "listen: $!";
if ( -e $pid_file ) {
open(PIDFILE,"<$pid_file");
#chomp( my $old_pid = <PIDFILE> );
my $old_pid = <PIDFILE>;
close PIDFILE;
$old_pid =~ /^(\d+)$/;
kill 'TERM', $1;
}
open(PIDFILE,">$pid_file");
print PIDFILE "$$\n";
close PIDFILE;
my($paddr);
for ( ; $paddr = accept(Client,Server); close Client) {
my($me,$old_password,$new_password,$new_gecos,$new_shell);
$me=<Client>;
$old_password=<Client>;
$new_password=<Client>;
$new_gecos=<Client>;
$new_shell=<Client>;
print $me,$old_password,$new_password,$new_gecos,$new_shell;
my($error);
$error=<STDIN>;
print Client $error;
close Client;
}
|