airrecord 1.0.6 → 1.0.7
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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +4 -0
- data/README.md +2 -0
- data/airrecord.gemspec +6 -5
- data/lib/airrecord.rb +3 -2
- data/lib/airrecord/client.rb +3 -3
- data/lib/airrecord/faraday_rate_limiter.rb +2 -1
- data/lib/airrecord/query_string.rb +4 -4
- data/lib/airrecord/table.rb +11 -10
- data/lib/airrecord/version.rb +1 -1
- metadata +15 -15
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: deb117e05bbf701e4e1e60cf3cccc659a173c7d4f1fc5cb6f80ee72af5603b0e
|
4
|
+
data.tar.gz: a4e928fbd33774f2d41508136da24e56eb2687775c2b962912df86e99eb34bdf
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 890dbffd8a3489d505db3da5149cefeb85acbee754d0cc39a9ecf15e5d38b145735df895de9a16a747e20a0b92ae533e01a954e21220d0e044beb7e73ddc3c3e
|
7
|
+
data.tar.gz: 518f7f4cbc0559bb20931ba39a7c000a5ed632075ebd6ce41ff4555334c5c31251256b1f92105d8cd44b21b93b79e52e6b820ab2f5875bbd26a219dd3334967b
|
data/CHANGELOG.md
CHANGED
data/README.md
CHANGED
@@ -255,6 +255,8 @@ tea["Village"] = "Feng Gang"
|
|
255
255
|
tea.save # persist to Airtable
|
256
256
|
```
|
257
257
|
|
258
|
+
_Airtable's API doesn't allow you to change attachment's filename. As a workaround you can delete the original attachment and [upload a new one](https://github.com/sirupsen/airrecord#file-uploads) with the original URL and a new filename._
|
259
|
+
|
258
260
|
### Deleting
|
259
261
|
|
260
262
|
An instantiated record can be deleted through `#destroy`:
|
data/airrecord.gemspec
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# coding: utf-8
|
2
|
+
|
2
3
|
lib = File.expand_path('../lib', __FILE__)
|
3
4
|
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
5
|
require 'airrecord/version'
|
@@ -18,13 +19,13 @@ Gem::Specification.new do |spec|
|
|
18
19
|
spec.bindir = "exe"
|
19
20
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
20
21
|
spec.require_paths = ["lib"]
|
21
|
-
spec.required_ruby_version =
|
22
|
+
spec.required_ruby_version = ">= 2.2"
|
22
23
|
|
23
|
-
spec.add_dependency
|
24
|
-
spec.add_dependency "net-http-persistent"
|
24
|
+
spec.add_dependency "faraday", [">= 0.10", "< 2.0"]
|
25
|
+
spec.add_dependency "net-http-persistent"
|
25
26
|
|
26
27
|
spec.add_development_dependency "bundler", "~> 2"
|
27
|
-
spec.add_development_dependency "rake", "~> 10.0"
|
28
|
-
spec.add_development_dependency "minitest", "~> 5.0"
|
29
28
|
spec.add_development_dependency "byebug"
|
29
|
+
spec.add_development_dependency "minitest", "~> 5.0"
|
30
|
+
spec.add_development_dependency "rake", "~> 10.0"
|
30
31
|
end
|
data/lib/airrecord.rb
CHANGED
@@ -7,12 +7,13 @@ require "airrecord/table"
|
|
7
7
|
|
8
8
|
module Airrecord
|
9
9
|
extend self
|
10
|
+
attr_accessor :api_key, :throttle
|
11
|
+
|
10
12
|
Error = Class.new(StandardError)
|
11
|
-
attr_accessor :api_key
|
12
|
-
attr_accessor :throttle
|
13
13
|
|
14
14
|
def throttle?
|
15
15
|
return true if @throttle.nil?
|
16
|
+
|
16
17
|
@throttle
|
17
18
|
end
|
18
19
|
end
|
data/lib/airrecord/client.rb
CHANGED
@@ -23,13 +23,13 @@ module Airrecord
|
|
23
23
|
"User-Agent" => "Airrecord/#{Airrecord::VERSION}",
|
24
24
|
"X-API-VERSION" => "0.1.0",
|
25
25
|
},
|
26
|
-
request: { params_encoder: Airrecord::QueryString }
|
27
|
-
)
|
26
|
+
request: { params_encoder: Airrecord::QueryString }
|
27
|
+
) do |conn|
|
28
28
|
if Airrecord.throttle?
|
29
29
|
conn.request :airrecord_rate_limiter, requests_per_second: AIRTABLE_RPS_LIMIT
|
30
30
|
end
|
31
31
|
conn.adapter :net_http_persistent
|
32
|
-
|
32
|
+
end
|
33
33
|
end
|
34
34
|
|
35
35
|
def escape(*args)
|
@@ -37,6 +37,7 @@ module Airrecord
|
|
37
37
|
def too_many_requests_in_last_second?
|
38
38
|
return false unless @rps
|
39
39
|
return false unless requests.size >= @rps
|
40
|
+
|
40
41
|
window_span < 1.0
|
41
42
|
end
|
42
43
|
|
@@ -56,5 +57,5 @@ end
|
|
56
57
|
|
57
58
|
Faraday::Request.register_middleware(
|
58
59
|
# Avoid polluting the global middleware namespace with a prefix.
|
59
|
-
:
|
60
|
+
airrecord_rate_limiter: Airrecord::FaradayRateLimiter
|
60
61
|
)
|
@@ -25,16 +25,16 @@ module Airrecord
|
|
25
25
|
end
|
26
26
|
|
27
27
|
TYPES = {
|
28
|
-
Array => lambda
|
28
|
+
Array => lambda do |prefix, array|
|
29
29
|
array.each_with_index.map do |value, index|
|
30
30
|
self[value].call("#{prefix}[#{index}]", value)
|
31
31
|
end
|
32
|
-
|
33
|
-
Hash => lambda
|
32
|
+
end,
|
33
|
+
Hash => lambda do |prefix, hash|
|
34
34
|
hash.map do |key, value|
|
35
35
|
self[value].call("#{prefix}[#{key}]", value)
|
36
36
|
end
|
37
|
-
|
37
|
+
end
|
38
38
|
}.freeze
|
39
39
|
|
40
40
|
DEFAULT = lambda do |key, value|
|
data/lib/airrecord/table.rb
CHANGED
@@ -17,7 +17,7 @@ module Airrecord
|
|
17
17
|
|
18
18
|
def has_many(method_name, options)
|
19
19
|
define_method(method_name.to_sym) do
|
20
|
-
# Get association ids in reverse order, because Airtable
|
20
|
+
# Get association ids in reverse order, because Airtable's UI and API
|
21
21
|
# sort associations in opposite directions. We want to match the UI.
|
22
22
|
ids = (self[options.fetch(:column)] || []).reverse
|
23
23
|
table = Kernel.const_get(options.fetch(:class))
|
@@ -56,7 +56,7 @@ module Airrecord
|
|
56
56
|
records(filter: formula).sort_by { |record| or_args.index(record.id) }
|
57
57
|
end
|
58
58
|
|
59
|
-
def create(fields, options={})
|
59
|
+
def create(fields, options = {})
|
60
60
|
new(fields).tap { |record| record.save(options) }
|
61
61
|
end
|
62
62
|
|
@@ -104,7 +104,7 @@ module Airrecord
|
|
104
104
|
client.handle_error(response.status, parsed_response)
|
105
105
|
end
|
106
106
|
end
|
107
|
-
|
107
|
+
alias all records
|
108
108
|
end
|
109
109
|
|
110
110
|
attr_reader :fields, :id, :created_at, :updated_keys
|
@@ -137,16 +137,17 @@ module Airrecord
|
|
137
137
|
def []=(key, value)
|
138
138
|
validate_key(key)
|
139
139
|
return if fields[key] == value # no-op
|
140
|
+
|
140
141
|
@updated_keys << key
|
141
142
|
fields[key] = value
|
142
143
|
end
|
143
144
|
|
144
|
-
def create(options={})
|
145
|
+
def create(options = {})
|
145
146
|
raise Error, "Record already exists (record has an id)" unless new_record?
|
146
147
|
|
147
148
|
body = {
|
148
149
|
fields: serializable_fields,
|
149
|
-
**options
|
150
|
+
**options
|
150
151
|
}.to_json
|
151
152
|
|
152
153
|
response = client.connection.post("/v0/#{self.class.base_key}/#{client.escape(self.class.table_name)}", body, { 'Content-Type' => 'application/json' })
|
@@ -161,9 +162,8 @@ module Airrecord
|
|
161
162
|
end
|
162
163
|
end
|
163
164
|
|
164
|
-
def save(options={})
|
165
|
+
def save(options = {})
|
165
166
|
return create(options) if new_record?
|
166
|
-
|
167
167
|
return true if @updated_keys.empty?
|
168
168
|
|
169
169
|
# To avoid trying to update computed fields we *always* use PATCH
|
@@ -171,7 +171,7 @@ module Airrecord
|
|
171
171
|
fields: Hash[@updated_keys.map { |key|
|
172
172
|
[key, fields[key]]
|
173
173
|
}],
|
174
|
-
**options
|
174
|
+
**options
|
175
175
|
}.to_json
|
176
176
|
|
177
177
|
response = client.connection.patch("/v0/#{self.class.base_key}/#{client.escape(self.class.table_name)}/#{self.id}", body, { 'Content-Type' => 'application/json' })
|
@@ -205,8 +205,7 @@ module Airrecord
|
|
205
205
|
self.class == other.class &&
|
206
206
|
serializable_fields == other.serializable_fields
|
207
207
|
end
|
208
|
-
|
209
|
-
alias_method :eql?, :==
|
208
|
+
alias eql? ==
|
210
209
|
|
211
210
|
def hash
|
212
211
|
serializable_fields.hash
|
@@ -221,6 +220,7 @@ module Airrecord
|
|
221
220
|
|
222
221
|
def created_at=(created_at)
|
223
222
|
return unless created_at
|
223
|
+
|
224
224
|
@created_at = Time.parse(created_at)
|
225
225
|
end
|
226
226
|
|
@@ -230,6 +230,7 @@ module Airrecord
|
|
230
230
|
|
231
231
|
def validate_key(key)
|
232
232
|
return true unless key.is_a?(Symbol)
|
233
|
+
|
233
234
|
raise(Error, [
|
234
235
|
"Airrecord 1.0 dropped support for Symbols as field names.",
|
235
236
|
"Please use the raw field name, a String, instead.",
|
data/lib/airrecord/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: airrecord
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Simon Eskildsen
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-08-03 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: faraday
|
@@ -36,14 +36,14 @@ dependencies:
|
|
36
36
|
requirements:
|
37
37
|
- - ">="
|
38
38
|
- !ruby/object:Gem::Version
|
39
|
-
version: '
|
39
|
+
version: '0'
|
40
40
|
type: :runtime
|
41
41
|
prerelease: false
|
42
42
|
version_requirements: !ruby/object:Gem::Requirement
|
43
43
|
requirements:
|
44
44
|
- - ">="
|
45
45
|
- !ruby/object:Gem::Version
|
46
|
-
version: '
|
46
|
+
version: '0'
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: bundler
|
49
49
|
requirement: !ruby/object:Gem::Requirement
|
@@ -59,19 +59,19 @@ dependencies:
|
|
59
59
|
- !ruby/object:Gem::Version
|
60
60
|
version: '2'
|
61
61
|
- !ruby/object:Gem::Dependency
|
62
|
-
name:
|
62
|
+
name: byebug
|
63
63
|
requirement: !ruby/object:Gem::Requirement
|
64
64
|
requirements:
|
65
|
-
- - "
|
65
|
+
- - ">="
|
66
66
|
- !ruby/object:Gem::Version
|
67
|
-
version: '
|
67
|
+
version: '0'
|
68
68
|
type: :development
|
69
69
|
prerelease: false
|
70
70
|
version_requirements: !ruby/object:Gem::Requirement
|
71
71
|
requirements:
|
72
|
-
- - "
|
72
|
+
- - ">="
|
73
73
|
- !ruby/object:Gem::Version
|
74
|
-
version: '
|
74
|
+
version: '0'
|
75
75
|
- !ruby/object:Gem::Dependency
|
76
76
|
name: minitest
|
77
77
|
requirement: !ruby/object:Gem::Requirement
|
@@ -87,19 +87,19 @@ dependencies:
|
|
87
87
|
- !ruby/object:Gem::Version
|
88
88
|
version: '5.0'
|
89
89
|
- !ruby/object:Gem::Dependency
|
90
|
-
name:
|
90
|
+
name: rake
|
91
91
|
requirement: !ruby/object:Gem::Requirement
|
92
92
|
requirements:
|
93
|
-
- - "
|
93
|
+
- - "~>"
|
94
94
|
- !ruby/object:Gem::Version
|
95
|
-
version: '0'
|
95
|
+
version: '10.0'
|
96
96
|
type: :development
|
97
97
|
prerelease: false
|
98
98
|
version_requirements: !ruby/object:Gem::Requirement
|
99
99
|
requirements:
|
100
|
-
- - "
|
100
|
+
- - "~>"
|
101
101
|
- !ruby/object:Gem::Version
|
102
|
-
version: '0'
|
102
|
+
version: '10.0'
|
103
103
|
description: Airtable client to make Airtable interactions a breeze
|
104
104
|
email:
|
105
105
|
- sirup@sirupsen.com
|
@@ -143,7 +143,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
143
143
|
- !ruby/object:Gem::Version
|
144
144
|
version: '0'
|
145
145
|
requirements: []
|
146
|
-
rubygems_version: 3.
|
146
|
+
rubygems_version: 3.2.15
|
147
147
|
signing_key:
|
148
148
|
specification_version: 4
|
149
149
|
summary: Airtable client
|