Module: Importer::Adapters::ActiveRecordAdapter::ClassMethods
- Defined in:
- lib/importer/adapters/active_record_adapter.rb
Instance Method Summary collapse
-
#find_on_import(import, attributes) ⇒ Object
Determines whether a detected object already exists in database.
-
#import(file, options = {}) ⇒ Object
The import process is wrapped in a transaction, so if anything goes wrong there is no harm done.
Instance Method Details
#find_on_import(import, attributes) ⇒ Object
Determines whether a detected object already exists in database. By default it tries to find an existing objects by id of the detected one. Returns the object or nil if it’s not found. Override this method in your model to change that default behavior.
-
import
- current import -
attributes
- detected object’s attributes hash
85 86 87 |
# File 'lib/importer/adapters/active_record_adapter.rb', line 85 def find_on_import(import, attributes) find_by_id(attributes["id"]) end |
#import(file, options = {}) ⇒ Object
The import process is wrapped in a transaction, so if anything goes wrong there is no harm done.
-
file
- path to an XML or CVS file, you can also import from other data formats, but you also need to provide a custom parser to read it
Possible options:
-
parser
- by default the parser is determined from file extension, but you can force the imported to use another one by passing it’s class here -
import
- by default importer returns instance ofImport
class that contains detailed report of import process, you can implement your own Import class and force the importer to use it by passing it’s class here -
import_options
- options passed to Import instance on it’s initialization
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
# File 'lib/importer/adapters/active_record_adapter.rb', line 46 def import(file, = {}) import = ([:import] || Importer::Import).new([:import_options]) parser = [:parser] || Importer::Parser.get_klass(file) data = parser.run(file) transaction do data.each do |attributes| imported_object = import.build_imported_object if object = find_on_import(import, attributes) imported_object.state = "existing_object" else object = new imported_object.state = "new_object" end imported_object.data = attributes object.merge_attributes_on_import(import, attributes) unless object.save imported_object.state = "invalid_object" imported_object.validation_errors = object.errors..uniq end imported_object.object = object import.add_object(imported_object) end end import end |