sheets_db 0.13.0 → 0.15.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.
- checksums.yaml +4 -4
- data/lib/sheets_db/resource.rb +18 -2
- data/lib/sheets_db/session.rb +9 -1
- data/lib/sheets_db/spreadsheet.rb +17 -1
- data/lib/sheets_db/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6656b055b485e05c1ff2d593bb7083c76bdac97302dd77e3667767ff5d4d34ff
|
4
|
+
data.tar.gz: 3d93d3d2fe190a1f8b34ce47ee2bdd83a117ee3abd96c1725a33fda48d1bc051
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 7414fba3a498bc109b5bce7d53beb5c9e119c1bf781ee642fac68485730b2d152a2beedc107c0b1d7860d4f72e7d2d27259d7c331782febc51592809a4f81ed7
|
7
|
+
data.tar.gz: 61b136a641a01378b44205ff06d273f3f5cba3cee35521046eba09778f40ad9e7b979e1dd51e819e5fd419abba51dadba0f0bb7799e29c8fdef4d26e71e6e01f
|
data/lib/sheets_db/resource.rb
CHANGED
@@ -16,10 +16,26 @@ module SheetsDB
|
|
16
16
|
@resource_type = resource_type
|
17
17
|
end
|
18
18
|
|
19
|
+
def find(id_or_url, session: SheetsDB::Session.default)
|
20
|
+
find_by_url(id_or_url, session: session)
|
21
|
+
rescue SheetsDB::Session::InvalidGoogleDriveUrlError
|
22
|
+
find_by_id(id_or_url, session: session)
|
23
|
+
end
|
24
|
+
|
25
|
+
def find_by_url(url, session: SheetsDB::Session.default)
|
26
|
+
wrap_google_drive_resource(session.raw_file_by_url(url))
|
27
|
+
end
|
28
|
+
|
19
29
|
def find_by_id(id, session: SheetsDB::Session.default)
|
20
|
-
|
30
|
+
wrap_google_drive_resource(session.raw_file_by_id(id))
|
31
|
+
end
|
32
|
+
|
33
|
+
def wrap_google_drive_resource(google_drive_resource)
|
21
34
|
if resource_type && !google_drive_resource.is_a?(resource_type)
|
22
|
-
fail(
|
35
|
+
fail(
|
36
|
+
ResourceTypeMismatchError,
|
37
|
+
"The file #{google_drive_resource.human_url} is not a #{resource_type}"
|
38
|
+
)
|
23
39
|
end
|
24
40
|
new(google_drive_resource)
|
25
41
|
end
|
data/lib/sheets_db/session.rb
CHANGED
@@ -4,6 +4,7 @@ module SheetsDB
|
|
4
4
|
class Session
|
5
5
|
class IllegalDefaultError < StandardError; end
|
6
6
|
class NoDefaultSetError < StandardError; end
|
7
|
+
class InvalidGoogleDriveUrlError < ArgumentError; end
|
7
8
|
|
8
9
|
def self.default=(default)
|
9
10
|
unless default.is_a?(self)
|
@@ -30,5 +31,12 @@ module SheetsDB
|
|
30
31
|
def raw_file_by_id(id)
|
31
32
|
@google_drive_session.file_by_id(id)
|
32
33
|
end
|
34
|
+
|
35
|
+
def raw_file_by_url(url)
|
36
|
+
@google_drive_session.file_by_url(url)
|
37
|
+
rescue GoogleDrive::Error => e
|
38
|
+
(raise InvalidGoogleDriveUrlError, url) if e.message.match(/not a known Google Drive URL/)
|
39
|
+
raise
|
40
|
+
end
|
33
41
|
end
|
34
|
-
end
|
42
|
+
end
|
@@ -4,6 +4,9 @@ module SheetsDB
|
|
4
4
|
class WorksheetNotFoundError < Resource::ChildResourceNotFoundError; end
|
5
5
|
class LastWorksheetCannotBeDeletedError < StandardError; end
|
6
6
|
|
7
|
+
SHEET_URL_REGEX = /spreadsheets\/d\/(?<sheet_id>[^\/]+)/.freeze
|
8
|
+
DEFAULT_WORKSHEET_TITLE = "Sheet1".freeze
|
9
|
+
|
7
10
|
set_resource_type GoogleDrive::Spreadsheet
|
8
11
|
|
9
12
|
class << self
|
@@ -28,6 +31,19 @@ module SheetsDB
|
|
28
31
|
worksheet_association(resource, **kwargs)
|
29
32
|
end
|
30
33
|
end
|
34
|
+
|
35
|
+
def extract_id_from_string(id_string)
|
36
|
+
(matches = SHEET_URL_REGEX.match(id_string)) ? matches[:sheet_id] : id_string.gsub("/", "")
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def write_raw_data_to_worksheet!(data, worksheet_title: nil, rewrite: false)
|
41
|
+
find_or_create_worksheet!(title: worksheet_title || DEFAULT_WORKSHEET_TITLE).
|
42
|
+
write_raw_data!(data, rewrite: rewrite)
|
43
|
+
end
|
44
|
+
|
45
|
+
def existing_raw_data_from_worksheet(worksheet_title: nil)
|
46
|
+
find_worksheet!(title: worksheet_title || DEFAULT_WORKSHEET_TITLE).existing_raw_data
|
31
47
|
end
|
32
48
|
|
33
49
|
def find_association_by_id(association_name, id)
|
@@ -93,7 +109,7 @@ module SheetsDB
|
|
93
109
|
end
|
94
110
|
|
95
111
|
def clean_up_default_worksheet!(force: false)
|
96
|
-
default_sheet = google_drive_resource.worksheet_by_title(
|
112
|
+
default_sheet = google_drive_resource.worksheet_by_title(DEFAULT_WORKSHEET_TITLE)
|
97
113
|
return unless default_sheet
|
98
114
|
|
99
115
|
raise LastWorksheetCannotBeDeletedError if google_drive_resource.worksheets.count == 1
|
data/lib/sheets_db/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sheets_db
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.15.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ravi Gadad
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2025-04-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: google_drive
|