ff_api 0.1.1 → 0.2.0

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.
Files changed (3) hide show
  1. checksums.yaml +4 -4
  2. data/lib/ff_api.rb +28 -6
  3. metadata +2 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 601131a4aa2b4ebf9302aea8b37082d4350cddd44060eeffa4d4d2504918ade1
4
- data.tar.gz: 95757f23e8f47488340ef5d7eb079a68bdc2f599c2baed70e070e3c75196e7c0
3
+ metadata.gz: 61ebbc1b9532e86b9b22b6483c6828d8840a56855b3a7e4ae41d91fd76f347de
4
+ data.tar.gz: 047d43755c9c058d3770f5db70af532d3bfabfeb0da4905ef35d0fb69c0a22d1
5
5
  SHA512:
6
- metadata.gz: 77873c1de12e4d8c9de40d4a6db6fffe4a540865b40f637548472044b72f87673723850f612a34650aa36c198615c220a67aa7e2e08dcf62cb12916477638b89
7
- data.tar.gz: 702f98934970ed046303cafd9d7aa9bda64f64f8b35368e8cad58bec92ab107ee569d20f6534bf661ca230d54ffb4c150461d02b4d3d57574e45c03db2a7be4c
6
+ metadata.gz: fafdd8f6358c0dda14a69f0ce0612dbd8237e0a80dc3966b1113074f8c45ba8dc8b9c82b039632f889a34fcfd2dad42bddbe91edf2ae1ed6f26ffc441a15589f
7
+ data.tar.gz: e1977ad401a3199a8cec27e87e3c97b8c062d993b9a81d755bedf8c8ea21efbda1af600f000a097a68397ff11c36d8e97a748e2224bb1279cdbe639e989e2ee4
data/lib/ff_api.rb CHANGED
@@ -17,14 +17,25 @@ module FfApi
17
17
  end
18
18
 
19
19
  def schools(params = {})
20
+ connection = Faraday.new(url: base_url)
21
+ if params.is_a?(Hash)
22
+ json = schools_as_json(params)
23
+ schools = json["results"]
24
+ json["json"] = schools.map { |school_hash| FfApi::School.new(school_hash) }
25
+ json
26
+ else
27
+ FfApi::School.new(schools_as_json)
28
+ end
29
+ end
30
+
31
+ def schools_as_json(params = {})
20
32
  connection = Faraday.new(url: base_url)
21
33
  if params.is_a?(Hash)
22
34
  response = connection.get("schools.json", params) do |request|
23
35
  request.headers["Authorization"] = "Bearer #{api_key}"
24
36
  end
25
37
  if response.status == 200
26
- schools = JSON.parse(response.body)
27
- schools.map { |school_hash| FfApi::School.new(school_hash) }
38
+ JSON.parse(response.body)
28
39
  else
29
40
  respond_to_error(response)
30
41
  end
@@ -33,7 +44,7 @@ module FfApi
33
44
  request.headers["Authorization"] = "Bearer #{api_key}"
34
45
  end
35
46
  if response.status == 200
36
- FfApi::School.new(JSON.parse(response.body))
47
+ JSON.parse(response.body)
37
48
  else
38
49
  respond_to_error(response)
39
50
  end
@@ -41,14 +52,25 @@ module FfApi
41
52
  end
42
53
 
43
54
  def districts(params = {})
55
+ connection = Faraday.new(url: base_url)
56
+ if params.is_a?(Hash)
57
+ json = districts_as_json(params)
58
+ districts = json["results"]
59
+ json["json"] = districts.map { |district_hash| FfApi::District.new(district_hash) }
60
+ json
61
+ else
62
+ FfApi::District.new(districts_as_json)
63
+ end
64
+ end
65
+
66
+ def districts_as_json(params = {})
44
67
  connection = Faraday.new(url: base_url)
45
68
  if params.is_a?(Hash)
46
69
  response = connection.get("districts.json", params) do |request|
47
70
  request.headers["Authorization"] = "Bearer #{api_key}"
48
71
  end
49
72
  if response.status == 200
50
- districts = JSON.parse(response.body)
51
- districts.map { |district_hash| FfApi::District.new(district_hash) }
73
+ JSON.parse(response.body)
52
74
  else
53
75
  respond_to_error(response)
54
76
  end
@@ -57,7 +79,7 @@ module FfApi
57
79
  request.headers["Authorization"] = "Bearer #{api_key}"
58
80
  end
59
81
  if response.status == 200
60
- FfApi::District.new(JSON.parse(response.body))
82
+ JSON.parse(response.body)
61
83
  else
62
84
  respond_to_error(response)
63
85
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ff_api
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Austin Cotant
@@ -32,7 +32,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
32
32
  requirements:
33
33
  - - ">="
34
34
  - !ruby/object:Gem::Version
35
- version: '0'
35
+ version: '3.0'
36
36
  required_rubygems_version: !ruby/object:Gem::Requirement
37
37
  requirements:
38
38
  - - ">="