specinfra 2.0.0.beta6 → 2.0.0.beta7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +2 -2
- data/lib/specinfra.rb +25 -0
- data/lib/specinfra/backend/exec.rb +15 -103
- data/lib/specinfra/backend/ssh.rb +1 -1
- data/lib/specinfra/command.rb +208 -29
- data/lib/specinfra/command/aix.rb +1 -66
- data/lib/specinfra/command/aix/base.rb +2 -0
- data/lib/specinfra/command/aix/base/file.rb +19 -0
- data/lib/specinfra/command/aix/base/group.rb +6 -0
- data/lib/specinfra/command/aix/base/package.rb +9 -0
- data/lib/specinfra/command/aix/base/port.rb +6 -0
- data/lib/specinfra/command/aix/base/service.rb +9 -0
- data/lib/specinfra/command/aix/base/user.rb +13 -0
- data/lib/specinfra/command/arch.rb +1 -38
- data/lib/specinfra/command/arch/base.rb +11 -0
- data/lib/specinfra/command/arch/base/file.rb +5 -0
- data/lib/specinfra/command/arch/base/package.rb +22 -0
- data/lib/specinfra/command/arch/base/service.rb +3 -0
- data/lib/specinfra/command/base.rb +74 -334
- data/lib/specinfra/command/base/cron.rb +10 -0
- data/lib/specinfra/command/base/file.rb +95 -0
- data/lib/specinfra/command/base/group.rb +10 -0
- data/lib/specinfra/command/base/host.rb +23 -0
- data/lib/specinfra/command/base/interface.rb +2 -0
- data/lib/specinfra/command/base/ipfilter.rb +2 -0
- data/lib/specinfra/command/base/ipnat.rb +2 -0
- data/lib/specinfra/command/base/iptables.rb +2 -0
- data/lib/specinfra/command/base/kernel_module.rb +2 -0
- data/lib/specinfra/command/base/lxc_container.rb +2 -0
- data/lib/specinfra/command/base/mail_alias.rb +6 -0
- data/lib/specinfra/command/base/package.rb +43 -0
- data/lib/specinfra/command/base/port.rb +8 -0
- data/lib/specinfra/command/base/ppa.rb +2 -0
- data/lib/specinfra/command/base/process.rb +14 -0
- data/lib/specinfra/command/base/routing_table.rb +5 -0
- data/lib/specinfra/command/base/selinux.rb +2 -0
- data/lib/specinfra/command/base/service.rb +25 -0
- data/lib/specinfra/command/base/user.rb +31 -0
- data/lib/specinfra/command/base/yumrepo.rb +3 -0
- data/lib/specinfra/command/base/zfs.rb +1 -0
- data/lib/specinfra/command/darwin.rb +1 -67
- data/lib/specinfra/command/darwin/base.rb +2 -0
- data/lib/specinfra/command/darwin/base/file.rb +37 -0
- data/lib/specinfra/command/darwin/base/package.rb +15 -0
- data/lib/specinfra/command/darwin/base/port.rb +6 -0
- data/lib/specinfra/command/darwin/base/service.rb +9 -0
- data/lib/specinfra/command/debian.rb +1 -31
- data/lib/specinfra/command/debian/base.rb +11 -0
- data/lib/specinfra/command/debian/base/package.rb +22 -0
- data/lib/specinfra/command/debian/base/ppa.rb +2 -0
- data/lib/specinfra/command/debian/base/service.rb +6 -0
- data/lib/specinfra/command/fedora.rb +1 -29
- data/lib/specinfra/command/fedora/base.rb +2 -0
- data/lib/specinfra/command/fedora/base/service.rb +10 -0
- data/lib/specinfra/command/fedora/v15.rb +1 -0
- data/lib/specinfra/command/fedora/v15/service.rb +3 -0
- data/lib/specinfra/command/freebsd.rb +1 -39
- data/lib/specinfra/command/freebsd/base.rb +3 -0
- data/lib/specinfra/command/freebsd/base/file.rb +10 -0
- data/lib/specinfra/command/freebsd/base/package.rb +17 -0
- data/lib/specinfra/command/freebsd/base/port.rb +6 -0
- data/lib/specinfra/command/freebsd/base/service.rb +5 -0
- data/lib/specinfra/command/freebsd/v10.rb +1 -0
- data/lib/specinfra/command/freebsd/v10/package.rb +17 -0
- data/lib/specinfra/command/gentoo.rb +1 -18
- data/lib/specinfra/command/gentoo/base.rb +2 -0
- data/lib/specinfra/command/gentoo/base/package.rb +5 -0
- data/lib/specinfra/command/gentoo/base/service.rb +17 -0
- data/lib/specinfra/command/linux.rb +1 -71
- data/lib/specinfra/command/linux/base.rb +2 -0
- data/lib/specinfra/command/linux/base/file.rb +13 -0
- data/lib/specinfra/command/linux/base/interface.rb +17 -0
- data/lib/specinfra/command/linux/base/iptables.rb +10 -0
- data/lib/specinfra/command/linux/base/kernel_module.rb +5 -0
- data/lib/specinfra/command/linux/base/lxc_container.rb +9 -0
- data/lib/specinfra/command/linux/base/package.rb +2 -0
- data/lib/specinfra/command/linux/base/ppa.rb +2 -0
- data/lib/specinfra/command/linux/base/selinux.rb +10 -0
- data/lib/specinfra/command/linux/base/service.rb +2 -0
- data/lib/specinfra/command/linux/base/yumrepo.rb +2 -0
- data/lib/specinfra/command/linux/base/zfs.rb +3 -0
- data/lib/specinfra/command/module.rb +2 -0
- data/lib/specinfra/command/module/systemd.rb +13 -0
- data/lib/specinfra/command/module/zfs.rb +14 -0
- data/lib/specinfra/command/nixos.rb +1 -28
- data/lib/specinfra/command/nixos/base.rb +2 -0
- data/lib/specinfra/command/nixos/base/package.rb +15 -0
- data/lib/specinfra/command/nixos/base/service.rb +3 -0
- data/lib/specinfra/command/openbsd.rb +1 -91
- data/lib/specinfra/command/openbsd/base.rb +4 -0
- data/lib/specinfra/command/openbsd/base/file.rb +39 -0
- data/lib/specinfra/command/openbsd/base/interface.rb +9 -0
- data/lib/specinfra/command/openbsd/base/mail_alias.rb +5 -0
- data/lib/specinfra/command/openbsd/base/package.rb +13 -0
- data/lib/specinfra/command/openbsd/base/port.rb +5 -0
- data/lib/specinfra/command/openbsd/base/service.rb +9 -0
- data/lib/specinfra/command/openbsd/base/user.rb +16 -0
- data/lib/specinfra/command/opensuse.rb +1 -14
- data/lib/specinfra/command/opensuse/base.rb +3 -0
- data/lib/specinfra/command/opensuse/base/service.rb +3 -0
- data/lib/specinfra/command/plamo.rb +1 -21
- data/lib/specinfra/command/plamo/base.rb +3 -0
- data/lib/specinfra/command/plamo/base/package.rb +9 -0
- data/lib/specinfra/command/plamo/base/service.rb +12 -0
- data/lib/specinfra/command/redhat.rb +1 -40
- data/lib/specinfra/command/redhat/base.rb +2 -0
- data/lib/specinfra/command/redhat/base/file.rb +6 -0
- data/lib/specinfra/command/redhat/base/iptables.rb +11 -0
- data/lib/specinfra/command/redhat/base/package.rb +28 -0
- data/lib/specinfra/command/redhat/base/service.rb +12 -0
- data/lib/specinfra/command/redhat/base/yumrepo.rb +11 -0
- data/lib/specinfra/command/redhat/v5.rb +2 -0
- data/lib/specinfra/command/redhat/v5/iptables.rb +8 -0
- data/lib/specinfra/command/redhat/v7.rb +2 -0
- data/lib/specinfra/command/redhat/v7/service.rb +3 -0
- data/lib/specinfra/command/smartos.rb +1 -25
- data/lib/specinfra/command/smartos/base.rb +3 -0
- data/lib/specinfra/command/smartos/base/package.rb +13 -0
- data/lib/specinfra/command/smartos/base/service.rb +9 -0
- data/lib/specinfra/command/smartos/tmp.rb +8 -0
- data/lib/specinfra/command/solaris.rb +1 -117
- data/lib/specinfra/command/solaris/base.rb +2 -0
- data/lib/specinfra/command/solaris/base/cron.rb +10 -0
- data/lib/specinfra/command/solaris/base/file.rb +17 -0
- data/lib/specinfra/command/solaris/base/group.rb +6 -0
- data/lib/specinfra/command/solaris/base/host.rb +12 -0
- data/lib/specinfra/command/solaris/base/ipfilter.rb +5 -0
- data/lib/specinfra/command/solaris/base/ipnat.rb +12 -0
- data/lib/specinfra/command/solaris/base/package.rb +12 -0
- data/lib/specinfra/command/solaris/base/port.rb +11 -0
- data/lib/specinfra/command/solaris/base/service.rb +19 -0
- data/lib/specinfra/command/solaris/base/user.rb +13 -0
- data/lib/specinfra/command/solaris/base/zfs.rb +11 -0
- data/lib/specinfra/command/solaris/v10.rb +1 -0
- data/lib/specinfra/command/solaris/v10/file.rb +40 -0
- data/lib/specinfra/command/solaris/v10/group.rb +5 -0
- data/lib/specinfra/command/solaris/v10/host.rb +11 -0
- data/lib/specinfra/command/solaris/v10/package.rb +9 -0
- data/lib/specinfra/command/solaris/v10/user.rb +16 -0
- data/lib/specinfra/command/suse.rb +1 -27
- data/lib/specinfra/command/suse/base.rb +2 -0
- data/lib/specinfra/command/suse/base/package.rb +19 -0
- data/lib/specinfra/command/suse/base/service.rb +12 -0
- data/lib/specinfra/command/ubuntu.rb +11 -23
- data/lib/specinfra/command/ubuntu/base.rb +2 -0
- data/lib/specinfra/command/ubuntu/base/ppa.rb +15 -0
- data/lib/specinfra/command/ubuntu/base/service.rb +5 -0
- data/lib/specinfra/command/windows.rb +1 -344
- data/lib/specinfra/command/windows/base.rb +14 -0
- data/lib/specinfra/command/windows/base/feature.rb +15 -0
- data/lib/specinfra/command/windows/base/file.rb +103 -0
- data/lib/specinfra/command/windows/base/group.rb +9 -0
- data/lib/specinfra/command/windows/base/host.rb +23 -0
- data/lib/specinfra/command/windows/base/hot_fix.rb +17 -0
- data/lib/specinfra/command/windows/base/iis_app_pool.rb +15 -0
- data/lib/specinfra/command/windows/base/iis_website.rb +36 -0
- data/lib/specinfra/command/windows/base/package.rb +9 -0
- data/lib/specinfra/command/windows/base/port.rb +15 -0
- data/lib/specinfra/command/windows/base/process.rb +7 -0
- data/lib/specinfra/command/windows/base/registry_key.rb +43 -0
- data/lib/specinfra/command/windows/base/scheduled_task.rb +8 -0
- data/lib/specinfra/command/windows/base/service.rb +29 -0
- data/lib/specinfra/command/windows/base/user.rb +20 -0
- data/lib/specinfra/configuration.rb +2 -1
- data/lib/specinfra/helper.rb +1 -1
- data/lib/specinfra/helper/backend.rb +1 -1
- data/lib/specinfra/helper/detect_os.rb +15 -21
- data/lib/specinfra/helper/detect_os/aix.rb +7 -0
- data/lib/specinfra/helper/detect_os/arch.rb +7 -0
- data/lib/specinfra/helper/detect_os/darwin.rb +7 -0
- data/lib/specinfra/helper/detect_os/debian.rb +24 -0
- data/lib/specinfra/helper/detect_os/freebsd.rb +11 -0
- data/lib/specinfra/helper/detect_os/gentoo.rb +7 -0
- data/lib/specinfra/helper/detect_os/nixos.rb +7 -0
- data/lib/specinfra/helper/detect_os/openbsd.rb +7 -0
- data/lib/specinfra/helper/detect_os/plamo.rb +7 -0
- data/lib/specinfra/helper/detect_os/redhat.rb +27 -0
- data/lib/specinfra/helper/detect_os/solaris.rb +15 -0
- data/lib/specinfra/helper/detect_os/suse.rb +15 -0
- data/lib/specinfra/helper/os.rb +47 -33
- data/lib/specinfra/version.rb +1 -1
- data/spec/backend/exec/build_command_spec.rb +16 -11
- data/spec/command/base/file_spec.rb +11 -0
- data/spec/command/base_spec.rb +28 -0
- data/spec/command/module/systemd_spec.rb +8 -0
- data/spec/command/redhat/package_spec.rb +12 -0
- data/spec/helper/os_spec.rb +58 -0
- metadata +163 -8
- data/lib/specinfra/command/freebsd10.rb +0 -21
- data/lib/specinfra/command/redhat7.rb +0 -9
- data/lib/specinfra/command/solaris10.rb +0 -78
- data/lib/specinfra/command/solaris11.rb +0 -7
- data/spec/command/base.rb +0 -28
@@ -1,66 +1 @@
|
|
1
|
-
module Specinfra
|
2
|
-
module Command
|
3
|
-
class AIX < Base
|
4
|
-
class NotImplementedError < Exception; end
|
5
|
-
|
6
|
-
def check_access_by_user(file, user, access)
|
7
|
-
"su -s sh -c \"test -#{access} #{file}\" #{user}"
|
8
|
-
end
|
9
|
-
|
10
|
-
def check_enabled(service,level=nil)
|
11
|
-
"lssrc -s #{escape(service)} | grep active"
|
12
|
-
end
|
13
|
-
|
14
|
-
def check_running(service)
|
15
|
-
"ps -ef | grep -v grep | grep #{escape(service)}"
|
16
|
-
end
|
17
|
-
|
18
|
-
def check_installed(package,version)
|
19
|
-
if version
|
20
|
-
"lslpp -L #{escape(package)} | awk '{print $2}' | grep -w -- #{version}"
|
21
|
-
else
|
22
|
-
"lslpp -L #{escape(package)}"
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
def check_listening(port)
|
27
|
-
regexp = "*.#{port} "
|
28
|
-
"netstat -an -f inet | awk '{print $4}' | grep -- #{regexp}"
|
29
|
-
#"netstat -an -f inet | awk '{print $4}' | grep -- #{escape(regexp)}"
|
30
|
-
end
|
31
|
-
|
32
|
-
def check_belonging_group(user, group)
|
33
|
-
"lsuser -a groups #{escape(user)} | awk -F'=' '{print $2}'| sed -e 's/,/ /g' |grep -w -- #{escape(group)}"
|
34
|
-
end
|
35
|
-
|
36
|
-
def check_gid(group, gid)
|
37
|
-
regexp = "^#{group}"
|
38
|
-
"cat etc/group | grep -w -- #{escape(regexp)} | cut -f 3 -d ':' | grep -w -- #{escape(gid)}"
|
39
|
-
end
|
40
|
-
|
41
|
-
def check_login_shell(user, path_to_shell)
|
42
|
-
"lsuser -a shell #{escape(user)} |awk -F'=' '{print $2}' | grep -w -- #{escape(path_to_shell)}"
|
43
|
-
end
|
44
|
-
|
45
|
-
def check_home_directory(user, path_to_home)
|
46
|
-
"lsuser -a home #{escape(user)} | awk -F'=' '{print $2}' | grep -w -- #{escape(path_to_home)}"
|
47
|
-
end
|
48
|
-
|
49
|
-
def check_mode(file, mode)
|
50
|
-
raise NotImplementedError.new
|
51
|
-
end
|
52
|
-
|
53
|
-
def check_owner(file, owner)
|
54
|
-
regexp = "^#{owner}$"
|
55
|
-
"ls -al #{escape(file)} | awk '{print $3}' | grep -- #{escape(regexp)}"
|
56
|
-
end
|
57
|
-
|
58
|
-
def check_grouped(file, group)
|
59
|
-
regexp = "^#{group}$"
|
60
|
-
"ls -al #{escape(file)} | awk '{print $4}' | grep -- #{escape(regexp)}"
|
61
|
-
end
|
62
|
-
|
63
|
-
|
64
|
-
end
|
65
|
-
end
|
66
|
-
end
|
1
|
+
module Specinfra::Command::Aix; end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
class Specinfra::Command::Aix::Base::File < Specinfra::Command::Base::File
|
2
|
+
def check_access_by_user(file, user, access)
|
3
|
+
"su -s sh -c \"test -#{access} #{file}\" #{user}"
|
4
|
+
end
|
5
|
+
|
6
|
+
def check_mode(file, mode)
|
7
|
+
raise NotImplementedError.new('check_mode is not implemented in Specinfra::Command::AIX::Base::File')
|
8
|
+
end
|
9
|
+
|
10
|
+
def check_is_owned_by(file, owner)
|
11
|
+
regexp = "^#{owner}$"
|
12
|
+
"ls -al #{escape(file)} | awk '{print $3}' | grep -- #{escape(regexp)}"
|
13
|
+
end
|
14
|
+
|
15
|
+
def check_is_grouped(file, group)
|
16
|
+
regexp = "^#{group}$"
|
17
|
+
"ls -al #{escape(file)} | awk '{print $4}' | grep -- #{escape(regexp)}"
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
class Specinfra::Command::Aix::Base::Package < Specinfra::Command::Base::Package
|
2
|
+
def check_is_installed(package, version=nil)
|
3
|
+
if version
|
4
|
+
"lslpp -L #{escape(package)} | awk '{print $2}' | grep -w -- #{version}"
|
5
|
+
else
|
6
|
+
"lslpp -L #{escape(package)}"
|
7
|
+
end
|
8
|
+
end
|
9
|
+
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
class Specinfra::Command::Aix::Base::Service < Specinfra::Command::Base::Service
|
2
|
+
def check_is_enabled(service,level=nil)
|
3
|
+
"lssrc -s #{escape(service)} | grep active"
|
4
|
+
end
|
5
|
+
|
6
|
+
def check_is_running(service)
|
7
|
+
"ps -ef | grep -v grep | grep #{escape(service)}"
|
8
|
+
end
|
9
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
class Specinfra::Command::Aix::Base::User < Specinfra::Command::Base::User
|
2
|
+
def check_is_belonging_to_group(user, group)
|
3
|
+
"lsuser -a groups #{escape(user)} | awk -F'=' '{print $2}'| sed -e 's/,/ /g' |grep -w -- #{escape(group)}"
|
4
|
+
end
|
5
|
+
|
6
|
+
def check_has_login_shell(user, path_to_shell)
|
7
|
+
"lsuser -a shell #{escape(user)} |awk -F'=' '{print $2}' | grep -w -- #{escape(path_to_shell)}"
|
8
|
+
end
|
9
|
+
|
10
|
+
def check_has_home_directory(user, path_to_home)
|
11
|
+
"lsuser -a home #{escape(user)} | awk -F'=' '{print $2}' | grep -w -- #{escape(path_to_home)}"
|
12
|
+
end
|
13
|
+
end
|
@@ -1,38 +1 @@
|
|
1
|
-
module Specinfra
|
2
|
-
module Command
|
3
|
-
class Arch < Linux
|
4
|
-
def check_access_by_user(file, user, access)
|
5
|
-
"runuser -s /bin/sh -c \"test -#{access} #{file}\" #{user}"
|
6
|
-
end
|
7
|
-
|
8
|
-
def check_enabled(service, level)
|
9
|
-
level = "multi-user.target" if level == 3
|
10
|
-
"systemctl --plain list-dependencies #{level} | grep '^#{escape(service)}.service$'"
|
11
|
-
end
|
12
|
-
|
13
|
-
def check_running(service)
|
14
|
-
"systemctl is-active #{escape(service)}.service"
|
15
|
-
end
|
16
|
-
|
17
|
-
def check_installed(package,version=nil)
|
18
|
-
if version
|
19
|
-
"pacman -Q | grep #{escape(package)} #{escape(version)}"
|
20
|
-
else
|
21
|
-
"pacman -Q | grep #{escape(package)}"
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
|
-
def sync_repos
|
26
|
-
"pacman -Syy"
|
27
|
-
end
|
28
|
-
|
29
|
-
def install(package)
|
30
|
-
"pacman -S --noconfirm #{package}"
|
31
|
-
end
|
32
|
-
|
33
|
-
def get_package_version(package, opts=nil)
|
34
|
-
"pacman -Qi #{package} | grep Version | awk '{print $3}'"
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
end
|
1
|
+
module Specinfra::Command::Arch; end
|
@@ -0,0 +1,22 @@
|
|
1
|
+
class Specinfra::Command::Arch::Base::Package < Specinfra::Command::Linux::Base::Package
|
2
|
+
def check_is_installed(package,version=nil)
|
3
|
+
if version
|
4
|
+
"pacman -Q | grep #{escape(package)} #{escape(version)}"
|
5
|
+
else
|
6
|
+
"pacman -Q | grep #{escape(package)}"
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
def get_version(package, opts=nil)
|
11
|
+
"pacman -Qi #{package} | grep Version | awk '{print $3}'"
|
12
|
+
end
|
13
|
+
|
14
|
+
def install(package)
|
15
|
+
"pacman -S --noconfirm #{package}"
|
16
|
+
end
|
17
|
+
|
18
|
+
# Should this method be here or not ?
|
19
|
+
def sync_repos
|
20
|
+
"pacman -Syy"
|
21
|
+
end
|
22
|
+
end
|
@@ -1,354 +1,94 @@
|
|
1
1
|
require 'shellwords'
|
2
|
+
class Specinfra::Command::Base
|
3
|
+
attr_accessor :types
|
2
4
|
|
3
|
-
|
4
|
-
module Command
|
5
|
-
class Base
|
6
|
-
class NotImplementedError < Exception; end
|
5
|
+
class NotImplementedError < Exception; end
|
7
6
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
target.source
|
12
|
-
else
|
13
|
-
target.to_s
|
14
|
-
end
|
15
|
-
|
16
|
-
Shellwords.shellescape(str)
|
17
|
-
end
|
18
|
-
|
19
|
-
def check_enabled(service, level=3)
|
20
|
-
raise NotImplementedError.new
|
21
|
-
end
|
22
|
-
|
23
|
-
def check_yumrepo(repository)
|
24
|
-
raise NotImplementedError.new
|
25
|
-
end
|
26
|
-
|
27
|
-
def check_yumrepo_enabled(repository)
|
28
|
-
raise NotImplementedError.new
|
29
|
-
end
|
30
|
-
|
31
|
-
def check_mounted(path)
|
32
|
-
regexp = "on #{path}"
|
33
|
-
"mount | grep -w -- #{escape(regexp)}"
|
34
|
-
end
|
35
|
-
|
36
|
-
def check_routing_table(destination)
|
37
|
-
"ip route | grep -E '^#{destination} |^default '"
|
38
|
-
end
|
39
|
-
|
40
|
-
def check_reachable(host, port, proto, timeout)
|
41
|
-
if port.nil?
|
42
|
-
"ping -w #{escape(timeout)} -c 2 -n #{escape(host)}"
|
43
|
-
else
|
44
|
-
"nc -vvvvz#{escape(proto[0].chr)} #{escape(host)} #{escape(port)} -w #{escape(timeout)}"
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
def check_resolvable(name, type)
|
49
|
-
if type == "dns"
|
50
|
-
"nslookup -timeout=1 #{escape(name)}"
|
51
|
-
elsif type == "hosts"
|
52
|
-
"grep -w -- #{escape(name)} /etc/hosts"
|
53
|
-
else
|
54
|
-
"getent hosts #{escape(name)}"
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
def check_file(file)
|
59
|
-
"test -f #{escape(file)}"
|
60
|
-
end
|
61
|
-
|
62
|
-
def get_file_mtime(file)
|
63
|
-
"stat -c %Y #{escape(file)}"
|
64
|
-
end
|
65
|
-
|
66
|
-
def get_file_size(file)
|
67
|
-
"stat -c %s #{escape(file)}"
|
68
|
-
end
|
69
|
-
|
70
|
-
def check_socket(file)
|
71
|
-
"test -S #{escape(file)}"
|
72
|
-
end
|
73
|
-
|
74
|
-
def check_directory(directory)
|
75
|
-
"test -d #{escape(directory)}"
|
76
|
-
end
|
77
|
-
|
78
|
-
def check_user(user)
|
79
|
-
"id #{escape(user)}"
|
80
|
-
end
|
81
|
-
|
82
|
-
def check_group(group)
|
83
|
-
"getent group #{escape(group)}"
|
84
|
-
end
|
85
|
-
|
86
|
-
def check_installed(package, version=nil)
|
87
|
-
raise NotImplementedError.new
|
88
|
-
end
|
89
|
-
|
90
|
-
def check_service_installed(service)
|
91
|
-
raise NotImplementedError.new
|
92
|
-
end
|
93
|
-
|
94
|
-
def check_service_start_mode(service, mode)
|
95
|
-
raise NotImplementedError.new
|
96
|
-
end
|
97
|
-
|
98
|
-
def check_listening(port, options = {})
|
99
|
-
pattern = ":#{port}"
|
100
|
-
pattern = " #{options[:local_address]}#{pattern}" if options[:local_address]
|
101
|
-
pattern = "^#{options[:protocol]} .*#{pattern}" if options[:protocol]
|
102
|
-
"netstat -tunl | grep -- #{escape(pattern)}"
|
103
|
-
end
|
104
|
-
|
105
|
-
def check_listening_with_protocol(port, protocol)
|
106
|
-
check_listening port, {:protocol => protocol}
|
107
|
-
end
|
108
|
-
|
109
|
-
def check_running(service)
|
110
|
-
"service #{escape(service)} status"
|
111
|
-
end
|
112
|
-
|
113
|
-
def check_running_under_supervisor(service)
|
114
|
-
"supervisorctl status #{escape(service)} | grep RUNNING"
|
115
|
-
end
|
116
|
-
|
117
|
-
def check_running_under_upstart(service)
|
118
|
-
"initctl status #{escape(service)} | grep running"
|
119
|
-
end
|
120
|
-
|
121
|
-
def check_monitored_by_monit(service)
|
122
|
-
"monit status"
|
123
|
-
end
|
124
|
-
|
125
|
-
def check_monitored_by_god(service)
|
126
|
-
"god status #{escape(service)}"
|
127
|
-
end
|
128
|
-
|
129
|
-
def check_process(process)
|
130
|
-
"ps aux | grep -w -- #{escape(process)} | grep -qv grep"
|
131
|
-
end
|
132
|
-
|
133
|
-
def check_process_count(process,count)
|
134
|
-
"test $(ps aux | grep -w -- #{escape(process)} | grep -v grep | wc -l) -eq #{escape(count)}"
|
135
|
-
end
|
136
|
-
|
137
|
-
def get_process(process, opts)
|
138
|
-
"ps -C #{escape(process)} -o #{opts[:format]} | head -1"
|
139
|
-
end
|
140
|
-
|
141
|
-
def check_file_contain(file, expected_pattern)
|
142
|
-
"#{check_file_contain_with_regexp(file, expected_pattern)} || #{check_file_contain_with_fixed_strings(file, expected_pattern)}"
|
143
|
-
end
|
144
|
-
|
145
|
-
def check_file_contain_with_regexp(file, expected_pattern)
|
146
|
-
"grep -q -- #{escape(expected_pattern)} #{escape(file)}"
|
147
|
-
end
|
148
|
-
|
149
|
-
def check_file_contain_with_fixed_strings(file, expected_pattern)
|
150
|
-
"grep -qF -- #{escape(expected_pattern)} #{escape(file)}"
|
151
|
-
end
|
152
|
-
|
153
|
-
def check_file_checksum(file, expected)
|
154
|
-
regexp = "^#{expected}"
|
155
|
-
"cksum #{escape(file)} | grep -iw -- #{escape(regexp)}"
|
156
|
-
end
|
157
|
-
|
158
|
-
def check_file_md5checksum(file, expected)
|
159
|
-
regexp = "^#{expected}"
|
160
|
-
"md5sum #{escape(file)} | grep -iw -- #{escape(regexp)}"
|
161
|
-
end
|
162
|
-
|
163
|
-
def check_file_sha256checksum(file, expected)
|
164
|
-
regexp = "^#{expected}"
|
165
|
-
"sha256sum #{escape(file)} | grep -iw -- #{escape(regexp)}"
|
166
|
-
end
|
167
|
-
|
168
|
-
def check_file_contain_within(file, expected_pattern, from=nil, to=nil)
|
169
|
-
from ||= '1'
|
170
|
-
to ||= '$'
|
171
|
-
sed = "sed -n #{escape(from)},#{escape(to)}p #{escape(file)}"
|
172
|
-
checker_with_regexp = check_file_contain_with_regexp("-", expected_pattern)
|
173
|
-
checker_with_fixed = check_file_contain_with_fixed_strings("-", expected_pattern)
|
174
|
-
"#{sed} | #{checker_with_regexp} || #{sed} | #{checker_with_fixed}"
|
175
|
-
end
|
176
|
-
|
177
|
-
def check_file_contain_lines(file, expected_lines, from=nil, to=nil)
|
178
|
-
require 'digest/md5'
|
179
|
-
from ||= '1'
|
180
|
-
to ||= '$'
|
181
|
-
sed = "sed -n #{escape(from)},#{escape(to)}p #{escape(file)}"
|
182
|
-
head_line = expected_lines.first.chomp
|
183
|
-
lines_checksum = Digest::MD5.hexdigest(expected_lines.map(&:chomp).join("\n") + "\n")
|
184
|
-
afterwards_length = expected_lines.length - 1
|
185
|
-
"#{sed} | grep -A #{escape(afterwards_length)} -F -- #{escape(head_line)} | md5sum | grep -qiw -- #{escape(lines_checksum)}"
|
186
|
-
end
|
187
|
-
|
188
|
-
def check_mode(file, mode)
|
189
|
-
regexp = "^#{mode}$"
|
190
|
-
"stat -c %a #{escape(file)} | grep -- #{escape(regexp)}"
|
191
|
-
end
|
192
|
-
|
193
|
-
def check_owner(file, owner)
|
194
|
-
regexp = "^#{owner}$"
|
195
|
-
"stat -c %U #{escape(file)} | grep -- #{escape(regexp)}"
|
196
|
-
end
|
197
|
-
|
198
|
-
def check_grouped(file, group)
|
199
|
-
regexp = "^#{group}$"
|
200
|
-
"stat -c %G #{escape(file)} | grep -- #{escape(regexp)}"
|
201
|
-
end
|
202
|
-
|
203
|
-
def check_cron_entry(user, entry)
|
204
|
-
entry_escaped = entry.gsub(/\*/, '\\*').gsub(/\[/, '\\[').gsub(/\]/, '\\]')
|
205
|
-
if user.nil?
|
206
|
-
"crontab -l | grep -v \"#\" -- | grep -- #{escape(entry_escaped)}"
|
207
|
-
else
|
208
|
-
"crontab -u #{escape(user)} -l | grep -v \"#\" | grep -- #{escape(entry_escaped)}"
|
209
|
-
end
|
210
|
-
end
|
211
|
-
|
212
|
-
def check_link(link, target)
|
213
|
-
"stat -c %N #{escape(link)} | egrep -e \"-> .#{escape(target)}.\""
|
214
|
-
end
|
215
|
-
|
216
|
-
def check_installed_by_gem(name, version=nil)
|
217
|
-
regexp = "^#{name}"
|
218
|
-
cmd = "gem list --local | grep -w -- #{escape(regexp)}"
|
219
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
220
|
-
cmd
|
221
|
-
end
|
222
|
-
|
223
|
-
def check_installed_by_npm(name, version=nil)
|
224
|
-
cmd = "npm ls #{escape(name)} -g"
|
225
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
226
|
-
cmd
|
227
|
-
end
|
228
|
-
|
229
|
-
def check_installed_by_pecl(name, version=nil)
|
230
|
-
regexp = "^#{name}"
|
231
|
-
cmd = "pecl list | grep -w -- #{escape(regexp)}"
|
232
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
233
|
-
cmd
|
234
|
-
end
|
235
|
-
|
236
|
-
def check_installed_by_pear(name, version=nil)
|
237
|
-
regexp = "^#{name}"
|
238
|
-
cmd = "pear list | grep -w -- #{escape(regexp)}"
|
239
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
240
|
-
cmd
|
241
|
-
end
|
242
|
-
|
243
|
-
def check_installed_by_pip(name, version=nil)
|
244
|
-
regexp = "^#{name}"
|
245
|
-
cmd = "pip list | grep -w -- #{escape(regexp)}"
|
246
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
247
|
-
cmd
|
248
|
-
end
|
249
|
-
|
250
|
-
def check_installed_by_cpan(name, version=nil)
|
251
|
-
regexp = "^#{name}"
|
252
|
-
cmd = "cpan -l | grep -w -- #{escape(regexp)}"
|
253
|
-
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
254
|
-
cmd
|
255
|
-
end
|
256
|
-
|
257
|
-
def check_belonging_group(user, group)
|
258
|
-
"id #{escape(user)} | awk '{print $3}' | grep -- #{escape(group)}"
|
259
|
-
end
|
260
|
-
|
261
|
-
def check_gid(group, gid)
|
262
|
-
regexp = "^#{group}"
|
263
|
-
"getent group | grep -w -- #{escape(regexp)} | cut -f 3 -d ':' | grep -w -- #{escape(gid)}"
|
264
|
-
end
|
265
|
-
|
266
|
-
def check_uid(user, uid)
|
267
|
-
regexp = "^uid=#{uid}("
|
268
|
-
"id #{escape(user)} | grep -- #{escape(regexp)}"
|
269
|
-
end
|
270
|
-
|
271
|
-
def check_login_shell(user, path_to_shell)
|
272
|
-
"getent passwd #{escape(user)} | cut -f 7 -d ':' | grep -w -- #{escape(path_to_shell)}"
|
273
|
-
end
|
274
|
-
|
275
|
-
def check_home_directory(user, path_to_home)
|
276
|
-
"getent passwd #{escape(user)} | cut -f 6 -d ':' | grep -w -- #{escape(path_to_home)}"
|
277
|
-
end
|
278
|
-
|
279
|
-
def check_authorized_key(user, key)
|
280
|
-
key.sub!(/\s+\S*$/, '') if key.match(/^\S+\s+\S+\s+\S*$/)
|
281
|
-
"grep -w -- #{escape(key)} ~#{escape(user)}/.ssh/authorized_keys"
|
282
|
-
end
|
283
|
-
|
284
|
-
def check_iptables_rule(rule, table=nil, chain=nil)
|
285
|
-
raise NotImplementedError.new
|
286
|
-
end
|
287
|
-
|
288
|
-
def check_zfs(zfs, property=nil, value=nil)
|
289
|
-
raise NotImplementedError.new
|
290
|
-
end
|
291
|
-
|
292
|
-
def get_mode(file)
|
293
|
-
"stat -c %a #{escape(file)}"
|
294
|
-
end
|
295
|
-
|
296
|
-
def check_ipfilter_rule(rule)
|
297
|
-
raise NotImplementedError.new
|
298
|
-
end
|
299
|
-
|
300
|
-
def check_ipnat_rule(rule)
|
301
|
-
raise NotImplementedError.new
|
302
|
-
end
|
7
|
+
def self.create
|
8
|
+
self.new
|
9
|
+
end
|
303
10
|
|
304
|
-
|
305
|
-
|
306
|
-
|
11
|
+
def escape(target)
|
12
|
+
str = case target
|
13
|
+
when Regexp
|
14
|
+
target.source
|
15
|
+
else
|
16
|
+
target.to_s
|
17
|
+
end
|
307
18
|
|
308
|
-
|
309
|
-
|
310
|
-
end
|
19
|
+
Shellwords.shellescape(str)
|
20
|
+
end
|
311
21
|
|
312
|
-
|
313
|
-
|
314
|
-
|
22
|
+
def method_missing(meth, *args)
|
23
|
+
action, resource_type, subaction = breakdown(meth)
|
24
|
+
method = action
|
25
|
+
method += "_#{subaction}" if subaction
|
26
|
+
command_object = command_class(resource_type).create
|
27
|
+
if command_object.respond_to?(method)
|
28
|
+
command_object.send(method, *args)
|
29
|
+
else
|
30
|
+
raise NotImplementedError.new("#{method} is not implemented in #{command_class(resource_type)}")
|
31
|
+
end
|
32
|
+
end
|
315
33
|
|
316
|
-
|
317
|
-
|
318
|
-
|
34
|
+
def command_class(resource_type)
|
35
|
+
family = os[:family]
|
36
|
+
version = os[:release] ? "V#{os[:release].to_i}" : nil
|
319
37
|
|
320
|
-
|
321
|
-
|
322
|
-
|
38
|
+
common_class = self.class.const_get('Specinfra').const_get('Command')
|
39
|
+
base_class = common_class.const_get('Base')
|
40
|
+
os_class = family.nil? ? base_class : common_class.const_get(family.capitalize)
|
323
41
|
|
324
|
-
|
325
|
-
|
42
|
+
if family && version
|
43
|
+
begin
|
44
|
+
version_class = os_class.const_get(version)
|
45
|
+
rescue
|
46
|
+
version_class = os_class.const_get('Base')
|
326
47
|
end
|
48
|
+
elsif family.nil?
|
49
|
+
version_class = os_class
|
50
|
+
elsif family != 'base' && version.nil?
|
51
|
+
version_class = os_class.const_get('Base')
|
52
|
+
end
|
327
53
|
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
54
|
+
begin
|
55
|
+
command_klass = version_class.const_get(resource_type.to_camel_case)
|
56
|
+
rescue
|
57
|
+
end
|
332
58
|
|
333
|
-
|
334
|
-
|
335
|
-
|
59
|
+
if command_klass.nil? ||( (command_klass < Specinfra::Command::Base).nil? && (command_klass < Specinfra::Command::Windows::Base).nil? )
|
60
|
+
command_klass = base_class.const_get(resource_type.to_camel_case)
|
61
|
+
end
|
336
62
|
|
337
|
-
|
338
|
-
|
339
|
-
end
|
63
|
+
command_klass
|
64
|
+
end
|
340
65
|
|
341
|
-
|
342
|
-
|
343
|
-
|
66
|
+
private
|
67
|
+
def breakdown(meth)
|
68
|
+
types = resource_types.map {|t| t.to_snake_case }.join('|')
|
69
|
+
md = meth.to_s.match(/^([^_]+)_(#{types})_?(.+)?$/)
|
70
|
+
if md.nil?
|
71
|
+
message = "Could not break down `#{meth}' to appropriate type and method.\n"
|
72
|
+
message += "The method name shoud be in the form of `action_type_subaction'."
|
73
|
+
raise message
|
74
|
+
end
|
75
|
+
return md[1], md[2], md[3]
|
76
|
+
end
|
344
77
|
|
345
|
-
|
346
|
-
|
78
|
+
def resource_types
|
79
|
+
if @types.nil?
|
80
|
+
@types = []
|
81
|
+
Specinfra::Command::Base.subclasses.each do |s|
|
82
|
+
@types << s.to_s.split(':')[-1]
|
347
83
|
end
|
348
|
-
|
349
|
-
|
350
|
-
"getent hosts #{escape(name)} | awk '{print $1}'"
|
84
|
+
Specinfra::Command::Windows::Base.subclasses.each do |s|
|
85
|
+
@types << s.to_s.split(':')[-1]
|
351
86
|
end
|
87
|
+
@types.uniq!
|
352
88
|
end
|
89
|
+
@types
|
353
90
|
end
|
354
91
|
end
|
92
|
+
|
93
|
+
|
94
|
+
|