activestorage 6.1.6.1 → 7.0.0.alpha1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of activestorage might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +127 -271
- data/MIT-LICENSE +1 -1
- data/README.md +25 -11
- data/app/assets/javascripts/activestorage.esm.js +844 -0
- data/app/assets/javascripts/activestorage.js +257 -376
- data/app/controllers/active_storage/base_controller.rb +1 -10
- data/app/controllers/active_storage/blobs/proxy_controller.rb +14 -4
- data/app/controllers/active_storage/blobs/redirect_controller.rb +6 -4
- data/app/controllers/active_storage/representations/base_controller.rb +5 -1
- data/app/controllers/active_storage/representations/proxy_controller.rb +6 -4
- data/app/controllers/active_storage/representations/redirect_controller.rb +6 -4
- data/app/controllers/concerns/active_storage/set_blob.rb +6 -2
- data/app/controllers/concerns/active_storage/set_current.rb +3 -3
- data/app/controllers/concerns/active_storage/streaming.rb +65 -0
- data/app/javascript/activestorage/ujs.js +1 -1
- data/app/models/active_storage/attachment.rb +35 -2
- data/app/models/active_storage/blob/representable.rb +7 -5
- data/app/models/active_storage/blob.rb +26 -27
- data/app/models/active_storage/current.rb +12 -2
- data/app/models/active_storage/preview.rb +6 -4
- data/app/models/active_storage/record.rb +1 -1
- data/app/models/active_storage/variant.rb +6 -9
- data/app/models/active_storage/variant_record.rb +2 -0
- data/app/models/active_storage/variant_with_record.rb +9 -5
- data/app/models/active_storage/variation.rb +3 -3
- data/config/routes.rb +10 -10
- data/db/migrate/20170806125915_create_active_storage_tables.rb +29 -8
- data/db/update_migrate/20191206030411_create_active_storage_variant_records.rb +15 -2
- data/lib/active_storage/analyzer/audio_analyzer.rb +65 -0
- data/lib/active_storage/analyzer/image_analyzer/image_magick.rb +39 -0
- data/lib/active_storage/analyzer/image_analyzer/vips.rb +49 -0
- data/lib/active_storage/analyzer/image_analyzer.rb +2 -30
- data/lib/active_storage/analyzer/video_analyzer.rb +26 -11
- data/lib/active_storage/analyzer.rb +8 -4
- data/lib/active_storage/attached/changes/create_many.rb +7 -3
- data/lib/active_storage/attached/changes/create_one.rb +1 -1
- data/lib/active_storage/attached/changes/create_one_of_many.rb +1 -1
- data/lib/active_storage/attached/changes/delete_many.rb +1 -1
- data/lib/active_storage/attached/changes/delete_one.rb +1 -1
- data/lib/active_storage/attached/changes/detach_many.rb +18 -0
- data/lib/active_storage/attached/changes/detach_one.rb +24 -0
- data/lib/active_storage/attached/changes/purge_many.rb +27 -0
- data/lib/active_storage/attached/changes/purge_one.rb +27 -0
- data/lib/active_storage/attached/changes.rb +7 -1
- data/lib/active_storage/attached/many.rb +27 -15
- data/lib/active_storage/attached/model.rb +31 -5
- data/lib/active_storage/attached/one.rb +32 -27
- data/lib/active_storage/downloader.rb +2 -2
- data/lib/active_storage/engine.rb +28 -16
- data/lib/active_storage/fixture_set.rb +76 -0
- data/lib/active_storage/gem_version.rb +4 -4
- data/lib/active_storage/previewer/video_previewer.rb +0 -2
- data/lib/active_storage/previewer.rb +4 -4
- data/lib/active_storage/reflection.rb +12 -2
- data/lib/active_storage/service/azure_storage_service.rb +1 -1
- data/lib/active_storage/service/configurator.rb +1 -1
- data/lib/active_storage/service/disk_service.rb +13 -18
- data/lib/active_storage/service/gcs_service.rb +91 -7
- data/lib/active_storage/service/mirror_service.rb +1 -1
- data/lib/active_storage/service/registry.rb +1 -1
- data/lib/active_storage/service/s3_service.rb +4 -4
- data/lib/active_storage/service.rb +3 -3
- data/lib/active_storage/transformers/image_processing_transformer.rb +1 -66
- data/lib/active_storage/transformers/transformer.rb +1 -1
- data/lib/active_storage.rb +3 -292
- metadata +32 -24
- data/app/controllers/concerns/active_storage/set_headers.rb +0 -12
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: c267f362a238a90819d7e7cd23917d10970b03acd2956d099ea6aeb26c2ce192
|
4
|
+
data.tar.gz: c669f3a56d9b6f3f5a08e89cfb49725d65d1abf0d7e933c50b6a3fc12c7d9a6d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: cf96bff832fd497ff5475a475c2b8d5d22b12243d4126bd973ec28c670f9fb57e2e787c073c2ebf4edd89fb3a1d2fbd703a47e0f9a76490389b22e7e9483e2bd
|
7
|
+
data.tar.gz: a405ab97196c4b8c60f284b3e7c664ed30756a08abfe2d1f5d50c43630ec5cfd46d71dcd533e545151312f16459aec534a55f533be95aa6ee47021d29ce30466
|
data/CHANGELOG.md
CHANGED
@@ -1,14 +1,14 @@
|
|
1
|
-
## Rails
|
1
|
+
## Rails 7.0.0.alpha1 (September 15, 2021) ##
|
2
2
|
|
3
|
-
*
|
3
|
+
* Emit Active Support instrumentation events from Active Storage analyzers.
|
4
4
|
|
5
|
+
Fixes #42930
|
5
6
|
|
6
|
-
|
7
|
+
*Shouichi Kamiya*
|
7
8
|
|
8
|
-
*
|
9
|
+
* Add support for byte range requests
|
9
10
|
|
10
|
-
|
11
|
-
## Rails 6.1.5 (March 09, 2022) ##
|
11
|
+
*Tom Prats*
|
12
12
|
|
13
13
|
* Attachments can be deleted after their association is no longer defined.
|
14
14
|
|
@@ -16,350 +16,206 @@
|
|
16
16
|
|
17
17
|
*Don Sisco*
|
18
18
|
|
19
|
+
* Make `vips` the default variant processor for new apps.
|
19
20
|
|
20
|
-
|
21
|
-
|
22
|
-
* Added image transformation validation via configurable allow-list.
|
23
|
-
|
24
|
-
Variant now offers a configurable allow-list for
|
25
|
-
transformation methods in addition to a configurable deny-list for arguments.
|
26
|
-
|
27
|
-
[CVE-2022-21831]
|
28
|
-
|
29
|
-
|
30
|
-
## Rails 6.1.4.6 (February 11, 2022) ##
|
31
|
-
|
32
|
-
* No changes.
|
33
|
-
|
34
|
-
|
35
|
-
## Rails 6.1.4.5 (February 11, 2022) ##
|
36
|
-
|
37
|
-
* No changes.
|
38
|
-
|
39
|
-
|
40
|
-
## Rails 6.1.4.4 (December 15, 2021) ##
|
41
|
-
|
42
|
-
* No changes.
|
43
|
-
|
44
|
-
|
45
|
-
## Rails 6.1.4.3 (December 14, 2021) ##
|
46
|
-
|
47
|
-
* No changes.
|
48
|
-
|
49
|
-
|
50
|
-
## Rails 6.1.4.2 (December 14, 2021) ##
|
51
|
-
|
52
|
-
* No changes.
|
53
|
-
|
54
|
-
|
55
|
-
## Rails 6.1.4.1 (August 19, 2021) ##
|
56
|
-
|
57
|
-
* No changes.
|
58
|
-
|
59
|
-
|
60
|
-
## Rails 6.1.4 (June 24, 2021) ##
|
61
|
-
|
62
|
-
* The parameters sent to `ffmpeg` for generating a video preview image are now
|
63
|
-
configurable under `config.active_storage.video_preview_arguments`.
|
64
|
-
|
65
|
-
*Brendon Muir*
|
66
|
-
|
67
|
-
* Fix Active Storage update task when running in an engine.
|
68
|
-
|
69
|
-
*Justin Malčić*
|
70
|
-
|
71
|
-
* Don't raise an error if the mime type is not recognized.
|
72
|
-
|
73
|
-
Fixes #41777.
|
74
|
-
|
75
|
-
*Alex Ghiculescu*
|
76
|
-
|
77
|
-
* `ActiveStorage::PreviewError` is raised when a previewer is unable to generate a preview image.
|
78
|
-
|
79
|
-
*Alex Robbin*
|
80
|
-
|
81
|
-
* respond with 404 given invalid variation key when asking for representations.
|
21
|
+
See the upgrade guide for instructions on converting from `mini_magick` to `vips`. `mini_magick` is
|
22
|
+
not deprecated, existing apps can keep using it.
|
82
23
|
|
83
|
-
*
|
84
|
-
|
85
|
-
* `Blob` creation shouldn't crash if no service selected.
|
86
|
-
|
87
|
-
*Alex Ghiculescu*
|
24
|
+
*Breno Gazzola*
|
88
25
|
|
26
|
+
* Deprecate `ActiveStorage::Current.host` in favor of `ActiveStorage::Current.url_options` which accepts
|
27
|
+
a host, protocol and port.
|
89
28
|
|
90
|
-
|
29
|
+
*Santiago Bartesaghi*
|
91
30
|
|
92
|
-
*
|
31
|
+
* Allow using [IAM](https://cloud.google.com/storage/docs/access-control/signed-urls) when signing URLs with GCS.
|
93
32
|
|
33
|
+
```yaml
|
34
|
+
gcs:
|
35
|
+
service: GCS
|
36
|
+
...
|
37
|
+
iam: true
|
38
|
+
```
|
94
39
|
|
95
|
-
|
96
|
-
|
97
|
-
* Marcel is upgraded to version 1.0.0 to avoid a dependency on GPL-licensed
|
98
|
-
mime types data.
|
99
|
-
|
100
|
-
*George Claghorn*
|
101
|
-
|
102
|
-
|
103
|
-
## Rails 6.1.3 (February 17, 2021) ##
|
104
|
-
|
105
|
-
* No changes.
|
106
|
-
|
107
|
-
|
108
|
-
## Rails 6.1.2.1 (February 10, 2021) ##
|
109
|
-
|
110
|
-
* No changes.
|
40
|
+
*RRethy*
|
111
41
|
|
42
|
+
* OpenSSL constants are now used for Digest computations.
|
112
43
|
|
113
|
-
|
44
|
+
*Dirkjan Bussink*
|
114
45
|
|
115
|
-
*
|
46
|
+
* Deprecate `config.active_storage.replace_on_assign_to_many`. Future versions of Rails
|
47
|
+
will behave the same way as when the config is set to `true`.
|
116
48
|
|
49
|
+
*Santiago Bartesaghi*
|
117
50
|
|
118
|
-
|
51
|
+
* Remove deprecated methods: `build_after_upload`, `create_after_upload!` in favor of `create_and_upload!`,
|
52
|
+
and `service_url` in favor of `url`.
|
119
53
|
|
120
|
-
*
|
54
|
+
*Santiago Bartesaghi*
|
121
55
|
|
122
|
-
|
56
|
+
* Add support of `strict_loading_by_default` to `ActiveStorage::Representations` controllers.
|
123
57
|
|
58
|
+
*Anton Topchii*, *Andrew White*
|
124
59
|
|
125
|
-
|
60
|
+
* Allow to detach an attachment when record is not persisted.
|
126
61
|
|
127
|
-
*
|
128
|
-
purge (`:active_storage_purge`) jobs to be the job adapter's default (`:default`).
|
62
|
+
*Jacopo Beschi*
|
129
63
|
|
130
|
-
|
64
|
+
* Use libvips instead of ImageMagick to analyze images when `active_storage.variant_processor = vips`.
|
131
65
|
|
132
|
-
*
|
66
|
+
*Breno Gazzola*
|
133
67
|
|
134
|
-
|
68
|
+
* Add metadata value for presence of video channel in video blobs.
|
135
69
|
|
136
|
-
|
70
|
+
The `metadata` attribute of video blobs has a new boolean key named `video` that is set to
|
71
|
+
`true` if the file has an video channel and `false` if it doesn't.
|
137
72
|
|
138
|
-
*
|
73
|
+
*Breno Gazzola*
|
139
74
|
|
140
|
-
*
|
75
|
+
* Deprecate usage of `purge` and `purge_later` from the association extension.
|
141
76
|
|
142
|
-
*
|
77
|
+
*Jacopo Beschi*
|
143
78
|
|
144
|
-
*
|
79
|
+
* Passing extra parameters in `ActiveStorage::Blob#url` to S3 Client.
|
145
80
|
|
146
|
-
|
81
|
+
This allows calls of `ActiveStorage::Blob#url` to have more interaction with
|
82
|
+
the S3 Presigner, enabling, amongst other options, custom S3 domain URL
|
83
|
+
Generation.
|
147
84
|
|
148
|
-
|
85
|
+
```ruby
|
86
|
+
blob = ActiveStorage::Blob.last
|
149
87
|
|
150
|
-
|
88
|
+
blob.url # => https://<bucket-name>.s3.<region>.amazonaws.com/<key>
|
89
|
+
blob.url(virtual_host: true) # => # => https://<bucket-name>/<key>
|
90
|
+
```
|
151
91
|
|
152
|
-
*
|
92
|
+
*josegomezr*
|
153
93
|
|
154
|
-
|
94
|
+
* Allow setting a `Cache-Control` on files uploaded to GCS.
|
155
95
|
|
156
|
-
|
157
|
-
|
158
|
-
|
96
|
+
```yaml
|
97
|
+
gcs:
|
98
|
+
service: GCS
|
99
|
+
...
|
100
|
+
cache_control: "public, max-age=3600"
|
101
|
+
```
|
159
102
|
|
160
|
-
*
|
103
|
+
*maleblond*
|
161
104
|
|
162
|
-
*
|
105
|
+
* The parameters sent to `ffmpeg` for generating a video preview image are now
|
106
|
+
configurable under `config.active_storage.video_preview_arguments`.
|
163
107
|
|
164
|
-
*
|
108
|
+
*Brendon Muir*
|
165
109
|
|
166
|
-
*
|
167
|
-
|
168
|
-
|
110
|
+
* The ActiveStorage video previewer will now use scene change detection to generate
|
111
|
+
better preview images (rather than the previous default of using the first frame
|
112
|
+
of the video). This change requires FFmpeg v3.4+.
|
169
113
|
|
170
|
-
|
171
|
-
<%= image_tag rails_storage_proxy_path(@user.avatar) %>
|
172
|
-
```
|
114
|
+
*Jonathan Hefner*
|
173
115
|
|
174
|
-
|
116
|
+
* Add support for ActiveStorage expiring URLs.
|
175
117
|
|
176
118
|
```ruby
|
177
|
-
|
178
|
-
config.active_storage.resolve_model_to_route = :rails_storage_proxy
|
179
|
-
```
|
180
|
-
|
181
|
-
```erb
|
182
|
-
<%= image_tag @user.avatar %>
|
183
|
-
```
|
184
|
-
|
185
|
-
To redirect to a signed service URL when the default file serving strategy
|
186
|
-
is set to proxying, use the `rails_storage_redirect_path` and `_url` helpers:
|
119
|
+
rails_blob_path(user.avatar, disposition: "attachment", expires_in: 30.minutes)
|
187
120
|
|
188
|
-
|
189
|
-
<%= image_tag rails_storage_redirect_path(@user.avatar) %>
|
121
|
+
<%= image_tag rails_blob_path(user.avatar.variant(resize: "100x100"), expires_in: 30.minutes) %>
|
190
122
|
```
|
191
123
|
|
192
|
-
|
193
|
-
|
194
|
-
* Add `config.active_storage.web_image_content_types` to allow applications
|
195
|
-
to add content types (like `image/webp`) in which variants can be processed,
|
196
|
-
instead of letting those images be converted to the fallback PNG format.
|
197
|
-
|
198
|
-
*Jeroen van Haperen*
|
124
|
+
If you want to set default expiration time for ActiveStorage URLs throughout your application, set `config.active_storage.urls_expire_in`.
|
199
125
|
|
200
|
-
*
|
126
|
+
*aki77*
|
201
127
|
|
202
|
-
|
128
|
+
* Allow to purge an attachment when record is not persisted for `has_many_attached`.
|
203
129
|
|
204
|
-
*
|
130
|
+
*Jacopo Beschi*
|
205
131
|
|
206
|
-
|
132
|
+
* Add `with_all_variant_records` method to eager load all variant records on an attachment at once.
|
133
|
+
`with_attached_image` scope now eager loads variant records if using variant tracking.
|
207
134
|
|
208
|
-
*
|
209
|
-
|
210
|
-
*Peter Zhu*
|
135
|
+
*Alex Ghiculescu*
|
211
136
|
|
212
|
-
*
|
137
|
+
* Add metadata value for presence of audio channel in video blobs.
|
213
138
|
|
214
|
-
|
139
|
+
The `metadata` attribute of video blobs has a new boolean key named `audio` that is set to
|
140
|
+
`true` if the file has an audio channel and `false` if it doesn't.
|
215
141
|
|
216
|
-
*
|
142
|
+
*Breno Gazzola*
|
217
143
|
|
218
|
-
|
219
|
-
`service_name` field in the generated URL in `DiskService`.
|
144
|
+
* Adds analyzer for audio files.
|
220
145
|
|
221
|
-
*
|
146
|
+
*Breno Gazzola*
|
222
147
|
|
223
|
-
*
|
148
|
+
* Respect Active Record's primary_key_type in Active Storage migrations.
|
224
149
|
|
225
|
-
*
|
150
|
+
*fatkodima*
|
226
151
|
|
227
|
-
*
|
152
|
+
* Allow `expires_in` for ActiveStorage signed ids.
|
228
153
|
|
229
|
-
|
230
|
-
`#url` method to be consistent with `Blob`.
|
154
|
+
*aki77*
|
231
155
|
|
232
|
-
|
156
|
+
* Allow to purge an attachment when record is not persisted for `has_one_attached`.
|
233
157
|
|
234
|
-
*
|
158
|
+
*Jacopo Beschi*
|
235
159
|
|
236
|
-
|
237
|
-
|
238
|
-
|
160
|
+
* Add a load hook called `active_storage_variant_record` (providing `ActiveStorage::VariantRecord`)
|
161
|
+
to allow for overriding aspects of the `ActiveStorage::VariantRecord` class. This makes
|
162
|
+
`ActiveStorage::VariantRecord` consistent with `ActiveStorage::Blob` and `ActiveStorage::Attachment`
|
163
|
+
that already have load hooks.
|
239
164
|
|
240
|
-
|
165
|
+
*Brendon Muir*
|
241
166
|
|
242
|
-
|
167
|
+
* `ActiveStorage::PreviewError` is raised when a previewer is unable to generate a preview image.
|
243
168
|
|
244
|
-
*
|
169
|
+
*Alex Robbin*
|
245
170
|
|
246
|
-
|
171
|
+
* Add `ActiveStorage::Streaming` module that can be included in a controller to get access to `#send_blob_stream`,
|
172
|
+
which wraps the new `ActionController::Base#send_stream` method to stream a blob from cloud storage:
|
247
173
|
|
248
|
-
|
174
|
+
```ruby
|
175
|
+
class MyPublicBlobsController < ApplicationController
|
176
|
+
include ActiveStorage::SetBlob, ActiveStorage::Streaming
|
177
|
+
|
178
|
+
def show
|
179
|
+
http_cache_forever(public: true) do
|
180
|
+
send_blob_stream @blob, disposition: params[:disposition]
|
181
|
+
end
|
182
|
+
end
|
183
|
+
end
|
184
|
+
```
|
249
185
|
|
250
|
-
*
|
186
|
+
*DHH*
|
251
187
|
|
252
|
-
*
|
188
|
+
* Add ability to use pre-defined variants.
|
253
189
|
|
254
190
|
```ruby
|
255
191
|
class User < ActiveRecord::Base
|
256
|
-
has_one_attached :avatar
|
192
|
+
has_one_attached :avatar do |attachable|
|
193
|
+
attachable.variant :thumb, resize: "100x100"
|
194
|
+
attachable.variant :medium, resize: "300x300", monochrome: true
|
195
|
+
end
|
257
196
|
end
|
258
197
|
|
259
198
|
class Gallery < ActiveRecord::Base
|
260
|
-
has_many_attached :photos
|
199
|
+
has_many_attached :photos do |attachable|
|
200
|
+
attachable.variant :thumb, resize: "100x100"
|
201
|
+
attachable.variant :medium, resize: "300x300", monochrome: true
|
202
|
+
end
|
261
203
|
end
|
262
|
-
```
|
263
|
-
|
264
|
-
*Dmitry Tsepelev*
|
265
204
|
|
266
|
-
|
267
|
-
|
268
|
-
```ruby
|
269
|
-
user.avatar.attach key: "avatars/#{user.id}.jpg",
|
270
|
-
io: io, content_type: "image/jpeg", filename: "avatar.jpg"
|
205
|
+
<%= image_tag user.avatar.variant(:thumb) %>
|
271
206
|
```
|
272
207
|
|
273
|
-
|
274
|
-
|
275
|
-
*George Claghorn*
|
276
|
-
|
277
|
-
* Replace `Blob.create_after_upload!` with `Blob.create_and_upload!` and deprecate the former.
|
278
|
-
|
279
|
-
`create_after_upload!` has been removed since it could lead to data
|
280
|
-
corruption by uploading to a key on the storage service which happened to
|
281
|
-
be already taken. Creating the record would then correctly raise a
|
282
|
-
database uniqueness exception but the stored object would already have
|
283
|
-
overwritten another. `create_and_upload!` swaps the order of operations
|
284
|
-
so that the key gets reserved up-front or the uniqueness error gets raised,
|
285
|
-
before the upload to a key takes place.
|
286
|
-
|
287
|
-
*Julik Tarkhanov*
|
208
|
+
*fatkodima*
|
288
209
|
|
289
|
-
*
|
210
|
+
* After setting `config.active_storage.resolve_model_to_route = :rails_storage_proxy`
|
211
|
+
`rails_blob_path` and `rails_representation_path` will generate proxy URLs by default.
|
290
212
|
|
291
|
-
*
|
213
|
+
*Ali Ismayilov*
|
292
214
|
|
293
|
-
*
|
294
|
-
|
295
|
-
|
296
|
-
*Gannon McGibbon*
|
297
|
-
|
298
|
-
* Switch from `azure-storage` gem to `azure-storage-blob` gem for Azure service.
|
299
|
-
|
300
|
-
*Peter Zhu*
|
301
|
-
|
302
|
-
* Add `config.active_storage.draw_routes` to disable Active Storage routes.
|
303
|
-
|
304
|
-
*Gannon McGibbon*
|
305
|
-
|
306
|
-
* Image analysis is skipped if ImageMagick returns an error.
|
307
|
-
|
308
|
-
`ActiveStorage::Analyzer::ImageAnalyzer#metadata` would previously raise a
|
309
|
-
`MiniMagick::Error`, which caused persistent `ActiveStorage::AnalyzeJob`
|
310
|
-
failures. It now logs the error and returns `{}`, resulting in no metadata
|
311
|
-
being added to the offending image blob.
|
312
|
-
|
313
|
-
*George Claghorn*
|
314
|
-
|
315
|
-
* Method calls on singular attachments return `nil` when no file is attached.
|
316
|
-
|
317
|
-
Previously, assuming the following User model, `user.avatar.filename` would
|
318
|
-
raise a `Module::DelegationError` if no avatar was attached:
|
319
|
-
|
320
|
-
```ruby
|
321
|
-
class User < ApplicationRecord
|
322
|
-
has_one_attached :avatar
|
323
|
-
end
|
324
|
-
```
|
325
|
-
|
326
|
-
They now return `nil`.
|
327
|
-
|
328
|
-
*Matthew Tanous*
|
329
|
-
|
330
|
-
* The mirror service supports direct uploads.
|
331
|
-
|
332
|
-
New files are directly uploaded to the primary service. When a
|
333
|
-
directly-uploaded file is attached to a record, a background job is enqueued
|
334
|
-
to copy it to each secondary service.
|
335
|
-
|
336
|
-
Configure the queue used to process mirroring jobs by setting
|
337
|
-
`config.active_storage.queues.mirror`. The default is `:active_storage_mirror`.
|
338
|
-
|
339
|
-
*George Claghorn*
|
340
|
-
|
341
|
-
* The S3 service now permits uploading files larger than 5 gigabytes.
|
342
|
-
|
343
|
-
When uploading a file greater than 100 megabytes in size, the service
|
344
|
-
transparently switches to [multipart uploads](https://docs.aws.amazon.com/AmazonS3/latest/dev/mpuoverview.html)
|
345
|
-
using a part size computed from the file's total size and S3's part count limit.
|
346
|
-
|
347
|
-
No application changes are necessary to take advantage of this feature. You
|
348
|
-
can customize the default 100 MB multipart upload threshold in your S3
|
349
|
-
service's configuration:
|
350
|
-
|
351
|
-
```yaml
|
352
|
-
production:
|
353
|
-
service: s3
|
354
|
-
access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
|
355
|
-
secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
|
356
|
-
region: us-east-1
|
357
|
-
bucket: my-bucket
|
358
|
-
upload:
|
359
|
-
multipart_threshold: <%= 250.megabytes %>
|
360
|
-
```
|
215
|
+
* Declare `ActiveStorage::FixtureSet` and `ActiveStorage::FixtureSet.blob` to
|
216
|
+
improve fixture integration.
|
361
217
|
|
362
|
-
*
|
218
|
+
*Sean Doyle*
|
363
219
|
|
364
220
|
|
365
|
-
Please check [6-
|
221
|
+
Please check [6-1-stable](https://github.com/rails/rails/blob/6-1-stable/activestorage/CHANGELOG.md) for previous changes.
|
data/MIT-LICENSE
CHANGED
data/README.md
CHANGED
@@ -32,7 +32,7 @@ class User < ApplicationRecord
|
|
32
32
|
end
|
33
33
|
|
34
34
|
# Attach an avatar to the user.
|
35
|
-
user.avatar.attach(io: File.open("/path/to/face.jpg"), filename: "face.jpg", content_type: "image/
|
35
|
+
user.avatar.attach(io: File.open("/path/to/face.jpg"), filename: "face.jpg", content_type: "image/jpeg")
|
36
36
|
|
37
37
|
# Does the user have an avatar?
|
38
38
|
user.avatar.attached? # => true
|
@@ -88,8 +88,7 @@ class MessagesController < ApplicationController
|
|
88
88
|
end
|
89
89
|
|
90
90
|
def create
|
91
|
-
message = Message.create! params.require(:message).permit(:title, :content)
|
92
|
-
message.images.attach(params[:message][:images])
|
91
|
+
message = Message.create! params.require(:message).permit(:title, :content, images: [])
|
93
92
|
redirect_to message
|
94
93
|
end
|
95
94
|
|
@@ -124,27 +123,42 @@ When the application is configured to proxy files by default, use the `rails_sto
|
|
124
123
|
|
125
124
|
Optionally, files can be proxied instead. This means that your application servers will download file data from the storage service in response to requests. This can be useful for serving files from a CDN.
|
126
125
|
|
127
|
-
|
128
|
-
|
129
|
-
```erb
|
130
|
-
<%= image_tag rails_storage_proxy_path(@user.avatar) %>
|
131
|
-
```
|
132
|
-
|
133
|
-
Or configure Active Storage to use proxying by default:
|
126
|
+
You can configure Active Storage to use proxying by default:
|
134
127
|
|
135
128
|
```ruby
|
136
129
|
# config/initializers/active_storage.rb
|
137
130
|
Rails.application.config.active_storage.resolve_model_to_route = :rails_storage_proxy
|
138
131
|
```
|
139
132
|
|
133
|
+
Or if you want to explicitly proxy specific attachments there are URL helpers you can use in the form of `rails_storage_proxy_path` and `rails_storage_proxy_url`.
|
134
|
+
|
135
|
+
```erb
|
136
|
+
<%= image_tag rails_storage_proxy_path(@user.avatar) %>
|
137
|
+
```
|
138
|
+
|
140
139
|
## Direct uploads
|
141
140
|
|
142
141
|
Active Storage, with its included JavaScript library, supports uploading directly from the client to the cloud.
|
143
142
|
|
144
143
|
### Direct upload installation
|
145
144
|
|
146
|
-
1. Include
|
145
|
+
1. Include the Active Storage JavaScript in your application's JavaScript bundle or reference it directly.
|
147
146
|
|
147
|
+
Requiring directly without bundling through the asset pipeline in the application html with autostart:
|
148
|
+
```html
|
149
|
+
<%= javascript_include_tag "activestorage" %>
|
150
|
+
```
|
151
|
+
Requiring via importmap-rails without bundling through the asset pipeline in the application html without autostart as ESM:
|
152
|
+
```ruby
|
153
|
+
# config/importmap.rb
|
154
|
+
pin "@rails/activestorage", to: "activestorage.esm.js"
|
155
|
+
```
|
156
|
+
```html
|
157
|
+
<script type="module-shim">
|
158
|
+
import * as ActiveStorage from "@rails/activestorage"
|
159
|
+
ActiveStorage.start()
|
160
|
+
</script>
|
161
|
+
```
|
148
162
|
Using the asset pipeline:
|
149
163
|
```js
|
150
164
|
//= require activestorage
|