Посев удаленных изображений Carrierwave - PullRequest
0 голосов
/ 15 сентября 2018

Я хотел бы заполнить свое приложение на heroku, поэтому мне нужно заполнить изображения, которые я загрузил на Amazon S3, и я не могу понять, как это сделать ...

Я использую Carrierwave с загрузчиком нескольких файлов

Вот что я имею в своих сильных параметрах:

 private

    def article_params
      params.require(:article).permit(:id, :title, :description, {attachments:[]})
    end

Вот как я пытаюсь засеять геройку, как я могу сделать так, чтобы URL был засеян?

Article.create!( 
        title:  Faker::Music.instrument,
        description: Faker::Lorem.paragraph(3), 
        attachments: 
         [ "https://s3-eu-west-1.amazonaws.com/mysite/images_site/seeds/image_1.jpg", 
           "https://s3-eu-west-1.amazonaws.com/mysite/images_site/seeds/image_2.jpg"]
        )
end

Это то, как я сею локально, и это прекрасно работает.

20.times do 
    Article.create!( 
        title:  Faker::Music.instrument,
        description: Faker::Lorem.paragraph(10),    
        attachments: 
         [ Rails.root.join("app/assets/images/seeds/image_1.jpg").open, 
           Rails.root.join("app/assets/images/seeds/image_2.jpg").open,
           Rails.root.join("app/assets/images/seeds/image_3.jpg").open, 
          ].shuffle)
    print "_"
end

EDIT

После предложения Карлоса Рамиреса III оно все еще не работает :(

➜  lesch git:(master) ✗ heroku run rails db:seed --trace                                                                                                          [2.4.4]
Running rails db:seed --trace on ⬢ new-lesch... up, run.1313 (Free)
** Invoke db:seed (first_time)
** Execute db:seed
** Invoke db:abort_if_pending_migrations (first_time)
** Invoke db:load_config (first_time)
** Invoke environment (first_time)
** Execute environment
** Execute db:load_config
** Execute db:abort_if_pending_migrations
D, [2018-09-15T13:55:37.031136 #4] DEBUG -- :    (7.1ms)  SELECT "schema_migrations"."version" FROM "schema_migrations" ORDER BY "schema_migrations"."version" ASC
rails aborted!
ArgumentError: extra arguments
/app/vendor/ruby-2.4.4/lib/ruby/2.4.0/open-uri.rb:136:in `open_uri'
/app/vendor/ruby-2.4.4/lib/ruby/2.4.0/open-uri.rb:721:in `open'
/app/vendor/ruby-2.4.4/lib/ruby/2.4.0/open-uri.rb:35:in `open'
/app/db/seeds.rb:17:in `block in <main>'
/app/db/seeds.rb:12:in `times'
/app/db/seeds.rb:12:in `<main>'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:50:in `load'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:50:in `load'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:281:in `block in load'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:253:in `load_dependency'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:281:in `load'
/app/vendor/bundle/ruby/2.4.0/gems/railties-5.2.1/lib/rails/engine.rb:551:in `load_seed'
/app/vendor/bundle/ruby/2.4.0/gems/activerecord-5.2.1/lib/active_record/tasks/database_tasks.rb:281:in `load_seed'
/app/vendor/bundle/ruby/2.4.0/gems/activerecord-5.2.1/lib/active_record/railties/databases.rake:194:in `block (2 levels) in <main>'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:271:in `block in execute'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:271:in `each'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:271:in `execute'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:213:in `block in invoke_with_call_chain'
/app/vendor/ruby-2.4.4/lib/ruby/2.4.0/monitor.rb:214:in `mon_synchronize'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:193:in `invoke_with_call_chain'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/task.rb:182:in `invoke'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:160:in `invoke_task'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:116:in `block (2 levels) in top_level'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:116:in `each'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:116:in `block in top_level'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:125:in `run_with_threads'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:110:in `top_level'
/app/vendor/bundle/ruby/2.4.0/gems/railties-5.2.1/lib/rails/commands/rake/rake_command.rb:23:in `block in perform'
/app/vendor/bundle/ruby/2.4.0/gems/rake-12.3.1/lib/rake/application.rb:186:in `standard_exception_handling'
/app/vendor/bundle/ruby/2.4.0/gems/railties-5.2.1/lib/rails/commands/rake/rake_command.rb:20:in `perform'
/app/vendor/bundle/ruby/2.4.0/gems/railties-5.2.1/lib/rails/command.rb:48:in `invoke'
/app/vendor/bundle/ruby/2.4.0/gems/railties-5.2.1/lib/rails/commands.rb:18:in `<main>'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:21:in `require'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:21:in `block in require_with_bootsnap_lfi'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/loaded_features_index.rb:65:in `register'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:20:in `require_with_bootsnap_lfi'
/app/vendor/bundle/ruby/2.4.0/gems/bootsnap-1.3.2/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:29:in `require'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:287:in `block in require'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:253:in `load_dependency'
/app/vendor/bundle/ruby/2.4.0/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:287:in `require'
/app/bin/rails:9:in `<main>'
Tasks: TOP => db:seed

Ответы [ 2 ]

0 голосов
/ 15 сентября 2018

Вы должны передать объекты ввода / вывода атрибутам загрузчика CarrierWave

В локальном примере вы вызываете .open по пути к файлу, который читает файл и возвращает объект File.

В удаленном примере вы просто передаете пути URI, которые являются строками, а не объектом ввода-вывода, таким как File.

Чтение удаленного файла

Чтобы прочитать удаленный файл прямо по пути URI, вы можете использовать метод open, предоставляемый модулем OpenURI.

open("https://s3-eu-west-1.amazonaws.com/mysite/images_site/seeds/image_1.jpg”)

Прочтите документацию здесь:
https://ruby -doc.org / stdlib-2.1.0 / libdoc / open-uri / rdoc / OpenURI.html

ПРИМЕЧАНИЕ. Возможно, вам придется добавить require "open-uri", если вы не используете Rails

Заполнение нескольких удаленных файлов с помощью CarrierWave

Вы можете исправить пример Heroku, обернув удаленный URIстроки с open примерно так:

Article.create!( 
    title:  Faker::Music.instrument,
    description: Faker::Lorem.paragraph(3), 
    attachments: 
     [ open("https://s3-eu-west-1.amazonaws.com/mysite/images_site/seeds/image_1.jpg”), 
       open("https://s3-eu-west-1.amazonaws.com/mysite/images_site/seeds/image_2.jpg”)]
    )
end
0 голосов
/ 15 сентября 2018

Просто создайте записи базы данных более ручным способом.Вам необходимо убедиться, что ваши ключи S3 соответствуют вашему экземпляру CarrierWave, который генерирует структуру ключей.

...