shrine-sql 1.1.2 → 1.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.
- checksums.yaml +4 -4
- data/README.md +22 -6
- data/lib/shrine/storage/sql.rb +1 -10
- data/shrine-sql.gemspec +1 -2
- metadata +3 -17
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 126334a0c1dbed11269ecab504b813d06dbe92f4
|
4
|
+
data.tar.gz: 4f342cc815db494fe44ca863be24b279b572e152
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a3e4681ed44a10a9d679e2c57482950ed3532c90a449a75b42a485b09dab9615286e90304a62329cf06b156c297849807540ad2e1085b93acf4db62459d14263
|
7
|
+
data.tar.gz: 29f9a03185d11bbcedf29770b3841b90760ddf58f2ae0e3bc895dff024de74131c32551cb4b10eb62e289fd8a4a62f82f9dceed4e2f2e94557502855f174cf1e
|
data/README.md
CHANGED
@@ -14,15 +14,31 @@ gem "shrine-sql"
|
|
14
14
|
We first need to create the table for our files, with "id" and "content" columns:
|
15
15
|
|
16
16
|
```rb
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
17
|
+
# for Sequel users
|
18
|
+
Sequel.migration do
|
19
|
+
change do
|
20
|
+
create_table :files do
|
21
|
+
primary_key :id
|
22
|
+
column :content, :blob # :bytea for PostgreSQL
|
23
|
+
column :metadata, :text # :varchar
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
```
|
28
|
+
```rb
|
29
|
+
# for ActiveRecord users
|
30
|
+
class CreateFiles < ActiveRecord::Migration
|
31
|
+
def change
|
32
|
+
create_table :files do |t|
|
33
|
+
t.binary :content
|
34
|
+
t.text :metadata
|
35
|
+
end
|
36
|
+
end
|
21
37
|
end
|
22
38
|
```
|
23
39
|
|
24
|
-
We
|
25
|
-
the table
|
40
|
+
We should instantiate the storage with a `Sequel::Database` object and the
|
41
|
+
name of the table, regardless of the ORM you're actually using in your app.
|
26
42
|
|
27
43
|
```rb
|
28
44
|
require "shrine/storage/sql"
|
data/lib/shrine/storage/sql.rb
CHANGED
@@ -1,5 +1,4 @@
|
|
1
1
|
require "shrine"
|
2
|
-
require "down"
|
3
2
|
require "sequel"
|
4
3
|
|
5
4
|
require "stringio"
|
@@ -20,18 +19,10 @@ class Shrine
|
|
20
19
|
id.replace(generated_id.to_s + File.extname(id))
|
21
20
|
end
|
22
21
|
|
23
|
-
def download(id)
|
24
|
-
Down.copy_to_tempfile(id, open(id))
|
25
|
-
end
|
26
|
-
|
27
22
|
def open(id)
|
28
23
|
StringIO.new(content(id))
|
29
24
|
end
|
30
25
|
|
31
|
-
def read(id)
|
32
|
-
content(id)
|
33
|
-
end
|
34
|
-
|
35
26
|
def exists?(id)
|
36
27
|
!find(id).get(Sequel::SQL::AliasedExpression.new(1, :one)).nil?
|
37
28
|
end
|
@@ -63,7 +54,7 @@ class Shrine
|
|
63
54
|
|
64
55
|
def find(id_or_ids)
|
65
56
|
ids = Array(id_or_ids).map { |s| File.basename(s, ".*") }
|
66
|
-
dataset.where(id: ids)
|
57
|
+
dataset.where(id: ids)
|
67
58
|
end
|
68
59
|
|
69
60
|
private
|
data/shrine-sql.gemspec
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
Gem::Specification.new do |gem|
|
2
2
|
gem.name = "shrine-sql"
|
3
|
-
gem.version = "1.
|
3
|
+
gem.version = "1.2.0"
|
4
4
|
|
5
5
|
gem.required_ruby_version = ">= 2.1"
|
6
6
|
|
@@ -15,7 +15,6 @@ Gem::Specification.new do |gem|
|
|
15
15
|
|
16
16
|
gem.add_dependency "shrine", "~> 2.0"
|
17
17
|
gem.add_dependency "sequel"
|
18
|
-
gem.add_dependency "down", ">= 1.0.3"
|
19
18
|
|
20
19
|
gem.add_development_dependency "sqlite3"
|
21
20
|
gem.add_development_dependency "rake"
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: shrine-sql
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Janko Marohnić
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-
|
11
|
+
date: 2017-06-21 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: shrine
|
@@ -38,20 +38,6 @@ dependencies:
|
|
38
38
|
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: '0'
|
41
|
-
- !ruby/object:Gem::Dependency
|
42
|
-
name: down
|
43
|
-
requirement: !ruby/object:Gem::Requirement
|
44
|
-
requirements:
|
45
|
-
- - ">="
|
46
|
-
- !ruby/object:Gem::Version
|
47
|
-
version: 1.0.3
|
48
|
-
type: :runtime
|
49
|
-
prerelease: false
|
50
|
-
version_requirements: !ruby/object:Gem::Requirement
|
51
|
-
requirements:
|
52
|
-
- - ">="
|
53
|
-
- !ruby/object:Gem::Version
|
54
|
-
version: 1.0.3
|
55
41
|
- !ruby/object:Gem::Dependency
|
56
42
|
name: sqlite3
|
57
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -125,7 +111,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
125
111
|
version: '0'
|
126
112
|
requirements: []
|
127
113
|
rubyforge_project:
|
128
|
-
rubygems_version: 2.
|
114
|
+
rubygems_version: 2.6.11
|
129
115
|
signing_key:
|
130
116
|
specification_version: 4
|
131
117
|
summary: Provides SQL database storage for Shrine.
|