campaign_cash 0.0.5 → 1.0

Sign up to get free protection for your applications and to get access to all the features.
data/README.rdoc CHANGED
@@ -23,9 +23,9 @@ You'll want to set your API key as an environment variable in order to run the t
23
23
  Currently there are methods to support retrieving candidates and committees, and every method requires at least one parameter,
24
24
  the election cycle. Some examples (provided you've done include CampaignCash):
25
25
 
26
- Candidate.find_by_fecid(2010,"H4NY07011") # find Gary Ackerman's details for the 2010 cycle
27
- Committee.search(2010, "Growth") # find all committees in the 2010 cycle with the word 'Growth' in the name.
28
- Candidate.search(2010, "Udall") # find all candidates in the 2010 cycle with the name 'Udall'
26
+ Candidate.find("H4NY07011", 2010) # find Gary Ackerman's details for the 2010 cycle
27
+ Committee.search("Growth", 2010) # find all committees in the 2010 cycle with the word 'Growth' in the name.
28
+ Candidate.search("Udall", 2010) # find all candidates in the 2010 cycle with the name 'Udall'
29
29
 
30
30
  Check out the tests for further examples.
31
31
 
@@ -9,7 +9,7 @@ module CampaignCash
9
9
  API_VERSION = 'v3'
10
10
  API_NAME = 'elections/us'
11
11
  API_BASE = "/svc/#{API_NAME}/#{API_VERSION}/finances"
12
- CURRENT_CYCLE = 2010
12
+ CURRENT_CYCLE = 2012
13
13
 
14
14
  @@api_key = nil
15
15
  @@copyright = nil
@@ -14,7 +14,7 @@ module CampaignCash
14
14
  end
15
15
  end
16
16
 
17
- def self.create_from_api(params={})
17
+ def self.create(params={})
18
18
  self.new :name => params['name'],
19
19
  :id => params['id'],
20
20
  :state => params['state'],
@@ -41,7 +41,7 @@ module CampaignCash
41
41
  :date_coverage_to => params['date_coverage_to']
42
42
  end
43
43
 
44
- def self.create_from_api_search_results(params={})
44
+ def self.create_from_search_results(params={})
45
45
  self.new :name => params['candidate']['name'],
46
46
  :id => params['candidate']['id'],
47
47
  :state => params['state'],
@@ -55,32 +55,32 @@ module CampaignCash
55
55
  def self.find(fecid, cycle=CURRENT_CYCLE)
56
56
  reply = invoke("#{cycle}/candidates/#{fecid}")
57
57
  result = reply['results']
58
- self.create_from_api(result.first) if result.first
58
+ self.create(result.first) if result.first
59
59
  end
60
60
 
61
61
  def self.leaders(category, cycle=CURRENT_CYCLE)
62
62
  reply = invoke("#{cycle}/candidates/leaders/#{category}",{})
63
63
  results = reply['results']
64
- results.map{|c| self.create_from_api(c)}
64
+ results.map{|c| self.create(c)}
65
65
  end
66
66
 
67
67
  def self.search(name, cycle=CURRENT_CYCLE)
68
68
  reply = invoke("#{cycle}/candidates/search", {:query => name})
69
69
  results = reply['results']
70
- results.map{|c| self.create_from_api_search_results(c)}
70
+ results.map{|c| self.create_from_search_results(c)}
71
71
  end
72
72
 
73
73
  def self.new_candidates(cycle=CURRENT_CYCLE)
74
74
  reply = invoke("#{cycle}/candidates/new",{})
75
75
  results = reply['results']
76
- results.map{|c| self.create_from_api(c)}
76
+ results.map{|c| self.create(c)}
77
77
  end
78
78
 
79
79
  def self.state_chamber(state, chamber, district=nil, cycle=CURRENT_CYCLE)
80
80
  district ? path = "#{cycle}/seats/#{state}/#{chamber}/#{district}" : path = "#{cycle}/seats/#{state}/#{chamber}"
81
81
  reply = invoke(path,{})
82
82
  results = reply['results']
83
- results.map{|c| self.create_from_api_search_results(c)}
83
+ results.map{|c| self.create_from_search_results(c)}
84
84
  end
85
85
 
86
86
  end
@@ -14,7 +14,7 @@ module CampaignCash
14
14
  end
15
15
  end
16
16
 
17
- def self.create_from_api(params={})
17
+ def self.create(params={})
18
18
  self.new :name => params['name'],
19
19
  :id => params['id'],
20
20
  :state => params['state'],
@@ -38,7 +38,7 @@ module CampaignCash
38
38
  :candidate => params['candidate']
39
39
  end
40
40
 
41
- def self.create_from_api_search_results(params={})
41
+ def self.create_from_search_results(params={})
42
42
  self.new :name => params['name'],
43
43
  :id => params['id'],
44
44
  :city => params['city'],
@@ -0,0 +1,26 @@
1
+ module CampaignCash
2
+ class Contribution < Base
3
+
4
+ attr_reader :date, :candidate_uri, :primary_general, :amount, :state, :name, :image_uri, :party, :district
5
+
6
+ def initialize(params={})
7
+ params.each_pair do |k,v|
8
+ instance_variable_set("@#{k}", v)
9
+ end
10
+ end
11
+
12
+ def self.create(cycle, committee, params={}, candidate = params['candidate'])
13
+ self.new :date => date_parser(params[:date]),
14
+ :candidate_uri => candidate,
15
+ :committee_uri => committee,
16
+ :primary_general => params[:primary_general],
17
+ :amount => params[:amount],
18
+ :state => params[:state],
19
+ :name => params[:name],
20
+ :image_uri => params[:image_uri],
21
+ :party => params[:party],
22
+ :district => params[:district],
23
+ :cycle => cycle
24
+ end
25
+ end
26
+ end
@@ -1,7 +1,7 @@
1
1
  module CampaignCash
2
2
  class Filing < Base
3
3
 
4
- attr_reader :committee_name, :date_coverage_from, :amended_uri, :fec_uri, :date_coverage_to, :committee, :report_title, :amended
4
+ attr_reader :committee_name, :date_coverage_from, :amended_uri, :fec_uri, :date_coverage_to, :committee, :report_title, :amended, :date_filed, :cycle, :form_type
5
5
 
6
6
  def initialize(params={})
7
7
  params.each_pair do |k,v|
@@ -9,30 +9,50 @@ module CampaignCash
9
9
  end
10
10
  end
11
11
 
12
- def self.create_from_api(params={})
12
+ def self.create(params={})
13
13
  self.new :committee_name => params['committee_name'],
14
14
  :date_coverage_from => date_parser(params['date_coverage_from']),
15
15
  :date_coverage_to => date_parser(params['date_coverage_to']),
16
16
  :committee => params['committee'],
17
- :report_title => params['report_title'],
17
+ :report_title => params['report_title'].strip,
18
18
  :fec_uri => params['fec_uri'],
19
19
  :amended => params['amended'],
20
- :amended_uri => params['amended_uri']
20
+ :amended_uri => params['amended_uri'],
21
+ :form_type => params['form_type']
21
22
  end
22
23
 
24
+ def self.create_from_filings(params={})
25
+ self.new :date_coverage_from => date_parser(params['date_coverage_from']),
26
+ :date_coverage_to => date_parser(params['date_coverage_to']),
27
+ :report_title => params['report_title'].strip,
28
+ :fec_uri => params['fec_uri'],
29
+ :amended => params['amended'],
30
+ :amended_uri => params['amended_uri'],
31
+ :cycle => params['cycle'],
32
+ :form_type => params['form_type'],
33
+ :date_filed => date_parser(params['date_filed'])
34
+ end
35
+
36
+
23
37
  def self.today
24
38
  cycle=CURRENT_CYCLE
25
39
  reply = Base.invoke("#{cycle}/filings", {})
26
40
  results = reply['results']
27
- @filings = results.map{|c| Filing.create_from_api(c)}
41
+ @filings = results.map{|c| Filing.create(c)}
28
42
  end
29
43
 
30
44
  def self.date(year, month, day)
31
45
  cycle = cycle_from_date(Date.parse("#{month}/#{day}/#{year}"))
32
46
  reply = Base.invoke("#{cycle}/filings/#{year}/#{month}/#{day}", {})
33
47
  results = reply['results']
34
- @filings = results.map{|c| Filing.create_from_api(c)}
48
+ @filings = results.map{|c| Filing.create(c)}
35
49
  end
36
50
 
37
- end
51
+ def self.by_type(cycle, form_type)
52
+ cycle = cycle
53
+ reply = Base.invoke("#{cycle}/filings/types/#{form_type}")
54
+ results = reply['results']
55
+ @filings = results.map{|c| Filing.create(c)}
56
+ end
57
+ end
38
58
  end
@@ -0,0 +1,24 @@
1
+ module CampaignCash
2
+ class Form < Base
3
+
4
+ attr_reader :id, :name
5
+
6
+ def initialize(params={})
7
+ params.each_pair do |k,v|
8
+ instance_variable_set("@#{k}", v)
9
+ end
10
+ end
11
+
12
+ def self.create(params={})
13
+ self.new :id => params['id'],
14
+ :name => params['name']
15
+ end
16
+
17
+ def self.form_types
18
+ reply = Base.invoke("#{Base::CURRENT_CYCLE}/filings/types")
19
+ results = reply['results']
20
+ @forms = results.map{|c| Form.create(c)}
21
+ end
22
+
23
+ end
24
+ end
@@ -1,3 +1,3 @@
1
1
  module CampaignCash
2
- VERSION = "0.0.5"
2
+ VERSION = "1.0"
3
3
  end
data/lib/campaign_cash.rb CHANGED
@@ -4,5 +4,7 @@ $:.unshift(File.dirname(__FILE__)) unless
4
4
  require "campaign_cash/base"
5
5
  require "campaign_cash/candidate"
6
6
  require "campaign_cash/committee"
7
+ require "campaign_cash/contribution"
7
8
  require "campaign_cash/filing"
9
+ require "campaign_cash/form"
8
10
  require "campaign_cash/version"
@@ -3,11 +3,11 @@ require File.dirname(__FILE__) + '/../test_helper.rb'
3
3
  class TestCampaignCash::TestCandidate < Test::Unit::TestCase
4
4
  include CampaignCash
5
5
 
6
- context "Candidate.create_from_api" do
6
+ context "Candidate.create" do
7
7
  setup do
8
8
  reply = Base.invoke('2010/candidates/H4NY07011', {})
9
9
  @result = reply['results'].first
10
- @candidate = Candidate.create_from_api(@result)
10
+ @candidate = Candidate.create(@result)
11
11
  end
12
12
 
13
13
  should "return an object of the Candidate type" do
@@ -25,7 +25,7 @@ class TestCampaignCash::TestCandidate < Test::Unit::TestCase
25
25
  setup do
26
26
  reply = Base.invoke('2010/candidates/search', {:query => "Udall"})
27
27
  results = reply['results']
28
- @candidates = results.map{|c| Candidate.create_from_api_search_results(c)}
28
+ @candidates = results.map{|c| Candidate.create_from_search_results(c)}
29
29
  end
30
30
 
31
31
  should "return two candidate objects" do
@@ -39,7 +39,7 @@ class TestCampaignCash::TestCandidate < Test::Unit::TestCase
39
39
  setup do
40
40
  reply = Base.invoke('2010/candidates/new', {})
41
41
  results = reply['results']
42
- @candidates = results.map{|c| Candidate.create_from_api(c)}
42
+ @candidates = results.map{|c| Candidate.create(c)}
43
43
  end
44
44
 
45
45
  should "return 20 new candidates" do
@@ -53,7 +53,7 @@ class TestCampaignCash::TestCandidate < Test::Unit::TestCase
53
53
  setup do
54
54
  reply = Base.invoke('2010/candidates/leaders/end_cash', {})
55
55
  results = reply['results']
56
- @candidates = results.map{|c| Candidate.create_from_api(c)}
56
+ @candidates = results.map{|c| Candidate.create(c)}
57
57
  end
58
58
 
59
59
  should "return 20 candidates each with a greater end_cash value than the next" do
@@ -7,7 +7,7 @@ class TestCampaignCash::TestCommittee < Test::Unit::TestCase
7
7
  setup do
8
8
  reply = Base.invoke('2010/committees/C00312223', {})
9
9
  @result = reply['results'].first
10
- @committee = Committee.create_from_api(@result)
10
+ @committee = Committee.create(@result)
11
11
  end
12
12
 
13
13
  should "return an object of the Committee type" do
@@ -25,7 +25,7 @@ class TestCampaignCash::TestCommittee < Test::Unit::TestCase
25
25
  setup do
26
26
  reply = Base.invoke('2010/committees/search', {:query => "Boeing"})
27
27
  results = reply['results']
28
- @committees = results.map{|c| Committee.create_from_api_search_results(c)}
28
+ @committees = results.map{|c| Committee.create_from_search_results(c)}
29
29
  end
30
30
 
31
31
  should "return two committee objects" do
@@ -39,7 +39,7 @@ class TestCampaignCash::TestCommittee < Test::Unit::TestCase
39
39
  setup do
40
40
  reply = Base.invoke('2010/committees/new', {})
41
41
  results = reply['results']
42
- @committees = results.map{|c| Committee.create_from_api_search_results(c)}
42
+ @committees = results.map{|c| Committee.create_from_search_results(c)}
43
43
  end
44
44
 
45
45
  should "return 20 new committees" do
@@ -56,4 +56,48 @@ class TestCampaignCash::TestCommittee < Test::Unit::TestCase
56
56
  end
57
57
  end
58
58
  end
59
+
60
+ context "committee filings" do
61
+ setup do
62
+ reply = Base.invoke('2010/committees/C00312223/filings', {})
63
+ results = reply['results']
64
+ @filings = results.map{|f| Filing.create_from_filings(f)}
65
+ end
66
+
67
+ should "return 10 filings" do
68
+ assert_equal @filings.size, 10
69
+ end
70
+ end
71
+
72
+ context "committee contributions" do
73
+ setup do
74
+ reply = Base.invoke('2010/committees/C00458588/contributions', {})
75
+ results = reply['results']
76
+ @committee = reply['committee']
77
+ @num_records = reply['total_results']
78
+ @total_amount = reply['total_amount']
79
+ @contributions = results.map{|c| Contribution.create(@committee, c)}
80
+ end
81
+
82
+ should "return 125 total results" do
83
+ assert_equal @num_records, 125
84
+ end
85
+ end
86
+
87
+ context "committee contributions to a candidate" do
88
+ setup do
89
+ reply = Base.invoke('2010/committees/C00458588/contributions/candidates/H0NC02059', {})
90
+ results = reply['results']
91
+ @cycle = reply['cycle']
92
+ @committee = reply['committee']
93
+ @candidate = reply['candidate']
94
+ @total_amount = reply['total_amount']
95
+ @contributions = results.map{|c| Contribution.create(@cycle, @committee, c, @candidate)}
96
+ end
97
+
98
+ should "return 2 results totaling $10,000" do
99
+ assert_equal @contributions.size, 2
100
+ assert_equal @total_amount, 10000
101
+ end
102
+ end
59
103
  end
@@ -24,4 +24,14 @@ class TestCampaignCash::TestFiling < Test::Unit::TestCase
24
24
  end
25
25
  end
26
26
 
27
+ context "recent statements of organization" do
28
+ setup do
29
+ @filings = Filing.by_type(2012, "F1")
30
+ end
31
+
32
+ should "return a list of the 20 most recent Filings that are statements of organization" do
33
+ assert_equal @filings.size, 20
34
+ assert_equal @filings.first.report_title, "STATEMENT OF ORGANIZATION"
35
+ end
36
+ end
27
37
  end
@@ -0,0 +1,15 @@
1
+ require File.dirname(__FILE__) + '/../test_helper.rb'
2
+
3
+ class TestCampaignCash::TestForm < Test::Unit::TestCase
4
+ include CampaignCash
5
+
6
+ context "form types" do
7
+ setup do
8
+ @forms = Form.form_types
9
+ end
10
+
11
+ should "return a list of objects of the Filing type" do
12
+ assert_kind_of(Form, @forms.first)
13
+ end
14
+ end
15
+ end
data/test/test_helper.rb CHANGED
@@ -8,7 +8,9 @@ require File.dirname(__FILE__) + '/../lib/campaign_cash'
8
8
  require File.dirname(__FILE__) + '/../lib/campaign_cash/base'
9
9
  require File.dirname(__FILE__) + '/../lib/campaign_cash/candidate'
10
10
  require File.dirname(__FILE__) + '/../lib/campaign_cash/committee'
11
+ require File.dirname(__FILE__) + '/../lib/campaign_cash/contribution'
11
12
  require File.dirname(__FILE__) + '/../lib/campaign_cash/filing'
13
+ require File.dirname(__FILE__) + '/../lib/campaign_cash/form'
12
14
 
13
15
  # set your NYT Campaign Finance API key as an environment variable to run the tests
14
16
  API_KEY = ENV['NYT_CAMPFIN_API_KEY']
metadata CHANGED
@@ -1,13 +1,12 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: campaign_cash
3
3
  version: !ruby/object:Gem::Version
4
- hash: 21
5
- prerelease: false
4
+ hash: 15
5
+ prerelease:
6
6
  segments:
7
+ - 1
7
8
  - 0
8
- - 0
9
- - 5
10
- version: 0.0.5
9
+ version: "1.0"
11
10
  platform: ruby
12
11
  authors:
13
12
  - Derek Willis
@@ -15,7 +14,7 @@ autorequire:
15
14
  bindir: bin
16
15
  cert_chain: []
17
16
 
18
- date: 2010-12-23 00:00:00 -05:00
17
+ date: 2011-02-11 00:00:00 -05:00
19
18
  default_executable:
20
19
  dependencies:
21
20
  - !ruby/object:Gem::Dependency
@@ -67,11 +66,14 @@ files:
67
66
  - lib/campaign_cash/base.rb
68
67
  - lib/campaign_cash/candidate.rb
69
68
  - lib/campaign_cash/committee.rb
69
+ - lib/campaign_cash/contribution.rb
70
70
  - lib/campaign_cash/filing.rb
71
+ - lib/campaign_cash/form.rb
71
72
  - lib/campaign_cash/version.rb
72
73
  - test/campaign_cash/test_candidate.rb
73
74
  - test/campaign_cash/test_committee.rb
74
75
  - test/campaign_cash/test_filing.rb
76
+ - test/campaign_cash/test_form.rb
75
77
  - test/test_helper.rb
76
78
  has_rdoc: true
77
79
  homepage: http://rubygems.org/gems/campaign_cash
@@ -105,7 +107,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
105
107
  requirements: []
106
108
 
107
109
  rubyforge_project: campaign_cash
108
- rubygems_version: 1.3.7
110
+ rubygems_version: 1.4.1
109
111
  signing_key:
110
112
  specification_version: 3
111
113
  summary: Following the money.