Class: SimpleDB::Runner

Inherits:
Object show all
Defined in:
lib/sdbcli/sdb-runner.rb

Defined Under Namespace

Classes: Rownum

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(accessKeyId, secretAccessKey, endpoint = 'sdb.amazonaws.com') ⇒ Runner

Returns a new instance of Runner.



172
173
174
175
# File 'lib/sdbcli/sdb-runner.rb', line 172

def initialize(accessKeyId, secretAccessKey, endpoint = 'sdb.amazonaws.com')
  endpoint = region_to_endpoint(endpoint)
  @driver = Driver.new(accessKeyId, secretAccessKey, endpoint)
end

Instance Attribute Details

#driverObject (readonly)

Returns the value of attribute driver.



170
171
172
# File 'lib/sdbcli/sdb-runner.rb', line 170

def driver
  @driver
end

Instance Method Details

#endpointObject



177
178
179
# File 'lib/sdbcli/sdb-runner.rb', line 177

def endpoint
  @driver.endpoint
end

#endpoint=(v) ⇒ Object



181
182
183
184
# File 'lib/sdbcli/sdb-runner.rb', line 181

def endpoint=(v)
  v = region_to_endpoint(v)
  @driver.endpoint = v
end

#execute(query, inline = true, consistent = false) ⇒ Object



206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
# File 'lib/sdbcli/sdb-runner.rb', line 206

def execute(query, inline = true, consistent = false)
  parsed = Parser.parse(query)
  command = parsed.class.name.split('::').last.to_sym

  case command
  when :GET
    item = @driver.get(parsed.domain, parsed.item_name, parsed.attr_names, consistent)
    item.inline! if inline
    item
  when :INSERT
    rownum = parsed.items.length
    @driver.insert(parsed.domain, parsed.items)
    Rownum.new(rownum)
  when :UPDATE
    rownum = parsed.items.length
    @driver.update(parsed.domain, parsed.items)
    Rownum.new(rownum)
  when :UPDATE_WITH_EXPR
    query = "SELECT itemName FROM #{parsed.domain} #{parsed.expr}"
    items = @driver.select(query, consistent).map {|i| [i[0], parsed.attrs] }
    rownum = items.length
    @driver.update(parsed.domain, items)
    Rownum.new(rownum)
  when :MERGE
    rownum = parsed.items.length
    @driver.insert(parsed.domain, parsed.items)
    Rownum.new(rownum)
  when :MERGE_WITH_EXPR
    query = "SELECT itemName FROM #{parsed.domain} #{parsed.expr}"
    items = @driver.select(query, consistent).map {|i| [i[0], parsed.attrs] }
    rownum = items.length
    @driver.insert(parsed.domain, items)
    Rownum.new(rownum)
  when :DELETE
    rownum = parsed.items.length
    @driver.delete(parsed.domain, parsed.items)
    Rownum.new(rownum)
  when :DELETE_WITH_EXPR
    query = "SELECT itemName FROM #{parsed.domain} #{parsed.expr}"
    items = @driver.select(query, consistent).map {|i| [i[0], parsed.attrs] }
    rownum = items.length
    @driver.delete(parsed.domain, items)
    Rownum.new(rownum)
  when :SELECT, :NEXT, :CURRENT, :PREV, :PAGE, :TAIL
    items = case command
            when :SELECT
              @driver.select(parsed.query, consistent, true)
            when :NEXT
              @driver.next_list(consistent)
            when :CURRENT
              @driver.current_list(consistent)
            when :PREV
              @driver.prev_list(consistent)
            when :PAGE
              parsed.page ? @driver.page_to(parsed.page, consistent) : @driver.current_page
            when :TAIL
              @driver.tail(parsed.domain, consistent)
            else
              raise 'must not happen'
            end

    unless items.kind_of?(Integer)
      items.as_rows!

      items.each do |item|
        item.as_row!
      end

      def items.group_by(name, &block)
        item_h = {}

        self.each do |item|
          key = item[1][name.to_s]

          unless item_h[key]
            item_list = [].as_rows
            item_h[key] = item_list
          end

          item_h[key] << item
        end

        if block
          old_item_h = item_h
          item_h = {}

          old_item_h.each do |key, item_list|
            if block.arity == 2
              new_item_list = block.call(item_list, key)
            else
              new_item_list = block.call(item_list)
            end

            item_h[key] = new_item_list
          end
        end

        item_h
      end
    end

    if parsed.script
      begin
        case parsed.script_type
        when :ruby
          items = items.instance_eval(parsed.script.strip)
        when :shell
          items = IO.popen(parsed.script.strip, "r+") do |f|
            f.puts(items.kind_of?(Array) ? items.map {|i| i.to_s }.join("\n") : items.to_s)
            f.close_write
            f.read
          end
        else
          raise 'must not happen'
        end
      rescue Exception => e
        raise SimpleDB::Error, e.message
      end
    end

    if inline and items.kind_of?(Array)
      items.each do |item|
        item.inline! if item.kind_of?(Array)
      end
    end

    items
  when :CREATE
    @driver.create_domain(parsed.domain)
    nil
  when :DROP
    @driver.drop_domain(parsed.domain)
    nil
  when :SHOW
    case parsed.operand
    when :domains
      @driver.show_domains
    when :regions
      SimpleDB::REGIONS.values.sort
    else
      raise 'must not happen'
    end
  when :USE
    self.endpoint = parsed.endpoint
    nil
  when :DESCRIBE
    @driver.describe(parsed.domain)
  when :RUBY
    eval(parsed.script.strip)
  when :EXEC
    `#{parsed.script.strip}`
  else
    raise 'must not happen'
  end
end

#iteratableObject



194
195
196
# File 'lib/sdbcli/sdb-runner.rb', line 194

def iteratable
  @driver.iteratable
end

#iteratable=(v) ⇒ Object



198
199
200
# File 'lib/sdbcli/sdb-runner.rb', line 198

def iteratable=(v)
  @driver.iteratable = v
end

#regionObject



202
203
204
# File 'lib/sdbcli/sdb-runner.rb', line 202

def region
  REGIONS[endpoint]
end

#timeoutObject



186
187
188
# File 'lib/sdbcli/sdb-runner.rb', line 186

def timeout
  @driver.timeout
end

#timeout=(v) ⇒ Object



190
191
192
# File 'lib/sdbcli/sdb-runner.rb', line 190

def timeout=(v)
  @driver.timeout = v
end