api_resource 0.2.8 → 0.2.9

Sign up to get free protection for your applications and to get access to all the features.
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.2.8
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"
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-03-28"
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.11"
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
- return @internal_object = contents if contents.is_a?(self.klass)
16
- return @internal_object = contents if contents.respond_to?(:internal_object) && contents.internal_object.is_a?(self.klass)
17
- return load(contents)
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?
@@ -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.include_blank_attributes_on_create = false
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
@@ -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
- 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_associations] = opts[:include_associations] ? opts[:include_associations].concat(args) : []
343
- opts[:include_extras] ||= []
344
- encode(opts)
345
- end
346
- TestResource.send(:define_method, :save) do |*args|
347
- new? ? create(*args) : update(*args)
348
- end
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
- hash = JSON.parse(tr.save)
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
- hash = JSON.parse(tr.save)
367
- hash['test_resource']['age'].should be_nil
368
- hash['test_resource']['name'].should eql("Ethan")
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
- hash = JSON.parse(tr.save(:include_extras => [:age]))
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
- hash = JSON.parse(tr.save)
381
- hash['test_resource'].key?('age').should be_true
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
- TestResource.send(:alias_method, :old_update, :update)
393
- TestResource.send(:alias_method, :old_save, :save)
432
+ # TestResource.send(:alias_method, :old_update, :update)
433
+ # TestResource.send(:alias_method, :old_save, :save)
394
434
 
395
- TestResource.send(:define_method, :update) do |*args|
396
- opts = args.extract_options!
397
- # When we create we should not include any blank attributes
398
- except = self.class.attribute_names - self.changed.symbolize_array
399
- changed_associations = self.changed.symbolize_array.select{|item| self.association?(item)}
400
- opts[:except] = opts[:except] ? opts[:except].concat(except).uniq.symbolize_array : except.symbolize_array
401
- opts[:include_associations] = opts[:include_associations] ? opts[:include_associations].concat(args).concat(changed_associations).uniq : changed_associations.concat(args)
402
- opts[:include_extras] ||= []
403
- opts[:except] = [:id] if self.class.include_all_attributes_on_update
404
- encode(opts)
405
- end
406
- TestResource.send(:define_method, :save) do |*args|
407
- new? ? create(*args) : update(*args)
408
- end
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
- it "should be able to put updated data via the update method" do
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
- hash = JSON.parse(tr.save)
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
- hash = JSON.parse(tr.save)
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
- hash = JSON.parse(tr.save(:has_many_objects))
447
- hash['test_resource']['has_many_objects'].should eql([])
503
+ tr.save(:has_many_objects)
448
504
  end
449
505
 
450
- it "should include all attributes if include_all_attributes_on_update is true" do
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
- hash = JSON.parse(tr.save)
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
- hash = JSON.parse(tr.update_attributes(:name => "Dan"))
463
- hash['test_resource']['name'].should eql "Dan"
464
-
582
+ tr.update_attributes(:name => "Dan")
465
583
  end
466
584
 
467
585
 
@@ -24,7 +24,11 @@ Mocks.define do
24
24
  end
25
25
 
26
26
  endpoint("/has_one_objects/new") do
27
- get({})
27
+ get({
28
+ "attributes" => {
29
+ "public" => ["size", "color"]
30
+ }
31
+ })
28
32
  end
29
33
 
30
34
  endpoint("/has_many_objects/new") do
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.8
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-03-28 00:00:00.000000000 Z
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: &2164460360 !ruby/object:Gem::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: *2164460360
24
+ version_requirements: *70119615332880
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: hash_dealer
27
- requirement: &2164459580 !ruby/object:Gem::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: *2164459580
35
+ version_requirements: *70119615331720
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: rest-client
38
- requirement: &2164458980 !ruby/object:Gem::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: *2164458980
46
+ version_requirements: *70119615329760
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: log4r
49
- requirement: &2164457880 !ruby/object:Gem::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: *2164457880
57
+ version_requirements: *70119615326880
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: differ
60
- requirement: &2164455760 !ruby/object:Gem::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: *2164455760
68
+ version_requirements: *70119615326000
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: colorize
71
- requirement: &2164452900 !ruby/object:Gem::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: *2164452900
79
+ version_requirements: *70119615325020
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: json
82
- requirement: &2164451320 !ruby/object:Gem::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: *2164451320
90
+ version_requirements: *70119615323980
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: rspec
93
- requirement: &2164449600 !ruby/object:Gem::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: *2164449600
101
+ version_requirements: *70119615323380
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: ruby-debug19
104
- requirement: &2164448560 !ruby/object:Gem::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: *2164448560
112
+ version_requirements: *70119615322500
113
113
  - !ruby/object:Gem::Dependency
114
114
  name: growl
115
- requirement: &2164447300 !ruby/object:Gem::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: *2164447300
123
+ version_requirements: *70119615321760
124
124
  - !ruby/object:Gem::Dependency
125
125
  name: rspec-rails
126
- requirement: &2164446240 !ruby/object:Gem::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: *2164446240
134
+ version_requirements: *70119615320480
135
135
  - !ruby/object:Gem::Dependency
136
136
  name: factory_girl
137
- requirement: &2164445640 !ruby/object:Gem::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: *2164445640
145
+ version_requirements: *70119615319500
146
146
  - !ruby/object:Gem::Dependency
147
147
  name: simplecov
148
- requirement: &2164445080 !ruby/object:Gem::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: *2164445080
156
+ version_requirements: *70119615314040
157
157
  - !ruby/object:Gem::Dependency
158
158
  name: faker
159
- requirement: &2164444480 !ruby/object:Gem::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: *2164444480
167
+ version_requirements: *70119615312520
168
168
  - !ruby/object:Gem::Dependency
169
169
  name: guard
170
- requirement: &2164443800 !ruby/object:Gem::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: *2164443800
178
+ version_requirements: *70119615310640
179
179
  - !ruby/object:Gem::Dependency
180
180
  name: guard-rspec
181
- requirement: &2164442660 !ruby/object:Gem::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: *2164442660
189
+ version_requirements: *70119615308840
190
190
  - !ruby/object:Gem::Dependency
191
191
  name: mocha
192
- requirement: &2164437840 !ruby/object:Gem::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: *2164437840
200
+ version_requirements: *70119615306880
201
201
  - !ruby/object:Gem::Dependency
202
202
  name: bundler
203
- requirement: &2164431020 !ruby/object:Gem::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: *2164431020
211
+ version_requirements: *70119615306320
212
212
  - !ruby/object:Gem::Dependency
213
213
  name: jeweler
214
- requirement: &2164419020 !ruby/object:Gem::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: *2164419020
222
+ version_requirements: *70119615299340
223
223
  - !ruby/object:Gem::Dependency
224
224
  name: activerecord
225
- requirement: &2164417240 !ruby/object:Gem::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: *2164417240
233
+ version_requirements: *70119615298400
234
234
  - !ruby/object:Gem::Dependency
235
235
  name: sqlite3
236
- requirement: &2164415040 !ruby/object:Gem::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: *2164415040
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: 3397384191218404417
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.11
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