train-core 3.9.2 → 3.10.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2d3eabbefcf1adac9f0d1142143709c390d4bac2b480ea26ab2b54b290d4c94b
4
- data.tar.gz: dd7f3e0edf4f7c0fad07582d2bf895578b31ebd1cba881bb6e5e7b32c9f312fb
3
+ metadata.gz: 579bb940034fbb7c1d8f6e8025b0d364e5b78f2161efd6155a0f7d65f03af7e0
4
+ data.tar.gz: f5ffb30dfd921debde3e54dc2f88d0f9c41644b02ec7bf3eb6d32797dcc81bc5
5
5
  SHA512:
6
- metadata.gz: 91b758fd870fd5c4f32672a7e671d468fced308acc7f58754204e4e9beaa4baba6c798c25215c8112ed438ef0a5910725af4dcff1764a322d917f343af38996c
7
- data.tar.gz: 48ccaea241788cf7d9aa7a682348781755a4e3cefcf95ae7134c8ede4b273acdc95eb2de109a5a169a00fc527364d74757c0506a98bef75cff44f786957f52c9
6
+ metadata.gz: f6972393f3e6721198c850213d00e120c49668fe29fe60d50d2d465bf5839d9e0ee7281d14e98143d2bd9bb33130f6bee9e859e9c111c490dfdca02ea0d96a27
7
+ data.tar.gz: a68a449c540c36712f68b69ef6103955e4bb10287c98b4448a65b0b103bdb8e9cbf401a3316bdca6a347e9fa85dd55fa4c1619fcb7ff4cc379fecb33032918b0
@@ -51,7 +51,7 @@ module Train::Platforms::Detect::Helpers
51
51
 
52
52
  def local_windows?
53
53
  @backend.class.to_s == "Train::Transports::Local::Connection" &&
54
- ruby_host_os(/mswin|mingw32|windows/)
54
+ ruby_host_os(/mswin|mingw|windows/)
55
55
  end
56
56
 
57
57
  # reads os name and version from wmic
@@ -0,0 +1,157 @@
1
+ require "docker"
2
+ require_relative "../errors"
3
+
4
+ module Train::Transports
5
+ class Podman < Train.plugin(1)
6
+
7
+ name "podman"
8
+
9
+ include_options Train::Extras::CommandWrapper
10
+ option :host, required: true
11
+ option :podman_url, required: false
12
+
13
+ def connection(state = {}, &block)
14
+ opts = merge_options(options, state || {})
15
+
16
+ validate_options(opts)
17
+
18
+ if @connection && @connection_options == opts
19
+ reuse_connection(&block)
20
+ else
21
+ create_new_connection(opts, &block)
22
+ end
23
+ end
24
+
25
+ private
26
+
27
+ # Creates a new Podman connection instance and save it for potential future
28
+ # reuse.
29
+ #
30
+ # @param options [Hash] connection options
31
+ # @return [Podman::Connection] a Podman connection instance
32
+ # @api private
33
+ def create_new_connection(options, &block)
34
+ if @connection
35
+ logger.debug("[Podman] shutting previous connection #{@connection}")
36
+ @connection.close
37
+ end
38
+
39
+ @connection_options = options
40
+ @connection = Connection.new(options, &block)
41
+ end
42
+
43
+ # Return the last saved Podman connection instance.
44
+ #
45
+ # @return [Podman::Connection] a Podman connection instance
46
+ # @api private
47
+ def reuse_connection
48
+ logger.debug("[Podman] reusing existing connection #{@connection}")
49
+ yield @connection if block_given?
50
+ @connection
51
+ end
52
+ end
53
+
54
+ class Train::Transports::Podman
55
+ class Connection < BaseConnection
56
+ def initialize(options)
57
+ super(options)
58
+
59
+ @id = options[:host]
60
+
61
+ if RUBY_PLATFORM =~ /windows|mswin|msys|mingw|cygwin/
62
+ raise "Unsupported host platform."
63
+ end
64
+
65
+ # Currently Podman url can be set using option and setting the environment variable.
66
+ uid = Process.uid
67
+ podman_url = options[:podman_url] || ENV["CONTAINER_HOST"]
68
+ podman_url ||= "unix:///run/podman/podman.sock" if uid == 0
69
+ podman_url ||= "unix:///run/user/#{uid}/podman/podman.sock"
70
+
71
+ Docker.url = podman_url
72
+
73
+ # Using docker-api ruby library to fetch the Podman container data.
74
+ @container = ::Docker::Container.get(@id) ||
75
+ raise("Can't find Podman container #{@id}")
76
+ @cmd_wrapper = nil
77
+ @cmd_wrapper = CommandWrapper.load(self, @options)
78
+ @probably_windows = nil
79
+ rescue Excon::Error::Socket
80
+ raise Train::TransportError, "Unable to connect to Podman using #{podman_url}"
81
+ rescue Docker::Error::NotFoundError => e
82
+ raise Train::TransportError, "Container Not Found: #{e.message}"
83
+ rescue Docker::Error::ServerError => e
84
+ raise Train::TransportError, "#{e.message}"
85
+ end
86
+
87
+ def close
88
+ # nothing to do at the moment
89
+ end
90
+
91
+ def uri
92
+ if @container.nil?
93
+ "podman://#{@id}"
94
+ else
95
+ "podman://#{@container.id}"
96
+ end
97
+ end
98
+
99
+ def unique_identifier
100
+ @container.nil? ? @id : @container.id # default uuid set to the podman host.
101
+ end
102
+
103
+ private
104
+
105
+ def file_via_connection(path)
106
+ if os.aix?
107
+ Train::File::Remote::Aix.new(self, path)
108
+ elsif os.solaris?
109
+ Train::File::Remote::Unix.new(self, path)
110
+ elsif os.windows?
111
+ Train::File::Remote::Windows.new(self, path)
112
+ else
113
+ Train::File::Remote::Linux.new(self, path)
114
+ end
115
+ end
116
+
117
+ def run_command_via_connection(cmd, &_data_handler)
118
+ cmd = @cmd_wrapper.run(cmd) unless @cmd_wrapper.nil?
119
+
120
+ # Cannot use os.windows? here because it calls run_command_via_connection,
121
+ # causing infinite recursion during initial platform detection
122
+ if sniff_for_windows?
123
+ invocation = cmd_run_command(cmd)
124
+ else
125
+ invocation = sh_run_command(cmd)
126
+ end
127
+ stdout, stderr, exit_status = @container.exec(
128
+ invocation, user: @options[:user]
129
+ )
130
+ CommandResult.new(stdout.join, stderr.join, exit_status)
131
+ rescue ::Docker::Error::DockerError => _
132
+ raise
133
+ rescue => _
134
+ # @TODO: differentiate any other error
135
+ raise
136
+ end
137
+
138
+ def sh_run_command(cmd)
139
+ ["/bin/sh", "-c", cmd]
140
+ end
141
+
142
+ def cmd_run_command(cmd)
143
+ ["cmd.exe", "/s", "/c", cmd]
144
+ end
145
+
146
+ def sniff_for_windows?
147
+ return @probably_windows unless @probably_windows.nil?
148
+
149
+ # Run a command using /bin/sh, which should fail under Windows
150
+ stdout, _stderr, _exit_status = @container.exec(
151
+ sh_run_command("true"), user: @options[:user]
152
+ )
153
+ @probably_windows = !!stdout.detect { |l| l.include? "failure in a Windows system call" }
154
+ end
155
+ end
156
+ end
157
+ end
data/lib/train/version.rb CHANGED
@@ -2,5 +2,5 @@
2
2
  # Author:: Dominik Richter (<dominik.richter@gmail.com>)
3
3
 
4
4
  module Train
5
- VERSION = "3.9.2".freeze
5
+ VERSION = "3.10.0".freeze
6
6
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: train-core
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.9.2
4
+ version: 3.10.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Chef InSpec Team
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-04-08 00:00:00.000000000 Z
11
+ date: 2022-06-28 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: addressable
@@ -162,6 +162,7 @@ files:
162
162
  - lib/train/transports/cisco_ios_connection.rb
163
163
  - lib/train/transports/local.rb
164
164
  - lib/train/transports/mock.rb
165
+ - lib/train/transports/podman.rb
165
166
  - lib/train/transports/ssh.rb
166
167
  - lib/train/transports/ssh_connection.rb
167
168
  - lib/train/version.rb
@@ -181,7 +182,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
181
182
  requirements:
182
183
  - - ">="
183
184
  - !ruby/object:Gem::Version
184
- version: '2.5'
185
+ version: '2.7'
185
186
  required_rubygems_version: !ruby/object:Gem::Requirement
186
187
  requirements:
187
188
  - - ">="