forked from choria-legacy/marionette-collective
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmc-rpc
executable file
·128 lines (100 loc) · 4.17 KB
/
mc-rpc
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#!/usr/bin/env ruby
# Generic client for MCollective Simple RPC
#
# http://marionette-collective.org/simplerpc/
require 'mcollective'
include MCollective::RPC
# As we're taking arguments on the command line we need a
# way to input booleans, true on the cli is a string so this
# method will take the ddl, find all arguments that are supposed
# to be boolean and if they are the strings "true"/"yes" or "false"/"no"
# turn them into the matching boolean
def booleanish_to_boolean(arguments, ddl)
arguments.keys.each do |key|
if ddl[:input].keys.include?(key)
if ddl[:input][key][:type] == :boolean
arguments[key] = true if arguments[key] == "true"
arguments[key] = true if arguments[key] == "yes"
arguments[key] = false if arguments[key] == "false"
arguments[key] = false if arguments[key] == "no"
end
end
end
end
begin
options = rpcoptions do |parser, options|
parser.banner = ""
parser.define_head "Generic Simple RPC client"
parser.separator ""
parser.separator "Usage: mc-rpc [options] [filters] --agent <agent> --action <action> [--argument <key=val> --argument ...]"
parser.separator "Alternate Usage: mc-rpc [options] [filters] <agent> <action> [<key=val> <key=val> ...]"
parser.separator "Alternate Usage: mc-rpc --agent-help agent"
parser.separator ""
options[:arguments] = {}
parser.on('--no-results', '--nr', "Do not process results, just send request") do |v|
options[:process_results] = false
end
parser.on('-a', '--agent AGENT', 'Agent to call') do |v|
options[:agent] = v
end
parser.on('--action ACTION', 'Action to call') do |v|
options[:action] = v
end
parser.on("--ah", "--agent-help AGENT", "Get help for an agent") do |v|
options[:agent_help] = v
end
parser.on('--arg', '--argument ARGUMENT', 'Arguments to pass to agent') do |v|
if v =~ /^(.+?)=(.+)$/
options[:arguments][$1.to_sym] = $2
else
STDERR.puts("Could not parse --arg #{v}")
end
end
end
# Parse the alternative command line
unless (options.include?(:agent) && options.include?(:action)) || options.include?(:agent_help)
if ARGV.length >= 2
options[:agent] = ARGV[0]
ARGV.delete_at(0)
options[:action] = ARGV[0]
ARGV.delete_at(0)
ARGV.each do |v|
if v =~ /^(.+?)=(.+)$/
options[:arguments][$1.to_sym] = $2
else
STDERR.puts("Could not parse --arg #{v}")
end
end
else
STDERR.puts("No agent, action and arguments specified")
exit!
end
end
# handle fire and forget mode
options[:process_results] = true unless options.include?(:process_results)
options[:arguments][:process_results] = options[:process_results]
if options[:agent_help]
config = MCollective::Config.instance
config.loadconfig(options[:config])
ddl = MCollective::RPC::DDL.new(options[:agent_help])
puts ddl.help(config.rpchelptemplate)
elsif options[:process_results]
mc = rpcclient(options[:agent], {:options => options})
booleanish_to_boolean(options[:arguments], mc.ddl.action_interface(options[:action])) unless mc.ddl.nil?
mc.agent_filter(options[:agent])
mc.discover :verbose => true
printrpc mc.send(options[:action], options[:arguments])
printrpcstats :caption => "#{options[:agent]}##{options[:action]} call stats"
mc.disconnect
else
mc = rpcclient(options[:agent], {:options => options})
booleanish_to_boolean(options[:arguments], mc.ddl.action_interface(options[:action])) unless mc.ddl.nil?
mc.agent_filter(options[:agent])
puts "Request sent with id: " + mc.send(options[:action], options[:arguments])
mc.disconnect
end
rescue Exception => e
STDERR.puts("Could not call agent: #{e}")
exit 1
end
# vi:tabstop=4:expandtab:ai