summaryrefslogtreecommitdiffstats
path: root/ftp/vsftpd/pkg-install
blob: 7127bb22180459fc0d8cb8008b2a8ce1cab624ef (plain)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#!/usr/bin/perl
#

@groups = ("operator");
%users = ('ftp', "operator");
# daemon, local, pop, queue, remote, deliver, respectively.
# alias is a special case above...
%gids = ('operator', 5);
%uids = ('ftp', 14);

if ($ENV{PACKAGE_BUILDING} || $ARGV[1] eq "PRE-INSTALL") {
	$doguid=1;  # Make sure we get the assigned guids.
}

foreach $group (@groups) {
	if (! getgrnam ($group)) {
		do checkrpw;  # May exit

		$x = "-g $gids{$group}";
		$result = system ("/usr/sbin/pw groupadd $group $x");
		if ($result) {
			die "Failed to add group $group as gid $gids{$group}\n";
		}
	}
}

foreach $user (keys %users) {
	if (! getpwnam ($user)) {
		do checkrpw;  # May exit

		$x = "-u $uids{$user}";
		$result = system ("/usr/sbin/pw useradd $user -g $users{$user} -d \"/var/ftp\" -s /nonexistent $x");
		if ($result) {
			die "Failed to add user $user as uid $uids{$user}\n";
		}
	}
}

# Check that all gids/uids are as they should be...
# If we are being installed as a package...
if ($doguid) {
	foreach $group (@groups) {
		if (getgrnam($group) != $gids{$group}) {
			die "Group $group should have gid $gids{$group}\n";
		}
	}

	foreach $user (keys %users) {
		if (getpwnam($user) != $uids{$user}) {
			die "User $user should have uid $uids{$user}\n";
		}
	}
}

exit 0;

sub checkrpw {
	if (! -x "/usr/sbin/pw") {
		print <<'EOM';
This system looks like a pre-2.2 version of FreeBSD.  We see that it
is missing the "pw" utility.  We need this utility.  Please get and
install it, and try again.  You can get the source from:

  ftp://ftp.freebsd.org/pub/FreeBSD/FreeBSD-current/src/usr.sbin/pw.tar.gz

EOM
		die "No /usr/sbin/pw";
	}

	if ($> != 0) {
		print "It is necessary to add missing vsftpd users/groups at";
		print "this stage.  Please either add them manually or retry";
		print "as root.";
		# Let pw(1) signal the failure so the user can see which
		# group/user is actually missing.
	}
}
OpenPOWER on IntegriCloud