Skip to content

Latest commit

 

History

History
111 lines (80 loc) · 1.97 KB

README.md

File metadata and controls

111 lines (80 loc) · 1.97 KB

ActiveArchiver

Provide export / import to ActiveRecord and support CarrierWave.

Installation

Add this line to your application's Gemfile:

gem 'active_archiver', github:'zaru/active_archiver'

And then execute:

$ bundle

Usage

sample code

export = User.find(1).export

User.find(1).destroy
User.find(1)
=> ActiveRecord::RecordNotFound: Couldn't find User with 'id'=1

User.import(export)
User.find(1)
=> #<User id: 1, ...>

export

Returns the specified model object as a hash. Images uploaded with CarrierWave are encoded in Base64.

export = User.last.export

=> {:attributes=>
  {"id"=>3,
   "last_name"=>"hoge",
   "first_name"=>"piyo",
   "email"=>"hogepiyo@example.com",
   "created_at"=>Sun, 06 Nov 2016 21:04:11 JST +09:00,
   "updated_at"=>Tue, 22 Nov 2016 12:16:28 JST +09:00},
 :associations=>[]}

If you want to export related models as well

export = User.last.export(includes: [:photos])

=> {:attributes=>
  {"id"=>3,
   "last_name"=>"hoge",
   "first_name"=>"piyo",
   "email"=>"hogepiyo@example.com",
   "created_at"=>Sun, 06 Nov 2016 21:04:11 JST +09:00,
   "updated_at"=>Tue, 22 Nov 2016 12:16:28 JST +09:00},
 :associations=>
   [{:model_name=>"Photo",
     :association_name=>:photos,
     :attributes=>
      {"id"=>57,
       "user_id"=>3,
       "image"=>
        {:url=>"https://example.com/uploads/hoge.png",
         :file_name=>"hoge.png",
         :blob=>
          "...

To specify a nested model.

class User < ApplicationRecord
  has_many :photos
  has_many :pets
end

class Pet < ApplicationRecord
  has_many :pet_photos
end
export = User.last.export(includes: [:photos, pets:[:pet_photos]])

import

User.import(export)

archive

Write the temporary file.

Hoge.find(1).archive

=> #<File:/tmp/20161125-12571-ak10w5.json (closed)>

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/zaru/active_archiver.