blob: bffe4585b3a89f695ceaec174ea0f09aa7a995ae (
plain)
1
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
require 'io/console'
module Net
module SSH
# Default prompt implementation, called for asking password from user.
# It will never be instantiated directly, but will instead be created for
# you automatically.
#
# A custom prompt objects can implement caching, or different UI. The prompt
# object should implemnted a start method, which should return something implementing
# ask and success. Net::SSH uses it like:
#
# prompter = options[:password_prompt].start({type:'password'})
# while !ok && max_retries < 3
# user = prompter.ask("user: ", {}, true)
# password = prompter.ask("password: ", {}, false)
# ok = send(user, password)
# prompter.sucess if ok
# end
#
class Prompt
# factory
def self.default(options = {})
@default ||= new(options)
end
def initialize(options = {}); end
# default prompt object implementation. More sophisticated implemenetations
# might implement caching.
class Prompter
def initialize(info)
if info[:type] == 'keyboard-interactive'
$stdout.puts(info[:name]) unless info[:name].empty?
$stdout.puts(info[:instruction]) unless info[:instruction].empty?
end
end
# ask input from user, a prompter might ask for multiple inputs
# (like user and password) in a single session.
def ask(prompt, echo=true)
$stdout.print(prompt)
$stdout.flush
ret = $stdin.noecho(&:gets).chomp
$stdout.print("\n")
ret
end
# success method will be called when the password was accepted
# It's a good time to save password asked to a cache.
def success; end
end
# start password session. Multiple questions might be asked multiple times
# on the returned object. Info hash tries to uniquely identify the password
# session, so caching implementations can save passwords properly.
def start(info)
Prompter.new(info)
end
end
end
end
|