net-ssh-cli 0.1.0 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/runner +10 -0
- data/lib/net/ssh/cli.rb +8 -3
- data/lib/net/ssh/cli/version.rb +1 -1
- data/net-ssh-cli.gemspec +1 -1
- metadata +7 -7
- data/.gitlab-ci.yml +0 -20
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: acbf06cc3c79c68f798c7eaa7ee15a904fe56679d115c6ba9a3de3663d9b9198
|
4
|
+
data.tar.gz: 3e5da2f3f30cb58ea964faf25ff66da3f52221735bb6b4f953ac6def4d5d3dbc
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f27705802860566503cc779c4e34a82270176bcb057d3b01545503673f4b0fb0244e4b2888afe85a09c0fe9f1e2510b7656d4ecfaaead6b751b98485046c1de2
|
7
|
+
data.tar.gz: c9d9f68b922206b848687164c5523682d5d349eed7195772c55b3f1f8e7e25a14adbd5c2201729f5c6effd4cea6a1ea2c8eda3ef71e469c86bd49fa1aecfaba7
|
data/bin/runner
ADDED
@@ -0,0 +1,10 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
require 'bundler/setup'
|
5
|
+
require 'net/ssh/cli'
|
6
|
+
|
7
|
+
# You can add fixtures and/or initialization code here to make experimenting
|
8
|
+
# with your gem easier. You can also use a different console, if you like.
|
9
|
+
|
10
|
+
ARGV.each {|arg| eval arg}
|
data/lib/net/ssh/cli.rb
CHANGED
@@ -32,7 +32,7 @@ module Net
|
|
32
32
|
#
|
33
33
|
|
34
34
|
DEFAULT = ActiveSupport::HashWithIndifferentAccess.new(
|
35
|
-
default_prompt: /^(\S
|
35
|
+
default_prompt: /^(\S+@.*)\z/,
|
36
36
|
process_time: 0.00001,
|
37
37
|
read_till_timeout: nil,
|
38
38
|
read_till_rm_prompt: false,
|
@@ -85,6 +85,10 @@ module Net
|
|
85
85
|
end
|
86
86
|
end
|
87
87
|
|
88
|
+
def formatted_net_ssh_options
|
89
|
+
net_ssh_options.symbolize_keys.reject {|k,v| [:host, :ip, :user].include?(k)}
|
90
|
+
end
|
91
|
+
|
88
92
|
## Net::SSH instance
|
89
93
|
#
|
90
94
|
|
@@ -92,7 +96,7 @@ module Net
|
|
92
96
|
return @net_ssh if @net_ssh
|
93
97
|
|
94
98
|
logger.debug { 'Net:SSH #start' }
|
95
|
-
self.net_ssh = Net::SSH.start(net_ssh_options[:ip] || net_ssh_options[:host], net_ssh_options[:user] || ENV['USER'],
|
99
|
+
self.net_ssh = Net::SSH.start(net_ssh_options[:ip] || net_ssh_options[:host], net_ssh_options[:user] || ENV['USER'], formatted_net_ssh_options)
|
96
100
|
rescue StandardError => error
|
97
101
|
self.net_ssh = nil
|
98
102
|
raise
|
@@ -186,6 +190,7 @@ module Net
|
|
186
190
|
process
|
187
191
|
content
|
188
192
|
end
|
193
|
+
alias stdin write
|
189
194
|
|
190
195
|
def write_n(content = String.new)
|
191
196
|
write content + "\n"
|
@@ -216,7 +221,7 @@ module Net
|
|
216
221
|
|
217
222
|
def detect_prompt(seconds: 5)
|
218
223
|
process(seconds)
|
219
|
-
self.default_prompt = read[
|
224
|
+
self.default_prompt = read[/.*\z/]
|
220
225
|
end
|
221
226
|
|
222
227
|
# prove a block where the default prompt changes
|
data/lib/net/ssh/cli/version.rb
CHANGED
data/net-ssh-cli.gemspec
CHANGED
@@ -37,7 +37,7 @@ Gem::Specification.new do |spec|
|
|
37
37
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
38
38
|
spec.require_paths = ['lib']
|
39
39
|
|
40
|
-
spec.add_development_dependency 'bundler'
|
40
|
+
spec.add_development_dependency 'bundler'
|
41
41
|
spec.add_development_dependency 'rake', '~> 10.0'
|
42
42
|
spec.add_development_dependency 'rspec', '~> 3.0'
|
43
43
|
spec.add_dependency 'activesupport', '>= 4.0'
|
metadata
CHANGED
@@ -1,29 +1,29 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: net-ssh-cli
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Fabian Stillhart
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2019-02-
|
11
|
+
date: 2019-02-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- - "
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: '
|
19
|
+
version: '0'
|
20
20
|
type: :development
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- - "
|
24
|
+
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: '
|
26
|
+
version: '0'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -89,7 +89,6 @@ extensions: []
|
|
89
89
|
extra_rdoc_files: []
|
90
90
|
files:
|
91
91
|
- ".gitignore"
|
92
|
-
- ".gitlab-ci.yml"
|
93
92
|
- ".rspec"
|
94
93
|
- ".rubocop.yml"
|
95
94
|
- ".rubocop_todo.yml"
|
@@ -103,6 +102,7 @@ files:
|
|
103
102
|
- Rakefile
|
104
103
|
- bin/console
|
105
104
|
- bin/localhost
|
105
|
+
- bin/runner
|
106
106
|
- bin/setup
|
107
107
|
- lib/net/ssh/cli.rb
|
108
108
|
- lib/net/ssh/cli/version.rb
|
data/.gitlab-ci.yml
DELETED
@@ -1,20 +0,0 @@
|
|
1
|
-
image: nni-hub.artifactory.safe-mgmt.swisscom.com/ruby-swisscom-certificates:2.6.0
|
2
|
-
|
3
|
-
variables:
|
4
|
-
http_proxy: "http://serverproxy.corproot.net:8080"
|
5
|
-
https_proxy: "http://serverproxy.corproot.net:8080"
|
6
|
-
HTTP_PROXY: "http://serverproxy.corproot.net:8080"
|
7
|
-
HTTPS_PROXY: "http://serverproxy.corproot.net:8080"
|
8
|
-
no_proxy: ".swissptt.ch"
|
9
|
-
|
10
|
-
stages:
|
11
|
-
- test
|
12
|
-
|
13
|
-
test:
|
14
|
-
stage: test
|
15
|
-
script:
|
16
|
-
- bundle install
|
17
|
-
- bundle exec rspec
|
18
|
-
# - bundle exec rubocop
|
19
|
-
tags:
|
20
|
-
- docker
|