specinfra 2.0.0.beta15 → 2.0.0.beta16
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/specinfra.rb +1 -1
- data/lib/specinfra/command/aix/base/file.rb +15 -13
- data/lib/specinfra/command/aix/base/group.rb +5 -3
- data/lib/specinfra/command/aix/base/package.rb +7 -5
- data/lib/specinfra/command/aix/base/port.rb +5 -3
- data/lib/specinfra/command/aix/base/service.rb +7 -5
- data/lib/specinfra/command/aix/base/user.rb +10 -8
- data/lib/specinfra/command/arch/base/file.rb +4 -2
- data/lib/specinfra/command/arch/base/package.rb +17 -15
- data/lib/specinfra/command/arch/base/service.rb +3 -1
- data/lib/specinfra/command/base.rb +70 -68
- data/lib/specinfra/command/base/cron.rb +8 -6
- data/lib/specinfra/command/base/file.rb +94 -92
- data/lib/specinfra/command/base/group.rb +8 -6
- data/lib/specinfra/command/base/host.rb +18 -16
- data/lib/specinfra/command/base/mail_alias.rb +5 -3
- data/lib/specinfra/command/base/package.rb +36 -34
- data/lib/specinfra/command/base/port.rb +7 -5
- data/lib/specinfra/command/base/process.rb +10 -9
- data/lib/specinfra/command/base/routing_table.rb +6 -4
- data/lib/specinfra/command/base/service.rb +19 -17
- data/lib/specinfra/command/base/user.rb +24 -22
- data/lib/specinfra/command/darwin/base/file.rb +35 -33
- data/lib/specinfra/command/darwin/base/package.rb +12 -10
- data/lib/specinfra/command/darwin/base/port.rb +5 -3
- data/lib/specinfra/command/darwin/base/service.rb +7 -5
- data/lib/specinfra/command/debian/base/package.rb +16 -14
- data/lib/specinfra/command/debian/base/service.rb +5 -3
- data/lib/specinfra/command/fedora/base/service.rb +7 -6
- data/lib/specinfra/command/fedora/v15/service.rb +3 -1
- data/lib/specinfra/command/freebsd/base/file.rb +8 -6
- data/lib/specinfra/command/freebsd/base/package.rb +13 -11
- data/lib/specinfra/command/freebsd/base/port.rb +5 -3
- data/lib/specinfra/command/freebsd/base/service.rb +4 -2
- data/lib/specinfra/command/freebsd/v10/package.rb +13 -11
- data/lib/specinfra/command/gentoo/base/package.rb +4 -2
- data/lib/specinfra/command/gentoo/base/service.rb +9 -7
- data/lib/specinfra/command/linux/base/file.rb +10 -8
- data/lib/specinfra/command/linux/base/interface.rb +13 -11
- data/lib/specinfra/command/linux/base/iptables.rb +9 -7
- data/lib/specinfra/command/linux/base/kernel_module.rb +4 -2
- data/lib/specinfra/command/linux/base/lxc_container.rb +7 -5
- data/lib/specinfra/command/linux/base/selinux.rb +9 -7
- data/lib/specinfra/command/linux/base/zfs.rb +3 -1
- data/lib/specinfra/command/nixos/base/package.rb +12 -10
- data/lib/specinfra/command/nixos/base/service.rb +3 -1
- data/lib/specinfra/command/openbsd/base/file.rb +31 -29
- data/lib/specinfra/command/openbsd/base/interface.rb +8 -13
- data/lib/specinfra/command/openbsd/base/mail_alias.rb +4 -2
- data/lib/specinfra/command/openbsd/base/package.rb +10 -8
- data/lib/specinfra/command/openbsd/base/port.rb +4 -2
- data/lib/specinfra/command/openbsd/base/service.rb +7 -5
- data/lib/specinfra/command/openbsd/base/user.rb +8 -6
- data/lib/specinfra/command/opensuse/base/service.rb +3 -1
- data/lib/specinfra/command/plamo/base/package.rb +7 -5
- data/lib/specinfra/command/plamo/base/service.rb +6 -4
- data/lib/specinfra/command/redhat/base/file.rb +5 -3
- data/lib/specinfra/command/redhat/base/package.rb +14 -12
- data/lib/specinfra/command/redhat/base/service.rb +4 -2
- data/lib/specinfra/command/redhat/base/yumrepo.rb +7 -5
- data/lib/specinfra/command/redhat/v5/iptables.rb +7 -5
- data/lib/specinfra/command/redhat/v7/service.rb +3 -1
- data/lib/specinfra/command/smartos/base/package.rb +10 -8
- data/lib/specinfra/command/smartos/base/service.rb +7 -5
- data/lib/specinfra/command/solaris/base/cron.rb +8 -6
- data/lib/specinfra/command/solaris/base/file.rb +15 -13
- data/lib/specinfra/command/solaris/base/group.rb +5 -3
- data/lib/specinfra/command/solaris/base/host.rb +7 -5
- data/lib/specinfra/command/solaris/base/ipfilter.rb +4 -2
- data/lib/specinfra/command/solaris/base/ipnat.rb +5 -3
- data/lib/specinfra/command/solaris/base/package.rb +7 -5
- data/lib/specinfra/command/solaris/base/port.rb +9 -7
- data/lib/specinfra/command/solaris/base/service.rb +14 -13
- data/lib/specinfra/command/solaris/base/user.rb +10 -8
- data/lib/specinfra/command/solaris/base/zfs.rb +3 -1
- data/lib/specinfra/command/solaris/v10/file.rb +33 -31
- data/lib/specinfra/command/solaris/v10/group.rb +4 -2
- data/lib/specinfra/command/solaris/v10/host.rb +9 -7
- data/lib/specinfra/command/solaris/v10/package.rb +7 -5
- data/lib/specinfra/command/solaris/v10/user.rb +8 -6
- data/lib/specinfra/command/suse/base/package.rb +14 -12
- data/lib/specinfra/command/suse/base/service.rb +4 -2
- data/lib/specinfra/command/ubuntu/base/ppa.rb +11 -9
- data/lib/specinfra/command/ubuntu/base/service.rb +4 -2
- data/lib/specinfra/command/windows/base.rb +11 -10
- data/lib/specinfra/command/windows/base/feature.rb +11 -9
- data/lib/specinfra/command/windows/base/file.rb +72 -71
- data/lib/specinfra/command/windows/base/group.rb +7 -5
- data/lib/specinfra/command/windows/base/host.rb +18 -16
- data/lib/specinfra/command/windows/base/hot_fix.rb +13 -11
- data/lib/specinfra/command/windows/base/iis_app_pool.rb +11 -9
- data/lib/specinfra/command/windows/base/iis_website.rb +26 -24
- data/lib/specinfra/command/windows/base/package.rb +7 -5
- data/lib/specinfra/command/windows/base/port.rb +11 -9
- data/lib/specinfra/command/windows/base/process.rb +5 -3
- data/lib/specinfra/command/windows/base/registry_key.rb +36 -35
- data/lib/specinfra/command/windows/base/scheduled_task.rb +6 -4
- data/lib/specinfra/command/windows/base/service.rb +21 -19
- data/lib/specinfra/command/windows/base/user.rb +16 -14
- data/lib/specinfra/runner.rb +1 -2
- data/lib/specinfra/version.rb +1 -1
- data/spec/command/base_spec.rb +12 -4
- data/spec/command/module/systemd_spec.rb +14 -4
- data/spec/command/redhat/interface_spec.rb +1 -1
- metadata +1 -2
- data/lib/specinfra/command/smartos/tmp.rb +0 -8
@@ -1,10 +1,12 @@
|
|
1
1
|
class Specinfra::Command::Base::Group < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_exists(group)
|
4
|
+
"getent group #{escape(group)}"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
-
|
8
|
-
|
7
|
+
def check_has_gid(group, gid)
|
8
|
+
regexp = "^#{group}"
|
9
|
+
"getent group | grep -w -- #{escape(regexp)} | cut -f 3 -d ':' | grep -w -- #{escape(gid)}"
|
10
|
+
end
|
9
11
|
end
|
10
12
|
end
|
@@ -1,23 +1,25 @@
|
|
1
1
|
class Specinfra::Command::Base::Host < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_resolvable(name, type)
|
4
|
+
if type == "dns"
|
5
|
+
"nslookup -timeout=1 #{escape(name)}"
|
6
|
+
elsif type == "hosts"
|
7
|
+
"grep -w -- #{escape(name)} /etc/hosts"
|
8
|
+
else
|
9
|
+
"getent hosts #{escape(name)}"
|
10
|
+
end
|
9
11
|
end
|
10
|
-
end
|
11
12
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
13
|
+
def check_is_reachable(host, port, proto, timeout)
|
14
|
+
if port.nil?
|
15
|
+
"ping -w #{escape(timeout)} -c 2 -n #{escape(host)}"
|
16
|
+
else
|
17
|
+
"nc -vvvvz#{escape(proto[0].chr)} #{escape(host)} #{escape(port)} -w #{escape(timeout)}"
|
18
|
+
end
|
17
19
|
end
|
18
|
-
end
|
19
20
|
|
20
|
-
|
21
|
-
|
21
|
+
def get_ipaddress(name)
|
22
|
+
"getent hosts #{escape(name)} | awk '{print $1}'"
|
23
|
+
end
|
22
24
|
end
|
23
25
|
end
|
@@ -1,6 +1,8 @@
|
|
1
1
|
class Specinfra::Command::Base::MailAlias < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_aliased_to(recipient, target)
|
4
|
+
target = "[[:space:]]#{target}"
|
5
|
+
"getent aliases #{escape(recipient)} | grep -- #{escape(target)}$"
|
6
|
+
end
|
5
7
|
end
|
6
8
|
end
|
@@ -1,42 +1,44 @@
|
|
1
1
|
class Specinfra::Command::Base::Package < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_installed_by_gem(name, version=nil)
|
4
|
+
regexp = "^#{name}"
|
5
|
+
cmd = "gem list --local | grep -w -- #{escape(regexp)}"
|
6
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
7
|
+
cmd
|
8
|
+
end
|
8
9
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
10
|
+
def check_is_installed_by_npm(name, version=nil)
|
11
|
+
cmd = "npm ls #{escape(name)} -g"
|
12
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
13
|
+
cmd
|
14
|
+
end
|
14
15
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
16
|
+
def check_is_installed_by_pecl(name, version=nil)
|
17
|
+
regexp = "^#{name}"
|
18
|
+
cmd = "pecl list | grep -w -- #{escape(regexp)}"
|
19
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
20
|
+
cmd
|
21
|
+
end
|
21
22
|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
23
|
+
def check_is_installed_by_pear(name, version=nil)
|
24
|
+
regexp = "^#{name}"
|
25
|
+
cmd = "pear list | grep -w -- #{escape(regexp)}"
|
26
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
27
|
+
cmd
|
28
|
+
end
|
28
29
|
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
30
|
+
def check_is_installed_by_pip(name, version=nil)
|
31
|
+
regexp = "^#{name}"
|
32
|
+
cmd = "pip list | grep -w -- #{escape(regexp)}"
|
33
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
34
|
+
cmd
|
35
|
+
end
|
35
36
|
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
37
|
+
def check_is_installed_by_cpan(name, version=nil)
|
38
|
+
regexp = "^#{name}"
|
39
|
+
cmd = "cpan -l | grep -w -- #{escape(regexp)}"
|
40
|
+
cmd = "#{cmd} | grep -w -- #{escape(version)}" if version
|
41
|
+
cmd
|
42
|
+
end
|
41
43
|
end
|
42
44
|
end
|
@@ -1,8 +1,10 @@
|
|
1
1
|
class Specinfra::Command::Base::Port < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_listening(port, options={})
|
4
|
+
pattern = ":#{port}"
|
5
|
+
pattern = " #{options[:local_address]}#{pattern}" if options[:local_address]
|
6
|
+
pattern = "^#{options[:protocol]} .*#{pattern}" if options[:protocol]
|
7
|
+
"netstat -tunl | grep -- #{escape(pattern)}"
|
8
|
+
end
|
7
9
|
end
|
8
10
|
end
|
@@ -1,14 +1,15 @@
|
|
1
1
|
class Specinfra::Command::Base::Process < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def get(process, opts)
|
4
|
+
"ps -C #{escape(process)} -o #{opts[:format]} | head -1"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
-
|
8
|
-
|
7
|
+
def check_is_running(process)
|
8
|
+
"ps aux | grep -w -- #{escape(process)} | grep -qv grep"
|
9
|
+
end
|
9
10
|
|
10
|
-
|
11
|
-
|
11
|
+
def check_count(process,count)
|
12
|
+
"test $(ps aux | grep -w -- #{escape(process)} | grep -v grep | wc -l) -eq #{escape(count)}"
|
13
|
+
end
|
12
14
|
end
|
13
|
-
|
14
15
|
end
|
@@ -1,7 +1,9 @@
|
|
1
1
|
class Specinfra::Command::Base::RoutingTable < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_has_entry(destination)
|
4
|
+
"ip route | grep -E '^#{destination} |^default '"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
+
alias :get_entry :check_has_entry
|
8
|
+
end
|
7
9
|
end
|
@@ -1,25 +1,27 @@
|
|
1
1
|
class Specinfra::Command::Base::Service < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_running(service)
|
4
|
+
"service #{escape(service)} status"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
-
|
8
|
-
|
7
|
+
def check_is_installed(service, level=3)
|
8
|
+
raise NotImplementedError.new
|
9
|
+
end
|
9
10
|
|
10
|
-
|
11
|
-
|
12
|
-
|
11
|
+
def check_is_running_under_supervisor(service)
|
12
|
+
"supervisorctl status #{escape(service)} | grep RUNNING"
|
13
|
+
end
|
13
14
|
|
14
|
-
|
15
|
-
|
16
|
-
|
15
|
+
def check_is_running_under_upstart(service)
|
16
|
+
"initctl status #{escape(service)} | grep running"
|
17
|
+
end
|
17
18
|
|
18
|
-
|
19
|
-
|
20
|
-
|
19
|
+
def check_is_monitored_by_monit(service)
|
20
|
+
"monit status"
|
21
|
+
end
|
21
22
|
|
22
|
-
|
23
|
-
|
23
|
+
def check_is_monitored_by_god(service)
|
24
|
+
"god status #{escape(service)}"
|
25
|
+
end
|
24
26
|
end
|
25
27
|
end
|
@@ -1,31 +1,33 @@
|
|
1
1
|
class Specinfra::Command::Base::User < Specinfra::Command::Base
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_exists(user)
|
4
|
+
"id #{escape(user)}"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
-
|
8
|
-
|
7
|
+
def check_belongs_to_group(user, group)
|
8
|
+
"id #{escape(user)} | awk '{print $3}' | grep -- #{escape(group)}"
|
9
|
+
end
|
9
10
|
|
10
|
-
|
11
|
-
|
12
|
-
|
11
|
+
def check_belongs_to_primary_group(user, group)
|
12
|
+
"id -gn #{escape(user)}| grep ^#{escape(group)}$"
|
13
|
+
end
|
13
14
|
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
15
|
+
def check_has_uid(user, uid)
|
16
|
+
regexp = "^uid=#{uid}("
|
17
|
+
"id #{escape(user)} | grep -- #{escape(regexp)}"
|
18
|
+
end
|
18
19
|
|
19
|
-
|
20
|
-
|
21
|
-
|
20
|
+
def check_has_home_directory(user, path_to_home)
|
21
|
+
"getent passwd #{escape(user)} | cut -f 6 -d ':' | grep -w -- #{escape(path_to_home)}"
|
22
|
+
end
|
22
23
|
|
23
|
-
|
24
|
-
|
25
|
-
|
24
|
+
def check_has_login_shell(user, path_to_shell)
|
25
|
+
"getent passwd #{escape(user)} | cut -f 7 -d ':' | grep -w -- #{escape(path_to_shell)}"
|
26
|
+
end
|
26
27
|
|
27
|
-
|
28
|
-
|
29
|
-
|
28
|
+
def check_has_authorized_key(user, key)
|
29
|
+
key.sub!(/\s+\S*$/, '') if key.match(/^\S+\s+\S+\s+\S*$/)
|
30
|
+
"grep -w -- #{escape(key)} ~#{escape(user)}/.ssh/authorized_keys"
|
31
|
+
end
|
30
32
|
end
|
31
33
|
end
|
@@ -1,37 +1,39 @@
|
|
1
1
|
class Specinfra::Command::Darwin::Base::File < Specinfra::Command::Base::File
|
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
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_accessible_by_user(file, user, access)
|
4
|
+
"sudo -u #{user} -s /bin/test -#{access} #{file}"
|
5
|
+
end
|
6
|
+
|
7
|
+
def check_has_md5checksum(file, expected)
|
8
|
+
"openssl md5 #{escape(file)} | cut -d'=' -f2 | cut -c 2- | grep -E ^#{escape(expected)}$"
|
9
|
+
end
|
10
|
+
|
11
|
+
def check_has_sha256checksum(file, expected)
|
12
|
+
"openssl sha256 #{escape(file)} | cut -d'=' -f2 | cut -c 2- | grep -E ^#{escape(expected)}$"
|
13
|
+
end
|
14
|
+
|
15
|
+
def check_is_linked_to(link, target)
|
16
|
+
"stat -f %Y #{escape(link)} | grep -- #{escape(target)}"
|
17
|
+
end
|
18
|
+
|
19
|
+
def check_has_mode(file, mode)
|
20
|
+
regexp = "^#{mode}$"
|
21
|
+
"stat -f%Lp #{escape(file)} | grep -- #{escape(regexp)}"
|
22
|
+
end
|
23
|
+
|
24
|
+
def check_is_owned_by(file, owner)
|
25
|
+
regexp = "^#{owner}$"
|
26
|
+
"stat -f %Su #{escape(file)} | grep -- #{escape(regexp)}"
|
27
|
+
end
|
28
|
+
|
29
|
+
def check_is_grouped(file, group)
|
30
|
+
regexp = "^#{group}$"
|
31
|
+
"stat -f %Sg #{escape(file)} | grep -- #{escape(regexp)}"
|
32
|
+
end
|
33
|
+
|
34
|
+
def get_mode(file)
|
35
|
+
"stat -f%Lp #{escape(file)}"
|
36
|
+
end
|
35
37
|
end
|
36
38
|
end
|
37
39
|
|
@@ -1,15 +1,17 @@
|
|
1
1
|
class Specinfra::Command::Darwin::Base::Package < Specinfra::Command::Base::Package
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_installed(package, version=nil)
|
4
|
+
escaped_package = escape(package)
|
5
|
+
if version
|
6
|
+
cmd = "/usr/local/bin/brew info #{escaped_package} | grep -E '^\/usr\/local\/Cellar\/#{escaped_package}\/#{escape(version)}'"
|
7
|
+
else
|
8
|
+
cmd = "/usr/local/bin/brew list -1 | grep -E '^#{escaped_package}$'"
|
9
|
+
end
|
10
|
+
cmd
|
8
11
|
end
|
9
|
-
cmd
|
10
|
-
end
|
11
12
|
|
12
|
-
|
13
|
-
|
13
|
+
def install(package)
|
14
|
+
cmd = "brew install '#{package}'"
|
15
|
+
end
|
14
16
|
end
|
15
17
|
end
|
@@ -1,6 +1,8 @@
|
|
1
1
|
class Specinfra::Command::Darwin::Base::Port < Specinfra::Command::Base::Port
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_listening(port, options={})
|
4
|
+
regexp = ":#{port} "
|
5
|
+
"lsof -nP -iTCP -sTCP:LISTEN | grep -- #{escape(regexp)}"
|
6
|
+
end
|
5
7
|
end
|
6
8
|
end
|
@@ -1,9 +1,11 @@
|
|
1
1
|
class Specinfra::Command::Darwin::Base::Service < Specinfra::Command::Base::Service
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class << self
|
3
|
+
def check_is_enabled(service, level=nil)
|
4
|
+
"launchctl list | grep #{escape(service)}"
|
5
|
+
end
|
5
6
|
|
6
|
-
|
7
|
-
|
7
|
+
def check_is_running(service)
|
8
|
+
"launchctl list | grep #{escape(service)} | grep -E '^[0-9]+'"
|
9
|
+
end
|
8
10
|
end
|
9
11
|
end
|