sheets_db 0.14.0 → 0.16.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 +1 -1
- data/lib/sheets_db/session.rb +4 -0
- 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: 7fdd721c7338f4f72e867213f6b8814cf929237ded24abb39646b8c94bef4619
|
4
|
+
data.tar.gz: d19f714993d00fa0a179a0fec2b09bf92c6c4ecc5632288ebb8f9f2b3c4ecb94
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f468e1c9d9943735e4ea8a5584a8fb5a6447d8a92e5f1d22822f41d36b572f0be76cb144e963a2ce3e8f958404ed49e1da26b6fe07b292a6ce616686ed43105f
|
7
|
+
data.tar.gz: 2ef1b49f7c5da317069e06de32a953c1ae342ef1228f449c5a85e20e4f68fb4885cc9fc7ea33f95044466fe9e766fa16f1831d529ba0b2fce349a9db5d8967cf
|
data/lib/sheets_db/resource.rb
CHANGED
@@ -72,7 +72,7 @@ module SheetsDB
|
|
72
72
|
end
|
73
73
|
|
74
74
|
extend Forwardable
|
75
|
-
def_delegators :google_drive_resource, :id, :name
|
75
|
+
def_delegators :google_drive_resource, :id, :name, :human_url
|
76
76
|
def_delegator :google_drive_resource, :created_time, :created_at
|
77
77
|
def_delegator :google_drive_resource, :modified_time, :updated_at
|
78
78
|
|
data/lib/sheets_db/session.rb
CHANGED
@@ -5,6 +5,7 @@ module SheetsDB
|
|
5
5
|
class IllegalDefaultError < StandardError; end
|
6
6
|
class NoDefaultSetError < StandardError; end
|
7
7
|
class InvalidGoogleDriveUrlError < ArgumentError; end
|
8
|
+
class GoogleDriveIdNotFoundError < ArgumentError; end
|
8
9
|
|
9
10
|
def self.default=(default)
|
10
11
|
unless default.is_a?(self)
|
@@ -30,6 +31,9 @@ module SheetsDB
|
|
30
31
|
|
31
32
|
def raw_file_by_id(id)
|
32
33
|
@google_drive_session.file_by_id(id)
|
34
|
+
rescue Google::Apis::ClientError => e
|
35
|
+
(raise GoogleDriveIdNotFoundError, id) if e.message.match(/File not found/)
|
36
|
+
raise
|
33
37
|
end
|
34
38
|
|
35
39
|
def raw_file_by_url(url)
|
@@ -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.16.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-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: google_drive
|