diff --git a/.gitignore b/.gitignore index c46f8e3a89..2005175ff1 100644 --- a/.gitignore +++ b/.gitignore @@ -92,3 +92,5 @@ Gemfile.lock *.txt *.orig +db/ +config/initializers diff --git a/authentication/lib/generators/refinery/authentication/authentication_generator.rb b/authentication/lib/generators/refinery/authentication/authentication_generator.rb index 733c7b5efe..446b5ce9e3 100644 --- a/authentication/lib/generators/refinery/authentication/authentication_generator.rb +++ b/authentication/lib/generators/refinery/authentication/authentication_generator.rb @@ -1,9 +1,13 @@ module Refinery class AuthenticationGenerator < Rails::Generators::Base + class_option :skip_migrations, :type => :boolean, :default => false, + :aliases => nil, :group => :runtime, + :desc => "Skip over installing or running migrations." + source_root File.expand_path("../templates", __FILE__) def rake_db - rake "refinery_authentication:install:migrations" + rake "refinery_authentication:install:migrations" unless self.options[:skip_migrations] end def generate_authentication_initializer diff --git a/core/lib/generators/refinery/cms/cms_generator.rb b/core/lib/generators/refinery/cms/cms_generator.rb index 41dcee5529..3d29564523 100644 --- a/core/lib/generators/refinery/cms/cms_generator.rb +++ b/core/lib/generators/refinery/cms/cms_generator.rb @@ -1,4 +1,5 @@ require 'pathname' +require 'refinery/core/environment_checker' module Refinery class CmsGenerator < Rails::Generators::Base @@ -191,36 +192,14 @@ def deploy_to_hosting_heroku!(message = nil) run "heroku restart" end - # Helper method to quickly convert destination_root to a Pathname for easy file path manipulation + # Helper method to quickly convert destination_root to a Pathname + # for easy file path manipulation def destination_path @destination_path ||= Pathname.new(self.destination_root) end def ensure_environments_are_sane! - # Massage environment files - %w(development test production).map{ |e| "config/environments/#{e}.rb"}.each do |env| - next unless destination_path.join(env).file? - - # Refinery does not necessarily expect action_mailer to be available as - # we may not always require it (currently only the authentication extension). - # Rails, however, will optimistically place config entries for action_mailer. - current_mailer_config = File.read(destination_path.join(env)).to_s. - match(%r{^\s.+?config\.action_mailer\..+([\w\W]*\})?}). - to_a.flatten.first - - if current_mailer_config.present? - new_mailer_config = [ - " if config.respond_to?(:action_mailer)", - current_mailer_config.gsub(%r{\A\n+?}, ''). # remove extraneous newlines at the start - gsub(%r{^\ \ }) { |line| " #{line}" }, # add indentation on each line - " end" - ].join("\n") - - gsub_file env, current_mailer_config, new_mailer_config, :verbose => false - end - - gsub_file env, "config.assets.compile = false", "config.assets.compile = true", :verbose => false - end + Refinery::Core::EnvironmentChecker.new(destination_path).call end def forced_overwriting? @@ -305,7 +284,7 @@ def sanity_check_heroku_application_name! message.join("\n") end - options[:heroku] = '' if options[:heroku] == 'heroku' + options.delete(:heroku) if options[:heroku] == 'heroku' end def start_pretending? diff --git a/core/lib/generators/refinery/dummy/dummy_generator.rb b/core/lib/generators/refinery/dummy/dummy_generator.rb index 0f9027b13e..7da8c883d8 100644 --- a/core/lib/generators/refinery/dummy/dummy_generator.rb +++ b/core/lib/generators/refinery/dummy/dummy_generator.rb @@ -1,20 +1,21 @@ -require 'rails/generators' require 'rails/generators/rails/app/app_generator' module Refinery class DummyGenerator < Rails::Generators::Base - desc "Creates blank Rails application, installs Refinery CMS, and all sample data" + desc "Creates a blank Rails application with Refinery CMS installed." class_option :database, :default => '' def self.source_paths - paths = self.superclass.source_paths - paths << File.expand_path('../templates', __FILE__) - paths.flatten + [ + self.superclass.source_paths, + File.expand_path('../templates', __FILE__) + ].flatten.compact end PASSTHROUGH_OPTIONS = [ - :skip_active_record, :skip_javascript, :database, :javascript, :quiet, :pretend, :force, :skip + :skip_active_record, :skip_javascript, :database, :javascript, :quiet, + :pretend, :force, :skip ] def generate_test_dummy @@ -22,8 +23,13 @@ def generate_test_dummy opts[:database] = 'sqlite3' if opts[:database].blank? opts[:force] = true opts[:skip_bundle] = true + opts[:skip_keeps] = true + opts[:skip_migrate] = true + opts[:template] = refinery_path.join("templates", "refinery", "edge.rb").to_s - invoke Rails::Generators::AppGenerator, [ File.expand_path(dummy_path, destination_root) ], opts + invoke Rails::Generators::AppGenerator, + [ File.expand_path(dummy_path, destination_root) ], + opts end def test_dummy_config @@ -65,19 +71,22 @@ def test_dummy_inherited_templates attr :database - protected + protected def dummy_path 'spec/dummy' end + def dummy_application_path + File.expand_path("#{dummy_path}/config/application.rb", destination_root) + end + def module_name 'Dummy' end def application_definition @application_definition ||= begin - dummy_application_path = File.expand_path("#{dummy_path}/config/application.rb", destination_root) unless options[:pretend] || !File.exists?(dummy_application_path) contents = File.read(dummy_application_path) contents[(contents.index("module #{module_name}"))..-1] @@ -91,7 +100,11 @@ def camelized end def gemfile_path - '../../../../Gemfile' + "../../../../Gemfile" + end + + def refinery_path + Pathname.new File.expand_path("../../../../../../", __FILE__) end end end diff --git a/core/lib/refinery/core/environment_checker.rb b/core/lib/refinery/core/environment_checker.rb new file mode 100644 index 0000000000..588c768675 --- /dev/null +++ b/core/lib/refinery/core/environment_checker.rb @@ -0,0 +1,54 @@ +# Check that Rails application configuration is consistent with what we expect. +require 'pathname' + +module Refinery + module Core + class EnvironmentChecker + + def initialize(root_path, environments: %w(development test production)) + @root_path = Pathname.new(root_path) + @environments = environments + end + + def call + environment_files.each do |env_file| + # Refinery does not necessarily expect action_mailer to be available as + # we may not always require it (currently only the authentication extension). + # Rails, however, will optimistically place config entries for action_mailer. + current_mailer_config = mailer_config(env_file) + + if current_mailer_config.present? + new_mailer_config = [ + " if config.respond_to?(:action_mailer)", + current_mailer_config.gsub(%r{\A\n+?}, ''). # remove extraneous newlines at the start + gsub(%r{^\ \ }) { |line| " #{line}" }, # add indentation on each line + " end" + ].join("\n") + + env_file.write( + env_file.read.gsub(current_mailer_config, new_mailer_config) + ) + end + + env_file.write( + env_file.read.gsub("assets.compile = false", "assets.compile = true") + ) + end + end + + private + attr_reader :environments, :root_path + + def environment_files + environments.map { |env| root_path.join("config", "environments", "#{env}.rb") } + .select(&:file?) + end + + def mailer_config(environment_file) + root_path.join(environment_file).read.match( + %r{^\s.+?config\.action_mailer\..+([\w\W]*\})?} + ).to_a.flatten.first + end + end + end +end diff --git a/images/db/migrate/20100913234707_create_refinerycms_images_schema.rb b/images/db/migrate/20100913234707_create_refinerycms_images_schema.rb index 7dd74d05ae..5ee56f08ed 100644 --- a/images/db/migrate/20100913234707_create_refinerycms_images_schema.rb +++ b/images/db/migrate/20100913234707_create_refinerycms_images_schema.rb @@ -9,7 +9,7 @@ def change t.string :image_uid t.string :image_ext - t.timestamps + t.timestamps null: false end end end diff --git a/images/lib/generators/refinery/images/images_generator.rb b/images/lib/generators/refinery/images/images_generator.rb index c3b892f1bf..45acf2442f 100644 --- a/images/lib/generators/refinery/images/images_generator.rb +++ b/images/lib/generators/refinery/images/images_generator.rb @@ -1,7 +1,8 @@ module Refinery class ImagesGenerator < Rails::Generators::Base - class_option :skip_migrations, :type => :boolean, :default => false, :aliases => nil, :group => :runtime, - :desc => "Skip over installing or running migrations." + class_option :skip_migrations, :type => :boolean, :default => false, + :aliases => nil, :group => :runtime, + :desc => "Skip over installing or running migrations." source_root File.expand_path('../templates', __FILE__) diff --git a/pages/db/migrate/20100913234708_create_refinerycms_pages_schema.rb b/pages/db/migrate/20100913234708_create_refinerycms_pages_schema.rb index fa01458972..0e02d87532 100644 --- a/pages/db/migrate/20100913234708_create_refinerycms_pages_schema.rb +++ b/pages/db/migrate/20100913234708_create_refinerycms_pages_schema.rb @@ -6,7 +6,7 @@ def up t.text :body t.integer :position - t.timestamps + t.timestamps null: false end add_index :refinery_page_parts, :id @@ -29,7 +29,7 @@ def up t.string :view_template t.string :layout_template - t.timestamps + t.timestamps null: false end add_index :refinery_pages, :depth diff --git a/pages/lib/generators/refinery/pages/pages_generator.rb b/pages/lib/generators/refinery/pages/pages_generator.rb index c1f530bde6..c81dfe6f34 100644 --- a/pages/lib/generators/refinery/pages/pages_generator.rb +++ b/pages/lib/generators/refinery/pages/pages_generator.rb @@ -1,7 +1,8 @@ module Refinery class PagesGenerator < Rails::Generators::Base - class_option :skip_migrations, :type => :boolean, :default => false, :aliases => nil, :group => :runtime, - :desc => "Skip over installing or running migrations." + class_option :skip_migrations, :type => :boolean, :default => false, + :aliases => nil, :group => :runtime, + :desc => "Skip over installing or running migrations." source_root File.expand_path('../templates', __FILE__) diff --git a/resources/db/migrate/20100913234709_create_refinerycms_resources_schema.rb b/resources/db/migrate/20100913234709_create_refinerycms_resources_schema.rb index 06942eb7b2..4627a2bc70 100644 --- a/resources/db/migrate/20100913234709_create_refinerycms_resources_schema.rb +++ b/resources/db/migrate/20100913234709_create_refinerycms_resources_schema.rb @@ -7,7 +7,7 @@ def change t.string :file_uid t.string :file_ext - t.timestamps + t.timestamps null: false end end end diff --git a/resources/lib/generators/refinery/resources/resources_generator.rb b/resources/lib/generators/refinery/resources/resources_generator.rb index 24b6185702..b98d644a3f 100644 --- a/resources/lib/generators/refinery/resources/resources_generator.rb +++ b/resources/lib/generators/refinery/resources/resources_generator.rb @@ -1,7 +1,8 @@ module Refinery class ResourcesGenerator < Rails::Generators::Base - class_option :skip_migrations, :type => :boolean, :default => false, :aliases => nil, :group => :runtime, - :desc => "Skip over installing or running migrations." + class_option :skip_migrations, :type => :boolean, :default => false, + :aliases => nil, :group => :runtime, + :desc => "Skip over installing or running migrations." source_root File.expand_path('../templates', __FILE__) diff --git a/templates/refinery/edge.rb b/templates/refinery/edge.rb index c173d6be81..b247e26725 100644 --- a/templates/refinery/edge.rb +++ b/templates/refinery/edge.rb @@ -14,11 +14,17 @@ gem "coffee-rails", :group => :assets end +refinerycms_source = if ENV['REFINERY_PATH'] + "path: '#{ENV['REFINERY_PATH']}'" +else + "git: 'https://github.com/refinery/refinerycms', branch: 'master'" +end + append_file 'Gemfile' do " -gem 'refinerycms', git: 'https://github.com/refinery/refinerycms', branch: 'master' +gem 'refinerycms', #{refinerycms_source} -gem 'quiet_assets', :group => :development +gem 'quiet_assets', group: :development # Add support for searching inside Refinery's admin interface. gem 'refinerycms-acts-as-indexed', ['~> 2.0', '>= 2.0.0'] @@ -31,10 +37,12 @@ run 'bundle install' rake 'db:create' +require 'refinery/core/environment_checker' +Refinery::Core::EnvironmentChecker.new(destination_root).call generate "refinery:cms --fresh-installation #{ARGV.join(' ')}" say <<-SAY ============================================================================ - Your new Refinery CMS application is now running on edge and mounted to /. + Your new Refinery CMS application is now running on edge and mounted at '/' ============================================================================ SAY