quakefyi 0.1.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 +7 -0
  2. data/lib/quakefyi.rb +125 -0
  3. metadata +47 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 4f6d5a4439fcfb46b0d30131df58d709a6dcc0d64ccf13524b6e04509d831fac
4
+ data.tar.gz: e16277a169d6d8ba622f33877a700834822c296fdd707ac9cc0a39d4b53b1baf
5
+ SHA512:
6
+ metadata.gz: 925ef785275163e2ffd9b8ff9bbb1baf1b0ae7e4f8735efbdc757feebac02cc1030821c72586c8f05de2a9aa33f181db5ffe4d8dbd5219b820f44d45e2bd68c8
7
+ data.tar.gz: bf706f73c9e6d3857842b4e27d9965d8e609504f5cc6eeb6e1b9f96dcc367ae0106ced9085b2063133c250a3dffa34b24baf3fb93fd8ea7fefa43a18035c3403
data/lib/quakefyi.rb ADDED
@@ -0,0 +1,125 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "net/http"
4
+ require "json"
5
+ require "uri"
6
+
7
+ # Ruby client for QuakeFYI REST API (quakefyi.com).
8
+ #
9
+ # client = QuakeFYI::Client.new
10
+ # result = client.search("query")
11
+ #
12
+ module QuakeFYI
13
+ class Client
14
+ BASE_URL = "https://quakefyi.com"
15
+
16
+ def initialize(base_url: BASE_URL)
17
+ @base_url = base_url
18
+ end
19
+
20
+ def search(query)
21
+ get("/api/v1/search/", q: query)
22
+ end
23
+
24
+ # List all case studies.
25
+ def list_case_studies
26
+ get("/api/v1/case-studies/")
27
+ end
28
+
29
+ # Get case study by slug.
30
+ def get_case_study(slug)
31
+ get("/api/v1/case-studies/#{slug}/")
32
+ end
33
+ # List all countries.
34
+ def list_countries
35
+ get("/api/v1/countries/")
36
+ end
37
+
38
+ # Get country by slug.
39
+ def get_country(slug)
40
+ get("/api/v1/countries/#{slug}/")
41
+ end
42
+ # List all earthquakes.
43
+ def list_earthquakes
44
+ get("/api/v1/earthquakes/")
45
+ end
46
+
47
+ # Get earthquake by slug.
48
+ def get_earthquake(slug)
49
+ get("/api/v1/earthquakes/#{slug}/")
50
+ end
51
+ # List all faqs.
52
+ def list_faqs
53
+ get("/api/v1/faqs/")
54
+ end
55
+
56
+ # Get faq by slug.
57
+ def get_faq(slug)
58
+ get("/api/v1/faqs/#{slug}/")
59
+ end
60
+ # List all faults.
61
+ def list_faults
62
+ get("/api/v1/faults/")
63
+ end
64
+
65
+ # Get fault by slug.
66
+ def get_fault(slug)
67
+ get("/api/v1/faults/#{slug}/")
68
+ end
69
+ # List all glossary.
70
+ def list_glossary
71
+ get("/api/v1/glossary/")
72
+ end
73
+
74
+ # Get term by slug.
75
+ def get_term(slug)
76
+ get("/api/v1/glossary/#{slug}/")
77
+ end
78
+ # List all guides.
79
+ def list_guides
80
+ get("/api/v1/guides/")
81
+ end
82
+
83
+ # Get guide by slug.
84
+ def get_guide(slug)
85
+ get("/api/v1/guides/#{slug}/")
86
+ end
87
+ # List all historical.
88
+ def list_historical
89
+ get("/api/v1/historical/")
90
+ end
91
+
92
+ # Get historical by slug.
93
+ def get_historical(slug)
94
+ get("/api/v1/historical/#{slug}/")
95
+ end
96
+ # List all plates.
97
+ def list_plates
98
+ get("/api/v1/plates/")
99
+ end
100
+
101
+ # Get plate by slug.
102
+ def get_plate(slug)
103
+ get("/api/v1/plates/#{slug}/")
104
+ end
105
+ # List all yearly summaries.
106
+ def list_yearly_summaries
107
+ get("/api/v1/yearly-summaries/")
108
+ end
109
+
110
+ # Get yearly summary by slug.
111
+ def get_yearly_summary(slug)
112
+ get("/api/v1/yearly-summaries/#{slug}/")
113
+ end
114
+
115
+ private
116
+
117
+ def get(path, **params)
118
+ uri = URI.join(@base_url, path)
119
+ uri.query = URI.encode_www_form(params) unless params.empty?
120
+ response = Net::HTTP.get_response(uri)
121
+ raise "HTTP #{response.code}" unless response.is_a?(Net::HTTPSuccess)
122
+ JSON.parse(response.body)
123
+ end
124
+ end
125
+ end
metadata ADDED
@@ -0,0 +1,47 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: quakefyi
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - FYIPedia
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2026-03-21 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: Ruby client for the QuakeFYI REST API at quakefyi.com. Zero external
14
+ dependencies.
15
+ email: dev@fyipedia.com
16
+ executables: []
17
+ extensions: []
18
+ extra_rdoc_files: []
19
+ files:
20
+ - lib/quakefyi.rb
21
+ homepage: https://quakefyi.com
22
+ licenses:
23
+ - MIT
24
+ metadata:
25
+ source_code_uri: https://github.com/fyipedia/quakefyi-rb
26
+ documentation_uri: https://quakefyi.com/api/v1/schema/
27
+ homepage_uri: https://quakefyi.com
28
+ post_install_message:
29
+ rdoc_options: []
30
+ require_paths:
31
+ - lib
32
+ required_ruby_version: !ruby/object:Gem::Requirement
33
+ requirements:
34
+ - - ">="
35
+ - !ruby/object:Gem::Version
36
+ version: '3.0'
37
+ required_rubygems_version: !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ">="
40
+ - !ruby/object:Gem::Version
41
+ version: '0'
42
+ requirements: []
43
+ rubygems_version: 3.0.3.1
44
+ signing_key:
45
+ specification_version: 4
46
+ summary: Ruby client for QuakeFYI API
47
+ test_files: []