api_resource 0.2.8 → 0.2.9
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.
- data/VERSION +1 -1
- data/api_resource.gemspec +3 -3
- data/lib/api_resource/associations/single_object_proxy.rb +7 -3
- data/lib/api_resource/base.rb +25 -10
- data/spec/lib/base_spec.rb +189 -71
- data/spec/support/mocks/association_mocks.rb +5 -1
- metadata +46 -46
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.2.
|
1
|
+
0.2.9
|
data/api_resource.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = "api_resource"
|
8
|
-
s.version = "0.2.
|
8
|
+
s.version = "0.2.9"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Ethan Langevin"]
|
12
|
-
s.date = "2012-
|
12
|
+
s.date = "2012-06-20"
|
13
13
|
s.description = "A replacement for ActiveResource for RESTful APIs that handles associated object and multiple data sources"
|
14
14
|
s.email = "ejl6266@gmail.com"
|
15
15
|
s.extra_rdoc_files = [
|
@@ -80,7 +80,7 @@ Gem::Specification.new do |s|
|
|
80
80
|
s.homepage = "http://github.com/ejlangev/resource"
|
81
81
|
s.licenses = ["MIT"]
|
82
82
|
s.require_paths = ["lib"]
|
83
|
-
s.rubygems_version = "1.8.
|
83
|
+
s.rubygems_version = "1.8.17"
|
84
84
|
s.summary = "A replacement for ActiveResource for RESTful APIs that handles associated object and multiple data sources"
|
85
85
|
|
86
86
|
if s.respond_to? :specification_version then
|
@@ -12,9 +12,13 @@ module ApiResource
|
|
12
12
|
end
|
13
13
|
|
14
14
|
def internal_object=(contents)
|
15
|
-
|
16
|
-
|
17
|
-
|
15
|
+
if contents.is_a?(self.klass) ||
|
16
|
+
contents.respond_to?(:internal_object) && contents.internal_object.is_a?(self.klass) ||
|
17
|
+
contents.nil?
|
18
|
+
return @internal_object = contents
|
19
|
+
else
|
20
|
+
return load(contents)
|
21
|
+
end
|
18
22
|
end
|
19
23
|
|
20
24
|
def blank?
|
data/lib/api_resource/base.rb
CHANGED
@@ -11,7 +11,7 @@ module ApiResource
|
|
11
11
|
|
12
12
|
class_inheritable_accessor :include_root_in_json; self.include_root_in_json = true
|
13
13
|
class_inheritable_accessor :include_blank_attributes_on_create; self.include_blank_attributes_on_create = false
|
14
|
-
class_inheritable_accessor :include_all_attributes_on_update; self.
|
14
|
+
class_inheritable_accessor :include_all_attributes_on_update; self.include_all_attributes_on_update = false
|
15
15
|
|
16
16
|
class_inheritable_accessor :primary_key; self.primary_key = "id"
|
17
17
|
|
@@ -527,6 +527,8 @@ module ApiResource
|
|
527
527
|
end
|
528
528
|
|
529
529
|
def serializable_hash(options = {})
|
530
|
+
action = options[:action]
|
531
|
+
include_blank_attributes = options[:include_blank_attributes]
|
530
532
|
options[:include_associations] = options[:include_associations] ? options[:include_associations].symbolize_array : self.changes.keys.symbolize_array.select{|k| self.association?(k)}
|
531
533
|
options[:include_extras] = options[:include_extras] ? options[:include_extras].symbolize_array : []
|
532
534
|
options[:except] ||= []
|
@@ -534,14 +536,14 @@ module ApiResource
|
|
534
536
|
# If this is an association and it's in include_associations then include it
|
535
537
|
if options[:include_extras].include?(key.to_sym)
|
536
538
|
accum.merge(key => val)
|
537
|
-
elsif options[:except].include?(key.to_sym)
|
539
|
+
elsif options[:except].include?(key.to_sym) || (!include_blank_attributes && val.blank?)
|
538
540
|
accum
|
539
541
|
else
|
540
542
|
!self.attribute?(key) || self.protected_attribute?(key) ? accum : accum.merge(key => val)
|
541
543
|
end
|
542
544
|
end
|
543
545
|
options[:include_associations].each do |assoc|
|
544
|
-
ret[assoc] = self.send(assoc).serializable_hash({:include_id => true}) if self.association?(assoc)
|
546
|
+
ret[assoc] = self.send(assoc).serializable_hash({:include_id => true, :include_blank_attributes => include_blank_attributes, :action => action}) if self.association?(assoc)
|
545
547
|
end
|
546
548
|
# include id - this is for nested updates
|
547
549
|
ret[:id] = self.id if options[:include_id] && !self.new?
|
@@ -570,32 +572,45 @@ module ApiResource
|
|
570
572
|
end
|
571
573
|
|
572
574
|
def create(*args)
|
575
|
+
body = setup_create_call(*args)
|
576
|
+
connection.post(collection_path, body, self.class.headers).tap do |response|
|
577
|
+
load_attributes_from_response(response)
|
578
|
+
end
|
579
|
+
end
|
580
|
+
|
581
|
+
def setup_create_call(*args)
|
573
582
|
opts = args.extract_options!
|
574
583
|
# When we create we should not include any blank attributes unless they are associations
|
575
584
|
except = self.class.include_blank_attributes_on_create ? {} : self.attributes.select{|k,v| v.blank?}
|
576
585
|
opts[:except] = opts[:except] ? opts[:except].concat(except.keys).uniq.symbolize_array : except.keys.symbolize_array
|
586
|
+
opts[:include_blank_attributes] = self.class.include_blank_attributes_on_create
|
577
587
|
opts[:include_associations] = opts[:include_associations] ? opts[:include_associations].concat(args) : []
|
578
588
|
opts[:include_extras] ||= []
|
589
|
+
opts[:action] = "create"
|
579
590
|
body = RestClient::Payload.has_file?(self.attributes) ? self.serializable_hash(opts) : encode(opts)
|
580
|
-
connection.post(collection_path, body, self.class.headers).tap do |response|
|
581
|
-
load_attributes_from_response(response)
|
582
|
-
end
|
583
591
|
end
|
592
|
+
|
584
593
|
|
585
594
|
def update(*args)
|
595
|
+
body = setup_update_call(*args)
|
596
|
+
# We can just ignore the response
|
597
|
+
connection.put(element_path(self.id, prefix_options), body, self.class.headers).tap do |response|
|
598
|
+
load_attributes_from_response(response)
|
599
|
+
end
|
600
|
+
end
|
601
|
+
|
602
|
+
def setup_update_call(*args)
|
586
603
|
opts = args.extract_options!
|
587
604
|
# When we create we should not include any blank attributes
|
588
605
|
except = self.class.attribute_names - self.changed.symbolize_array
|
589
606
|
changed_associations = self.changed.symbolize_array.select{|item| self.association?(item)}
|
590
607
|
opts[:except] = opts[:except] ? opts[:except].concat(except).uniq.symbolize_array : except.symbolize_array
|
608
|
+
opts[:include_blank_attributes] = self.include_all_attributes_on_update
|
591
609
|
opts[:include_associations] = opts[:include_associations] ? opts[:include_associations].concat(args).concat(changed_associations).uniq : changed_associations.concat(args)
|
592
610
|
opts[:include_extras] ||= []
|
611
|
+
opts[:action] = "update"
|
593
612
|
opts[:except] = [:id] if self.class.include_all_attributes_on_update
|
594
613
|
body = RestClient::Payload.has_file?(self.attributes) ? self.serializable_hash(opts) : encode(opts)
|
595
|
-
# We can just ignore the response
|
596
|
-
connection.put(element_path(self.id, prefix_options), body, self.class.headers).tap do |response|
|
597
|
-
load_attributes_from_response(response)
|
598
|
-
end
|
599
614
|
end
|
600
615
|
|
601
616
|
private
|
data/spec/lib/base_spec.rb
CHANGED
@@ -331,54 +331,94 @@ describe "Base" do
|
|
331
331
|
context("Override create to return the json") do
|
332
332
|
|
333
333
|
before(:all) do
|
334
|
-
TestResource.send(:alias_method, :old_create, :create)
|
335
|
-
TestResource.send(:alias_method, :old_save, :save)
|
334
|
+
# TestResource.send(:alias_method, :old_create, :create)
|
335
|
+
# TestResource.send(:alias_method, :old_save, :save)
|
336
336
|
|
337
|
-
TestResource.send(:define_method, :create) do |*args|
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
337
|
+
# TestResource.send(:define_method, :create) do |*args|
|
338
|
+
# opts = args.extract_options!
|
339
|
+
# # When we create we should not include any blank attributes unless they are associations
|
340
|
+
# except = self.class.include_blank_attributes_on_create ? {} : self.attributes.select{|k,v| v.blank?}
|
341
|
+
# opts[:except] = opts[:except] ? opts[:except].concat(except.keys).uniq.symbolize_array : except.keys.symbolize_array
|
342
|
+
# opts[:include_blank_attributes] = self.class.include_blank_attributes_on_create
|
343
|
+
# opts[:include_associations] = opts[:include_associations] ? opts[:include_associations].concat(args) : []
|
344
|
+
# opts[:include_extras] ||= []
|
345
|
+
# opts[:action] = "create"
|
346
|
+
# encode(opts)
|
347
|
+
# end
|
348
|
+
|
349
|
+
# TestResource.send(:define_method, :save) do |*args|
|
350
|
+
# new? ? create(*args) : update(*args)
|
351
|
+
# end
|
352
|
+
RestClient::Payload.stubs(:has_file? => false)
|
349
353
|
end
|
350
354
|
|
351
355
|
after(:all) do
|
352
|
-
TestResource.send(:alias_method, :create, :old_create)
|
353
|
-
TestResource.send(:alias_method, :save, :old_save)
|
356
|
+
# TestResource.send(:alias_method, :create, :old_create)
|
357
|
+
# TestResource.send(:alias_method, :save, :old_save)
|
354
358
|
end
|
355
359
|
|
360
|
+
|
356
361
|
it "should be able to include associations when saving if they are specified" do
|
362
|
+
ApiResource::Connection.any_instance.expects(:post).with(
|
363
|
+
"/test_resources.json",
|
364
|
+
"{\"test_resource\":{\"name\":\"Ethan\",\"age\":20}}",
|
365
|
+
{}
|
366
|
+
)
|
367
|
+
|
357
368
|
tr = TestResource.build(:name => "Ethan", :age => 20)
|
358
|
-
|
359
|
-
hash['test_resource']['has_many_objects'].should be_nil
|
360
|
-
hash = JSON.parse(tr.save(:include_associations => [:has_many_objects]))
|
361
|
-
hash['test_resource']['has_many_objects'].should eql([])
|
369
|
+
tr.save
|
362
370
|
end
|
363
371
|
|
372
|
+
|
364
373
|
it "should not include nil attributes when creating by default" do
|
374
|
+
ApiResource::Connection.any_instance.expects(:post).with(
|
375
|
+
"/test_resources.json",
|
376
|
+
"{\"test_resource\":{\"name\":\"Ethan\"}}",
|
377
|
+
{}
|
378
|
+
)
|
379
|
+
|
365
380
|
tr = TestResource.build(:name => "Ethan")
|
366
|
-
|
367
|
-
|
368
|
-
|
381
|
+
tr.save
|
382
|
+
end
|
383
|
+
|
384
|
+
|
385
|
+
it "should not include nil attributes for associated objects when creating by default" do
|
386
|
+
ApiResource::Connection.any_instance.expects(:post).with(
|
387
|
+
"/test_resources.json",
|
388
|
+
"{\"test_resource\":{\"name\":\"Ethan\",\"has_one_object\":{\"size\":\"large\"}}}",
|
389
|
+
{}
|
390
|
+
)
|
391
|
+
|
392
|
+
tr = TestResource.build(:name => "Ethan")
|
393
|
+
tr.has_one_object = HasOneObject.new(:size => "large", :color => nil)
|
394
|
+
tr.save(:include_associations => [:has_one_object])
|
369
395
|
end
|
370
396
|
|
397
|
+
|
371
398
|
it "should include nil attributes if they are passed in through the include_extras" do
|
399
|
+
ApiResource::Connection.any_instance.expects(:post).with(
|
400
|
+
"/test_resources.json",
|
401
|
+
"{\"test_resource\":{\"name\":\"Ethan\",\"age\":null}}",
|
402
|
+
{}
|
403
|
+
)
|
404
|
+
|
372
405
|
tr = TestResource.build(:name => "Ethan")
|
373
|
-
|
374
|
-
hash['test_resource'].key?('age').should be_true
|
406
|
+
tr.save(:include_extras => [:age])
|
375
407
|
end
|
376
408
|
|
409
|
+
|
377
410
|
it "should include nil attributes when creating if include_nil_attributes_on_create is true" do
|
411
|
+
ApiResource::Connection.any_instance.expects(:post).with(
|
412
|
+
"/test_resources.json",
|
413
|
+
"{\"test_resource\":{\"name\":\"Ethan\",\"age\":null,\"bday\":null}}",
|
414
|
+
{}
|
415
|
+
)
|
416
|
+
|
378
417
|
TestResource.include_blank_attributes_on_create = true
|
379
418
|
tr = TestResource.build(:name => "Ethan")
|
380
|
-
|
381
|
-
|
419
|
+
tr.save
|
420
|
+
|
421
|
+
#hash['test_resource'].key?('age').should be_true
|
382
422
|
TestResource.include_blank_attributes_on_create = false
|
383
423
|
end
|
384
424
|
end
|
@@ -389,79 +429,157 @@ describe "Base" do
|
|
389
429
|
TestResource.reload_class_attributes
|
390
430
|
TestResource.has_many :has_many_objects
|
391
431
|
|
392
|
-
|
393
|
-
|
432
|
+
# TestResource.send(:alias_method, :old_update, :update)
|
433
|
+
# TestResource.send(:alias_method, :old_save, :save)
|
394
434
|
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
435
|
+
# TestResource.send(:define_method, :update) do |*args|
|
436
|
+
# debugger
|
437
|
+
# opts = args.extract_options!
|
438
|
+
# # When we create we should not include any blank attributes
|
439
|
+
# except = self.class.attribute_names - self.changed.symbolize_array
|
440
|
+
# changed_associations = self.changed.symbolize_array.select{|item| self.association?(item)}
|
441
|
+
# opts[:except] = opts[:except] ? opts[:except].concat(except).uniq.symbolize_array : except.symbolize_array
|
442
|
+
# opts[:include_associations] = opts[:include_associations] ? opts[:include_associations].concat(args).concat(changed_associations).uniq : changed_associations.concat(args)
|
443
|
+
# opts[:include_extras] ||= []
|
444
|
+
# opts[:action] = "update"
|
445
|
+
# opts[:except] = [:id] if self.class.include_all_attributes_on_update
|
446
|
+
# encode(opts)
|
447
|
+
# end
|
448
|
+
|
449
|
+
# TestResource.send(:define_method, :save) do |*args|
|
450
|
+
# new? ? create(*args) : update(*args)
|
451
|
+
# end
|
452
|
+
RestClient::Payload.stubs(:has_file? => false)
|
409
453
|
end
|
410
454
|
|
411
455
|
after(:all) do
|
412
|
-
TestResource.send(:alias_method, :update, :old_update)
|
413
|
-
TestResource.send(:alias_method, :save, :old_save)
|
456
|
+
# TestResource.send(:alias_method, :update, :old_update)
|
457
|
+
# TestResource.send(:alias_method, :save, :old_save)
|
414
458
|
end
|
415
459
|
|
416
|
-
|
460
|
+
|
461
|
+
it "should be able to put updated data via the update method and
|
462
|
+
should only include changed attributes when updating" do
|
463
|
+
|
464
|
+
# Note that age is a non-nil attribute and is present in the
|
465
|
+
# put request, but name is not present since it has not changed.
|
466
|
+
|
467
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
468
|
+
"/test_resources/1.json",
|
469
|
+
"{\"test_resource\":{\"age\":6}}",
|
470
|
+
{}
|
471
|
+
)
|
472
|
+
|
417
473
|
tr = TestResource.new(:id => 1, :name => "Ethan")
|
418
474
|
tr.should_not be_new
|
419
|
-
# Thus we know we are calling update
|
420
|
-
tr.age = 6
|
421
|
-
hash = JSON.parse(tr.update)
|
422
|
-
hash['test_resource']['age'].should eql(6)
|
423
475
|
|
424
|
-
hash = JSON.parse(tr.save)
|
425
|
-
hash['test_resource']['age'].should eql(6)
|
426
|
-
end
|
427
|
-
|
428
|
-
it "should only include changed attributes when updating" do
|
429
|
-
tr = TestResource.new(:id => 1, :name => "Ethan")
|
430
|
-
tr.should_not be_new
|
431
476
|
# Thus we know we are calling update
|
432
477
|
tr.age = 6
|
433
|
-
|
434
|
-
hash['test_resource']['name'].should be_nil
|
478
|
+
tr.save
|
435
479
|
end
|
436
480
|
|
481
|
+
|
437
482
|
it "should include changed associations without specification" do
|
483
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
484
|
+
"/test_resources/1.json",
|
485
|
+
"{\"test_resource\":{\"has_many_objects\":[{}]}}",
|
486
|
+
{}
|
487
|
+
)
|
488
|
+
|
438
489
|
tr = TestResource.new(:id => 1, :name => "Ethan")
|
439
490
|
tr.has_many_objects = [HasManyObject.new]
|
440
|
-
|
441
|
-
hash['test_resource']['has_many_objects'].should_not be_blank
|
491
|
+
tr.save
|
442
492
|
end
|
443
493
|
|
494
|
+
|
444
495
|
it "should include unchanged associations if they are specified" do
|
496
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
497
|
+
"/test_resources/1.json",
|
498
|
+
"{\"test_resource\":{\"has_many_objects\":[]}}",
|
499
|
+
{}
|
500
|
+
)
|
501
|
+
|
445
502
|
tr = TestResource.new(:id => 1, :name => "Ethan")
|
446
|
-
|
447
|
-
hash['test_resource']['has_many_objects'].should eql([])
|
503
|
+
tr.save(:has_many_objects)
|
448
504
|
end
|
449
505
|
|
450
|
-
|
506
|
+
|
507
|
+
it "should not include nil attributes of associated objects when updating,
|
508
|
+
unless the attributes have changed to nil" do
|
509
|
+
|
510
|
+
correct_order = sequence("ordering")
|
511
|
+
|
512
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
513
|
+
"/test_resources/1.json",
|
514
|
+
"{\"test_resource\":{\"has_one_object\":{\"size\":\"large\"}}}",
|
515
|
+
{}
|
516
|
+
).in_sequence(correct_order)
|
517
|
+
|
518
|
+
tr = TestResource.new(:id => 1, :name => "Ethan")
|
519
|
+
tr.has_one_object = HasOneObject.new(:size => "large", :color => nil)
|
520
|
+
tr.save(:include_associations => [:has_one_object])
|
521
|
+
|
522
|
+
|
523
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
524
|
+
"/test_resources/1.json",
|
525
|
+
"{\"test_resource\":{\"has_one_object\":{}}}",
|
526
|
+
{}
|
527
|
+
).in_sequence(correct_order)
|
528
|
+
|
529
|
+
tr.has_one_object.size = nil
|
530
|
+
tr.save(:include_associations => [:has_one_object])
|
531
|
+
end
|
532
|
+
|
533
|
+
|
534
|
+
it "should not include nil values for association objects when updating,
|
535
|
+
unless the association has changed to nil" do
|
536
|
+
|
537
|
+
correct_order = sequence("ordering")
|
538
|
+
|
539
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
540
|
+
"/test_resources/1.json",
|
541
|
+
"{\"test_resource\":{\"has_one_object\":{\"size\":\"large\"}}}",
|
542
|
+
{}
|
543
|
+
).in_sequence(correct_order)
|
544
|
+
|
545
|
+
tr = TestResource.new(:id => 1, :name => "Ethan")
|
546
|
+
tr.has_one_object = HasOneObject.new(:size => "large", :color => nil)
|
547
|
+
tr.save(:include_associations => [:has_one_object])
|
548
|
+
|
549
|
+
|
550
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
551
|
+
"/test_resources/1.json",
|
552
|
+
"{\"test_resource\":{\"has_one_object\":null}}",
|
553
|
+
{}
|
554
|
+
).in_sequence(correct_order)
|
555
|
+
|
556
|
+
tr.has_one_object = nil
|
557
|
+
tr.save(:include_associations => [:has_one_object])
|
558
|
+
end
|
559
|
+
|
560
|
+
|
561
|
+
it "should include all attributes if include_all_attributes_on_update is true" do
|
562
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
563
|
+
"/test_resources/1.json",
|
564
|
+
"{\"test_resource\":{\"name\":\"Ethan\",\"age\":null,\"bday\":null}}",
|
565
|
+
{}
|
566
|
+
)
|
567
|
+
|
451
568
|
TestResource.include_all_attributes_on_update = true
|
452
569
|
tr = TestResource.new(:id => 1, :name => "Ethan")
|
453
|
-
|
454
|
-
hash['test_resource']['name'].should eql("Ethan")
|
455
|
-
hash['test_resource'].key?('age').should be_true
|
570
|
+
tr.save
|
456
571
|
TestResource.include_all_attributes_on_update = false
|
457
572
|
end
|
458
573
|
|
459
574
|
it "should provide an update_attributes method to set attrs and save" do
|
460
|
-
|
575
|
+
ApiResource::Connection.any_instance.expects(:put).with(
|
576
|
+
"/test_resources/1.json",
|
577
|
+
"{\"test_resource\":{\"name\":\"Dan\"}}",
|
578
|
+
{}
|
579
|
+
)
|
580
|
+
|
461
581
|
tr = TestResource.new(:id => 1, :name => "Ethan")
|
462
|
-
|
463
|
-
hash['test_resource']['name'].should eql "Dan"
|
464
|
-
|
582
|
+
tr.update_attributes(:name => "Dan")
|
465
583
|
end
|
466
584
|
|
467
585
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: api_resource
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.9
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-
|
12
|
+
date: 2012-06-20 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rails
|
16
|
-
requirement: &
|
16
|
+
requirement: &70119615332880 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - =
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: 3.0.9
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70119615332880
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: hash_dealer
|
27
|
-
requirement: &
|
27
|
+
requirement: &70119615331720 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :runtime
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70119615331720
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: rest-client
|
38
|
-
requirement: &
|
38
|
+
requirement: &70119615329760 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '0'
|
44
44
|
type: :runtime
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *70119615329760
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: log4r
|
49
|
-
requirement: &
|
49
|
+
requirement: &70119615326880 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :runtime
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *70119615326880
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: differ
|
60
|
-
requirement: &
|
60
|
+
requirement: &70119615326000 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ! '>='
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: '0'
|
66
66
|
type: :runtime
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *70119615326000
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: colorize
|
71
|
-
requirement: &
|
71
|
+
requirement: &70119615325020 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ! '>='
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0'
|
77
77
|
type: :runtime
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *70119615325020
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: json
|
82
|
-
requirement: &
|
82
|
+
requirement: &70119615323980 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ! '>='
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: '0'
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *70119615323980
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: rspec
|
93
|
-
requirement: &
|
93
|
+
requirement: &70119615323380 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ! '>='
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: '0'
|
99
99
|
type: :development
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *70119615323380
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: ruby-debug19
|
104
|
-
requirement: &
|
104
|
+
requirement: &70119615322500 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ! '>='
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: '0'
|
110
110
|
type: :development
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *70119615322500
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: growl
|
115
|
-
requirement: &
|
115
|
+
requirement: &70119615321760 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ! '>='
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: '0'
|
121
121
|
type: :development
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *70119615321760
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: rspec-rails
|
126
|
-
requirement: &
|
126
|
+
requirement: &70119615320480 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ! '>='
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: '0'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *70119615320480
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: factory_girl
|
137
|
-
requirement: &
|
137
|
+
requirement: &70119615319500 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ! '>='
|
@@ -142,10 +142,10 @@ dependencies:
|
|
142
142
|
version: '0'
|
143
143
|
type: :development
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *70119615319500
|
146
146
|
- !ruby/object:Gem::Dependency
|
147
147
|
name: simplecov
|
148
|
-
requirement: &
|
148
|
+
requirement: &70119615314040 !ruby/object:Gem::Requirement
|
149
149
|
none: false
|
150
150
|
requirements:
|
151
151
|
- - ! '>='
|
@@ -153,10 +153,10 @@ dependencies:
|
|
153
153
|
version: '0'
|
154
154
|
type: :development
|
155
155
|
prerelease: false
|
156
|
-
version_requirements: *
|
156
|
+
version_requirements: *70119615314040
|
157
157
|
- !ruby/object:Gem::Dependency
|
158
158
|
name: faker
|
159
|
-
requirement: &
|
159
|
+
requirement: &70119615312520 !ruby/object:Gem::Requirement
|
160
160
|
none: false
|
161
161
|
requirements:
|
162
162
|
- - ! '>='
|
@@ -164,10 +164,10 @@ dependencies:
|
|
164
164
|
version: '0'
|
165
165
|
type: :development
|
166
166
|
prerelease: false
|
167
|
-
version_requirements: *
|
167
|
+
version_requirements: *70119615312520
|
168
168
|
- !ruby/object:Gem::Dependency
|
169
169
|
name: guard
|
170
|
-
requirement: &
|
170
|
+
requirement: &70119615310640 !ruby/object:Gem::Requirement
|
171
171
|
none: false
|
172
172
|
requirements:
|
173
173
|
- - ! '>='
|
@@ -175,10 +175,10 @@ dependencies:
|
|
175
175
|
version: '0'
|
176
176
|
type: :development
|
177
177
|
prerelease: false
|
178
|
-
version_requirements: *
|
178
|
+
version_requirements: *70119615310640
|
179
179
|
- !ruby/object:Gem::Dependency
|
180
180
|
name: guard-rspec
|
181
|
-
requirement: &
|
181
|
+
requirement: &70119615308840 !ruby/object:Gem::Requirement
|
182
182
|
none: false
|
183
183
|
requirements:
|
184
184
|
- - ! '>='
|
@@ -186,10 +186,10 @@ dependencies:
|
|
186
186
|
version: '0'
|
187
187
|
type: :development
|
188
188
|
prerelease: false
|
189
|
-
version_requirements: *
|
189
|
+
version_requirements: *70119615308840
|
190
190
|
- !ruby/object:Gem::Dependency
|
191
191
|
name: mocha
|
192
|
-
requirement: &
|
192
|
+
requirement: &70119615306880 !ruby/object:Gem::Requirement
|
193
193
|
none: false
|
194
194
|
requirements:
|
195
195
|
- - ! '>='
|
@@ -197,10 +197,10 @@ dependencies:
|
|
197
197
|
version: '0'
|
198
198
|
type: :development
|
199
199
|
prerelease: false
|
200
|
-
version_requirements: *
|
200
|
+
version_requirements: *70119615306880
|
201
201
|
- !ruby/object:Gem::Dependency
|
202
202
|
name: bundler
|
203
|
-
requirement: &
|
203
|
+
requirement: &70119615306320 !ruby/object:Gem::Requirement
|
204
204
|
none: false
|
205
205
|
requirements:
|
206
206
|
- - ! '>='
|
@@ -208,10 +208,10 @@ dependencies:
|
|
208
208
|
version: '0'
|
209
209
|
type: :development
|
210
210
|
prerelease: false
|
211
|
-
version_requirements: *
|
211
|
+
version_requirements: *70119615306320
|
212
212
|
- !ruby/object:Gem::Dependency
|
213
213
|
name: jeweler
|
214
|
-
requirement: &
|
214
|
+
requirement: &70119615299340 !ruby/object:Gem::Requirement
|
215
215
|
none: false
|
216
216
|
requirements:
|
217
217
|
- - ~>
|
@@ -219,10 +219,10 @@ dependencies:
|
|
219
219
|
version: 1.6.4
|
220
220
|
type: :development
|
221
221
|
prerelease: false
|
222
|
-
version_requirements: *
|
222
|
+
version_requirements: *70119615299340
|
223
223
|
- !ruby/object:Gem::Dependency
|
224
224
|
name: activerecord
|
225
|
-
requirement: &
|
225
|
+
requirement: &70119615298400 !ruby/object:Gem::Requirement
|
226
226
|
none: false
|
227
227
|
requirements:
|
228
228
|
- - =
|
@@ -230,10 +230,10 @@ dependencies:
|
|
230
230
|
version: 3.0.9
|
231
231
|
type: :development
|
232
232
|
prerelease: false
|
233
|
-
version_requirements: *
|
233
|
+
version_requirements: *70119615298400
|
234
234
|
- !ruby/object:Gem::Dependency
|
235
235
|
name: sqlite3
|
236
|
-
requirement: &
|
236
|
+
requirement: &70119615297600 !ruby/object:Gem::Requirement
|
237
237
|
none: false
|
238
238
|
requirements:
|
239
239
|
- - ! '>='
|
@@ -241,7 +241,7 @@ dependencies:
|
|
241
241
|
version: '0'
|
242
242
|
type: :development
|
243
243
|
prerelease: false
|
244
|
-
version_requirements: *
|
244
|
+
version_requirements: *70119615297600
|
245
245
|
description: A replacement for ActiveResource for RESTful APIs that handles associated
|
246
246
|
object and multiple data sources
|
247
247
|
email: ejl6266@gmail.com
|
@@ -325,7 +325,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
325
325
|
version: '0'
|
326
326
|
segments:
|
327
327
|
- 0
|
328
|
-
hash:
|
328
|
+
hash: 1315035305681384085
|
329
329
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
330
330
|
none: false
|
331
331
|
requirements:
|
@@ -334,7 +334,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
334
334
|
version: '0'
|
335
335
|
requirements: []
|
336
336
|
rubyforge_project:
|
337
|
-
rubygems_version: 1.8.
|
337
|
+
rubygems_version: 1.8.17
|
338
338
|
signing_key:
|
339
339
|
specification_version: 3
|
340
340
|
summary: A replacement for ActiveResource for RESTful APIs that handles associated
|