2011-06-01 19:11:57 +00:00
|
|
|
require 'wordpress'
|
|
|
|
|
|
|
|
namespace :wordpress do
|
|
|
|
desc "Reset the blog relevant tables for a clean import"
|
2011-06-02 12:41:31 +00:00
|
|
|
task :reset_blog do
|
2011-06-01 19:11:57 +00:00
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
%w(posts post_translations taggings tags).each do |table_name|
|
2011-06-01 19:11:57 +00:00
|
|
|
p "Truncating #{table_name} ..."
|
2011-06-02 12:41:31 +00:00
|
|
|
ActiveRecord::Base.connection.execute "DELETE FROM #{table_name}"
|
2011-06-01 19:11:57 +00:00
|
|
|
end
|
|
|
|
|
2011-06-02 14:22:50 +00:00
|
|
|
end
|
2011-06-02 12:41:31 +00:00
|
|
|
|
2014-03-04 22:47:53 +00:00
|
|
|
desc "import blog data from a WordPressImport XML dump"
|
2011-06-02 12:41:31 +00:00
|
|
|
task :import_blog, :file_name do |task, params|
|
2011-06-01 19:11:57 +00:00
|
|
|
Rake::Task["environment"].invoke
|
2014-03-07 00:25:39 +00:00
|
|
|
p "Loading XML from #{params[:file_name]} ..."
|
2014-03-04 22:47:53 +00:00
|
|
|
dump = WordPressImport::Dump.new(params[:file_name])
|
2011-06-01 19:11:57 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
p "Importing #{dump.authors.count} authors ..."
|
|
|
|
dump.authors.each(&:to_rails)
|
2011-06-03 09:35:11 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# by default, import all; unless $ONLY_PUBLISHED = "true"
|
2011-06-03 09:35:11 +00:00
|
|
|
only_published = ENV['ONLY_PUBLISHED'] == 'true' ? true : false
|
2014-03-07 00:25:39 +00:00
|
|
|
p "Importing #{dump.posts(only_published).count} posts ..."
|
|
|
|
|
|
|
|
if only_published
|
|
|
|
p "(only published posts)"
|
|
|
|
else
|
|
|
|
p "(export ONLY_PUBLISHED=true to import only published posts)"
|
|
|
|
end
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
dump.posts(only_published).each(&:to_rails)
|
2011-06-01 19:11:57 +00:00
|
|
|
end
|
|
|
|
|
2014-03-04 22:47:53 +00:00
|
|
|
desc "reset blog tables and then import blog data from a WordPressImport XML dump"
|
2011-06-02 14:22:50 +00:00
|
|
|
task :reset_and_import_blog, :file_name do |task, params|
|
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
Rake::Task["wordpress:reset_blog"].invoke
|
|
|
|
Rake::Task["wordpress:import_blog"].invoke(params[:file_name])
|
2011-06-01 19:11:57 +00:00
|
|
|
end
|
|
|
|
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# desc "Reset the cms relevant tables for a clean import"
|
|
|
|
# task :reset_pages do
|
|
|
|
# Rake::Task["environment"].invoke
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# %w(page_part_translations page_translations page_parts pages).each do |table_name|
|
|
|
|
# p "Truncating #{table_name} ..."
|
|
|
|
# ActiveRecord::Base.connection.execute "DELETE FROM #{table_name}"
|
|
|
|
# end
|
|
|
|
# end
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# desc "import cms data from a WordPress XML dump"
|
|
|
|
# task :import_pages, :file_name do |task, params|
|
|
|
|
# Rake::Task["environment"].invoke
|
|
|
|
# dump = WordPressImport::Dump.new(params[:file_name])
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# only_published = ENV['ONLY_PUBLISHED'] == 'true' ? true : false
|
|
|
|
# dump.pages(only_published).each(&:to_rails)
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# # After all pages are persisted we can now create the parent - child
|
|
|
|
# # relationships. This is necessary, as WordPress doesn't dump the pages in
|
|
|
|
# # a correct order.
|
|
|
|
# dump.pages(only_published).each do |dump_page|
|
|
|
|
# page = ::Page.find(dump_page.post_id)
|
|
|
|
# page.parent_id = dump_page.parent_id
|
|
|
|
# page.save!
|
|
|
|
# end
|
|
|
|
|
|
|
|
# WordPressImport::Post.create_blog_page_if_necessary
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# ENV["MODEL"] = 'Page'
|
|
|
|
# Rake::Task["friendly_id:redo_slugs"].invoke
|
|
|
|
# ENV.delete("MODEL")
|
|
|
|
# end
|
2011-06-03 16:50:27 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# desc "reset cms tables and then import cms data from a WordPress XML dump"
|
|
|
|
# task :reset_and_import_pages, :file_name do |task, params|
|
|
|
|
# Rake::Task["environment"].invoke
|
|
|
|
# Rake::Task["wordpress:reset_pages"].invoke
|
|
|
|
# Rake::Task["wordpress:import_pages"].invoke(params[:file_name])
|
|
|
|
# end
|
2011-06-13 16:48:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
desc "Reset the media relevant tables for a clean import"
|
|
|
|
task :reset_media do
|
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
%w(rich_rich_files).each do |table_name|
|
2011-06-13 16:48:17 +00:00
|
|
|
p "Truncating #{table_name} ..."
|
|
|
|
ActiveRecord::Base.connection.execute "DELETE FROM #{table_name}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc "import media data (images and files) from a WordPress XML dump and replace target URLs in pages and posts"
|
|
|
|
task :import_and_replace_media, :file_name do |task, params|
|
|
|
|
Rake::Task["environment"].invoke
|
2014-03-04 22:47:53 +00:00
|
|
|
dump = WordPressImport::Dump.new(params[:file_name])
|
2011-06-13 16:48:17 +00:00
|
|
|
|
2014-03-07 01:20:09 +00:00
|
|
|
p "Importing #{dump.attachments.each_slice(200).first.count} attachments ..."
|
|
|
|
attachments = dump.attachments.each_slice(200).first.each(&:to_rails)
|
|
|
|
unless $ATTACHMENT_EXCEPTIONS.blank?
|
|
|
|
p "----------------------------------------------------------"
|
|
|
|
p "ERRORS WERE ENCOUNTERED IMPORTING ATTACHMENTS:"
|
|
|
|
$ATTACHMENT_EXCEPTIONS.each{|exception| puts exception}
|
|
|
|
p "----------------------------------------------------------"
|
|
|
|
end
|
2011-06-13 16:48:17 +00:00
|
|
|
|
2014-03-07 00:25:39 +00:00
|
|
|
# parse all created Post and Page bodys and replace the old wordpress media urls
|
2011-06-13 16:48:17 +00:00
|
|
|
# with the newly created ones
|
2014-03-07 00:25:39 +00:00
|
|
|
p "Replacing attachment URLs found in posts/pages ..."
|
|
|
|
attachments.each(&:replace_url)
|
2014-03-07 01:20:09 +00:00
|
|
|
|
|
|
|
unless $REPLACEMENT_EXCEPTIONS.blank?
|
|
|
|
p "----------------------------------------------------------"
|
|
|
|
p "ERRORS WERE ENCOUNTERED REPLACING ATTACHMENTS:"
|
|
|
|
$REPLACEMENT_EXCEPTIONS.each{|exception| puts exception}
|
|
|
|
p "----------------------------------------------------------"
|
|
|
|
end
|
2011-06-13 16:48:17 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
desc "reset media tables and then import media data from a WordPress XML dump"
|
|
|
|
task :reset_import_and_replace_media, :file_name do |task, params|
|
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
Rake::Task["wordpress:reset_media"].invoke
|
|
|
|
Rake::Task["wordpress:import_and_replace_media"].invoke(params[:file_name])
|
|
|
|
end
|
|
|
|
|
|
|
|
desc "reset and import all data (see the other tasks)"
|
|
|
|
task :full_import, :file_name do |task, params|
|
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
Rake::Task["wordpress:reset_and_import_blog"].invoke(params[:file_name])
|
2014-03-07 00:25:39 +00:00
|
|
|
#Rake::Task["wordpress:reset_and_import_pages"].invoke(params[:file_name])
|
|
|
|
#Rake::Task["wordpress:reset_import_and_replace_media"].invoke(params[:file_name])
|
|
|
|
Rake::Task["wordpress:import_and_replace_media"].invoke(params[:file_name])
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
desc "Local First master import (no resets)"
|
|
|
|
task :lfa_import, :file_name do |task, params|
|
|
|
|
Rake::Task["environment"].invoke
|
|
|
|
Rake::Task["wordpress:import_blog"].invoke(params[:file_name])
|
|
|
|
Rake::Task["wordpress:import_and_replace_media"].invoke(params[:file_name])
|
2011-06-13 16:48:17 +00:00
|
|
|
end
|
2011-06-01 19:11:57 +00:00
|
|
|
end
|