Linux ip-172-26-2-223 5.4.0-1018-aws #18-Ubuntu SMP Wed Jun 24 01:15:00 UTC 2020 x86_64
Apache
: 172.26.2.223 | : 3.15.26.71
Cant Read [ /etc/named.conf ]
8.1.13
www
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
snap /
core22 /
1963 /
usr /
sbin /
[ HOME SHELL ]
Name
Size
Permission
Action
aa-remove-unknown
3
KB
-rwxr-xr-x
aa-status
62.62
KB
-rwxr-xr-x
aa-teardown
137
B
-rwxr-xr-x
add-shell
1.03
KB
-rwxr-xr-x
addgroup
37.35
KB
-rwxr-xr-x
adduser
37.35
KB
-rwxr-xr-x
agetty
55.56
KB
-rwxr-xr-x
apparmor_parser
1.48
MB
-rwxr-xr-x
apparmor_status
62.62
KB
-rwxr-xr-x
arpd
26.33
KB
-rwxr-xr-x
arptables
219.04
KB
-rwxr-xr-x
arptables-nft
219.04
KB
-rwxr-xr-x
arptables-nft-restore
219.04
KB
-rwxr-xr-x
arptables-nft-save
219.04
KB
-rwxr-xr-x
arptables-restore
219.04
KB
-rwxr-xr-x
arptables-save
219.04
KB
-rwxr-xr-x
badblocks
34.32
KB
-rwxr-xr-x
blkdeactivate
15.97
KB
-rwxr-xr-x
blkdiscard
22.38
KB
-rwxr-xr-x
blkid
50.41
KB
-rwxr-xr-x
blkzone
34.38
KB
-rwxr-xr-x
blockdev
30.38
KB
-rwxr-xr-x
bridge
92.49
KB
-rwxr-xr-x
capsh
30.3
KB
-rwxr-xr-x
cfdisk
94.73
KB
-rwxr-xr-x
chcpu
30.38
KB
-rwxr-xr-x
chgpasswd
58.13
KB
-rwxr-xr-x
chmem
34.38
KB
-rwxr-xr-x
chpasswd
54.16
KB
-rwxr-xr-x
chroot
38.51
KB
-rwxr-xr-x
cpgr
48.29
KB
-rwxr-xr-x
cppw
48.29
KB
-rwxr-xr-x
cryptdisks_start
1.51
KB
-rwxr-xr-x
cryptdisks_stop
844
B
-rwxr-xr-x
cryptsetup
169.92
KB
-rwxr-xr-x
cryptsetup-reencrypt
90.38
KB
-rwxr-xr-x
cryptsetup-ssh
23.53
KB
-rwxr-xr-x
ctrlaltdel
14.38
KB
-rwxr-xr-x
dcb
80.52
KB
-rwxr-xr-x
debugfs
229.8
KB
-rwxr-xr-x
delgroup
16.11
KB
-rwxr-xr-x
deluser
16.11
KB
-rwxr-xr-x
depmod
170.34
KB
-rwxr-xr-x
devlink
142.86
KB
-rwxr-xr-x
dhclient
442.66
KB
-rwxr-xr-x
dhclient-script
15.92
KB
-rwxr-xr-x
dmsetup
171.02
KB
-rwxr-xr-x
dmstats
171.02
KB
-rwxr-xr-x
dosfsck
82.38
KB
-rwxr-xr-x
dosfslabel
38.38
KB
-rwxr-xr-x
dumpe2fs
30.31
KB
-rwxr-xr-x
e2freefrag
14.3
KB
-rwxr-xr-x
e2fsck
351.84
KB
-rwxr-xr-x
e2image
42.31
KB
-rwxr-xr-x
e2label
102.55
KB
-rwxr-xr-x
e2mmpstatus
30.31
KB
-rwxr-xr-x
e2scrub
7.13
KB
-rwxr-xr-x
e2scrub_all
5.27
KB
-rwxr-xr-x
e2undo
22.3
KB
-rwxr-xr-x
e4crypt
30.38
KB
-rwxr-xr-x
e4defrag
30.3
KB
-rwxr-xr-x
ebtables
219.04
KB
-rwxr-xr-x
ebtables-nft
219.04
KB
-rwxr-xr-x
ebtables-nft-restore
219.04
KB
-rwxr-xr-x
ebtables-nft-save
219.04
KB
-rwxr-xr-x
ebtables-restore
219.04
KB
-rwxr-xr-x
ebtables-save
219.04
KB
-rwxr-xr-x
faillock
14.15
KB
-rwxr-xr-x
fatlabel
38.38
KB
-rwxr-xr-x
fdisk
110.42
KB
-rwxr-xr-x
filefrag
18.32
KB
-rwxr-xr-x
findfs
14.38
KB
-rwxr-xr-x
fsck
42.42
KB
-rwxr-xr-x
fsck.cramfs
30.44
KB
-rwxr-xr-x
fsck.ext2
351.84
KB
-rwxr-xr-x
fsck.ext3
351.84
KB
-rwxr-xr-x
fsck.ext4
351.84
KB
-rwxr-xr-x
fsck.fat
82.38
KB
-rwxr-xr-x
fsck.minix
54.41
KB
-rwxr-xr-x
fsck.msdos
82.38
KB
-rwxr-xr-x
fsck.vfat
82.38
KB
-rwxr-xr-x
fsfreeze
14.38
KB
-rwxr-xr-x
fstab-decode
18.3
KB
-rwxr-xr-x
fstrim
42.38
KB
-rwxr-xr-x
genl
90.44
KB
-rwxr-xr-x
getcap
14.3
KB
-rwxr-xr-x
getpcaps
14.3
KB
-rwxr-xr-x
getty
55.56
KB
-rwxr-xr-x
groupadd
66.91
KB
-rwxr-xr-x
groupdel
62.73
KB
-rwxr-xr-x
groupmems
54.19
KB
-rwxr-xr-x
groupmod
66.82
KB
-rwxr-xr-x
grpck
58.13
KB
-rwxr-xr-x
grpconv
50.01
KB
-rwxr-xr-x
grpunconv
50.01
KB
-rwxr-xr-x
halt
973.23
KB
-rwxr-xr-x
hwclock
50.5
KB
-rwxr-xr-x
iconvconfig
30.4
KB
-rwxr-xr-x
init
1.55
MB
-rwxr-xr-x
insmod
170.34
KB
-rwxr-xr-x
installkernel
2.6
KB
-rwxr-xr-x
integritysetup
54.07
KB
-rwxr-xr-x
invoke-rc.d
16.12
KB
-rwxr-xr-x
ip
597.62
KB
-rwxr-xr-x
ip6tables
219.04
KB
-rwxr-xr-x
ip6tables-apply
6.89
KB
-rwxr-xr-x
ip6tables-legacy
96.95
KB
-rwxr-xr-x
ip6tables-legacy-restore
96.95
KB
-rwxr-xr-x
ip6tables-legacy-save
96.95
KB
-rwxr-xr-x
ip6tables-nft
219.04
KB
-rwxr-xr-x
ip6tables-nft-restore
219.04
KB
-rwxr-xr-x
ip6tables-nft-save
219.04
KB
-rwxr-xr-x
ip6tables-restore
219.04
KB
-rwxr-xr-x
ip6tables-restore-translate
219.04
KB
-rwxr-xr-x
ip6tables-save
219.04
KB
-rwxr-xr-x
ip6tables-translate
219.04
KB
-rwxr-xr-x
iptables
219.04
KB
-rwxr-xr-x
iptables-apply
6.89
KB
-rwxr-xr-x
iptables-legacy
96.95
KB
-rwxr-xr-x
iptables-legacy-restore
96.95
KB
-rwxr-xr-x
iptables-legacy-save
96.95
KB
-rwxr-xr-x
iptables-nft
219.04
KB
-rwxr-xr-x
iptables-nft-restore
219.04
KB
-rwxr-xr-x
iptables-nft-save
219.04
KB
-rwxr-xr-x
iptables-restore
219.04
KB
-rwxr-xr-x
iptables-restore-translate
219.04
KB
-rwxr-xr-x
iptables-save
219.04
KB
-rwxr-xr-x
iptables-translate
219.04
KB
-rwxr-xr-x
isosize
14.38
KB
-rwxr-xr-x
killall5
30.38
KB
-rwxr-xr-x
ldattach
26.38
KB
-rwxr-xr-x
ldconfig
387
B
-rwxr-xr-x
ldconfig.real
1.16
MB
-rwxr-xr-x
logsave
14.16
KB
-rwxr-xr-x
losetup
70.52
KB
-rwxr-xr-x
lsmod
170.34
KB
-rwxr-xr-x
luksformat
3.32
KB
-rwxr-xr-x
mkdosfs
50.83
KB
-rwxr-xr-x
mke2fs
130.62
KB
-rwxr-xr-x
mkfs
14.38
KB
-rwxr-xr-x
mkfs.bfs
22.38
KB
-rwxr-xr-x
mkfs.cramfs
34.32
KB
-rwxr-xr-x
mkfs.ext2
130.62
KB
-rwxr-xr-x
mkfs.ext3
130.62
KB
-rwxr-xr-x
mkfs.ext4
130.62
KB
-rwxr-xr-x
mkfs.fat
50.83
KB
-rwxr-xr-x
mkfs.minix
42.39
KB
-rwxr-xr-x
mkfs.msdos
50.83
KB
-rwxr-xr-x
mkfs.vfat
50.83
KB
-rwxr-xr-x
mkhomedir_helper
22.17
KB
-rwxr-xr-x
mklost+found
14.3
KB
-rwxr-xr-x
mkswap
46.38
KB
-rwxr-xr-x
modinfo
170.34
KB
-rwxr-xr-x
modprobe
170.34
KB
-rwxr-xr-x
netplan
798
B
-rwxr-xr-x
newusers
74.73
KB
-rwxr-xr-x
nfnl_osf
18.3
KB
-rwxr-xr-x
nologin
14.3
KB
-rwxr-xr-x
pam-auth-update
20.5
KB
-rwxr-xr-x
pam_extrausers_chkpwd
22.15
KB
-rwxr-sr-x
pam_extrausers_update
30.15
KB
-rwxr-xr-x
pam_getenv
2.82
KB
-rwxr-xr-x
pam_timestamp_check
14.15
KB
-rwxr-xr-x
pivot_root
14.38
KB
-rwxr-xr-x
plymouthd
150.55
KB
-rwxr-xr-x
poweroff
973.23
KB
-rwxr-xr-x
pwck
50.13
KB
-rwxr-xr-x
pwconv
46.01
KB
-rwxr-xr-x
pwunconv
42.01
KB
-rwxr-xr-x
readprofile
22.41
KB
-rwxr-xr-x
reboot
973.23
KB
-rwxr-xr-x
remove-shell
1.07
KB
-rwxr-xr-x
resize2fs
66.3
KB
-rwxr-xr-x
rfkill
30.23
KB
-rwxr-xr-x
rmmod
170.34
KB
-rwxr-xr-x
rmt
58.57
KB
-rwxr-xr-x
rmt-tar
58.57
KB
-rwxr-xr-x
rtacct
28.31
KB
-rwxr-xr-x
rtcwake
34.38
KB
-rwxr-xr-x
rtmon
90.39
KB
-rwxr-xr-x
runlevel
973.23
KB
-rwxr-xr-x
runuser
54.38
KB
-rwxr-xr-x
service
8.88
KB
-rwxr-xr-x
setcap
14.3
KB
-rwxr-xr-x
sfdisk
102.38
KB
-rwxr-xr-x
shadowconfig
885
B
-rwxr-xr-x
shutdown
973.23
KB
-rwxr-xr-x
sshd
895.7
KB
-rwxr-xr-x
start-stop-daemon
47.35
KB
-rwxr-xr-x
sudo_logsrvd
200.1
KB
-rwxr-xr-x
sudo_sendlog
107.34
KB
-rwxr-xr-x
sulogin
42.38
KB
-rwxr-xr-x
swaplabel
18.38
KB
-rwxr-xr-x
swapoff
22.38
KB
-rwxr-xr-x
swapon
42.38
KB
-rwxr-xr-x
switch_root
22.38
KB
-rwxr-xr-x
sysctl
30.23
KB
-rwxr-xr-x
tarcat
936
B
-rwxr-xr-x
tc
614.08
KB
-rwxr-xr-x
telinit
973.23
KB
-rwxr-xr-x
tipc
90.44
KB
-rwxr-xr-x
tune2fs
102.55
KB
-rwxr-xr-x
tzconfig
106
B
-rwxr-xr-x
unix_chkpwd
26.15
KB
-rwxr-sr-x
unix_update
30.15
KB
-rwxr-xr-x
update-ca-certificates
5.29
KB
-rwxr-xr-x
update-passwd
34.56
KB
-rwxr-xr-x
update-rc.d
16.92
KB
-rwxr-xr-x
update-shells
3.72
KB
-rwxr-xr-x
useradd
127.66
KB
-rwxr-xr-x
userdel
86.85
KB
-rwxr-xr-x
usermod
123.46
KB
-rwxr-xr-x
vdpa
30.56
KB
-rwxr-xr-x
veritysetup
43.76
KB
-rwxr-xr-x
vigr
56.53
KB
-rwxr-xr-x
vipw
56.53
KB
-rwxr-xr-x
visudo
219.79
KB
-rwxr-xr-x
wipefs
38.38
KB
-rwxr-xr-x
wpa_action
1.69
KB
-rwxr-xr-x
wpa_cli
140.31
KB
-rwxr-xr-x
wpa_supplicant
3.24
MB
-rwxr-xr-x
xtables-legacy-multi
96.95
KB
-rwxr-xr-x
xtables-monitor
219.04
KB
-rwxr-xr-x
xtables-nft-multi
219.04
KB
-rwxr-xr-x
zic
62.32
KB
-rwxr-xr-x
zramctl
54.52
KB
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : update-rc.d
#! /usr/bin/perl # vim: ft=perl # # update-rc.d Update the links in /etc/rc[0-9S].d/ # use strict; use warnings; # NB: All Perl modules used here must be in perl-base. Specifically, depending # on modules in perl-modules is not okay! See bug #716923 my $initd = "/etc/init.d"; my $etcd = "/etc/rc"; # Print usage message and die. sub usage { print STDERR "update-rc.d: error: @_\n" if ($#_ >= 0); print STDERR <<EOF; usage: update-rc.d [-f] <basename> remove update-rc.d [-f] <basename> defaults update-rc.d [-f] <basename> defaults-disabled update-rc.d <basename> disable|enable [S|2|3|4|5] -f: force The disable|enable API is not stable and might change in the future. EOF exit (1); } exit main(@ARGV); sub info { print STDOUT "update-rc.d: @_\n"; } sub warning { print STDERR "update-rc.d: warning: @_\n"; } sub error { print STDERR "update-rc.d: error: @_\n"; exit (1); } sub error_code { my $rc = shift; print STDERR "update-rc.d: error: @_\n"; exit ($rc); } sub make_path { my ($path) = @_; my @dirs = (); my @path = split /\//, $path; map { push @dirs, $_; mkdir join('/', @dirs), 0755; } @path; } # Given a script name, return any runlevels except 0 or 6 in which the # script is enabled. If that gives nothing and the script is not # explicitly disabled, return 6 if the script is disabled in runlevel # 0 or 6. sub script_runlevels { my ($scriptname) = @_; my @links=<"/etc/rc[S12345].d/S[0-9][0-9]$scriptname">; if (@links) { return map(substr($_, 7, 1), @links); } elsif (! <"/etc/rc[S12345].d/K[0-9][0-9]$scriptname">) { @links=<"/etc/rc[06].d/K[0-9][0-9]$scriptname">; return ("6") if (@links); } else { return ; } } # Map the sysvinit runlevel to that of openrc. sub openrc_rlconv { my %rl_table = ( "S" => "sysinit", "1" => "recovery", "2" => "default", "3" => "default", "4" => "default", "5" => "default", "6" => "off" ); my %seen; # return unique runlevels return grep !$seen{$_}++, map($rl_table{$_}, @_); } sub systemd_reload { if (-d "/run/systemd/system") { system("systemctl", "daemon-reload"); } } # Creates the necessary links to enable/disable a SysV init script (fallback if # no insserv/rc-update exists) sub make_sysv_links { my ($scriptname, $action) = @_; # for "remove" we cannot rely on the init script still being present, as # this gets called in postrm for purging. Just remove all symlinks. if ("remove" eq $action) { unlink($_) for glob("/etc/rc?.d/[SK][0-9][0-9]$scriptname"); return; } # if the service already has any links, do not touch them # numbers we don't care about, but enabled/disabled state we do return if glob("/etc/rc?.d/[SK][0-9][0-9]$scriptname"); # for "defaults", parse Default-{Start,Stop} and create these links my ($lsb_start_ref, $lsb_stop_ref) = parse_def_start_stop("/etc/init.d/$scriptname"); my $start = $action eq "defaults-disabled" ? "K" : "S"; foreach my $lvl (@$lsb_start_ref) { make_path("/etc/rc$lvl.d"); my $l = "/etc/rc$lvl.d/${start}01$scriptname"; symlink("../init.d/$scriptname", $l); } foreach my $lvl (@$lsb_stop_ref) { make_path("/etc/rc$lvl.d"); my $l = "/etc/rc$lvl.d/K01$scriptname"; symlink("../init.d/$scriptname", $l); } } # Creates the necessary links to enable/disable the service (equivalent of an # initscript) in systemd. sub make_systemd_links { my ($scriptname, $action) = @_; # If called by systemctl (via systemd-sysv-install), do nothing to avoid # an endless loop. if (defined($ENV{_SKIP_SYSTEMD_NATIVE}) && $ENV{_SKIP_SYSTEMD_NATIVE} == 1) { return; } # If systemctl is available, let's use that to create the symlinks. if (-x "/bin/systemctl" || -x "/usr/bin/systemctl") { # Set this env var to avoid loop in systemd-sysv-install. local $ENV{SYSTEMCTL_SKIP_SYSV} = 1; # Use --quiet to mimic the old update-rc.d behaviour. system("systemctl", "--quiet", "$action", "$scriptname"); return; } # In addition to the insserv call we also enable/disable the service # for systemd by creating the appropriate symlink in case there is a # native systemd service. In case systemd is not installed we do this # on our own instead of using systemctl. my $service_path; if (-f "/etc/systemd/system/$scriptname.service") { $service_path = "/etc/systemd/system/$scriptname.service"; } elsif (-f "/lib/systemd/system/$scriptname.service") { $service_path = "/lib/systemd/system/$scriptname.service"; } elsif (-f "/usr/lib/systemd/system/$scriptname.service") { $service_path = "/usr/lib/systemd/system/$scriptname.service"; } if (defined($service_path)) { my $changed_sth; open my $fh, '<', $service_path or error("unable to read $service_path"); while (<$fh>) { chomp; if (/^\s*WantedBy=(.+)$/i) { my $wants_dir = "/etc/systemd/system/$1.wants"; my $service_link = "$wants_dir/$scriptname.service"; if ("enable" eq $action) { make_path($wants_dir); symlink($service_path, $service_link); } else { unlink($service_link) if -e $service_link; } } } close($fh); } } sub create_sequence { my $force = (@_); my $insserv = "/usr/lib/insserv/insserv"; # Fallback for older insserv package versions [2014-04-16] $insserv = "/sbin/insserv" if ( -x "/sbin/insserv"); # If insserv is not configured it is not fully installed my $insserv_installed = -x $insserv && -e "/etc/insserv.conf"; my @opts; push(@opts, '-f') if $force; # Add force flag if initscripts is not installed # This enables inistcripts-less systems to not fail when a facility is missing unshift(@opts, '-f') unless is_initscripts_installed(); my $openrc_installed = -x "/sbin/openrc"; my $sysv_insserv ={}; $sysv_insserv->{remove} = sub { my ($scriptname) = @_; if ( -f "/etc/init.d/$scriptname" ) { return system($insserv, @opts, "-r", $scriptname) >> 8; } else { # insserv removes all dangling symlinks, no need to tell it # what to look for. my $rc = system($insserv, @opts) >> 8; error_code($rc, "insserv rejected the script header") if $rc; } }; $sysv_insserv->{defaults} = sub { my ($scriptname) = @_; if ( -f "/etc/init.d/$scriptname" ) { my $rc = system($insserv, @opts, $scriptname) >> 8; error_code($rc, "insserv rejected the script header") if $rc; } else { error("initscript does not exist: /etc/init.d/$scriptname"); } }; $sysv_insserv->{defaults_disabled} = sub { my ($scriptname) = @_; return if glob("/etc/rc?.d/[SK][0-9][0-9]$scriptname"); if ( -f "/etc/init.d/$scriptname" ) { my $rc = system($insserv, @opts, $scriptname) >> 8; error_code($rc, "insserv rejected the script header") if $rc; } else { error("initscript does not exist: /etc/init.d/$scriptname"); } sysv_toggle("disable", $scriptname); }; $sysv_insserv->{toggle} = sub { my ($action, $scriptname) = (shift, shift); sysv_toggle($action, $scriptname, @_); # Call insserv to resequence modified links my $rc = system($insserv, @opts, $scriptname) >> 8; error_code($rc, "insserv rejected the script header") if $rc; }; my $sysv_plain = {}; $sysv_plain->{remove} = sub { my ($scriptname) = @_; make_sysv_links($scriptname, "remove"); }; $sysv_plain->{defaults} = sub { my ($scriptname) = @_; make_sysv_links($scriptname, "defaults"); }; $sysv_plain->{defaults_disabled} = sub { my ($scriptname) = @_; make_sysv_links($scriptname, "defaults-disabled"); }; $sysv_plain->{toggle} = sub { my ($action, $scriptname) = (shift, shift); sysv_toggle($action, $scriptname, @_); }; my $systemd = {}; $systemd->{remove} = sub { systemd_reload; }; $systemd->{defaults} = sub { systemd_reload; }; $systemd->{defaults_disabled} = sub { systemd_reload; }; $systemd->{toggle} = sub { my ($action, $scriptname) = (shift, shift); make_systemd_links($scriptname, $action); systemd_reload; }; # Should we check exit codeS? my $openrc = {}; $openrc->{remove} = sub { my ($scriptname) = @_; system("rc-update", "-qqa", "delete", $scriptname); }; $openrc->{defaults} = sub { my ($scriptname) = @_; # OpenRC does not distinguish halt and reboot. They are handled # by /etc/init.d/transit instead. return if ("halt" eq $scriptname || "reboot" eq $scriptname); # no need to consider default disabled runlevels # because everything is disabled by openrc by default my @rls=script_runlevels($scriptname); if ( @rls ) { system("rc-update", "add", $scriptname, openrc_rlconv(@rls)); } }; $openrc->{defaults_disabled} = sub { # In openrc everything is disabled by default }; $openrc->{toggle} = sub { my ($action, $scriptname) = (shift, shift); my (@toggle_lvls, $start_lvls, $stop_lvls, @symlinks); my $lsb_header = lsb_header_for_script($scriptname); # Extra arguments to disable|enable action are runlevels. If none # given parse LSB info for Default-Start value. if ($#_ >= 0) { @toggle_lvls = @_; } else { ($start_lvls, $stop_lvls) = parse_def_start_stop($lsb_header); @toggle_lvls = @$start_lvls; if ($#toggle_lvls < 0) { error("$scriptname Default-Start contains no runlevels, aborting."); } } my %openrc_act = ( "disable" => "del", "enable" => "add" ); system("rc-update", $openrc_act{$action}, $scriptname, openrc_rlconv(@toggle_lvls)) }; my @sequence; if ($insserv_installed) { push @sequence, $sysv_insserv; } else { push @sequence, $sysv_plain; } # OpenRC has to be after sysv_{insserv,plain} because it depends on them to synchronize # states. if ($openrc_installed) { push @sequence, $openrc; } push @sequence, $systemd; return @sequence; } ## Dependency based sub main { my @args = @_; my $scriptname; my $action; my $force = 0; while($#args >= 0 && ($_ = $args[0]) =~ /^-/) { shift @args; if (/^-f$/) { $force = 1; next } if (/^-h|--help$/) { usage(); } usage("unknown option"); } usage("not enough arguments") if ($#args < 1); my @sequence = create_sequence($force); $scriptname = shift @args; $action = shift @args; if ("remove" eq $action) { foreach my $init (@sequence) { $init->{remove}->($scriptname); } } elsif ("defaults" eq $action || "start" eq $action || "stop" eq $action) { # All start/stop/defaults arguments are discarded so emit a # message if arguments have been given and are in conflict # with Default-Start/Default-Stop values of LSB comment. if ("start" eq $action || "stop" eq $action) { cmp_args_with_defaults($scriptname, $action, @args); } foreach my $init (@sequence) { $init->{defaults}->($scriptname); } } elsif ("defaults-disabled" eq $action) { foreach my $init (@sequence) { $init->{defaults_disabled}->($scriptname); } } elsif ("disable" eq $action || "enable" eq $action) { foreach my $init (@sequence) { $init->{toggle}->($action, $scriptname, @args); } } else { usage(); } } sub parse_def_start_stop { my $script = shift; my (%lsb, @def_start_lvls, @def_stop_lvls); open my $fh, '<', $script or error("unable to read $script"); while (<$fh>) { chomp; if (m/^### BEGIN INIT INFO\s*$/) { $lsb{'begin'}++; } elsif (m/^### END INIT INFO\s*$/) { $lsb{'end'}++; last; } elsif ($lsb{'begin'} and not $lsb{'end'}) { if (m/^# Default-Start:\s*(\S?.*)$/) { @def_start_lvls = split(' ', $1); } if (m/^# Default-Stop:\s*(\S?.*)$/) { @def_stop_lvls = split(' ', $1); } } } close($fh); return (\@def_start_lvls, \@def_stop_lvls); } sub lsb_header_for_script { my $name = shift; foreach my $file ("/etc/insserv/overrides/$name", "/etc/init.d/$name", "/usr/share/insserv/overrides/$name") { return $file if -s $file; } error("cannot find a LSB script for $name"); } sub cmp_args_with_defaults { my ($name, $act) = (shift, shift); my ($lsb_start_ref, $lsb_stop_ref, $arg_str, $lsb_str); my (@arg_start_lvls, @arg_stop_lvls, @lsb_start_lvls, @lsb_stop_lvls); ($lsb_start_ref, $lsb_stop_ref) = parse_def_start_stop("/etc/init.d/$name"); @lsb_start_lvls = @$lsb_start_ref; @lsb_stop_lvls = @$lsb_stop_ref; return if (!@lsb_start_lvls and !@lsb_stop_lvls); warning "start and stop actions are no longer supported; falling back to defaults"; my $start = $act eq 'start' ? 1 : 0; my $stop = $act eq 'stop' ? 1 : 0; # The legacy part of this program passes arguments starting with # "start|stop NN x y z ." but the insserv part gives argument list # starting with sequence number (ie. strips off leading "start|stop") # Start processing arguments immediately after the first seq number. my $argi = $_[0] eq $act ? 2 : 1; while (defined $_[$argi]) { my $arg = $_[$argi]; # Runlevels 0 and 6 are always stop runlevels if ($arg eq 0 or $arg eq 6) { $start = 0; $stop = 1; } elsif ($arg eq 'start') { $start = 1; $stop = 0; $argi++; next; } elsif ($arg eq 'stop') { $start = 0; $stop = 1; $argi++; next; } elsif ($arg eq '.') { next; } push(@arg_start_lvls, $arg) if $start; push(@arg_stop_lvls, $arg) if $stop; } continue { $argi++; } if ($#arg_start_lvls != $#lsb_start_lvls or join("\0", sort @arg_start_lvls) ne join("\0", sort @lsb_start_lvls)) { $arg_str = @arg_start_lvls ? "@arg_start_lvls" : "none"; $lsb_str = @lsb_start_lvls ? "@lsb_start_lvls" : "none"; warning "start runlevel arguments ($arg_str) do not match", "$name Default-Start values ($lsb_str)"; } if ($#arg_stop_lvls != $#lsb_stop_lvls or join("\0", sort @arg_stop_lvls) ne join("\0", sort @lsb_stop_lvls)) { $arg_str = @arg_stop_lvls ? "@arg_stop_lvls" : "none"; $lsb_str = @lsb_stop_lvls ? "@lsb_stop_lvls" : "none"; warning "stop runlevel arguments ($arg_str) do not match", "$name Default-Stop values ($lsb_str)"; } } sub sysv_toggle { my ($act, $name) = (shift, shift); my (@toggle_lvls, $start_lvls, $stop_lvls, @symlinks); my $lsb_header = lsb_header_for_script($name); # Extra arguments to disable|enable action are runlevels. If none # given parse LSB info for Default-Start value. if ($#_ >= 0) { @toggle_lvls = @_; } else { ($start_lvls, $stop_lvls) = parse_def_start_stop($lsb_header); @toggle_lvls = @$start_lvls; if ($#toggle_lvls < 0) { error("$name Default-Start contains no runlevels, aborting."); } } # Find symlinks in rc.d directories. Refuse to modify links in runlevels # not used for normal system start sequence. for my $lvl (@toggle_lvls) { if ($lvl !~ /^[S2345]$/) { warning("$act action will have no effect on runlevel $lvl"); next; } push(@symlinks, $_) for glob("/etc/rc$lvl.d/[SK][0-9][0-9]$name"); } if (!@symlinks) { error("no runlevel symlinks to modify, aborting!"); } # Toggle S/K bit of script symlink. for my $cur_lnk (@symlinks) { my $sk; my @new_lnk = split(//, $cur_lnk); if ("disable" eq $act) { $sk = rindex($cur_lnk, '/S') + 1; next if $sk < 1; $new_lnk[$sk] = 'K'; } else { $sk = rindex($cur_lnk, '/K') + 1; next if $sk < 1; $new_lnk[$sk] = 'S'; } rename($cur_lnk, join('', @new_lnk)) or error($!); } } # Try to determine if initscripts is installed sub is_initscripts_installed { # Check if mountkernfs is available. We cannot make inferences # using the running init system because we may be running in a # chroot return glob('/etc/rcS.d/S??mountkernfs.sh'); }
Close