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.
Files changed (194) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +2 -2
  3. data/lib/specinfra.rb +25 -0
  4. data/lib/specinfra/backend/exec.rb +15 -103
  5. data/lib/specinfra/backend/ssh.rb +1 -1
  6. data/lib/specinfra/command.rb +208 -29
  7. data/lib/specinfra/command/aix.rb +1 -66
  8. data/lib/specinfra/command/aix/base.rb +2 -0
  9. data/lib/specinfra/command/aix/base/file.rb +19 -0
  10. data/lib/specinfra/command/aix/base/group.rb +6 -0
  11. data/lib/specinfra/command/aix/base/package.rb +9 -0
  12. data/lib/specinfra/command/aix/base/port.rb +6 -0
  13. data/lib/specinfra/command/aix/base/service.rb +9 -0
  14. data/lib/specinfra/command/aix/base/user.rb +13 -0
  15. data/lib/specinfra/command/arch.rb +1 -38
  16. data/lib/specinfra/command/arch/base.rb +11 -0
  17. data/lib/specinfra/command/arch/base/file.rb +5 -0
  18. data/lib/specinfra/command/arch/base/package.rb +22 -0
  19. data/lib/specinfra/command/arch/base/service.rb +3 -0
  20. data/lib/specinfra/command/base.rb +74 -334
  21. data/lib/specinfra/command/base/cron.rb +10 -0
  22. data/lib/specinfra/command/base/file.rb +95 -0
  23. data/lib/specinfra/command/base/group.rb +10 -0
  24. data/lib/specinfra/command/base/host.rb +23 -0
  25. data/lib/specinfra/command/base/interface.rb +2 -0
  26. data/lib/specinfra/command/base/ipfilter.rb +2 -0
  27. data/lib/specinfra/command/base/ipnat.rb +2 -0
  28. data/lib/specinfra/command/base/iptables.rb +2 -0
  29. data/lib/specinfra/command/base/kernel_module.rb +2 -0
  30. data/lib/specinfra/command/base/lxc_container.rb +2 -0
  31. data/lib/specinfra/command/base/mail_alias.rb +6 -0
  32. data/lib/specinfra/command/base/package.rb +43 -0
  33. data/lib/specinfra/command/base/port.rb +8 -0
  34. data/lib/specinfra/command/base/ppa.rb +2 -0
  35. data/lib/specinfra/command/base/process.rb +14 -0
  36. data/lib/specinfra/command/base/routing_table.rb +5 -0
  37. data/lib/specinfra/command/base/selinux.rb +2 -0
  38. data/lib/specinfra/command/base/service.rb +25 -0
  39. data/lib/specinfra/command/base/user.rb +31 -0
  40. data/lib/specinfra/command/base/yumrepo.rb +3 -0
  41. data/lib/specinfra/command/base/zfs.rb +1 -0
  42. data/lib/specinfra/command/darwin.rb +1 -67
  43. data/lib/specinfra/command/darwin/base.rb +2 -0
  44. data/lib/specinfra/command/darwin/base/file.rb +37 -0
  45. data/lib/specinfra/command/darwin/base/package.rb +15 -0
  46. data/lib/specinfra/command/darwin/base/port.rb +6 -0
  47. data/lib/specinfra/command/darwin/base/service.rb +9 -0
  48. data/lib/specinfra/command/debian.rb +1 -31
  49. data/lib/specinfra/command/debian/base.rb +11 -0
  50. data/lib/specinfra/command/debian/base/package.rb +22 -0
  51. data/lib/specinfra/command/debian/base/ppa.rb +2 -0
  52. data/lib/specinfra/command/debian/base/service.rb +6 -0
  53. data/lib/specinfra/command/fedora.rb +1 -29
  54. data/lib/specinfra/command/fedora/base.rb +2 -0
  55. data/lib/specinfra/command/fedora/base/service.rb +10 -0
  56. data/lib/specinfra/command/fedora/v15.rb +1 -0
  57. data/lib/specinfra/command/fedora/v15/service.rb +3 -0
  58. data/lib/specinfra/command/freebsd.rb +1 -39
  59. data/lib/specinfra/command/freebsd/base.rb +3 -0
  60. data/lib/specinfra/command/freebsd/base/file.rb +10 -0
  61. data/lib/specinfra/command/freebsd/base/package.rb +17 -0
  62. data/lib/specinfra/command/freebsd/base/port.rb +6 -0
  63. data/lib/specinfra/command/freebsd/base/service.rb +5 -0
  64. data/lib/specinfra/command/freebsd/v10.rb +1 -0
  65. data/lib/specinfra/command/freebsd/v10/package.rb +17 -0
  66. data/lib/specinfra/command/gentoo.rb +1 -18
  67. data/lib/specinfra/command/gentoo/base.rb +2 -0
  68. data/lib/specinfra/command/gentoo/base/package.rb +5 -0
  69. data/lib/specinfra/command/gentoo/base/service.rb +17 -0
  70. data/lib/specinfra/command/linux.rb +1 -71
  71. data/lib/specinfra/command/linux/base.rb +2 -0
  72. data/lib/specinfra/command/linux/base/file.rb +13 -0
  73. data/lib/specinfra/command/linux/base/interface.rb +17 -0
  74. data/lib/specinfra/command/linux/base/iptables.rb +10 -0
  75. data/lib/specinfra/command/linux/base/kernel_module.rb +5 -0
  76. data/lib/specinfra/command/linux/base/lxc_container.rb +9 -0
  77. data/lib/specinfra/command/linux/base/package.rb +2 -0
  78. data/lib/specinfra/command/linux/base/ppa.rb +2 -0
  79. data/lib/specinfra/command/linux/base/selinux.rb +10 -0
  80. data/lib/specinfra/command/linux/base/service.rb +2 -0
  81. data/lib/specinfra/command/linux/base/yumrepo.rb +2 -0
  82. data/lib/specinfra/command/linux/base/zfs.rb +3 -0
  83. data/lib/specinfra/command/module.rb +2 -0
  84. data/lib/specinfra/command/module/systemd.rb +13 -0
  85. data/lib/specinfra/command/module/zfs.rb +14 -0
  86. data/lib/specinfra/command/nixos.rb +1 -28
  87. data/lib/specinfra/command/nixos/base.rb +2 -0
  88. data/lib/specinfra/command/nixos/base/package.rb +15 -0
  89. data/lib/specinfra/command/nixos/base/service.rb +3 -0
  90. data/lib/specinfra/command/openbsd.rb +1 -91
  91. data/lib/specinfra/command/openbsd/base.rb +4 -0
  92. data/lib/specinfra/command/openbsd/base/file.rb +39 -0
  93. data/lib/specinfra/command/openbsd/base/interface.rb +9 -0
  94. data/lib/specinfra/command/openbsd/base/mail_alias.rb +5 -0
  95. data/lib/specinfra/command/openbsd/base/package.rb +13 -0
  96. data/lib/specinfra/command/openbsd/base/port.rb +5 -0
  97. data/lib/specinfra/command/openbsd/base/service.rb +9 -0
  98. data/lib/specinfra/command/openbsd/base/user.rb +16 -0
  99. data/lib/specinfra/command/opensuse.rb +1 -14
  100. data/lib/specinfra/command/opensuse/base.rb +3 -0
  101. data/lib/specinfra/command/opensuse/base/service.rb +3 -0
  102. data/lib/specinfra/command/plamo.rb +1 -21
  103. data/lib/specinfra/command/plamo/base.rb +3 -0
  104. data/lib/specinfra/command/plamo/base/package.rb +9 -0
  105. data/lib/specinfra/command/plamo/base/service.rb +12 -0
  106. data/lib/specinfra/command/redhat.rb +1 -40
  107. data/lib/specinfra/command/redhat/base.rb +2 -0
  108. data/lib/specinfra/command/redhat/base/file.rb +6 -0
  109. data/lib/specinfra/command/redhat/base/iptables.rb +11 -0
  110. data/lib/specinfra/command/redhat/base/package.rb +28 -0
  111. data/lib/specinfra/command/redhat/base/service.rb +12 -0
  112. data/lib/specinfra/command/redhat/base/yumrepo.rb +11 -0
  113. data/lib/specinfra/command/redhat/v5.rb +2 -0
  114. data/lib/specinfra/command/redhat/v5/iptables.rb +8 -0
  115. data/lib/specinfra/command/redhat/v7.rb +2 -0
  116. data/lib/specinfra/command/redhat/v7/service.rb +3 -0
  117. data/lib/specinfra/command/smartos.rb +1 -25
  118. data/lib/specinfra/command/smartos/base.rb +3 -0
  119. data/lib/specinfra/command/smartos/base/package.rb +13 -0
  120. data/lib/specinfra/command/smartos/base/service.rb +9 -0
  121. data/lib/specinfra/command/smartos/tmp.rb +8 -0
  122. data/lib/specinfra/command/solaris.rb +1 -117
  123. data/lib/specinfra/command/solaris/base.rb +2 -0
  124. data/lib/specinfra/command/solaris/base/cron.rb +10 -0
  125. data/lib/specinfra/command/solaris/base/file.rb +17 -0
  126. data/lib/specinfra/command/solaris/base/group.rb +6 -0
  127. data/lib/specinfra/command/solaris/base/host.rb +12 -0
  128. data/lib/specinfra/command/solaris/base/ipfilter.rb +5 -0
  129. data/lib/specinfra/command/solaris/base/ipnat.rb +12 -0
  130. data/lib/specinfra/command/solaris/base/package.rb +12 -0
  131. data/lib/specinfra/command/solaris/base/port.rb +11 -0
  132. data/lib/specinfra/command/solaris/base/service.rb +19 -0
  133. data/lib/specinfra/command/solaris/base/user.rb +13 -0
  134. data/lib/specinfra/command/solaris/base/zfs.rb +11 -0
  135. data/lib/specinfra/command/solaris/v10.rb +1 -0
  136. data/lib/specinfra/command/solaris/v10/file.rb +40 -0
  137. data/lib/specinfra/command/solaris/v10/group.rb +5 -0
  138. data/lib/specinfra/command/solaris/v10/host.rb +11 -0
  139. data/lib/specinfra/command/solaris/v10/package.rb +9 -0
  140. data/lib/specinfra/command/solaris/v10/user.rb +16 -0
  141. data/lib/specinfra/command/suse.rb +1 -27
  142. data/lib/specinfra/command/suse/base.rb +2 -0
  143. data/lib/specinfra/command/suse/base/package.rb +19 -0
  144. data/lib/specinfra/command/suse/base/service.rb +12 -0
  145. data/lib/specinfra/command/ubuntu.rb +11 -23
  146. data/lib/specinfra/command/ubuntu/base.rb +2 -0
  147. data/lib/specinfra/command/ubuntu/base/ppa.rb +15 -0
  148. data/lib/specinfra/command/ubuntu/base/service.rb +5 -0
  149. data/lib/specinfra/command/windows.rb +1 -344
  150. data/lib/specinfra/command/windows/base.rb +14 -0
  151. data/lib/specinfra/command/windows/base/feature.rb +15 -0
  152. data/lib/specinfra/command/windows/base/file.rb +103 -0
  153. data/lib/specinfra/command/windows/base/group.rb +9 -0
  154. data/lib/specinfra/command/windows/base/host.rb +23 -0
  155. data/lib/specinfra/command/windows/base/hot_fix.rb +17 -0
  156. data/lib/specinfra/command/windows/base/iis_app_pool.rb +15 -0
  157. data/lib/specinfra/command/windows/base/iis_website.rb +36 -0
  158. data/lib/specinfra/command/windows/base/package.rb +9 -0
  159. data/lib/specinfra/command/windows/base/port.rb +15 -0
  160. data/lib/specinfra/command/windows/base/process.rb +7 -0
  161. data/lib/specinfra/command/windows/base/registry_key.rb +43 -0
  162. data/lib/specinfra/command/windows/base/scheduled_task.rb +8 -0
  163. data/lib/specinfra/command/windows/base/service.rb +29 -0
  164. data/lib/specinfra/command/windows/base/user.rb +20 -0
  165. data/lib/specinfra/configuration.rb +2 -1
  166. data/lib/specinfra/helper.rb +1 -1
  167. data/lib/specinfra/helper/backend.rb +1 -1
  168. data/lib/specinfra/helper/detect_os.rb +15 -21
  169. data/lib/specinfra/helper/detect_os/aix.rb +7 -0
  170. data/lib/specinfra/helper/detect_os/arch.rb +7 -0
  171. data/lib/specinfra/helper/detect_os/darwin.rb +7 -0
  172. data/lib/specinfra/helper/detect_os/debian.rb +24 -0
  173. data/lib/specinfra/helper/detect_os/freebsd.rb +11 -0
  174. data/lib/specinfra/helper/detect_os/gentoo.rb +7 -0
  175. data/lib/specinfra/helper/detect_os/nixos.rb +7 -0
  176. data/lib/specinfra/helper/detect_os/openbsd.rb +7 -0
  177. data/lib/specinfra/helper/detect_os/plamo.rb +7 -0
  178. data/lib/specinfra/helper/detect_os/redhat.rb +27 -0
  179. data/lib/specinfra/helper/detect_os/solaris.rb +15 -0
  180. data/lib/specinfra/helper/detect_os/suse.rb +15 -0
  181. data/lib/specinfra/helper/os.rb +47 -33
  182. data/lib/specinfra/version.rb +1 -1
  183. data/spec/backend/exec/build_command_spec.rb +16 -11
  184. data/spec/command/base/file_spec.rb +11 -0
  185. data/spec/command/base_spec.rb +28 -0
  186. data/spec/command/module/systemd_spec.rb +8 -0
  187. data/spec/command/redhat/package_spec.rb +12 -0
  188. data/spec/helper/os_spec.rb +58 -0
  189. metadata +163 -8
  190. data/lib/specinfra/command/freebsd10.rb +0 -21
  191. data/lib/specinfra/command/redhat7.rb +0 -9
  192. data/lib/specinfra/command/solaris10.rb +0 -78
  193. data/lib/specinfra/command/solaris11.rb +0 -7
  194. 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,2 @@
1
+ class Specinfra::Command::Aix::Base < Specinfra::Command::Base
2
+ 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,6 @@
1
+ class Specinfra::Command::Aix::Base::Group < Specinfra::Command::Base::Group
2
+ def check_has_gid(group, gid)
3
+ regexp = "^#{group}"
4
+ "cat etc/group | grep -w -- #{escape(regexp)} | cut -f 3 -d ':' | grep -w -- #{escape(gid)}"
5
+ end
6
+ 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,6 @@
1
+ class Specinfra::Command::Aix::Base::Port < Specinfra::Command::Base::Port
2
+ def check_is_listening(port, options={})
3
+ regexp = "*.#{port} "
4
+ "netstat -an -f inet | awk '{print $4}' | grep -- #{regexp}"
5
+ end
6
+ 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,11 @@
1
+ class Specinfra::Command::Arch::Base < Specinfra::Command::Linux::Base
2
+ end
3
+
4
+
5
+
6
+
7
+
8
+
9
+
10
+
11
+
@@ -0,0 +1,5 @@
1
+ class Specinfra::Command::Arch::Base::File < Specinfra::Command::Linux::Base::File
2
+ def check_access_by_user(file, user, access)
3
+ "runuser -s /bin/sh -c \"test -#{access} #{file}\" #{user}"
4
+ end
5
+ 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
@@ -0,0 +1,3 @@
1
+ class Specinfra::Command::Arch::Base::Service < Specinfra::Command::Linux::Base::Service
2
+ include Specinfra::Command::Module::Systemd
3
+ end
@@ -1,354 +1,94 @@
1
1
  require 'shellwords'
2
+ class Specinfra::Command::Base
3
+ attr_accessor :types
2
4
 
3
- module Specinfra
4
- module Command
5
- class Base
6
- class NotImplementedError < Exception; end
5
+ class NotImplementedError < Exception; end
7
6
 
8
- def escape(target)
9
- str = case target
10
- when Regexp
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
- def check_svcprop(svc, property, value)
305
- raise NotImplementedError.new
306
- end
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
- def check_svcprops(svc, property)
309
- raise NotImplementedError.new
310
- end
19
+ Shellwords.shellescape(str)
20
+ end
311
21
 
312
- def check_selinux(mode)
313
- raise NotImplementedError.new
314
- end
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
- def check_access_by_user(file, user, access)
317
- raise NotImplementedError.new
318
- end
34
+ def command_class(resource_type)
35
+ family = os[:family]
36
+ version = os[:release] ? "V#{os[:release].to_i}" : nil
319
37
 
320
- def check_kernel_module_loaded(name)
321
- raise NotImplementedError.new
322
- end
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
- def check_ipv4_address(interface, ip_address)
325
- raise NotImplementedError.new
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
- def check_mail_alias(recipient, target)
329
- target = "[[:space:]]#{target}"
330
- "getent aliases #{escape(recipient)} | grep -- #{escape(target)}$"
331
- end
54
+ begin
55
+ command_klass = version_class.const_get(resource_type.to_camel_case)
56
+ rescue
57
+ end
332
58
 
333
- def get_file_content(file)
334
- "cat #{file} 2> /dev/null || echo -n"
335
- end
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
- def check_container(container)
338
- raise NotImplementedError.new
339
- end
63
+ command_klass
64
+ end
340
65
 
341
- def check_cotainer_running(container)
342
- raise NotImplementedError.new
343
- end
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
- def get_package_version(package, opts=nil)
346
- raise NotImplementedError.new
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
- def get_ipaddress_of_host(name)
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
+