trusty-cms 3.8.2 → 3.8.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +0 -1
- data/Gemfile.lock +1 -1
- data/app/helpers/scoped_helper.rb +1 -1
- data/app/models/trusty_cms/config.rb +2 -5
- data/config/application.rb +4 -4
- data/config/initializers/devise.rb +1 -1
- data/db/migrate/{001_create_radiant_tables.rb → 001_create_trusty_tables.rb} +1 -1
- data/db/migrate/20111016150725_extend_page_part_content_limit.rb +0 -2
- data/lib/configuration_extensions/configuration_extensions.rb +9 -9
- data/lib/tasks/extensions.rake +4 -4
- data/lib/tasks/framework.rake +28 -28
- data/lib/tasks/radiant_config.rake +4 -4
- data/lib/trusty_cms.rb +1 -1
- data/lib/trusty_cms/config/definition.rb +1 -1
- data/lib/trusty_cms/extension_loader.rb +1 -1
- data/lib/trusty_cms/extension_path.rb +1 -1
- data/lib/trusty_cms/initializer.rb +14 -14
- data/lib/trusty_cms/taggable.rb +1 -1
- data/lib/trusty_cms/task_support.rb +2 -2
- data/spec/dummy/config/application.rb +8 -8
- data/vendor/extensions/clipped-extension/lib/tasks/clipped_extension_tasks.rake +2 -2
- data/vendor/extensions/multi-site-extension/lib/tasks/scoped_admin_extension_tasks.rake +2 -2
- metadata +3 -103
- data/CONTRIBUTORS.md +0 -279
- data/Vagrantfile +0 -122
- data/app/mailers/password_mailer.rb +0 -10
- data/bin/ci/before_script +0 -10
- data/bin/trusty_test +0 -3
- data/lib/generators/extension/USAGE +0 -30
- data/lib/generators/extension/extension_generator.rb +0 -97
- data/lib/generators/extension/templates/README.md +0 -6
- data/lib/generators/extension/templates/RSpecRakefile +0 -109
- data/lib/generators/extension/templates/Rakefile +0 -25
- data/lib/generators/extension/templates/cucumber.yml +0 -1
- data/lib/generators/extension/templates/cucumber_env.rb +0 -11
- data/lib/generators/extension/templates/cucumber_paths.rb +0 -22
- data/lib/generators/extension/templates/en.yml +0 -3
- data/lib/generators/extension/templates/extension.rb +0 -21
- data/lib/generators/extension/templates/functional_test.rb +0 -15
- data/lib/generators/extension/templates/gemspec.rb +0 -29
- data/lib/generators/extension/templates/lib.rb +0 -8
- data/lib/generators/extension/templates/migration.rb +0 -9
- data/lib/generators/extension/templates/radiant_config.rb +0 -3
- data/lib/generators/extension/templates/routes.rb +0 -5
- data/lib/generators/extension/templates/spec.opts +0 -6
- data/lib/generators/extension/templates/spec_helper.rb +0 -42
- data/lib/generators/extension/templates/tasks.rake +0 -47
- data/lib/generators/extension/templates/test_helper.rb +0 -26
- data/lib/generators/extension_controller/USAGE +0 -36
- data/lib/generators/extension_controller/extension_controller_generator.rb +0 -84
- data/lib/generators/extension_controller/templates/controller.rb +0 -10
- data/lib/generators/extension_controller/templates/controller_spec.rb +0 -23
- data/lib/generators/extension_controller/templates/functional_test.rb +0 -11
- data/lib/generators/extension_controller/templates/helper.rb +0 -2
- data/lib/generators/extension_controller/templates/helper_spec.rb +0 -11
- data/lib/generators/extension_controller/templates/helper_test.rb +0 -4
- data/lib/generators/extension_controller/templates/view.html.erb +0 -2
- data/lib/generators/extension_controller/templates/view_spec.rb +0 -12
- data/lib/generators/extension_mailer/USAGE +0 -17
- data/lib/generators/extension_mailer/extension_mailer_generator.rb +0 -68
- data/lib/generators/extension_mailer/templates/fixture.erb +0 -3
- data/lib/generators/extension_mailer/templates/mailer.rb +0 -15
- data/lib/generators/extension_mailer/templates/unit_test.rb +0 -21
- data/lib/generators/extension_mailer/templates/view.erb +0 -3
- data/lib/generators/extension_migration/USAGE +0 -34
- data/lib/generators/extension_migration/extension_migration_generator.rb +0 -25
- data/lib/generators/extension_migration/templates/migration.rb +0 -11
- data/lib/generators/extension_model/USAGE +0 -35
- data/lib/generators/extension_model/extension_model_generator.rb +0 -68
- data/lib/generators/extension_model/templates/fixtures.yml +0 -19
- data/lib/generators/extension_model/templates/migration.rb +0 -16
- data/lib/generators/extension_model/templates/model.rb +0 -2
- data/lib/generators/extension_model/templates/model_spec.rb +0 -11
- data/lib/generators/extension_model/templates/unit_test.rb +0 -8
- data/lib/generators/generator_base_extension.rb +0 -18
- data/lib/generators/instance/instance_generator.rb +0 -148
- data/lib/generators/instance/templates/databases/db2.yml +0 -40
- data/lib/generators/instance/templates/databases/mysql.yml +0 -47
- data/lib/generators/instance/templates/databases/postgresql.yml +0 -44
- data/lib/generators/instance/templates/databases/sqlite3.yml +0 -16
- data/lib/generators/instance/templates/databases/sqlserver.yml +0 -21
- data/lib/generators/instance/templates/instance_boot.rb +0 -122
- data/lib/generators/instance/templates/instance_config.ru +0 -2
- data/lib/generators/instance/templates/instance_environment.rb +0 -93
- data/lib/generators/instance/templates/instance_gemfile +0 -78
- data/lib/generators/instance/templates/instance_generate +0 -6
- data/lib/generators/instance/templates/instance_radiant_config.rb +0 -16
- data/lib/generators/instance/templates/instance_rakefile +0 -3
- data/lib/generators/instance/templates/instance_routes.rb +0 -1
- data/lib/generators/language_extension/USAGE +0 -27
- data/lib/generators/language_extension/language_extension_generator.rb +0 -71
- data/lib/generators/language_extension/templates/README +0 -3
- data/lib/generators/language_extension/templates/RSpecRakefile +0 -123
- data/lib/generators/language_extension/templates/Rakefile +0 -25
- data/lib/generators/language_extension/templates/available_tags.yml +0 -553
- data/lib/generators/language_extension/templates/cucumber.yml +0 -1
- data/lib/generators/language_extension/templates/cucumber_env.rb +0 -16
- data/lib/generators/language_extension/templates/cucumber_paths.rb +0 -14
- data/lib/generators/language_extension/templates/extension.rb +0 -12
- data/lib/generators/language_extension/templates/functional_test.rb +0 -15
- data/lib/generators/language_extension/templates/gemspec.rb +0 -24
- data/lib/generators/language_extension/templates/lang.yml +0 -181
- data/lib/generators/language_extension/templates/lib.rb +0 -8
- data/lib/generators/language_extension/templates/spec.opts +0 -6
- data/lib/generators/language_extension/templates/spec_helper.rb +0 -36
- data/lib/generators/language_extension/templates/tasks.rake +0 -28
- data/lib/generators/language_extension/templates/test_helper.rb +0 -26
- data/lib/generators/trusty_cms/USAGE +0 -8
- data/lib/generators/trusty_cms/templates/Rakefile.erb +0 -7
- data/lib/generators/trusty_cms/templates/application.rb.erb +0 -149
- data/lib/generators/trusty_cms/templates/boot.rb.erb +0 -9
- data/lib/generators/trusty_cms/templates/config.ru.erb +0 -4
- data/lib/generators/trusty_cms/templates/database.yml.erb +0 -28
- data/lib/generators/trusty_cms/templates/environment.rb.erb +0 -5
- data/lib/generators/trusty_cms/templates/environments/development.rb.erb +0 -24
- data/lib/generators/trusty_cms/templates/environments/production.rb.erb +0 -26
- data/lib/generators/trusty_cms/templates/environments/test.rb.erb +0 -35
- data/lib/generators/trusty_cms/templates/initializers/secret_token.rb.erb +0 -13
- data/lib/generators/trusty_cms/templates/initializers/session_store.rb.erb +0 -8
- data/lib/generators/trusty_cms/templates/initializers/trusty_cms_config.rb.erb +0 -16
- data/lib/generators/trusty_cms/templates/preinitializer.rb.erb +0 -18
- data/lib/generators/trusty_cms/templates/routes.rb.erb +0 -0
- data/lib/generators/trusty_cms/trusty_cms_generator.rb +0 -32
@@ -1,17 +0,0 @@
|
|
1
|
-
Description:
|
2
|
-
Stubs out a new mailer and its views for the given extension.
|
3
|
-
Pass the mailer name, either CamelCased or under_scored,
|
4
|
-
and an optional list of emails as arguments.
|
5
|
-
|
6
|
-
This generates a mailer class in app/models, view templates in
|
7
|
-
app/views/mailer_name, a unit test in test/unit, and fixtures in
|
8
|
-
test/fixtures.
|
9
|
-
|
10
|
-
Example:
|
11
|
-
`./script/generate extension_mailer MyExt Notifications signup forgot_password invoice`
|
12
|
-
|
13
|
-
creates a Notifications mailer class, views, test, and fixtures:
|
14
|
-
Mailer: vendor/my_ext/app/models/notifications.rb
|
15
|
-
Views: vendor/my_ext/app/views/notifications/signup.erb [...]
|
16
|
-
Test: vendor/my_ext/test/unit/test/unit/notifications_test.rb
|
17
|
-
Fixtures: vendor/my_ext/test/fixtures/notifications/signup [...]
|
@@ -1,68 +0,0 @@
|
|
1
|
-
require 'rails_generator/base'
|
2
|
-
require 'rails_generator/generators/components/mailer/mailer_generator'
|
3
|
-
|
4
|
-
class ExtensionMailerGenerator < MailerGenerator
|
5
|
-
|
6
|
-
attr_accessor :extension_name
|
7
|
-
default_options :with_test_unit => false
|
8
|
-
|
9
|
-
def initialize(runtime_args, runtime_options = {})
|
10
|
-
runtime_args = runtime_args.dup
|
11
|
-
@extension_name = runtime_args.shift
|
12
|
-
super(runtime_args, runtime_options)
|
13
|
-
end
|
14
|
-
|
15
|
-
def manifest
|
16
|
-
if extension_uses_rspec?
|
17
|
-
rspec_manifest
|
18
|
-
else
|
19
|
-
super
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
def rspec_manifest
|
24
|
-
record do |m|
|
25
|
-
# Check for class naming collisions.
|
26
|
-
m.class_collisions class_path, class_name
|
27
|
-
|
28
|
-
# Mailer, view, test, and fixture directories.
|
29
|
-
m.directory File.join('app/models', class_path)
|
30
|
-
m.directory File.join('app/views', file_path)
|
31
|
-
|
32
|
-
# Mailer class and unit test.
|
33
|
-
m.template "mailer:mailer.rb", File.join('app/models', class_path, "#{file_name}.rb")
|
34
|
-
|
35
|
-
# View template and fixture for each action.
|
36
|
-
actions.each do |action|
|
37
|
-
relative_path = File.join(file_path, action)
|
38
|
-
view_path = File.join('app/views', "#{relative_path}.erb")
|
39
|
-
|
40
|
-
m.template "mailer:view.erb", view_path,
|
41
|
-
:assigns => { :action => action, :path => view_path }
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
def banner
|
47
|
-
"Usage: #{$0} #{spec.name} ExtensionName #{spec.name.camelize}Name [options]"
|
48
|
-
end
|
49
|
-
|
50
|
-
def extension_path
|
51
|
-
File.join('vendor', 'extensions', @extension_name.underscore)
|
52
|
-
end
|
53
|
-
|
54
|
-
def destination_root
|
55
|
-
File.join(Rails.root, extension_path)
|
56
|
-
end
|
57
|
-
|
58
|
-
def extension_uses_rspec?
|
59
|
-
File.exists?(File.join(destination_root, 'spec')) && !options[:with_test_unit]
|
60
|
-
end
|
61
|
-
|
62
|
-
def add_options!(opt)
|
63
|
-
opt.separator ''
|
64
|
-
opt.separator 'Options:'
|
65
|
-
opt.on("--with-test-unit",
|
66
|
-
"Use Test::Unit tests instead sof RSpec.") { |v| options[:with_test_unit] = v }
|
67
|
-
end
|
68
|
-
end
|
@@ -1,15 +0,0 @@
|
|
1
|
-
class <%= class_name %> < ActionMailer::Base
|
2
|
-
|
3
|
-
<% for action in actions -%>
|
4
|
-
|
5
|
-
def <%= action %>(sent_at = Time.now)
|
6
|
-
subject '<%= class_name %>#<%= action %>'
|
7
|
-
recipients ''
|
8
|
-
from ''
|
9
|
-
sent_on sent_at
|
10
|
-
|
11
|
-
body :greeting => 'Hi,'
|
12
|
-
end
|
13
|
-
<% end -%>
|
14
|
-
|
15
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
require File.dirname(__FILE__) + '<%= '/..' * class_nesting_depth %>/../test_helper'
|
2
|
-
|
3
|
-
class <%= class_name %>Test < ActionMailer::TestCase
|
4
|
-
tests <%= class_name %>
|
5
|
-
<% for action in actions -%>
|
6
|
-
def test_<%= action %>
|
7
|
-
@expected.subject = '<%= class_name %>#<%= action %>'
|
8
|
-
@expected.body = read_fixture('<%= action %>')
|
9
|
-
@expected.date = Time.now
|
10
|
-
|
11
|
-
assert_equal @expected.encoded, <%= class_name %>.create_<%= action %>(@expected.date).encoded
|
12
|
-
end
|
13
|
-
|
14
|
-
<% end -%>
|
15
|
-
<% if actions.blank? -%>
|
16
|
-
# replace this with your real tests
|
17
|
-
def test_truth
|
18
|
-
assert true
|
19
|
-
end
|
20
|
-
<% end -%>
|
21
|
-
end
|
@@ -1,34 +0,0 @@
|
|
1
|
-
Description:
|
2
|
-
The extension_migration generator creates a stub for a new migration for an
|
3
|
-
extension.
|
4
|
-
|
5
|
-
The generator takes the extension name, a migration name as its arguments,
|
6
|
-
and an optional list of attribute pairs as arguments. The migration name
|
7
|
-
may be given in CamelCase or under_score.
|
8
|
-
|
9
|
-
You can name your migration in either of these formats to generate add/remove
|
10
|
-
column lines from supplied attributes: AddColumnsToTable or RemoveColumnsFromTable
|
11
|
-
|
12
|
-
A migration class is generated in vendor/extensions/extension_name/db/migrate
|
13
|
-
prefixed by a timestamp of the current date and time.
|
14
|
-
|
15
|
-
Examples:
|
16
|
-
`./script/generate extension_migration MyExt AddSslFlag`
|
17
|
-
|
18
|
-
If the current date is May 14, 2008 and the current time 09:09:12, this creates the AddSslFlag migration
|
19
|
-
vendor/extensions/my_ext/db/migrate/20080514090912_add_ssl_flag.rb
|
20
|
-
|
21
|
-
`./script/generate migration MyExt AddTitleBodyToPost title:string body:text published:boolean`
|
22
|
-
|
23
|
-
This will create the AddTitleBodyToPost in vendor/extensions/my_ext/db/migrate/20080514090912_add_title_body_to_post.rb
|
24
|
-
with this in the Up migration:
|
25
|
-
|
26
|
-
add_column :posts, :title, :string
|
27
|
-
add_column :posts, :body, :text
|
28
|
-
add_column :posts, :published, :boolean
|
29
|
-
|
30
|
-
And this in the Down migration:
|
31
|
-
|
32
|
-
remove_column :posts, :published
|
33
|
-
remove_column :posts, :body
|
34
|
-
remove_column :posts, :title
|
@@ -1,25 +0,0 @@
|
|
1
|
-
require 'rails_generator/base'
|
2
|
-
require 'rails_generator/generators/components/migration/migration_generator'
|
3
|
-
|
4
|
-
class ExtensionMigrationGenerator < MigrationGenerator
|
5
|
-
|
6
|
-
attr_accessor :extension_name
|
7
|
-
|
8
|
-
def initialize(runtime_args, runtime_options = {})
|
9
|
-
runtime_args = runtime_args.dup
|
10
|
-
@extension_name = runtime_args.shift
|
11
|
-
super(runtime_args, runtime_options)
|
12
|
-
end
|
13
|
-
|
14
|
-
def banner
|
15
|
-
"Usage: #{$0} extension_migration ExtensionName MigrationName [field:type, field:type]"
|
16
|
-
end
|
17
|
-
|
18
|
-
def extension_path
|
19
|
-
File.join('vendor', 'extensions', @extension_name.underscore)
|
20
|
-
end
|
21
|
-
|
22
|
-
def destination_root
|
23
|
-
File.join(Rails.root, extension_path)
|
24
|
-
end
|
25
|
-
end
|
@@ -1,11 +0,0 @@
|
|
1
|
-
class <%= class_name.underscore.camelize %> < ActiveRecord::Migration[5.2]
|
2
|
-
def self.up<% attributes.each do |attribute| %>
|
3
|
-
<%= migration_action %>_column :<%= table_name %>, :<%= attribute.name %><% if migration_action == 'add' %>, :<%= attribute.type %><% end -%>
|
4
|
-
<%- end %>
|
5
|
-
end
|
6
|
-
|
7
|
-
def self.down<% attributes.reverse.each do |attribute| %>
|
8
|
-
<%= migration_action == 'add' ? 'remove' : 'add' %>_column :<%= table_name %>, :<%= attribute.name %><% if migration_action == 'remove' %>, :<%= attribute.type %><% end -%>
|
9
|
-
<%- end %>
|
10
|
-
end
|
11
|
-
end
|
@@ -1,35 +0,0 @@
|
|
1
|
-
Description:
|
2
|
-
The extension_model generator creates stubs for a new model for an
|
3
|
-
extension.
|
4
|
-
|
5
|
-
The generator takes the extension name and a model name as its arguments.
|
6
|
-
The model name may be given in CamelCase or under_score and should not be
|
7
|
-
suffixed with 'Model'.
|
8
|
-
|
9
|
-
As additional parameters, the generator will take attribute pairs
|
10
|
-
described by name and type. These attributes will be used to prepopulate
|
11
|
-
the migration to create the table for the model and give you a set of
|
12
|
-
predefined fixtures. You don't have to think up all attributes up front,
|
13
|
-
but it's a good idea of adding just the baseline of what's needed to start
|
14
|
-
really working with the resource.
|
15
|
-
|
16
|
-
The generator creates a model class in
|
17
|
-
vendor/extensions/extension_name/app/models, a test suite in
|
18
|
-
vendor/extensions/extension_name/test/unit, test fixtures in
|
19
|
-
vendor/extensions/extension_name/test/fixtures/singular_name.yml, and a
|
20
|
-
migration in vendor/extensions/extension_name/db/migrate.
|
21
|
-
|
22
|
-
Examples:
|
23
|
-
./script/generate extension_model MyExt account
|
24
|
-
|
25
|
-
This will create an Account model:
|
26
|
-
|
27
|
-
Model: vendor/extensions/my_ext/app/models/account.rb
|
28
|
-
Migration: vendor/extensions/my_ext/db/migrate/XXX_add_accounts.rb
|
29
|
-
Spec: vendor/extensions/my_ext/spec/models/account_spec.rb
|
30
|
-
Test: vendor/extensions/my_ext/test/unit/account_test.rb (if extension created with "--with-test-unit")
|
31
|
-
Fixtures: vendor/extensions/my_ext/test/fixtures/accounts.yml (if extension created with "--with-test-unit")
|
32
|
-
|
33
|
-
./script/generate extension_model MyExt post title:string body:text
|
34
|
-
|
35
|
-
Creates post model with predefined attributes.
|
@@ -1,68 +0,0 @@
|
|
1
|
-
require 'rails_generator/base'
|
2
|
-
require 'rails_generator/generators/components/model/model_generator'
|
3
|
-
|
4
|
-
class ExtensionModelGenerator < ModelGenerator
|
5
|
-
|
6
|
-
attr_accessor :extension_name
|
7
|
-
default_options :with_test_unit => false
|
8
|
-
|
9
|
-
def initialize(runtime_args, runtime_options = {})
|
10
|
-
runtime_args = runtime_args.dup
|
11
|
-
@extension_name = runtime_args.shift
|
12
|
-
super(runtime_args, runtime_options)
|
13
|
-
end
|
14
|
-
|
15
|
-
def manifest
|
16
|
-
if extension_uses_rspec?
|
17
|
-
rspec_manifest
|
18
|
-
else
|
19
|
-
super
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
def rspec_manifest
|
24
|
-
record do |m|
|
25
|
-
# Check for class naming collisions.
|
26
|
-
m.class_collisions class_path, class_name
|
27
|
-
|
28
|
-
# Model, spec, and fixture directories.
|
29
|
-
m.directory File.join('app/models', class_path)
|
30
|
-
m.directory File.join('spec/models', class_path)
|
31
|
-
# m.directory File.join('spec/fixtures', class_path)
|
32
|
-
|
33
|
-
# Model class, spec and fixtures.
|
34
|
-
m.template 'model:model.rb', File.join('app/models', class_path, "#{file_name}.rb")
|
35
|
-
# m.template 'model:fixtures.yml', File.join('spec/fixtures', class_path, "#{table_name}.yml")
|
36
|
-
m.template 'model_spec.rb', File.join('spec/models', class_path, "#{file_name}_spec.rb")
|
37
|
-
|
38
|
-
unless options[:skip_migration]
|
39
|
-
m.migration_template 'model:migration.rb', 'db/migrate', :assigns => {
|
40
|
-
:migration_name => "Create#{class_name.pluralize.gsub(/::/, '')}"
|
41
|
-
}, :migration_file_name => "create_#{file_path.gsub(/\//, '_').pluralize}"
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
def banner
|
47
|
-
"Usage: #{$0} extension_model ExtensionName ModelName [field:type, field:type]"
|
48
|
-
end
|
49
|
-
|
50
|
-
def extension_path
|
51
|
-
File.join('vendor', 'extensions', @extension_name.underscore)
|
52
|
-
end
|
53
|
-
|
54
|
-
def destination_root
|
55
|
-
File.join(Rails.root, extension_path)
|
56
|
-
end
|
57
|
-
|
58
|
-
def extension_uses_rspec?
|
59
|
-
File.exists?(File.join(destination_root, 'spec')) && !options[:with_test_unit]
|
60
|
-
end
|
61
|
-
|
62
|
-
def add_options!(opt)
|
63
|
-
opt.separator ''
|
64
|
-
opt.separator 'Options:'
|
65
|
-
opt.on("--with-test-unit",
|
66
|
-
"Use Test::Unit tests instead sof RSpec.") { |v| options[:with_test_unit] = v }
|
67
|
-
end
|
68
|
-
end
|
@@ -1,19 +0,0 @@
|
|
1
|
-
# Read about fixtures at http://ar.rubyonrails.org/classes/Fixtures.html
|
2
|
-
|
3
|
-
<% unless attributes.empty? -%>
|
4
|
-
one:
|
5
|
-
<% for attribute in attributes -%>
|
6
|
-
<%= attribute.name %>: <%= attribute.default %>
|
7
|
-
<% end -%>
|
8
|
-
|
9
|
-
two:
|
10
|
-
<% for attribute in attributes -%>
|
11
|
-
<%= attribute.name %>: <%= attribute.default %>
|
12
|
-
<% end -%>
|
13
|
-
<% else -%>
|
14
|
-
# one:
|
15
|
-
# column: value
|
16
|
-
#
|
17
|
-
# two:
|
18
|
-
# column: value
|
19
|
-
<% end -%>
|
@@ -1,16 +0,0 @@
|
|
1
|
-
class <%= migration_name %> < ActiveRecord::Migration[5.2]
|
2
|
-
def self.up
|
3
|
-
create_table :<%= table_name %> do |t|
|
4
|
-
<% for attribute in attributes -%>
|
5
|
-
t.<%= attribute.type %> :<%= attribute.name %>
|
6
|
-
<% end -%>
|
7
|
-
<% unless options[:skip_timestamps] %>
|
8
|
-
t.timestamps
|
9
|
-
<% end -%>
|
10
|
-
end
|
11
|
-
end
|
12
|
-
|
13
|
-
def self.down
|
14
|
-
drop_table :<%= table_name %>
|
15
|
-
end
|
16
|
-
end
|
@@ -1,11 +0,0 @@
|
|
1
|
-
require File.dirname(__FILE__) + '<%= '/..' * class_nesting_depth %>/../spec_helper'
|
2
|
-
|
3
|
-
describe <%= class_name %> do
|
4
|
-
before(:each) do
|
5
|
-
@<%= file_name %> = <%= class_name %>.new
|
6
|
-
end
|
7
|
-
|
8
|
-
it "should be valid" do
|
9
|
-
@<%= file_name %>.should be_valid
|
10
|
-
end
|
11
|
-
end
|
@@ -1,18 +0,0 @@
|
|
1
|
-
require 'rails_generator'
|
2
|
-
module TrustyCms
|
3
|
-
module GeneratorBaseExtension
|
4
|
-
def self.included(base)
|
5
|
-
base.class_eval {
|
6
|
-
alias_method :existing_migrations_without_extensions, :existing_migrations
|
7
|
-
alias_method :existing_migrations, :existing_migrations_with_extensions
|
8
|
-
}
|
9
|
-
end
|
10
|
-
|
11
|
-
def existing_migrations_with_extensions(file_name)
|
12
|
-
Dir.glob("#{destination_path(@migration_directory)}/[0-9]*_*.rb").grep(/[0-9]+_#{file_name}.rb$/)
|
13
|
-
end
|
14
|
-
|
15
|
-
end
|
16
|
-
end
|
17
|
-
|
18
|
-
Rails::Generator::Commands::Base.class_eval { include TrustyCms::GeneratorBaseExtension }
|
@@ -1,148 +0,0 @@
|
|
1
|
-
require 'rbconfig'
|
2
|
-
|
3
|
-
# Small addition to enable the enqueing of "bundle install"
|
4
|
-
class Rails::Generator::Commands::Create
|
5
|
-
def run_bundler(destination_root)
|
6
|
-
# thanks to http://spectator.in/2011/01/28/bundler-in-subshells/
|
7
|
-
bundler_vars = %w(BUNDLE_GEMFILE RUBYOPT )
|
8
|
-
command = %{"#{Gem.ruby}" -rubygems "#{Gem.bin_path('bundler', 'bundle')}" install --gemfile="#{File.join(File.expand_path(destination_root), 'Gemfile')}"}
|
9
|
-
begin
|
10
|
-
bundled_env = ENV.to_hash
|
11
|
-
bundler_vars.each{ |var| ENV.delete(var) }
|
12
|
-
print `#{command}`
|
13
|
-
ensure
|
14
|
-
ENV.replace(bundled_env)
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
|
19
|
-
class InstanceGenerator < Rails::Generator::Base
|
20
|
-
DEFAULT_SHEBANG = File.join(Config::CONFIG['bindir'],
|
21
|
-
Config::CONFIG['ruby_install_name'])
|
22
|
-
|
23
|
-
DATABASES = %w( mysql postgresql sqlite3 sqlserver db2 )
|
24
|
-
|
25
|
-
MYSQL_SOCKET_LOCATIONS = [
|
26
|
-
"/tmp/mysql.sock", # default
|
27
|
-
"/var/run/mysqld/mysqld.sock", # debian/gentoo
|
28
|
-
"/var/tmp/mysql.sock", # freebsd
|
29
|
-
"/var/lib/mysql/mysql.sock", # fedora
|
30
|
-
"/opt/local/lib/mysql/mysql.sock", # fedora
|
31
|
-
"/opt/local/var/run/mysqld/mysqld.sock", # mac + darwinports + mysql
|
32
|
-
"/opt/local/var/run/mysql4/mysqld.sock", # mac + darwinports + mysql4
|
33
|
-
"/opt/local/var/run/mysql5/mysqld.sock" # mac + darwinports + mysql5
|
34
|
-
]
|
35
|
-
|
36
|
-
default_options :db => "sqlite3", :shebang => DEFAULT_SHEBANG, :freeze => false
|
37
|
-
|
38
|
-
def initialize(runtime_args, runtime_options = {})
|
39
|
-
super
|
40
|
-
usage if args.empty?
|
41
|
-
usage("Databases supported for preconfiguration are: #{DATABASES.join(", ")}") if (options[:db] && !DATABASES.include?(options[:db]))
|
42
|
-
@destination_root = args.shift
|
43
|
-
end
|
44
|
-
|
45
|
-
def manifest
|
46
|
-
# The absolute location of the TrustyCms files
|
47
|
-
root = File.expand_path(TRUSTY_CMS_ROOT)
|
48
|
-
|
49
|
-
# Use /usr/bin/env if no special shebang was specified
|
50
|
-
script_options = { :chmod => 0755, :shebang => options[:shebang] == DEFAULT_SHEBANG ? nil : options[:shebang] }
|
51
|
-
dispatcher_options = { :chmod => 0755, :shebang => options[:shebang] }
|
52
|
-
|
53
|
-
record do |m|
|
54
|
-
# Root directory
|
55
|
-
m.directory ""
|
56
|
-
|
57
|
-
# Standard files and directories
|
58
|
-
base_dirs = %w(config config/environments config/initializers db log script public vendor/plugins vendor/extensions)
|
59
|
-
text_files = %w(CHANGELOG.md CONTRIBUTORS.md LICENSE.md INSTALL.md README.md)
|
60
|
-
environments = Dir["#{root}/config/environments/*.rb"]
|
61
|
-
bundler_compatibility_files = %w{config/preinitializer.rb}
|
62
|
-
schema_file = %w{db/schema.rb}
|
63
|
-
scripts = Dir["#{root}/script/**/*"].reject { |f| f =~ /(destroy|generate|plugin)$/ }
|
64
|
-
public_files = ["public/.htaccess"] + Dir["#{root}/public/**/*"]
|
65
|
-
test_files = ["config/cucumber.yml"]
|
66
|
-
|
67
|
-
files = base_dirs + text_files + environments + bundler_compatibility_files + schema_file + scripts + public_files + test_files
|
68
|
-
files.map! { |f| f = $1 if f =~ %r{^#{root}/(.+)$}; f }
|
69
|
-
files.sort!
|
70
|
-
|
71
|
-
files.each do |file|
|
72
|
-
case
|
73
|
-
when File.directory?("#{root}/#{file}")
|
74
|
-
m.directory file
|
75
|
-
when file =~ %r{^script/}
|
76
|
-
m.file radiant_root(file), file, script_options
|
77
|
-
when file =~ %r{^public/dispatch}
|
78
|
-
m.file radiant_root(file), file, dispatcher_options
|
79
|
-
else
|
80
|
-
m.file radiant_root(file), file
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
# script/generate
|
85
|
-
m.file "instance_generate", "script/generate", script_options
|
86
|
-
|
87
|
-
# database.yml and .htaccess
|
88
|
-
m.template "databases/#{options[:db]}.yml", "config/database.yml", :assigns => {
|
89
|
-
:app_name => File.basename(File.expand_path(@destination_root)),
|
90
|
-
:socket => options[:db] == "mysql" ? mysql_socket_location : nil
|
91
|
-
}
|
92
|
-
|
93
|
-
# Instance Gemfile
|
94
|
-
m.template "instance_gemfile", "Gemfile", :assigns => {
|
95
|
-
:radiant_version => TrustyCms::VERSION.to_s,
|
96
|
-
:db => options[:db]
|
97
|
-
}
|
98
|
-
|
99
|
-
# Instance Rakefile
|
100
|
-
m.file "instance_rakefile", "Rakefile"
|
101
|
-
|
102
|
-
# Config.ru is useful in rack-based situations like Pow
|
103
|
-
m.file "instance_config.ru", "config.ru"
|
104
|
-
|
105
|
-
# Instance Configurations
|
106
|
-
m.file "instance_routes.rb", "config/routes.rb"
|
107
|
-
m.template "instance_environment.rb", "config/environment.rb", :assigns => {
|
108
|
-
:radiant_environment => File.join(File.dirname(__FILE__), 'templates', radiant_root("config/environment.rb")),
|
109
|
-
:app_name => File.basename(File.expand_path(@destination_root))
|
110
|
-
}
|
111
|
-
m.template "instance_boot.rb", "config/boot.rb"
|
112
|
-
m.file "instance_radiant_config.rb", "config/initializers/radiant_config.rb"
|
113
|
-
|
114
|
-
# Run bundler
|
115
|
-
m.run_bundler @destination_root
|
116
|
-
|
117
|
-
m.readme radiant_root("INSTALL.md")
|
118
|
-
end
|
119
|
-
end
|
120
|
-
|
121
|
-
protected
|
122
|
-
|
123
|
-
def banner
|
124
|
-
"Usage: #{$0} /path/to/trusty_cms/app [options]"
|
125
|
-
end
|
126
|
-
|
127
|
-
def add_options!(opt)
|
128
|
-
opt.separator ''
|
129
|
-
opt.separator 'Options:'
|
130
|
-
opt.on("-r", "--ruby=path", String,
|
131
|
-
"Path to the Ruby binary of your choice (otherwise scripts use env, dispatchers current path).",
|
132
|
-
"Default: #{DEFAULT_SHEBANG}") { |v| options[:shebang] = v }
|
133
|
-
opt.on("-d", "--database=name", String,
|
134
|
-
"Preconfigure for selected database (options: #{DATABASES.join(", ")}).",
|
135
|
-
"Default: sqlite3") { |v| options[:db] = v }
|
136
|
-
end
|
137
|
-
|
138
|
-
def mysql_socket_location
|
139
|
-
RUBY_PLATFORM =~ /mswin32/ ? MYSQL_SOCKET_LOCATIONS.find { |f| File.exists?(f) } : nil
|
140
|
-
end
|
141
|
-
|
142
|
-
private
|
143
|
-
|
144
|
-
def radiant_root(filename = '')
|
145
|
-
File.join("..", "..", "..", "..", filename)
|
146
|
-
end
|
147
|
-
|
148
|
-
end
|