Class: Arvados::Model
- Inherits:
-
Object
- Object
- Arvados::Model
- Defined in:
- lib/arvados.rb
Class Method Summary collapse
- .api_exec(method, parameters = {}) ⇒ Object
- .arvados_api ⇒ Object
- .client ⇒ Object
- .debuglog(*args) ⇒ Object
Instance Method Summary collapse
Class Method Details
.api_exec(method, parameters = {}) ⇒ Object
189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 |
# File 'lib/arvados.rb', line 189 def self.api_exec(method, parameters={}) api_method = arvados_api.send(api_models_sym).send(method.name.to_sym) parameters = parameters. merge(:api_token => arvados.config['ARVADOS_API_TOKEN']) parameters.each do |k,v| parameters[k] = v.to_json if v.is_a? Array or v.is_a? Hash end # Look for objects expected by request.properties.(key).$ref and # move them from parameters (query string) to request body. body = nil method.discovery_document['request']. andand['properties']. andand.each do |k,v| if v.is_a? Hash and v['$ref'] body ||= {} body[k] = parameters.delete k.to_sym end end result = client. execute(:api_method => api_method, :authenticated => false, :parameters => parameters, :body => body) resp = JSON.parse result.body, :symbolize_names => true if resp[:errors] raise Arvados::TransactionFailedError.new(resp[:errors]) elsif resp[:uuid] and resp[:etag] self.new(resp) elsif resp[:items].is_a? Array resp.merge(items: resp[:items].collect do |i| self.new(i) end) else resp end end |
.arvados_api ⇒ Object
177 178 179 |
# File 'lib/arvados.rb', line 177 def self.arvados_api arvados.arvados_api end |
.client ⇒ Object
180 181 182 |
# File 'lib/arvados.rb', line 180 def self.client arvados.client end |
.debuglog(*args) ⇒ Object
183 184 185 |
# File 'lib/arvados.rb', line 183 def self.debuglog(*args) arvados.class.debuglog *args end |
Instance Method Details
#[](x) ⇒ Object
230 231 232 233 234 235 236 237 238 |
# File 'lib/arvados.rb', line 230 def [](x) if @attributes[x].is_a? Hash or @attributes[x].is_a? Array # We won't be notified via []= if these change, so we'll just # assume they are going to get changed, and submit them if # save() is called. @attributes_to_update[x] = @attributes[x] end @attributes[x] end |
#[]=(x, y) ⇒ Object
226 227 228 229 |
# File 'lib/arvados.rb', line 226 def []=(x,y) @attributes_to_update[x] = y @attributes[x] = y end |
#debuglog(*args) ⇒ Object
186 187 188 |
# File 'lib/arvados.rb', line 186 def debuglog(*args) self.class.arvados.class.debuglog *args end |
#save ⇒ Object
239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 |
# File 'lib/arvados.rb', line 239 def save @attributes_to_update.keys.each do |k| @attributes_to_update[k] = @attributes[k] end j = self.class.api_exec :update, { :uuid => @attributes[:uuid], self.class.api_model_sym => @attributes_to_update.to_json } unless j.respond_to? :[] and j[:uuid] debuglog "Failed to save #{self.to_s}: #{j[:errors] rescue nil}", 0 nil else @attributes_to_update = {} @attributes = j end end |