activestorage 6.1.4.4 → 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.

Files changed (67) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +130 -235
  3. data/MIT-LICENSE +1 -1
  4. data/README.md +25 -11
  5. data/app/assets/javascripts/activestorage.esm.js +844 -0
  6. data/app/assets/javascripts/activestorage.js +257 -376
  7. data/app/controllers/active_storage/base_controller.rb +1 -10
  8. data/app/controllers/active_storage/blobs/proxy_controller.rb +14 -4
  9. data/app/controllers/active_storage/blobs/redirect_controller.rb +6 -4
  10. data/app/controllers/active_storage/representations/base_controller.rb +5 -1
  11. data/app/controllers/active_storage/representations/proxy_controller.rb +6 -4
  12. data/app/controllers/active_storage/representations/redirect_controller.rb +6 -4
  13. data/app/controllers/concerns/active_storage/set_blob.rb +6 -2
  14. data/app/controllers/concerns/active_storage/set_current.rb +3 -3
  15. data/app/controllers/concerns/active_storage/streaming.rb +65 -0
  16. data/app/javascript/activestorage/ujs.js +1 -1
  17. data/app/models/active_storage/attachment.rb +36 -3
  18. data/app/models/active_storage/blob/representable.rb +7 -5
  19. data/app/models/active_storage/blob.rb +26 -27
  20. data/app/models/active_storage/current.rb +12 -2
  21. data/app/models/active_storage/preview.rb +6 -4
  22. data/app/models/active_storage/record.rb +1 -1
  23. data/app/models/active_storage/variant.rb +3 -6
  24. data/app/models/active_storage/variant_record.rb +2 -0
  25. data/app/models/active_storage/variant_with_record.rb +9 -5
  26. data/app/models/active_storage/variation.rb +2 -2
  27. data/config/routes.rb +10 -10
  28. data/db/migrate/20170806125915_create_active_storage_tables.rb +29 -8
  29. data/db/update_migrate/20191206030411_create_active_storage_variant_records.rb +15 -2
  30. data/lib/active_storage/analyzer/audio_analyzer.rb +65 -0
  31. data/lib/active_storage/analyzer/image_analyzer/image_magick.rb +39 -0
  32. data/lib/active_storage/analyzer/image_analyzer/vips.rb +49 -0
  33. data/lib/active_storage/analyzer/image_analyzer.rb +2 -30
  34. data/lib/active_storage/analyzer/video_analyzer.rb +26 -11
  35. data/lib/active_storage/analyzer.rb +8 -4
  36. data/lib/active_storage/attached/changes/create_many.rb +7 -3
  37. data/lib/active_storage/attached/changes/create_one.rb +1 -1
  38. data/lib/active_storage/attached/changes/create_one_of_many.rb +1 -1
  39. data/lib/active_storage/attached/changes/delete_many.rb +1 -1
  40. data/lib/active_storage/attached/changes/delete_one.rb +1 -1
  41. data/lib/active_storage/attached/changes/detach_many.rb +18 -0
  42. data/lib/active_storage/attached/changes/detach_one.rb +24 -0
  43. data/lib/active_storage/attached/changes/purge_many.rb +27 -0
  44. data/lib/active_storage/attached/changes/purge_one.rb +27 -0
  45. data/lib/active_storage/attached/changes.rb +7 -1
  46. data/lib/active_storage/attached/many.rb +27 -15
  47. data/lib/active_storage/attached/model.rb +31 -5
  48. data/lib/active_storage/attached/one.rb +32 -27
  49. data/lib/active_storage/downloader.rb +2 -2
  50. data/lib/active_storage/engine.rb +28 -1
  51. data/lib/active_storage/fixture_set.rb +76 -0
  52. data/lib/active_storage/gem_version.rb +4 -4
  53. data/lib/active_storage/previewer.rb +4 -4
  54. data/lib/active_storage/reflection.rb +12 -2
  55. data/lib/active_storage/service/azure_storage_service.rb +1 -1
  56. data/lib/active_storage/service/configurator.rb +1 -1
  57. data/lib/active_storage/service/disk_service.rb +13 -18
  58. data/lib/active_storage/service/gcs_service.rb +91 -7
  59. data/lib/active_storage/service/mirror_service.rb +1 -1
  60. data/lib/active_storage/service/registry.rb +1 -1
  61. data/lib/active_storage/service/s3_service.rb +4 -4
  62. data/lib/active_storage/service.rb +3 -3
  63. data/lib/active_storage/transformers/image_processing_transformer.rb +1 -1
  64. data/lib/active_storage/transformers/transformer.rb +1 -1
  65. data/lib/active_storage.rb +3 -1
  66. metadata +27 -18
  67. 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: 15736d93623ce99c6d521c797c51d4a764e684191f575cf8b7ad521b72e9ba3f
4
- data.tar.gz: 95ef6c6c968b0ca1a283fcd40c6976d860817ab08d4b667e9eb83a4246d7e777
3
+ metadata.gz: c267f362a238a90819d7e7cd23917d10970b03acd2956d099ea6aeb26c2ce192
4
+ data.tar.gz: c669f3a56d9b6f3f5a08e89cfb49725d65d1abf0d7e933c50b6a3fc12c7d9a6d
5
5
  SHA512:
6
- metadata.gz: bff2aacb5bc1ee40540d7720fbd4a96aa914ff627956d1a63a20ea219c3b9e6026fe6380c2f626a0a1c2af96a0ea00f7a40076d0a46e4f5484420311a72bd665
7
- data.tar.gz: 43f9315265d1bb707f0c9166b6c0ac1581f02120a3c1d226a3320357e91c49516f792f304082407fd77ff2753292d71ee896378748d4512ce1e631faa46a540f
6
+ metadata.gz: cf96bff832fd497ff5475a475c2b8d5d22b12243d4126bd973ec28c670f9fb57e2e787c073c2ebf4edd89fb3a1d2fbd703a47e0f9a76490389b22e7e9483e2bd
7
+ data.tar.gz: a405ab97196c4b8c60f284b3e7c664ed30756a08abfe2d1f5d50c43630ec5cfd46d71dcd533e545151312f16459aec534a55f533be95aa6ee47021d29ce30466
data/CHANGELOG.md CHANGED
@@ -1,326 +1,221 @@
1
- ## Rails 6.1.4.4 (December 15, 2021) ##
1
+ ## Rails 7.0.0.alpha1 (September 15, 2021) ##
2
2
 
3
- * No changes.
3
+ * Emit Active Support instrumentation events from Active Storage analyzers.
4
4
 
5
+ Fixes #42930
5
6
 
6
- ## Rails 6.1.4.3 (December 14, 2021) ##
7
+ *Shouichi Kamiya*
7
8
 
8
- * No changes.
9
+ * Add support for byte range requests
9
10
 
11
+ *Tom Prats*
10
12
 
11
- ## Rails 6.1.4.2 (December 14, 2021) ##
13
+ * Attachments can be deleted after their association is no longer defined.
12
14
 
13
- * No changes.
15
+ Fixes #42514
14
16
 
17
+ *Don Sisco*
15
18
 
16
- ## Rails 6.1.4.1 (August 19, 2021) ##
19
+ * Make `vips` the default variant processor for new apps.
17
20
 
18
- * No changes.
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.
19
23
 
24
+ *Breno Gazzola*
20
25
 
21
- ## Rails 6.1.4 (June 24, 2021) ##
26
+ * Deprecate `ActiveStorage::Current.host` in favor of `ActiveStorage::Current.url_options` which accepts
27
+ a host, protocol and port.
22
28
 
23
- * The parameters sent to `ffmpeg` for generating a video preview image are now
24
- configurable under `config.active_storage.video_preview_arguments`.
25
-
26
- *Brendon Muir*
27
-
28
- * Fix Active Storage update task when running in an engine.
29
-
30
- Justin Malčić*
31
-
32
- * Don't raise an error if the mime type is not recognized.
33
-
34
- Fixes #41777.
35
-
36
- *Alex Ghiculescu*
37
-
38
- * `ActiveStorage::PreviewError` is raised when a previewer is unable to generate a preview image.
39
-
40
- *Alex Robbin*
41
-
42
- * respond with 404 given invalid variation key when asking for representations.
43
-
44
- *George Claghorn*
45
-
46
- * `Blob` creation shouldn't crash if no service selected.
47
-
48
- *Alex Ghiculescu*
49
-
50
-
51
- ## Rails 6.1.3.2 (May 05, 2021) ##
52
-
53
- * No changes.
29
+ *Santiago Bartesaghi*
54
30
 
31
+ * Allow using [IAM](https://cloud.google.com/storage/docs/access-control/signed-urls) when signing URLs with GCS.
55
32
 
56
- ## Rails 6.1.3.1 (March 26, 2021) ##
57
-
58
- * Marcel is upgraded to version 1.0.0 to avoid a dependency on GPL-licensed
59
- mime types data.
60
-
61
- *George Claghorn*
62
-
63
-
64
- ## Rails 6.1.3 (February 17, 2021) ##
65
-
66
- * No changes.
67
-
68
-
69
- ## Rails 6.1.2.1 (February 10, 2021) ##
33
+ ```yaml
34
+ gcs:
35
+ service: GCS
36
+ ...
37
+ iam: true
38
+ ```
70
39
 
71
- * No changes.
40
+ *RRethy*
72
41
 
42
+ * OpenSSL constants are now used for Digest computations.
73
43
 
74
- ## Rails 6.1.2 (February 09, 2021) ##
44
+ *Dirkjan Bussink*
75
45
 
76
- * No changes.
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`.
77
48
 
49
+ *Santiago Bartesaghi*
78
50
 
79
- ## Rails 6.1.1 (January 07, 2021) ##
51
+ * Remove deprecated methods: `build_after_upload`, `create_after_upload!` in favor of `create_and_upload!`,
52
+ and `service_url` in favor of `url`.
80
53
 
81
- * Fix S3 multipart uploads when threshold is larger than file.
54
+ *Santiago Bartesaghi*
82
55
 
83
- *Matt Muller*
56
+ * Add support of `strict_loading_by_default` to `ActiveStorage::Representations` controllers.
84
57
 
58
+ *Anton Topchii*, *Andrew White*
85
59
 
86
- ## Rails 6.1.0 (December 09, 2020) ##
60
+ * Allow to detach an attachment when record is not persisted.
87
61
 
88
- * Change default queue name of the analysis (`:active_storage_analysis`) and
89
- purge (`:active_storage_purge`) jobs to be the job adapter's default (`:default`).
62
+ *Jacopo Beschi*
90
63
 
91
- *Rafael Mendonça França*
64
+ * Use libvips instead of ImageMagick to analyze images when `active_storage.variant_processor = vips`.
92
65
 
93
- * Implement `strict_loading` on ActiveStorage associations.
66
+ *Breno Gazzola*
94
67
 
95
- *David Angulo*
68
+ * Add metadata value for presence of video channel in video blobs.
96
69
 
97
- * Remove deprecated support to pass `:combine_options` operations to `ActiveStorage::Transformers::ImageProcessing`.
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.
98
72
 
99
- *Rafael Mendonça França*
73
+ *Breno Gazzola*
100
74
 
101
- * Remove deprecated `ActiveStorage::Transformers::MiniMagickTransformer`.
75
+ * Deprecate usage of `purge` and `purge_later` from the association extension.
102
76
 
103
- *Rafael Mendonça França*
77
+ *Jacopo Beschi*
104
78
 
105
- * Remove deprecated `config.active_storage.queue`.
79
+ * Passing extra parameters in `ActiveStorage::Blob#url` to S3 Client.
106
80
 
107
- *Rafael Mendonça França*
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.
108
84
 
109
- * Remove deprecated `ActiveStorage::Downloading`.
85
+ ```ruby
86
+ blob = ActiveStorage::Blob.last
110
87
 
111
- *Rafael Mendonça França*
88
+ blob.url # => https://<bucket-name>.s3.<region>.amazonaws.com/<key>
89
+ blob.url(virtual_host: true) # => # => https://<bucket-name>/<key>
90
+ ```
112
91
 
113
- * Add per-environment configuration support
92
+ *josegomezr*
114
93
 
115
- *Pietro Moro*
94
+ * Allow setting a `Cache-Control` on files uploaded to GCS.
116
95
 
117
- * The Poppler PDF previewer renders a preview image using the original
118
- document's crop box rather than its media box, hiding print margins. This
119
- matches the behavior of the MuPDF previewer.
96
+ ```yaml
97
+ gcs:
98
+ service: GCS
99
+ ...
100
+ cache_control: "public, max-age=3600"
101
+ ```
120
102
 
121
- *Vincent Robert*
103
+ *maleblond*
122
104
 
123
- * Touch parent model when an attachment is purged.
105
+ * The parameters sent to `ffmpeg` for generating a video preview image are now
106
+ configurable under `config.active_storage.video_preview_arguments`.
124
107
 
125
- *Víctor Pérez Rodríguez*
108
+ *Brendon Muir*
126
109
 
127
- * Files can now be served by proxying them from the underlying storage service
128
- instead of redirecting to a signed service URL. Use the
129
- `rails_storage_proxy_path` and `_url` helpers to proxy an attached file:
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+.
130
113
 
131
- ```erb
132
- <%= image_tag rails_storage_proxy_path(@user.avatar) %>
133
- ```
114
+ *Jonathan Hefner*
134
115
 
135
- To proxy by default, set `config.active_storage.resolve_model_to_route`:
116
+ * Add support for ActiveStorage expiring URLs.
136
117
 
137
118
  ```ruby
138
- # Proxy attached files instead.
139
- config.active_storage.resolve_model_to_route = :rails_storage_proxy
140
- ```
119
+ rails_blob_path(user.avatar, disposition: "attachment", expires_in: 30.minutes)
141
120
 
142
- ```erb
143
- <%= image_tag @user.avatar %>
121
+ <%= image_tag rails_blob_path(user.avatar.variant(resize: "100x100"), expires_in: 30.minutes) %>
144
122
  ```
145
123
 
146
- To redirect to a signed service URL when the default file serving strategy
147
- is set to proxying, use the `rails_storage_redirect_path` and `_url` helpers:
148
-
149
- ```erb
150
- <%= image_tag rails_storage_redirect_path(@user.avatar) %>
151
- ```
152
-
153
- *Jonathan Fleckenstein*
154
-
155
- * Add `config.active_storage.web_image_content_types` to allow applications
156
- to add content types (like `image/webp`) in which variants can be processed,
157
- instead of letting those images be converted to the fallback PNG format.
124
+ If you want to set default expiration time for ActiveStorage URLs throughout your application, set `config.active_storage.urls_expire_in`.
158
125
 
159
- *Jeroen van Haperen*
126
+ *aki77*
160
127
 
161
- * Add support for creating variants of `WebP` images out of the box.
128
+ * Allow to purge an attachment when record is not persisted for `has_many_attached`.
162
129
 
163
- *Dino Maric*
130
+ *Jacopo Beschi*
164
131
 
165
- * Only enqueue analysis jobs for blobs with non-null analyzer classes.
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.
166
134
 
167
- *Gannon McGibbon*
168
-
169
- * Previews are created on the same service as the original blob.
170
-
171
- *Peter Zhu*
135
+ *Alex Ghiculescu*
172
136
 
173
- * Remove unused `disposition` and `content_type` query parameters for `DiskService`.
137
+ * Add metadata value for presence of audio channel in video blobs.
174
138
 
175
- *Peter Zhu*
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.
176
141
 
177
- * Use `DiskController` for both public and private files.
142
+ *Breno Gazzola*
178
143
 
179
- `DiskController` is able to handle multiple services by adding a
180
- `service_name` field in the generated URL in `DiskService`.
144
+ * Adds analyzer for audio files.
181
145
 
182
- *Peter Zhu*
146
+ *Breno Gazzola*
183
147
 
184
- * Variants are tracked in the database to avoid existence checks in the storage service.
148
+ * Respect Active Record's primary_key_type in Active Storage migrations.
185
149
 
186
- *George Claghorn*
150
+ *fatkodima*
187
151
 
188
- * Deprecate `service_url` methods in favour of `url`.
152
+ * Allow `expires_in` for ActiveStorage signed ids.
189
153
 
190
- Deprecate `Variant#service_url` and `Preview#service_url` to instead use
191
- `#url` method to be consistent with `Blob`.
154
+ *aki77*
192
155
 
193
- *Peter Zhu*
156
+ * Allow to purge an attachment when record is not persisted for `has_one_attached`.
194
157
 
195
- * Permanent URLs for public storage blobs.
158
+ *Jacopo Beschi*
196
159
 
197
- Services can be configured in `config/storage.yml` with a new key
198
- `public: true | false` to indicate whether a service holds public
199
- blobs or private blobs. Public services will always return a permanent URL.
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.
200
164
 
201
- Deprecates `Blob#service_url` in favor of `Blob#url`.
165
+ *Brendon Muir*
202
166
 
203
- *Peter Zhu*
167
+ * `ActiveStorage::PreviewError` is raised when a previewer is unable to generate a preview image.
204
168
 
205
- * Make services aware of configuration names.
169
+ *Alex Robbin*
206
170
 
207
- *Gannon McGibbon*
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:
208
173
 
209
- * The `Content-Type` header is set on image variants when they're uploaded to third-party storage services.
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
+ ```
210
185
 
211
- *Kyle Ribordy*
186
+ *DHH*
212
187
 
213
- * Allow storage services to be configured per attachment.
188
+ * Add ability to use pre-defined variants.
214
189
 
215
190
  ```ruby
216
191
  class User < ActiveRecord::Base
217
- has_one_attached :avatar, service: :s3
192
+ has_one_attached :avatar do |attachable|
193
+ attachable.variant :thumb, resize: "100x100"
194
+ attachable.variant :medium, resize: "300x300", monochrome: true
195
+ end
218
196
  end
219
197
 
220
198
  class Gallery < ActiveRecord::Base
221
- has_many_attached :photos, service: :s3
199
+ has_many_attached :photos do |attachable|
200
+ attachable.variant :thumb, resize: "100x100"
201
+ attachable.variant :medium, resize: "300x300", monochrome: true
202
+ end
222
203
  end
223
- ```
224
-
225
- *Dmitry Tsepelev*
226
204
 
227
- * You can optionally provide a custom blob key when attaching a new file:
228
-
229
- ```ruby
230
- user.avatar.attach key: "avatars/#{user.id}.jpg",
231
- io: io, content_type: "image/jpeg", filename: "avatar.jpg"
205
+ <%= image_tag user.avatar.variant(:thumb) %>
232
206
  ```
233
207
 
234
- Active Storage will store the blob's data on the configured service at the provided key.
235
-
236
- *George Claghorn*
237
-
238
- * Replace `Blob.create_after_upload!` with `Blob.create_and_upload!` and deprecate the former.
239
-
240
- `create_after_upload!` has been removed since it could lead to data
241
- corruption by uploading to a key on the storage service which happened to
242
- be already taken. Creating the record would then correctly raise a
243
- database uniqueness exception but the stored object would already have
244
- overwritten another. `create_and_upload!` swaps the order of operations
245
- so that the key gets reserved up-front or the uniqueness error gets raised,
246
- before the upload to a key takes place.
247
-
248
- *Julik Tarkhanov*
249
-
250
- * Set content disposition in direct upload using `filename` and `disposition` parameters to `ActiveStorage::Service#headers_for_direct_upload`.
251
-
252
- *Peter Zhu*
253
-
254
- * Allow record to be optionally passed to blob finders to make sharding
255
- easier.
256
-
257
- *Gannon McGibbon*
258
-
259
- * Switch from `azure-storage` gem to `azure-storage-blob` gem for Azure service.
208
+ *fatkodima*
260
209
 
261
- *Peter Zhu*
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.
262
212
 
263
- * Add `config.active_storage.draw_routes` to disable Active Storage routes.
213
+ *Ali Ismayilov*
264
214
 
265
- *Gannon McGibbon*
266
-
267
- * Image analysis is skipped if ImageMagick returns an error.
268
-
269
- `ActiveStorage::Analyzer::ImageAnalyzer#metadata` would previously raise a
270
- `MiniMagick::Error`, which caused persistent `ActiveStorage::AnalyzeJob`
271
- failures. It now logs the error and returns `{}`, resulting in no metadata
272
- being added to the offending image blob.
273
-
274
- *George Claghorn*
275
-
276
- * Method calls on singular attachments return `nil` when no file is attached.
277
-
278
- Previously, assuming the following User model, `user.avatar.filename` would
279
- raise a `Module::DelegationError` if no avatar was attached:
280
-
281
- ```ruby
282
- class User < ApplicationRecord
283
- has_one_attached :avatar
284
- end
285
- ```
286
-
287
- They now return `nil`.
288
-
289
- *Matthew Tanous*
290
-
291
- * The mirror service supports direct uploads.
292
-
293
- New files are directly uploaded to the primary service. When a
294
- directly-uploaded file is attached to a record, a background job is enqueued
295
- to copy it to each secondary service.
296
-
297
- Configure the queue used to process mirroring jobs by setting
298
- `config.active_storage.queues.mirror`. The default is `:active_storage_mirror`.
299
-
300
- *George Claghorn*
301
-
302
- * The S3 service now permits uploading files larger than 5 gigabytes.
303
-
304
- When uploading a file greater than 100 megabytes in size, the service
305
- transparently switches to [multipart uploads](https://docs.aws.amazon.com/AmazonS3/latest/dev/mpuoverview.html)
306
- using a part size computed from the file's total size and S3's part count limit.
307
-
308
- No application changes are necessary to take advantage of this feature. You
309
- can customize the default 100 MB multipart upload threshold in your S3
310
- service's configuration:
311
-
312
- ```yaml
313
- production:
314
- service: s3
315
- access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
316
- secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
317
- region: us-east-1
318
- bucket: my-bucket
319
- upload:
320
- multipart_threshold: <%= 250.megabytes %>
321
- ```
215
+ * Declare `ActiveStorage::FixtureSet` and `ActiveStorage::FixtureSet.blob` to
216
+ improve fixture integration.
322
217
 
323
- *George Claghorn*
218
+ *Sean Doyle*
324
219
 
325
220
 
326
- Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/activestorage/CHANGELOG.md) for previous changes.
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
@@ -1,4 +1,4 @@
1
- Copyright (c) 2017-2020 David Heinemeier Hansson, Basecamp
1
+ Copyright (c) 2017-2021 David Heinemeier Hansson, Basecamp
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
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/jpg")
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
- Explicitly proxy attachments using the `rails_storage_proxy_path` and `_url` route helpers:
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 `activestorage.js` in your application's JavaScript bundle.
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