sequel_impala 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/CHANGELOG.md +50 -0
- data/LICENSE +463 -0
- data/README.md +45 -0
- data/Rakefile +39 -0
- data/lib/driver/commons-collections-3.2.1.jar +0 -0
- data/lib/driver/commons-configuration-1.10.jar +0 -0
- data/lib/driver/commons-logging-1.2.jar +0 -0
- data/lib/driver/hadoop-auth-2.9.0.jar +0 -0
- data/lib/driver/hadoop-common-2.9.0.jar +0 -0
- data/lib/driver/hadoop-core-2.6.0.jar +0 -0
- data/lib/driver/hive-exec-1.1.0.jar +0 -0
- data/lib/driver/hive-jdbc-1.1.0.jar +0 -0
- data/lib/driver/hive-metastore-1.1.0.jar +0 -0
- data/lib/driver/hive-service-1.1.0.jar +0 -0
- data/lib/driver/httpclient-4.3.jar +0 -0
- data/lib/driver/httpcore-4.3.jar +0 -0
- data/lib/driver/libfb303-0.9.0.jar +0 -0
- data/lib/driver/log4j-1.2.17.jar +0 -0
- data/lib/driver/slf4j-api-1.7.5.jar +0 -0
- data/lib/driver/stax2-api-3.1.4.jar +0 -0
- data/lib/driver/woodstox-core-asl-4.4.1.jar +0 -0
- data/lib/impala.rb +55 -0
- data/lib/impala/connection.rb +180 -0
- data/lib/impala/cursor.rb +200 -0
- data/lib/impala/progress_reporter.rb +40 -0
- data/lib/impala/protocol.rb +8 -0
- data/lib/impala/protocol/beeswax_constants.rb +15 -0
- data/lib/impala/protocol/beeswax_service.rb +747 -0
- data/lib/impala/protocol/beeswax_types.rb +193 -0
- data/lib/impala/protocol/exec_stats_constants.rb +13 -0
- data/lib/impala/protocol/exec_stats_types.rb +133 -0
- data/lib/impala/protocol/facebook_service.rb +706 -0
- data/lib/impala/protocol/fb303_constants.rb +15 -0
- data/lib/impala/protocol/fb303_types.rb +25 -0
- data/lib/impala/protocol/hive_metastore_constants.rb +53 -0
- data/lib/impala/protocol/hive_metastore_types.rb +698 -0
- data/lib/impala/protocol/impala_hive_server2_service.rb +137 -0
- data/lib/impala/protocol/impala_service.rb +443 -0
- data/lib/impala/protocol/impala_service_constants.rb +13 -0
- data/lib/impala/protocol/impala_service_types.rb +192 -0
- data/lib/impala/protocol/status_constants.rb +13 -0
- data/lib/impala/protocol/status_types.rb +46 -0
- data/lib/impala/protocol/t_c_l_i_service.rb +1108 -0
- data/lib/impala/protocol/t_c_l_i_service_constants.rb +72 -0
- data/lib/impala/protocol/t_c_l_i_service_types.rb +1802 -0
- data/lib/impala/protocol/thrift_hive_metastore.rb +4707 -0
- data/lib/impala/protocol/types_constants.rb +13 -0
- data/lib/impala/protocol/types_types.rb +332 -0
- data/lib/impala/sasl_transport.rb +117 -0
- data/lib/impala/thrift_patch.rb +31 -0
- data/lib/impala/version.rb +3 -0
- data/lib/jdbc/hive2.rb +52 -0
- data/lib/jdbc/impala.rb +50 -0
- data/lib/rbhive.rb +8 -0
- data/lib/rbhive/connection.rb +150 -0
- data/lib/rbhive/explain_result.rb +46 -0
- data/lib/rbhive/result_set.rb +37 -0
- data/lib/rbhive/schema_definition.rb +86 -0
- data/lib/rbhive/t_c_l_i_connection.rb +466 -0
- data/lib/rbhive/t_c_l_i_result_set.rb +3 -0
- data/lib/rbhive/t_c_l_i_schema_definition.rb +87 -0
- data/lib/rbhive/table_schema.rb +122 -0
- data/lib/rbhive/version.rb +3 -0
- data/lib/sequel/adapters/impala.rb +220 -0
- data/lib/sequel/adapters/jdbc/hive2.rb +36 -0
- data/lib/sequel/adapters/jdbc/impala.rb +38 -0
- data/lib/sequel/adapters/rbhive.rb +177 -0
- data/lib/sequel/adapters/shared/impala.rb +808 -0
- data/lib/sequel/extensions/csv_to_parquet.rb +166 -0
- data/lib/thrift/facebook_service.rb +700 -0
- data/lib/thrift/fb303_constants.rb +9 -0
- data/lib/thrift/fb303_types.rb +19 -0
- data/lib/thrift/hive_metastore_constants.rb +41 -0
- data/lib/thrift/hive_metastore_types.rb +630 -0
- data/lib/thrift/hive_service_constants.rb +13 -0
- data/lib/thrift/hive_service_types.rb +72 -0
- data/lib/thrift/queryplan_constants.rb +13 -0
- data/lib/thrift/queryplan_types.rb +261 -0
- data/lib/thrift/sasl_client_transport.rb +161 -0
- data/lib/thrift/serde_constants.rb +92 -0
- data/lib/thrift/serde_types.rb +7 -0
- data/lib/thrift/t_c_l_i_service.rb +1054 -0
- data/lib/thrift/t_c_l_i_service_constants.rb +72 -0
- data/lib/thrift/t_c_l_i_service_types.rb +1768 -0
- data/lib/thrift/thrift_hive.rb +508 -0
- data/lib/thrift/thrift_hive_metastore.rb +3856 -0
- data/spec/database_test.rb +56 -0
- data/spec/dataset_test.rb +1268 -0
- data/spec/files/bad_down_migration/001_create_alt_basic.rb +4 -0
- data/spec/files/bad_down_migration/002_create_alt_advanced.rb +4 -0
- data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +9 -0
- data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +9 -0
- data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +3 -0
- data/spec/files/bad_up_migration/001_create_alt_basic.rb +4 -0
- data/spec/files/bad_up_migration/002_create_alt_advanced.rb +3 -0
- data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +9 -0
- data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +9 -0
- data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +4 -0
- data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +9 -0
- data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +9 -0
- data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +9 -0
- data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +9 -0
- data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +4 -0
- data/spec/files/integer_migrations/001_create_sessions.rb +9 -0
- data/spec/files/integer_migrations/002_create_nodes.rb +9 -0
- data/spec/files/integer_migrations/003_3_create_users.rb +4 -0
- data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +9 -0
- data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +9 -0
- data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +9 -0
- data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +9 -0
- data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +4 -0
- data/spec/files/reversible_migrations/001_reversible.rb +5 -0
- data/spec/files/reversible_migrations/002_reversible.rb +5 -0
- data/spec/files/reversible_migrations/003_reversible.rb +5 -0
- data/spec/files/reversible_migrations/004_reversible.rb +5 -0
- data/spec/files/reversible_migrations/005_reversible.rb +10 -0
- data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +9 -0
- data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +9 -0
- data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +4 -0
- data/spec/impala_test.rb +290 -0
- data/spec/migrator_test.rb +240 -0
- data/spec/plugin_test.rb +91 -0
- data/spec/prepared_statement_test.rb +327 -0
- data/spec/schema_test.rb +356 -0
- data/spec/spec_helper.rb +19 -0
- data/spec/timezone_test.rb +86 -0
- data/spec/type_test.rb +99 -0
- metadata +294 -0
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
require 'securerandom'
|
|
2
|
+
require 'csv'
|
|
3
|
+
require 'open3'
|
|
4
|
+
|
|
5
|
+
module Sequel::CsvToParquet
|
|
6
|
+
# Load a CSV file into an existing parquet table. By default,
|
|
7
|
+
# assumes the CSV file has headers that match the column names
|
|
8
|
+
# in the parquet table. If this isn't true, the :headers or
|
|
9
|
+
# :mapping option should be specified.
|
|
10
|
+
#
|
|
11
|
+
# This works by adding the CSV file to HDFS via hdfs -put, then
|
|
12
|
+
# creating an external CSV table in Impala, then inserting into
|
|
13
|
+
# parquet table from the CSV table.
|
|
14
|
+
#
|
|
15
|
+
# Options:
|
|
16
|
+
# :empty_null :: Convert empty CSV cells to \N when adding to HDFS,
|
|
17
|
+
# so Impala will treat them as NULL instead of the
|
|
18
|
+
# empty string. Defaults to using 2 sed processes to
|
|
19
|
+
# convert empty cells. Can be set to :perl to use a
|
|
20
|
+
# single perl process. Can be set to :ruby to do the
|
|
21
|
+
# processing inside the ruby process, which will also
|
|
22
|
+
# convert quoted CSV cells (which Hive/Impala do not
|
|
23
|
+
# support) to escaped CSV cells (which Hive/Impala do
|
|
24
|
+
# support).
|
|
25
|
+
# :headers :: Specify the headers to use in the CSV file, assuming the
|
|
26
|
+
# csv file does not contain headers. If :skip_headers is set
|
|
27
|
+
# to true, this will ignore the existing headers in the file.
|
|
28
|
+
# :hdfs_tmp_dir :: The temporary HDFS directory to use when uploading.
|
|
29
|
+
# :mapping :: Override the mapping of the CSV columns to the parquet table
|
|
30
|
+
# columns. By default, assumes the CSV header names are the
|
|
31
|
+
# same as the parquet table columns, and uses both. If specified
|
|
32
|
+
# this should be a hash with parquet column symbol keys, with the
|
|
33
|
+
# value being the value to insert into the parquet table. This
|
|
34
|
+
# can be used to transform the data from the CSV table when loading
|
|
35
|
+
# it into the parquet table.
|
|
36
|
+
# :overwrite :: Set to true to overwrite existing data in the parquet table
|
|
37
|
+
# with the information from the CSV file. The default is to
|
|
38
|
+
# append the data to the existing parquet table.
|
|
39
|
+
# :skip_header :: Specifies that the first row contains headers and should
|
|
40
|
+
# be skipped when copying the CSV file to HDFS. If not
|
|
41
|
+
# specified, headers are skipped unless the :headers option
|
|
42
|
+
# is given.
|
|
43
|
+
# :tmp_table :: The temporary table name to use for the CSV table.
|
|
44
|
+
# :types :: Specify the types to use for the temporary CSV table. By default,
|
|
45
|
+
# it introspects the parquet table to get the type information, and
|
|
46
|
+
# uses the type for the matching column name.
|
|
47
|
+
def load_csv(local_csv_path, into_table, opts={})
|
|
48
|
+
tmp_num = SecureRandom.hex(8)
|
|
49
|
+
hdfs_tmp_dir = opts[:hdfs_tmp_dir] || "/tmp/cvs-#{tmp_num}"
|
|
50
|
+
hdfs_tmp_file = "#{hdfs_tmp_dir}/#{File.basename(local_csv_path)}"
|
|
51
|
+
tmp_table = opts[:tmp_table] || "csv_#{tmp_num}"
|
|
52
|
+
|
|
53
|
+
skip_header = opts.fetch(:skip_header, !opts.has_key?(:headers))
|
|
54
|
+
mapping = opts[:mapping]
|
|
55
|
+
overwrite = opts[:overwrite]
|
|
56
|
+
|
|
57
|
+
raw_data = File.open(local_csv_path, 'rb')
|
|
58
|
+
|
|
59
|
+
if columns = opts[:headers]
|
|
60
|
+
columns = columns.split(',') if columns.is_a?(String)
|
|
61
|
+
raw_data.readline if skip_header
|
|
62
|
+
else
|
|
63
|
+
columns = raw_data.readline.chomp.split(',').map(&:downcase).map(&:to_sym)
|
|
64
|
+
end
|
|
65
|
+
raw_data.seek(raw_data.pos, IO::SEEK_SET)
|
|
66
|
+
|
|
67
|
+
into_table_columns = describe(into_table) rescue nil
|
|
68
|
+
|
|
69
|
+
if types = opts[:types]
|
|
70
|
+
types = types.split(',') if types.is_a?(String)
|
|
71
|
+
elsif (into_table_columns)
|
|
72
|
+
sch = Hash[into_table_columns.map { |h| [h[:name].downcase.to_sym, h[:type]]}]
|
|
73
|
+
types = columns.map { |col| sch[col] || "string" }
|
|
74
|
+
else
|
|
75
|
+
types = ["string"] * columns.length
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
unless types.length == columns.length
|
|
79
|
+
raise ArgumentError, "number of types doesn't match number of columns"
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
system("hdfs", "dfs", "-mkdir", hdfs_tmp_dir)
|
|
83
|
+
hdfs_put = ['hdfs', 'dfs', '-put', '-', hdfs_tmp_file]
|
|
84
|
+
|
|
85
|
+
case opts[:empty_null]
|
|
86
|
+
when nil, false
|
|
87
|
+
system(*hdfs_put, :in=>raw_data)
|
|
88
|
+
when :ruby
|
|
89
|
+
error_in_thread = nil
|
|
90
|
+
csv_data, input = IO.pipe
|
|
91
|
+
csv_thread = Thread.new do
|
|
92
|
+
begin
|
|
93
|
+
comma = ','.freeze
|
|
94
|
+
comma_rep = '\\,'.freeze
|
|
95
|
+
nl = "\n".freeze
|
|
96
|
+
null = '\\N'.freeze
|
|
97
|
+
empty = ''.freeze
|
|
98
|
+
|
|
99
|
+
write_col = lambda do |col, after|
|
|
100
|
+
if !col || col == empty
|
|
101
|
+
col = null
|
|
102
|
+
else
|
|
103
|
+
col.gsub!(nl, empty)
|
|
104
|
+
col.gsub!(comma, comma_rep)
|
|
105
|
+
end
|
|
106
|
+
input.write(col)
|
|
107
|
+
input.write(after)
|
|
108
|
+
end
|
|
109
|
+
|
|
110
|
+
raw_data.seek(0, IO::SEEK_SET)
|
|
111
|
+
CSV.open(raw_data) do |csv|
|
|
112
|
+
csv.shift if skip_header
|
|
113
|
+
csv.each do |row|
|
|
114
|
+
last = row.pop
|
|
115
|
+
row.each do |col|
|
|
116
|
+
write_col.call(col, comma)
|
|
117
|
+
end
|
|
118
|
+
write_col.call(last, nl)
|
|
119
|
+
end
|
|
120
|
+
end
|
|
121
|
+
ensure
|
|
122
|
+
input.close
|
|
123
|
+
csv_data.close
|
|
124
|
+
end
|
|
125
|
+
end
|
|
126
|
+
system(*hdfs_put, :in=>csv_data)
|
|
127
|
+
csv_thread.join
|
|
128
|
+
when :perl
|
|
129
|
+
Open3.pipeline(
|
|
130
|
+
['perl', '-p', '-e', 's/(^|,)(?=,|$)/\\1\\\\N/g', {:in=>raw_data}],
|
|
131
|
+
hdfs_put
|
|
132
|
+
)
|
|
133
|
+
else
|
|
134
|
+
Open3.pipeline(
|
|
135
|
+
['sed', '-r', 's/(^|,)(,|$)/\\1\\\\N\\2/g', {:in=>raw_data}],
|
|
136
|
+
['sed', '-r', 's/(^|,)(,|$)/\\1\\\\N\\2/g'],
|
|
137
|
+
hdfs_put
|
|
138
|
+
)
|
|
139
|
+
end
|
|
140
|
+
|
|
141
|
+
create_table(tmp_table, :external=>true, :field_term=>',', :field_escape=>'\\', :location=>hdfs_tmp_dir) do
|
|
142
|
+
columns.zip(types) do |c, t|
|
|
143
|
+
column c, t
|
|
144
|
+
end
|
|
145
|
+
end
|
|
146
|
+
|
|
147
|
+
ds = from(into_table)
|
|
148
|
+
ds = ds.insert_overwrite if overwrite
|
|
149
|
+
|
|
150
|
+
if mapping
|
|
151
|
+
table_columns, csv_columns = mapping.to_a.transpose
|
|
152
|
+
else
|
|
153
|
+
table_columns = csv_columns = into_table_columns.map { |h| h[:name].to_sym }
|
|
154
|
+
end
|
|
155
|
+
ds.insert(table_columns, from(tmp_table).select(*csv_columns))
|
|
156
|
+
|
|
157
|
+
ensure
|
|
158
|
+
raw_data.close if raw_data && !raw_data.closed?
|
|
159
|
+
|
|
160
|
+
system("hdfs", "dfs", "-rm", hdfs_tmp_file)
|
|
161
|
+
system("hdfs", "dfs", "-rmdir", hdfs_tmp_dir)
|
|
162
|
+
drop_table?(tmp_table)
|
|
163
|
+
end
|
|
164
|
+
end
|
|
165
|
+
|
|
166
|
+
Sequel::Database.register_extension(:csv_to_parquet, Sequel::CsvToParquet)
|
|
@@ -0,0 +1,700 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Autogenerated by Thrift Compiler (0.9.0)
|
|
3
|
+
#
|
|
4
|
+
# DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING
|
|
5
|
+
#
|
|
6
|
+
|
|
7
|
+
require 'thrift'
|
|
8
|
+
require_relative 'fb303_types'
|
|
9
|
+
|
|
10
|
+
module FacebookService
|
|
11
|
+
class Client
|
|
12
|
+
include ::Thrift::Client
|
|
13
|
+
|
|
14
|
+
def getName()
|
|
15
|
+
send_getName()
|
|
16
|
+
return recv_getName()
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def send_getName()
|
|
20
|
+
send_message('getName', GetName_args)
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def recv_getName()
|
|
24
|
+
result = receive_message(GetName_result)
|
|
25
|
+
return result.success unless result.success.nil?
|
|
26
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getName failed: unknown result')
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def getVersion()
|
|
30
|
+
send_getVersion()
|
|
31
|
+
return recv_getVersion()
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
def send_getVersion()
|
|
35
|
+
send_message('getVersion', GetVersion_args)
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def recv_getVersion()
|
|
39
|
+
result = receive_message(GetVersion_result)
|
|
40
|
+
return result.success unless result.success.nil?
|
|
41
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getVersion failed: unknown result')
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def getStatus()
|
|
45
|
+
send_getStatus()
|
|
46
|
+
return recv_getStatus()
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
def send_getStatus()
|
|
50
|
+
send_message('getStatus', GetStatus_args)
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def recv_getStatus()
|
|
54
|
+
result = receive_message(GetStatus_result)
|
|
55
|
+
return result.success unless result.success.nil?
|
|
56
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getStatus failed: unknown result')
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def getStatusDetails()
|
|
60
|
+
send_getStatusDetails()
|
|
61
|
+
return recv_getStatusDetails()
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def send_getStatusDetails()
|
|
65
|
+
send_message('getStatusDetails', GetStatusDetails_args)
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
def recv_getStatusDetails()
|
|
69
|
+
result = receive_message(GetStatusDetails_result)
|
|
70
|
+
return result.success unless result.success.nil?
|
|
71
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getStatusDetails failed: unknown result')
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
def getCounters()
|
|
75
|
+
send_getCounters()
|
|
76
|
+
return recv_getCounters()
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
def send_getCounters()
|
|
80
|
+
send_message('getCounters', GetCounters_args)
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
def recv_getCounters()
|
|
84
|
+
result = receive_message(GetCounters_result)
|
|
85
|
+
return result.success unless result.success.nil?
|
|
86
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getCounters failed: unknown result')
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
def getCounter(key)
|
|
90
|
+
send_getCounter(key)
|
|
91
|
+
return recv_getCounter()
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
def send_getCounter(key)
|
|
95
|
+
send_message('getCounter', GetCounter_args, :key => key)
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
def recv_getCounter()
|
|
99
|
+
result = receive_message(GetCounter_result)
|
|
100
|
+
return result.success unless result.success.nil?
|
|
101
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getCounter failed: unknown result')
|
|
102
|
+
end
|
|
103
|
+
|
|
104
|
+
def setOption(key, value)
|
|
105
|
+
send_setOption(key, value)
|
|
106
|
+
recv_setOption()
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
def send_setOption(key, value)
|
|
110
|
+
send_message('setOption', SetOption_args, :key => key, :value => value)
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
def recv_setOption()
|
|
114
|
+
result = receive_message(SetOption_result)
|
|
115
|
+
return
|
|
116
|
+
end
|
|
117
|
+
|
|
118
|
+
def getOption(key)
|
|
119
|
+
send_getOption(key)
|
|
120
|
+
return recv_getOption()
|
|
121
|
+
end
|
|
122
|
+
|
|
123
|
+
def send_getOption(key)
|
|
124
|
+
send_message('getOption', GetOption_args, :key => key)
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
def recv_getOption()
|
|
128
|
+
result = receive_message(GetOption_result)
|
|
129
|
+
return result.success unless result.success.nil?
|
|
130
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getOption failed: unknown result')
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
def getOptions()
|
|
134
|
+
send_getOptions()
|
|
135
|
+
return recv_getOptions()
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
def send_getOptions()
|
|
139
|
+
send_message('getOptions', GetOptions_args)
|
|
140
|
+
end
|
|
141
|
+
|
|
142
|
+
def recv_getOptions()
|
|
143
|
+
result = receive_message(GetOptions_result)
|
|
144
|
+
return result.success unless result.success.nil?
|
|
145
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getOptions failed: unknown result')
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
def getCpuProfile(profileDurationInSec)
|
|
149
|
+
send_getCpuProfile(profileDurationInSec)
|
|
150
|
+
return recv_getCpuProfile()
|
|
151
|
+
end
|
|
152
|
+
|
|
153
|
+
def send_getCpuProfile(profileDurationInSec)
|
|
154
|
+
send_message('getCpuProfile', GetCpuProfile_args, :profileDurationInSec => profileDurationInSec)
|
|
155
|
+
end
|
|
156
|
+
|
|
157
|
+
def recv_getCpuProfile()
|
|
158
|
+
result = receive_message(GetCpuProfile_result)
|
|
159
|
+
return result.success unless result.success.nil?
|
|
160
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'getCpuProfile failed: unknown result')
|
|
161
|
+
end
|
|
162
|
+
|
|
163
|
+
def aliveSince()
|
|
164
|
+
send_aliveSince()
|
|
165
|
+
return recv_aliveSince()
|
|
166
|
+
end
|
|
167
|
+
|
|
168
|
+
def send_aliveSince()
|
|
169
|
+
send_message('aliveSince', AliveSince_args)
|
|
170
|
+
end
|
|
171
|
+
|
|
172
|
+
def recv_aliveSince()
|
|
173
|
+
result = receive_message(AliveSince_result)
|
|
174
|
+
return result.success unless result.success.nil?
|
|
175
|
+
raise ::Thrift::ApplicationException.new(::Thrift::ApplicationException::MISSING_RESULT, 'aliveSince failed: unknown result')
|
|
176
|
+
end
|
|
177
|
+
|
|
178
|
+
def reinitialize()
|
|
179
|
+
send_reinitialize()
|
|
180
|
+
end
|
|
181
|
+
|
|
182
|
+
def send_reinitialize()
|
|
183
|
+
send_message('reinitialize', Reinitialize_args)
|
|
184
|
+
end
|
|
185
|
+
def shutdown()
|
|
186
|
+
send_shutdown()
|
|
187
|
+
end
|
|
188
|
+
|
|
189
|
+
def send_shutdown()
|
|
190
|
+
send_message('shutdown', Shutdown_args)
|
|
191
|
+
end
|
|
192
|
+
end
|
|
193
|
+
|
|
194
|
+
class Processor
|
|
195
|
+
include ::Thrift::Processor
|
|
196
|
+
|
|
197
|
+
def process_getName(seqid, iprot, oprot)
|
|
198
|
+
args = read_args(iprot, GetName_args)
|
|
199
|
+
result = GetName_result.new()
|
|
200
|
+
result.success = @handler.getName()
|
|
201
|
+
write_result(result, oprot, 'getName', seqid)
|
|
202
|
+
end
|
|
203
|
+
|
|
204
|
+
def process_getVersion(seqid, iprot, oprot)
|
|
205
|
+
args = read_args(iprot, GetVersion_args)
|
|
206
|
+
result = GetVersion_result.new()
|
|
207
|
+
result.success = @handler.getVersion()
|
|
208
|
+
write_result(result, oprot, 'getVersion', seqid)
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
def process_getStatus(seqid, iprot, oprot)
|
|
212
|
+
args = read_args(iprot, GetStatus_args)
|
|
213
|
+
result = GetStatus_result.new()
|
|
214
|
+
result.success = @handler.getStatus()
|
|
215
|
+
write_result(result, oprot, 'getStatus', seqid)
|
|
216
|
+
end
|
|
217
|
+
|
|
218
|
+
def process_getStatusDetails(seqid, iprot, oprot)
|
|
219
|
+
args = read_args(iprot, GetStatusDetails_args)
|
|
220
|
+
result = GetStatusDetails_result.new()
|
|
221
|
+
result.success = @handler.getStatusDetails()
|
|
222
|
+
write_result(result, oprot, 'getStatusDetails', seqid)
|
|
223
|
+
end
|
|
224
|
+
|
|
225
|
+
def process_getCounters(seqid, iprot, oprot)
|
|
226
|
+
args = read_args(iprot, GetCounters_args)
|
|
227
|
+
result = GetCounters_result.new()
|
|
228
|
+
result.success = @handler.getCounters()
|
|
229
|
+
write_result(result, oprot, 'getCounters', seqid)
|
|
230
|
+
end
|
|
231
|
+
|
|
232
|
+
def process_getCounter(seqid, iprot, oprot)
|
|
233
|
+
args = read_args(iprot, GetCounter_args)
|
|
234
|
+
result = GetCounter_result.new()
|
|
235
|
+
result.success = @handler.getCounter(args.key)
|
|
236
|
+
write_result(result, oprot, 'getCounter', seqid)
|
|
237
|
+
end
|
|
238
|
+
|
|
239
|
+
def process_setOption(seqid, iprot, oprot)
|
|
240
|
+
args = read_args(iprot, SetOption_args)
|
|
241
|
+
result = SetOption_result.new()
|
|
242
|
+
@handler.setOption(args.key, args.value)
|
|
243
|
+
write_result(result, oprot, 'setOption', seqid)
|
|
244
|
+
end
|
|
245
|
+
|
|
246
|
+
def process_getOption(seqid, iprot, oprot)
|
|
247
|
+
args = read_args(iprot, GetOption_args)
|
|
248
|
+
result = GetOption_result.new()
|
|
249
|
+
result.success = @handler.getOption(args.key)
|
|
250
|
+
write_result(result, oprot, 'getOption', seqid)
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
def process_getOptions(seqid, iprot, oprot)
|
|
254
|
+
args = read_args(iprot, GetOptions_args)
|
|
255
|
+
result = GetOptions_result.new()
|
|
256
|
+
result.success = @handler.getOptions()
|
|
257
|
+
write_result(result, oprot, 'getOptions', seqid)
|
|
258
|
+
end
|
|
259
|
+
|
|
260
|
+
def process_getCpuProfile(seqid, iprot, oprot)
|
|
261
|
+
args = read_args(iprot, GetCpuProfile_args)
|
|
262
|
+
result = GetCpuProfile_result.new()
|
|
263
|
+
result.success = @handler.getCpuProfile(args.profileDurationInSec)
|
|
264
|
+
write_result(result, oprot, 'getCpuProfile', seqid)
|
|
265
|
+
end
|
|
266
|
+
|
|
267
|
+
def process_aliveSince(seqid, iprot, oprot)
|
|
268
|
+
args = read_args(iprot, AliveSince_args)
|
|
269
|
+
result = AliveSince_result.new()
|
|
270
|
+
result.success = @handler.aliveSince()
|
|
271
|
+
write_result(result, oprot, 'aliveSince', seqid)
|
|
272
|
+
end
|
|
273
|
+
|
|
274
|
+
def process_reinitialize(seqid, iprot, oprot)
|
|
275
|
+
args = read_args(iprot, Reinitialize_args)
|
|
276
|
+
@handler.reinitialize()
|
|
277
|
+
return
|
|
278
|
+
end
|
|
279
|
+
|
|
280
|
+
def process_shutdown(seqid, iprot, oprot)
|
|
281
|
+
args = read_args(iprot, Shutdown_args)
|
|
282
|
+
@handler.shutdown()
|
|
283
|
+
return
|
|
284
|
+
end
|
|
285
|
+
|
|
286
|
+
end
|
|
287
|
+
|
|
288
|
+
# HELPER FUNCTIONS AND STRUCTURES
|
|
289
|
+
|
|
290
|
+
class GetName_args
|
|
291
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
292
|
+
|
|
293
|
+
FIELDS = {
|
|
294
|
+
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
def struct_fields; FIELDS; end
|
|
298
|
+
|
|
299
|
+
def validate
|
|
300
|
+
end
|
|
301
|
+
|
|
302
|
+
::Thrift::Struct.generate_accessors self
|
|
303
|
+
end
|
|
304
|
+
|
|
305
|
+
class GetName_result
|
|
306
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
307
|
+
SUCCESS = 0
|
|
308
|
+
|
|
309
|
+
FIELDS = {
|
|
310
|
+
SUCCESS => {:type => ::Thrift::Types::STRING, :name => 'success'}
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
def struct_fields; FIELDS; end
|
|
314
|
+
|
|
315
|
+
def validate
|
|
316
|
+
end
|
|
317
|
+
|
|
318
|
+
::Thrift::Struct.generate_accessors self
|
|
319
|
+
end
|
|
320
|
+
|
|
321
|
+
class GetVersion_args
|
|
322
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
323
|
+
|
|
324
|
+
FIELDS = {
|
|
325
|
+
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
def struct_fields; FIELDS; end
|
|
329
|
+
|
|
330
|
+
def validate
|
|
331
|
+
end
|
|
332
|
+
|
|
333
|
+
::Thrift::Struct.generate_accessors self
|
|
334
|
+
end
|
|
335
|
+
|
|
336
|
+
class GetVersion_result
|
|
337
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
338
|
+
SUCCESS = 0
|
|
339
|
+
|
|
340
|
+
FIELDS = {
|
|
341
|
+
SUCCESS => {:type => ::Thrift::Types::STRING, :name => 'success'}
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
def struct_fields; FIELDS; end
|
|
345
|
+
|
|
346
|
+
def validate
|
|
347
|
+
end
|
|
348
|
+
|
|
349
|
+
::Thrift::Struct.generate_accessors self
|
|
350
|
+
end
|
|
351
|
+
|
|
352
|
+
class GetStatus_args
|
|
353
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
354
|
+
|
|
355
|
+
FIELDS = {
|
|
356
|
+
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
def struct_fields; FIELDS; end
|
|
360
|
+
|
|
361
|
+
def validate
|
|
362
|
+
end
|
|
363
|
+
|
|
364
|
+
::Thrift::Struct.generate_accessors self
|
|
365
|
+
end
|
|
366
|
+
|
|
367
|
+
class GetStatus_result
|
|
368
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
369
|
+
SUCCESS = 0
|
|
370
|
+
|
|
371
|
+
FIELDS = {
|
|
372
|
+
SUCCESS => {:type => ::Thrift::Types::I32, :name => 'success', :enum_class => ::Fb_status}
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
def struct_fields; FIELDS; end
|
|
376
|
+
|
|
377
|
+
def validate
|
|
378
|
+
unless @success.nil? || ::Fb_status::VALID_VALUES.include?(@success)
|
|
379
|
+
raise ::Thrift::ProtocolException.new(::Thrift::ProtocolException::UNKNOWN, 'Invalid value of field success!')
|
|
380
|
+
end
|
|
381
|
+
end
|
|
382
|
+
|
|
383
|
+
::Thrift::Struct.generate_accessors self
|
|
384
|
+
end
|
|
385
|
+
|
|
386
|
+
class GetStatusDetails_args
|
|
387
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
388
|
+
|
|
389
|
+
FIELDS = {
|
|
390
|
+
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
def struct_fields; FIELDS; end
|
|
394
|
+
|
|
395
|
+
def validate
|
|
396
|
+
end
|
|
397
|
+
|
|
398
|
+
::Thrift::Struct.generate_accessors self
|
|
399
|
+
end
|
|
400
|
+
|
|
401
|
+
class GetStatusDetails_result
|
|
402
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
403
|
+
SUCCESS = 0
|
|
404
|
+
|
|
405
|
+
FIELDS = {
|
|
406
|
+
SUCCESS => {:type => ::Thrift::Types::STRING, :name => 'success'}
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
def struct_fields; FIELDS; end
|
|
410
|
+
|
|
411
|
+
def validate
|
|
412
|
+
end
|
|
413
|
+
|
|
414
|
+
::Thrift::Struct.generate_accessors self
|
|
415
|
+
end
|
|
416
|
+
|
|
417
|
+
class GetCounters_args
|
|
418
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
419
|
+
|
|
420
|
+
FIELDS = {
|
|
421
|
+
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
def struct_fields; FIELDS; end
|
|
425
|
+
|
|
426
|
+
def validate
|
|
427
|
+
end
|
|
428
|
+
|
|
429
|
+
::Thrift::Struct.generate_accessors self
|
|
430
|
+
end
|
|
431
|
+
|
|
432
|
+
class GetCounters_result
|
|
433
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
434
|
+
SUCCESS = 0
|
|
435
|
+
|
|
436
|
+
FIELDS = {
|
|
437
|
+
SUCCESS => {:type => ::Thrift::Types::MAP, :name => 'success', :key => {:type => ::Thrift::Types::STRING}, :value => {:type => ::Thrift::Types::I64}}
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
def struct_fields; FIELDS; end
|
|
441
|
+
|
|
442
|
+
def validate
|
|
443
|
+
end
|
|
444
|
+
|
|
445
|
+
::Thrift::Struct.generate_accessors self
|
|
446
|
+
end
|
|
447
|
+
|
|
448
|
+
class GetCounter_args
|
|
449
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
450
|
+
KEY = 1
|
|
451
|
+
|
|
452
|
+
FIELDS = {
|
|
453
|
+
KEY => {:type => ::Thrift::Types::STRING, :name => 'key'}
|
|
454
|
+
}
|
|
455
|
+
|
|
456
|
+
def struct_fields; FIELDS; end
|
|
457
|
+
|
|
458
|
+
def validate
|
|
459
|
+
end
|
|
460
|
+
|
|
461
|
+
::Thrift::Struct.generate_accessors self
|
|
462
|
+
end
|
|
463
|
+
|
|
464
|
+
class GetCounter_result
|
|
465
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
466
|
+
SUCCESS = 0
|
|
467
|
+
|
|
468
|
+
FIELDS = {
|
|
469
|
+
SUCCESS => {:type => ::Thrift::Types::I64, :name => 'success'}
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
def struct_fields; FIELDS; end
|
|
473
|
+
|
|
474
|
+
def validate
|
|
475
|
+
end
|
|
476
|
+
|
|
477
|
+
::Thrift::Struct.generate_accessors self
|
|
478
|
+
end
|
|
479
|
+
|
|
480
|
+
class SetOption_args
|
|
481
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
482
|
+
KEY = 1
|
|
483
|
+
VALUE = 2
|
|
484
|
+
|
|
485
|
+
FIELDS = {
|
|
486
|
+
KEY => {:type => ::Thrift::Types::STRING, :name => 'key'},
|
|
487
|
+
VALUE => {:type => ::Thrift::Types::STRING, :name => 'value'}
|
|
488
|
+
}
|
|
489
|
+
|
|
490
|
+
def struct_fields; FIELDS; end
|
|
491
|
+
|
|
492
|
+
def validate
|
|
493
|
+
end
|
|
494
|
+
|
|
495
|
+
::Thrift::Struct.generate_accessors self
|
|
496
|
+
end
|
|
497
|
+
|
|
498
|
+
class SetOption_result
|
|
499
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
500
|
+
|
|
501
|
+
FIELDS = {
|
|
502
|
+
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
def struct_fields; FIELDS; end
|
|
506
|
+
|
|
507
|
+
def validate
|
|
508
|
+
end
|
|
509
|
+
|
|
510
|
+
::Thrift::Struct.generate_accessors self
|
|
511
|
+
end
|
|
512
|
+
|
|
513
|
+
class GetOption_args
|
|
514
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
515
|
+
KEY = 1
|
|
516
|
+
|
|
517
|
+
FIELDS = {
|
|
518
|
+
KEY => {:type => ::Thrift::Types::STRING, :name => 'key'}
|
|
519
|
+
}
|
|
520
|
+
|
|
521
|
+
def struct_fields; FIELDS; end
|
|
522
|
+
|
|
523
|
+
def validate
|
|
524
|
+
end
|
|
525
|
+
|
|
526
|
+
::Thrift::Struct.generate_accessors self
|
|
527
|
+
end
|
|
528
|
+
|
|
529
|
+
class GetOption_result
|
|
530
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
531
|
+
SUCCESS = 0
|
|
532
|
+
|
|
533
|
+
FIELDS = {
|
|
534
|
+
SUCCESS => {:type => ::Thrift::Types::STRING, :name => 'success'}
|
|
535
|
+
}
|
|
536
|
+
|
|
537
|
+
def struct_fields; FIELDS; end
|
|
538
|
+
|
|
539
|
+
def validate
|
|
540
|
+
end
|
|
541
|
+
|
|
542
|
+
::Thrift::Struct.generate_accessors self
|
|
543
|
+
end
|
|
544
|
+
|
|
545
|
+
class GetOptions_args
|
|
546
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
547
|
+
|
|
548
|
+
FIELDS = {
|
|
549
|
+
|
|
550
|
+
}
|
|
551
|
+
|
|
552
|
+
def struct_fields; FIELDS; end
|
|
553
|
+
|
|
554
|
+
def validate
|
|
555
|
+
end
|
|
556
|
+
|
|
557
|
+
::Thrift::Struct.generate_accessors self
|
|
558
|
+
end
|
|
559
|
+
|
|
560
|
+
class GetOptions_result
|
|
561
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
562
|
+
SUCCESS = 0
|
|
563
|
+
|
|
564
|
+
FIELDS = {
|
|
565
|
+
SUCCESS => {:type => ::Thrift::Types::MAP, :name => 'success', :key => {:type => ::Thrift::Types::STRING}, :value => {:type => ::Thrift::Types::STRING}}
|
|
566
|
+
}
|
|
567
|
+
|
|
568
|
+
def struct_fields; FIELDS; end
|
|
569
|
+
|
|
570
|
+
def validate
|
|
571
|
+
end
|
|
572
|
+
|
|
573
|
+
::Thrift::Struct.generate_accessors self
|
|
574
|
+
end
|
|
575
|
+
|
|
576
|
+
class GetCpuProfile_args
|
|
577
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
578
|
+
PROFILEDURATIONINSEC = 1
|
|
579
|
+
|
|
580
|
+
FIELDS = {
|
|
581
|
+
PROFILEDURATIONINSEC => {:type => ::Thrift::Types::I32, :name => 'profileDurationInSec'}
|
|
582
|
+
}
|
|
583
|
+
|
|
584
|
+
def struct_fields; FIELDS; end
|
|
585
|
+
|
|
586
|
+
def validate
|
|
587
|
+
end
|
|
588
|
+
|
|
589
|
+
::Thrift::Struct.generate_accessors self
|
|
590
|
+
end
|
|
591
|
+
|
|
592
|
+
class GetCpuProfile_result
|
|
593
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
594
|
+
SUCCESS = 0
|
|
595
|
+
|
|
596
|
+
FIELDS = {
|
|
597
|
+
SUCCESS => {:type => ::Thrift::Types::STRING, :name => 'success'}
|
|
598
|
+
}
|
|
599
|
+
|
|
600
|
+
def struct_fields; FIELDS; end
|
|
601
|
+
|
|
602
|
+
def validate
|
|
603
|
+
end
|
|
604
|
+
|
|
605
|
+
::Thrift::Struct.generate_accessors self
|
|
606
|
+
end
|
|
607
|
+
|
|
608
|
+
class AliveSince_args
|
|
609
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
610
|
+
|
|
611
|
+
FIELDS = {
|
|
612
|
+
|
|
613
|
+
}
|
|
614
|
+
|
|
615
|
+
def struct_fields; FIELDS; end
|
|
616
|
+
|
|
617
|
+
def validate
|
|
618
|
+
end
|
|
619
|
+
|
|
620
|
+
::Thrift::Struct.generate_accessors self
|
|
621
|
+
end
|
|
622
|
+
|
|
623
|
+
class AliveSince_result
|
|
624
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
625
|
+
SUCCESS = 0
|
|
626
|
+
|
|
627
|
+
FIELDS = {
|
|
628
|
+
SUCCESS => {:type => ::Thrift::Types::I64, :name => 'success'}
|
|
629
|
+
}
|
|
630
|
+
|
|
631
|
+
def struct_fields; FIELDS; end
|
|
632
|
+
|
|
633
|
+
def validate
|
|
634
|
+
end
|
|
635
|
+
|
|
636
|
+
::Thrift::Struct.generate_accessors self
|
|
637
|
+
end
|
|
638
|
+
|
|
639
|
+
class Reinitialize_args
|
|
640
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
641
|
+
|
|
642
|
+
FIELDS = {
|
|
643
|
+
|
|
644
|
+
}
|
|
645
|
+
|
|
646
|
+
def struct_fields; FIELDS; end
|
|
647
|
+
|
|
648
|
+
def validate
|
|
649
|
+
end
|
|
650
|
+
|
|
651
|
+
::Thrift::Struct.generate_accessors self
|
|
652
|
+
end
|
|
653
|
+
|
|
654
|
+
class Reinitialize_result
|
|
655
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
656
|
+
|
|
657
|
+
FIELDS = {
|
|
658
|
+
|
|
659
|
+
}
|
|
660
|
+
|
|
661
|
+
def struct_fields; FIELDS; end
|
|
662
|
+
|
|
663
|
+
def validate
|
|
664
|
+
end
|
|
665
|
+
|
|
666
|
+
::Thrift::Struct.generate_accessors self
|
|
667
|
+
end
|
|
668
|
+
|
|
669
|
+
class Shutdown_args
|
|
670
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
671
|
+
|
|
672
|
+
FIELDS = {
|
|
673
|
+
|
|
674
|
+
}
|
|
675
|
+
|
|
676
|
+
def struct_fields; FIELDS; end
|
|
677
|
+
|
|
678
|
+
def validate
|
|
679
|
+
end
|
|
680
|
+
|
|
681
|
+
::Thrift::Struct.generate_accessors self
|
|
682
|
+
end
|
|
683
|
+
|
|
684
|
+
class Shutdown_result
|
|
685
|
+
include ::Thrift::Struct, ::Thrift::Struct_Union
|
|
686
|
+
|
|
687
|
+
FIELDS = {
|
|
688
|
+
|
|
689
|
+
}
|
|
690
|
+
|
|
691
|
+
def struct_fields; FIELDS; end
|
|
692
|
+
|
|
693
|
+
def validate
|
|
694
|
+
end
|
|
695
|
+
|
|
696
|
+
::Thrift::Struct.generate_accessors self
|
|
697
|
+
end
|
|
698
|
+
|
|
699
|
+
end
|
|
700
|
+
|