engine/lib/locomotive/import/job.rb

186 lines
4.7 KiB
Ruby
Raw Normal View History

require 'zip/zipfilesystem'
module Locomotive
module Import
class Job
include Logger
def initialize(zipfile, site, options = {})
@site_id = site._id.to_s
@options = {
:reset => false,
:samples => false,
:enabled => {}
}.merge(options)
@identifier = self.store_zipfile(zipfile)
raise "Theme identifier not found" if @identifier.blank?
# empty instance variables before serialization (issue with ruby 1.9.2)
@uploader = @site = nil
end
def before(worker)
@worker = worker
end
def site
@site ||= Locomotive::Site.find(@site_id)
end
def perform
self.log "theme identifier #{@identifier} / site_id #{@site_id}"
self.unzip!
2011-06-17 21:32:54 +00:00
raise "No config/compiled_site.yml found in the theme zipfile" if @database.nil?
2010-09-23 23:00:13 +00:00
context = {
:database => @database,
:site => self.site,
:theme_path => @theme_path,
:error => nil,
:worker => @worker
2010-09-23 23:00:13 +00:00
}
self.reset! if @options[:reset]
# %w(site content_types content_assets snippets pages).each do |step|
%w(site assets snippets pages).each do |step|
if @options[:enabled][step] != false
"Locomotive::Import::#{step.camelize}".constantize.process(context, @options)
@worker.update_attributes :step => step if @worker
else
self.log "skipping #{step}"
end
sleep 10 # FIXME DEBUG PURPOSE
end
end
def success(worker)
self.log 'deleting original zip file'
uploader = self.get_uploader(self.site)
uploader.retrieve_from_store!(@identifier)
uploader.remove!
self.log 'deleting working folder'
FileUtils.rm_rf(themes_folder) rescue nil
end
def self.run!(zipfile, site, options = {})
job = self.new(zipfile, site, options)
if Locomotive.config.delayed_job
Delayed::Job.enqueue job, { :site_id => site._id, :job_type => 'import' }
else
job.perform
end
end
protected
def themes_folder
File.join(Rails.root, 'tmp', 'themes', self.site._id.to_s)
end
def prepare_folder
FileUtils.rm_rf self.themes_folder if File.exists?(self.themes_folder)
FileUtils.mkdir_p(self.themes_folder)
end
def store_zipfile(zipfile)
return nil if zipfile.blank?
uploader = self.get_uploader(self.site)
begin
if zipfile.is_a?(String) && zipfile =~ /^https?:\/\//
uploader.download!(zipfile)
uploader.store!
else
file = ::CarrierWave::SanitizedFile.new(zipfile)
uploader.store!(file)
end
uploader.identifier
rescue ::CarrierWave::IntegrityError
nil
end
end
def retrieve_zipfile
uploader = self.get_uploader(self.site)
uploader.retrieve_from_store!(@identifier)
if uploader.file.respond_to?(:url)
self.log 'file from remote storage'
@theme_file = File.join(self.themes_folder, @identifier)
2011-01-27 13:07:10 +00:00
if RUBY_VERSION =~ /1\.9/
bytes = uploader.file.read.force_encoding('UTF-8')
else
bytes = uploader.file.read
end
File.open(@theme_file, 'w') { |f| f.write(bytes) }
else # local filesystem
self.log 'file from local storage'
@theme_file = uploader.path
end
end
def unzip!
self.prepare_folder
self.retrieve_zipfile
self.log "unzip #{@theme_file}"
Zip::ZipFile.open(@theme_file) do |zipfile|
destination_path = self.themes_folder
zipfile.each do |entry|
next if entry.name =~ /__MACOSX/
2011-06-17 21:32:54 +00:00
if entry.name =~ /config\/compiled_site.yml$/
@database = YAML.load(zipfile.read(entry.name))
2011-06-17 21:32:54 +00:00
@theme_path = File.join(destination_path, entry.name.gsub('config/compiled_site.yml', ''))
next
end
2010-09-23 23:00:13 +00:00
FileUtils.mkdir_p(File.dirname(File.join(destination_path, entry.name)))
zipfile.extract(entry, File.join(destination_path, entry.name))
end
end
end
def reset!
self.site.pages.destroy_all
self.site.content_assets.destroy_all
self.site.theme_assets.destroy_all
self.site.content_types.destroy_all
end
def get_uploader(site)
unless Locomotive.config.delayed_job
ThemeUploader.storage = :file
end
@uploader ||= ThemeUploader.new(site)
end
end
end
2011-11-26 05:22:48 +00:00
end