hobo 1.1.0 → 1.3.0.RC
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGES.txt +238 -287
- data/Rakefile +14 -31
- data/VERSION +1 -0
- data/{lib/hobo → app/controllers}/dev_controller.rb +6 -6
- data/app/controllers/dryml_support_controller.rb +13 -0
- data/{rails_generators/hobo_front_controller/templates → app/views/dev}/summary.dryml +7 -10
- data/bin/hobo +12 -144
- data/config/initializers/inflections.rb +3 -0
- data/config/routes.rb +6 -0
- data/{doctest → doctests}/hobo/lifecycles.rdoctest +40 -59
- data/{doctest → doctests/hobo}/model.rdoctest +33 -40
- data/{doctest → doctests/hobo}/multi_model_forms.rdoctest +15 -19
- data/{doctest → doctests/hobo}/scopes.rdoctest +27 -41
- data/doctests/prepare_testapp.rb +8 -0
- data/hobo.gemspec +26 -199
- data/lib/generators/hobo/activation_email.rb +11 -0
- data/lib/generators/hobo/admin_subsite/admin_subsite_generator.rb +35 -0
- data/lib/generators/hobo/admin_subsite/templates/admin.css +20 -0
- data/lib/generators/hobo/admin_subsite/templates/admin_tag_injection.erb +10 -0
- data/{rails_generators/hobo_admin_site → lib/generators/hobo/admin_subsite}/templates/application.dryml +0 -0
- data/{rails_generators/hobo_admin_site/templates/controller.rb → lib/generators/hobo/admin_subsite/templates/controller.rb.erb} +5 -5
- data/lib/generators/hobo/admin_subsite/templates/users_index.dryml +7 -0
- data/lib/generators/hobo/assets/assets_generator.rb +18 -0
- data/{rails_generators/hobo → lib/generators/hobo/assets}/templates/application.css +0 -0
- data/lib/generators/hobo/assets/templates/application.dryml.erb +9 -0
- data/{rails_generators/hobo → lib/generators/hobo/assets}/templates/dryml-support.js +2 -2
- data/lib/generators/hobo/assets/templates/dryml_taglibs_initializer.rb +1 -0
- data/lib/generators/hobo/assets/templates/en_injection.yml +19 -0
- data/{rails_generators/hobo → lib/generators/hobo/assets}/templates/guest.rb +1 -1
- data/lib/generators/hobo/controller.rb +35 -0
- data/lib/generators/hobo/controller/controller_generator.rb +6 -0
- data/lib/generators/hobo/controller/templates/controller.rb.erb +7 -0
- data/{rails_generators/hobo_front_controller → lib/generators/hobo/front_controller}/USAGE +0 -0
- data/lib/generators/hobo/front_controller/front_controller_generator.rb +55 -0
- data/{rails_generators/hobo_front_controller/templates/controller.rb → lib/generators/hobo/front_controller/templates/controller.rb.erb} +0 -0
- data/{rails_generators/hobo_front_controller → lib/generators/hobo/front_controller}/templates/index.dryml +6 -12
- data/lib/generators/hobo/i18n/i18n_generator.rb +35 -0
- data/lib/generators/hobo/i18n/templates/app.de.yml +30 -0
- data/lib/generators/hobo/i18n/templates/app.en.yml +25 -0
- data/lib/generators/hobo/i18n/templates/app.es.yml +31 -0
- data/lib/generators/hobo/i18n/templates/app.fr.yml +26 -0
- data/lib/generators/hobo/i18n/templates/app.it.yml +28 -0
- data/lib/generators/hobo/i18n/templates/app.pt-PT.yml +25 -0
- data/lib/generators/hobo/i18n/templates/app.ru.yml +24 -0
- data/lib/generators/hobo/i18n/templates/hobo.de.yml +204 -0
- data/lib/generators/hobo/i18n/templates/hobo.en.yml +195 -0
- data/lib/generators/hobo/i18n/templates/hobo.es.yml +202 -0
- data/lib/generators/hobo/i18n/templates/hobo.fr.yml +195 -0
- data/lib/generators/hobo/i18n/templates/hobo.it.yml +202 -0
- data/lib/generators/hobo/i18n/templates/hobo.pt-PT.yml +196 -0
- data/lib/generators/hobo/i18n/templates/hobo.ru.yml +200 -0
- data/lib/generators/hobo/invite_only.rb +18 -0
- data/lib/generators/hobo/model/USAGE +19 -0
- data/lib/generators/hobo/model/model_generator.rb +11 -0
- data/{rails_generators/hobo_model/templates/model.rb → lib/generators/hobo/model/templates/model_injection.rb.erb} +0 -2
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/USAGE +0 -0
- data/lib/generators/hobo/rapid/rapid_generator.rb +24 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/IE7.js +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/blank.gif +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/hobo-rapid.css +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/hobo-rapid.js +65 -65
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/ie7-recalc.js +21 -21
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/lowpro.js +31 -31
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/reset.css +1 -1
- data/lib/generators/hobo/rapid/templates/themes/clean-sidemenu/public/images/100-ACD3E6-DBE1E5-H.png +0 -0
- data/lib/generators/hobo/rapid/templates/themes/clean-sidemenu/public/images/100-DBE1E5-FCFEF5-H.png +0 -0
- data/lib/generators/hobo/rapid/templates/themes/clean-sidemenu/public/images/300-3B5F87-ACD3E6-H.png +0 -0
- data/{rails_generators/hobo_rapid/templates/themes/clean → lib/generators/hobo/rapid/templates/themes/clean-sidemenu}/public/images/spinner.gif +0 -0
- data/lib/generators/hobo/rapid/templates/themes/clean-sidemenu/public/stylesheets/clean-sidemenu.css +81 -0
- data/lib/generators/hobo/rapid/templates/themes/clean-sidemenu/views/clean-sidemenu.dryml +30 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/101-3B5F87-ACD3E6.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/30-3E547A-242E42.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/30-DBE1E5-FCFEF5.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/300-ACD3E6-fff.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/50-ACD3E6-fff.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/fieldbg.gif +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/pencil.png +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/images/small_close.png +0 -0
- data/lib/generators/hobo/rapid/templates/themes/clean/public/images/spinner.gif +0 -0
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/stylesheets/clean.css +16 -16
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/public/stylesheets/rapid-ui.css +3 -3
- data/{rails_generators/hobo_rapid → lib/generators/hobo/rapid}/templates/themes/clean/views/clean.dryml +1 -1
- data/lib/generators/hobo/resource/resource_generator.rb +23 -0
- data/lib/generators/hobo/routes/USAGE +9 -0
- data/lib/generators/hobo/routes/router.rb +115 -0
- data/lib/generators/hobo/routes/routes_generator.rb +40 -0
- data/lib/generators/hobo/routes/templates/hobo_routes.rb.erb +33 -0
- data/lib/generators/hobo/setup_wizard/USAGE +4 -0
- data/lib/generators/hobo/setup_wizard/setup_wizard_generator.rb +274 -0
- data/lib/generators/hobo/subsite.rb +48 -0
- data/lib/generators/hobo/subsite/subsite_generator.rb +16 -0
- data/{rails_generators/hobo_subsite → lib/generators/hobo/subsite}/templates/application.dryml +0 -0
- data/{rails_generators/hobo_subsite/templates/controller.rb → lib/generators/hobo/subsite/templates/controller.rb.erb} +1 -1
- data/lib/generators/hobo/subsite_taglib/subsite_taglib_generator.rb +16 -0
- data/{rails_generators/hobo_admin_site/templates/site_taglib.dryml → lib/generators/hobo/subsite_taglib/templates/taglib.dryml.erb} +9 -10
- data/lib/generators/hobo/taglib.rb +12 -0
- data/lib/generators/hobo/test_framework/test_framework_generator.rb +72 -0
- data/lib/generators/hobo/test_options.rb +19 -0
- data/{rails_generators/hobo_user_controller → lib/generators/hobo/user_controller}/templates/accept_invitation.dryml +0 -0
- data/lib/generators/hobo/user_controller/templates/controller.rb.erb +31 -0
- data/lib/generators/hobo/user_controller/user_controller_generator.rb +25 -0
- data/lib/generators/hobo/user_mailer/templates/activation.erb +9 -0
- data/{rails_generators/hobo_user_model → lib/generators/hobo/user_mailer}/templates/forgot_password.erb +2 -2
- data/{rails_generators/hobo_user_model → lib/generators/hobo/user_mailer}/templates/invite.erb +2 -2
- data/lib/generators/hobo/user_mailer/templates/mailer.rb.erb +25 -0
- data/lib/generators/hobo/user_mailer/user_mailer_generator.rb +33 -0
- data/lib/generators/hobo/user_model/USAGE +12 -0
- data/{rails_generators/hobo_user_model/templates/model.rb → lib/generators/hobo/user_model/templates/model_injection.rb.erb} +40 -20
- data/lib/generators/hobo/user_model/user_model_generator.rb +23 -0
- data/lib/generators/hobo/user_resource/user_resource_generator.rb +27 -0
- data/lib/hobo.rb +29 -129
- data/lib/hobo/controller.rb +37 -47
- data/lib/hobo/controller/authentication_support.rb +109 -0
- data/lib/hobo/{model_controller.rb → controller/model.rb} +71 -79
- data/lib/hobo/{user_controller.rb → controller/user.rb} +59 -49
- data/lib/hobo/engine.rb +80 -0
- data/lib/hobo/extensions/action_controller/hobo_methods.rb +44 -0
- data/lib/hobo/extensions/action_mailer/helper.rb +38 -0
- data/lib/{action_view_extensions/helpers → hobo/extensions/action_view}/tag_helper.rb +5 -2
- data/lib/hobo/extensions/action_view/translation_helper.rb +25 -0
- data/lib/hobo/extensions/active_model/name.rb +16 -0
- data/lib/hobo/extensions/active_model/translation.rb +35 -0
- data/lib/{active_record/association_collection.rb → hobo/extensions/active_record/associations/collection.rb} +8 -17
- data/lib/{active_record/association_proxy.rb → hobo/extensions/active_record/associations/proxy.rb} +6 -7
- data/lib/hobo/extensions/active_record/associations/reflection.rb +23 -0
- data/lib/hobo/extensions/active_record/associations/scope.rb +35 -0
- data/lib/hobo/extensions/active_record/hobo_methods.rb +11 -0
- data/lib/hobo/extensions/active_record/permissions.rb +159 -0
- data/lib/hobo/extensions/active_record/relation_with_origin.rb +28 -0
- data/lib/hobo/extensions/array.rb +27 -0
- data/lib/hobo/extensions/enumerable.rb +12 -0
- data/lib/hobo/extensions/i18n.rb +17 -0
- data/lib/hobo/{hobo_helper.rb → helper.rb} +58 -31
- data/lib/hobo/helper/translations.rb +54 -0
- data/lib/hobo/helper/translations/normalizer.rb +39 -0
- data/lib/hobo/model.rb +61 -95
- data/lib/hobo/model/accessible_associations.rb +178 -0
- data/lib/hobo/{find_for.rb → model/find_for.rb} +17 -17
- data/lib/hobo/model/guest.rb +25 -0
- data/lib/hobo/model/include_in_save.rb +55 -0
- data/lib/hobo/model/lifecycles.rb +119 -0
- data/lib/hobo/model/lifecycles/actions.rb +146 -0
- data/lib/hobo/model/lifecycles/creator.rb +74 -0
- data/lib/hobo/model/lifecycles/lifecycle.rb +243 -0
- data/lib/hobo/model/lifecycles/state.rb +22 -0
- data/lib/hobo/model/lifecycles/transition.rb +70 -0
- data/lib/hobo/model/permissions.rb +448 -0
- data/lib/hobo/model/scopes.rb +38 -0
- data/lib/hobo/model/scopes/apply_scopes.rb +21 -0
- data/lib/hobo/model/scopes/automatic_scopes.rb +428 -0
- data/lib/hobo/model/user_base.rb +184 -0
- data/lib/hobo/model/view_hints.rb +123 -0
- data/{rapid_generators → lib/hobo/rapid/generators}/rapid/cards.dryml.erb +2 -2
- data/{rapid_generators → lib/hobo/rapid/generators}/rapid/forms.dryml.erb +3 -3
- data/{rapid_generators → lib/hobo/rapid/generators}/rapid/pages.dryml.erb +38 -51
- data/lib/hobo/rapid/helper.rb +166 -0
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid.dryml +6 -5
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_core.dryml +286 -118
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_document_tags.dryml +2 -2
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_editing.dryml +45 -45
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_forms.dryml +190 -158
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_generics.dryml +12 -9
- data/lib/hobo/rapid/taglibs/rapid_i18n.dryml +107 -0
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_lifecycles.dryml +7 -7
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_navigation.dryml +15 -15
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_pages.dryml +37 -36
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_plus.dryml +107 -43
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_summary.dryml +28 -57
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_support.dryml +9 -9
- data/{taglibs → lib/hobo/rapid/taglibs}/rapid_user_pages.dryml +41 -40
- data/lib/hobo/routes.rb +31 -0
- data/{doctest → test/doctest}/hobo/hobo_helper.rdoctest +11 -11
- data/test/irt/generators/admin_subsite.irt +27 -0
- data/test/irt/generators/assets.irt +16 -0
- data/test/irt/generators/controller.irt +6 -0
- data/test/irt/generators/front_controller.irt +30 -0
- data/test/irt/generators/helper.rb +31 -0
- data/test/irt/generators/model.irt +28 -0
- data/test/irt/generators/partials/_account_user_model_tests.rb +21 -0
- data/test/irt/generators/partials/_accounts_users_controller_tests.rb +15 -0
- data/test/irt/generators/partials/_default_user_model_tests.rb +21 -0
- data/test/irt/generators/partials/_default_users_controller_tests.rb +16 -0
- data/test/irt/generators/partials/_house_controller_tests.rb +15 -0
- data/test/irt/generators/partials/_house_model_tests.rb +18 -0
- data/test/irt/generators/partials/_subsite_taglib_admin.rb +4 -0
- data/test/irt/generators/partials/_subsite_taglib_admin_invite_only.rb +3 -0
- data/test/irt/generators/partials/_subsite_taglib_noopt.rb +4 -0
- data/test/irt/generators/partials/_subsite_taglib_variables.rb +27 -0
- data/test/irt/generators/partials/_user_mailer_tests.rb +19 -0
- data/test/irt/generators/rapid.irt +29 -0
- data/test/irt/generators/resource.irt +8 -0
- data/test/irt/generators/subsite.irt +52 -0
- data/test/irt/generators/subsite_taglib.irt +23 -0
- data/test/irt/generators/test_framework.irt +62 -0
- data/test/irt/generators/user_controller.irt +10 -0
- data/test/irt/generators/user_mailer.irt +20 -0
- data/test/irt/generators/user_model.irt +10 -0
- data/test/irt/generators/user_resource.irt +14 -0
- data/test/irt/readme.txt +7 -0
- data/test/permissions/models/models.rb +27 -24
- data/test/permissions/test_permissions.rb +104 -104
- metadata +239 -217
- data/lib/active_record/association_reflection.rb +0 -20
- data/lib/active_record/viewhints_validations_interceptor.rb +0 -9
- data/lib/hobo/accessible_associations.rb +0 -183
- data/lib/hobo/authentication_support.rb +0 -131
- data/lib/hobo/generator.rb +0 -26
- data/lib/hobo/guest.rb +0 -25
- data/lib/hobo/include_in_save.rb +0 -55
- data/lib/hobo/lifecycles.rb +0 -137
- data/lib/hobo/lifecycles/actions.rb +0 -142
- data/lib/hobo/lifecycles/creator.rb +0 -72
- data/lib/hobo/lifecycles/lifecycle.rb +0 -249
- data/lib/hobo/lifecycles/state.rb +0 -22
- data/lib/hobo/lifecycles/transition.rb +0 -70
- data/lib/hobo/model_router.rb +0 -290
- data/lib/hobo/permissions.rb +0 -451
- data/lib/hobo/permissions/associations.rb +0 -175
- data/lib/hobo/rapid_helper.rb +0 -157
- data/lib/hobo/scopes.rb +0 -43
- data/lib/hobo/scopes/apply_scopes.rb +0 -23
- data/lib/hobo/scopes/association_proxy_extensions.rb +0 -62
- data/lib/hobo/scopes/automatic_scopes.rb +0 -421
- data/lib/hobo/scopes/named_scope_extensions.rb +0 -39
- data/lib/hobo/tasks/rails.rb +0 -4
- data/lib/hobo/translations.rb +0 -93
- data/lib/hobo/undefined_access_error.rb +0 -5
- data/lib/hobo/user.rb +0 -182
- data/lib/hobo/view_hints.rb +0 -115
- data/rails/init.rb +0 -10
- data/rails_generators/hobo/USAGE +0 -4
- data/rails_generators/hobo/hobo_generator.rb +0 -53
- data/rails_generators/hobo/templates/application.dryml +0 -1
- data/rails_generators/hobo/templates/initializer.rb +0 -2
- data/rails_generators/hobo_admin_site/USAGE +0 -16
- data/rails_generators/hobo_admin_site/hobo_admin_site_generator.rb +0 -45
- data/rails_generators/hobo_admin_site/templates/admin.css +0 -2
- data/rails_generators/hobo_admin_site/templates/users_index.dryml +0 -5
- data/rails_generators/hobo_front_controller/hobo_front_controller_generator.rb +0 -95
- data/rails_generators/hobo_front_controller/templates/functional_test.rb +0 -8
- data/rails_generators/hobo_front_controller/templates/helper.rb +0 -2
- data/rails_generators/hobo_model/USAGE +0 -25
- data/rails_generators/hobo_model/hobo_model_generator.rb +0 -43
- data/rails_generators/hobo_model/templates/fixtures.yml +0 -6
- data/rails_generators/hobo_model/templates/hints.rb +0 -7
- data/rails_generators/hobo_model/templates/unit_test.rb +0 -8
- data/rails_generators/hobo_model_controller/USAGE +0 -30
- data/rails_generators/hobo_model_controller/hobo_model_controller_generator.rb +0 -46
- data/rails_generators/hobo_model_controller/templates/controller.rb +0 -7
- data/rails_generators/hobo_model_controller/templates/functional_test.rb +0 -8
- data/rails_generators/hobo_model_controller/templates/helper.rb +0 -2
- data/rails_generators/hobo_model_resource/USAGE +0 -38
- data/rails_generators/hobo_model_resource/hobo_model_resource_generator.rb +0 -73
- data/rails_generators/hobo_model_resource/templates/controller.rb +0 -7
- data/rails_generators/hobo_model_resource/templates/functional_test.rb +0 -8
- data/rails_generators/hobo_model_resource/templates/helper.rb +0 -2
- data/rails_generators/hobo_rapid/hobo_rapid_generator.rb +0 -94
- data/rails_generators/hobo_subsite/USAGE +0 -16
- data/rails_generators/hobo_subsite/hobo_subsite_generator.rb +0 -73
- data/rails_generators/hobo_subsite/templates/site_taglib.dryml +0 -13
- data/rails_generators/hobo_user_controller/USAGE +0 -34
- data/rails_generators/hobo_user_controller/hobo_user_controller_generator.rb +0 -65
- data/rails_generators/hobo_user_controller/templates/controller.rb +0 -29
- data/rails_generators/hobo_user_controller/templates/functional_test.rb +0 -8
- data/rails_generators/hobo_user_controller/templates/helper.rb +0 -2
- data/rails_generators/hobo_user_model/USAGE +0 -16
- data/rails_generators/hobo_user_model/hobo_user_model_generator.rb +0 -46
- data/rails_generators/hobo_user_model/templates/fixtures.yml +0 -19
- data/rails_generators/hobo_user_model/templates/mailer.rb +0 -29
- data/rails_generators/hobo_user_model/templates/unit_test.rb +0 -8
- data/script/destroy +0 -14
- data/script/generate +0 -14
- data/taglibs/rapid_translations.dryml +0 -36
- data/tasks/environments.rake +0 -19
- data/tasks/hobo_tasks.rake +0 -58
- data/test/generators/test_generator_helper.rb +0 -29
- data/test/generators/test_helper.rb +0 -1
- data/test/generators/test_hobo_model_controller_generator.rb +0 -56
@@ -0,0 +1,48 @@
|
|
1
|
+
require 'fileutils'
|
2
|
+
module Generators
|
3
|
+
module Hobo
|
4
|
+
Subsite = classy_module do
|
5
|
+
|
6
|
+
include Generators::Hobo::InviteOnly
|
7
|
+
include Generators::Hobo::Taglib
|
8
|
+
|
9
|
+
class_option :make_front_site,
|
10
|
+
:type => :boolean,
|
11
|
+
:desc => "Rename application.dryml to front_site.dryml"
|
12
|
+
|
13
|
+
# check_class_collision :suffix => 'SiteController'
|
14
|
+
|
15
|
+
def move_and_generate_files
|
16
|
+
if options[:make_front_site]
|
17
|
+
unless can_mv_application_to_front_site?
|
18
|
+
say "Cannot rename application.dryml to #{file_name}_site.dryml"
|
19
|
+
exit 1
|
20
|
+
end
|
21
|
+
say "Renaming app/views/taglibs/application.dryml to app/views/taglibs/front_site.dryml" \
|
22
|
+
unless options[:quiet]
|
23
|
+
unless options[:pretend]
|
24
|
+
FileUtils.mv('app/views/taglibs/application.dryml', "app/views/taglibs/front_site.dryml")
|
25
|
+
copy_file "application.dryml", 'app/views/taglibs/application.dryml'
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
template "controller.rb.erb", File.join('app/controllers', file_name, "#{file_name}_site_controller.rb")
|
30
|
+
end
|
31
|
+
|
32
|
+
hook_for :test_framework, :as => :controller do | instance, controller_test |
|
33
|
+
instance.invoke controller_test, ["#{instance.name}_site"]
|
34
|
+
end
|
35
|
+
|
36
|
+
private
|
37
|
+
|
38
|
+
def subsite_name
|
39
|
+
class_name
|
40
|
+
end
|
41
|
+
|
42
|
+
def can_mv_application_to_front_site?
|
43
|
+
File.exist?('app/views/taglibs/application.dryml') && !File.exist?('app/views/taglibs/front_site.dryml')
|
44
|
+
end
|
45
|
+
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module Hobo
|
2
|
+
class SubsiteGenerator < Rails::Generators::NamedBase
|
3
|
+
source_root File.expand_path('../templates', __FILE__)
|
4
|
+
|
5
|
+
def self.banner
|
6
|
+
"rails generate hobo:subsite NAME [options]"
|
7
|
+
end
|
8
|
+
|
9
|
+
include Generators::Hobo::Subsite
|
10
|
+
|
11
|
+
def generate_site_taglib
|
12
|
+
invoke 'hobo:subsite_taglib', [name], options
|
13
|
+
end
|
14
|
+
|
15
|
+
end
|
16
|
+
end
|
data/{rails_generators/hobo_subsite → lib/generators/hobo/subsite}/templates/application.dryml
RENAMED
File without changes
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module Hobo
|
2
|
+
class SubsiteTaglibGenerator < Rails::Generators::NamedBase
|
3
|
+
source_root File.expand_path('../templates', __FILE__)
|
4
|
+
include Generators::Hobo::InviteOnly
|
5
|
+
include Generators::Hobo::Taglib
|
6
|
+
|
7
|
+
def self.banner
|
8
|
+
"rails generate hobo:subsite_taglib NAME [options]"
|
9
|
+
end
|
10
|
+
|
11
|
+
def generate_taglib
|
12
|
+
template "taglib.dryml.erb", File.join('app/views/taglibs', "#{file_name}_site.dryml")
|
13
|
+
end
|
14
|
+
|
15
|
+
end
|
16
|
+
end
|
@@ -1,32 +1,31 @@
|
|
1
|
-
<!-- Tag definitions for the <%=
|
2
|
-
|
3
|
-
|
4
|
-
<include src="rapid" plugin="hobo"/>
|
1
|
+
<!-- Tag definitions for the <%= file_name %> subsite -->
|
2
|
+
|
3
|
+
<include src="rapid" gem="hobo"/>
|
5
4
|
|
6
5
|
<include src="taglibs/auto/<%= file_name %>/rapid/cards"/>
|
7
6
|
<include src="taglibs/auto/<%= file_name %>/rapid/pages"/>
|
8
7
|
<include src="taglibs/auto/<%= file_name %>/rapid/forms"/>
|
9
8
|
|
10
9
|
<set-theme name="clean"/>
|
11
|
-
<% end -%>
|
12
10
|
|
13
|
-
|
11
|
+
<% if options[:admin]%>
|
14
12
|
|
15
13
|
<extend tag="page">
|
16
14
|
<old-page merge>
|
17
15
|
<append-stylesheets:>
|
18
|
-
<stylesheet name="
|
16
|
+
<stylesheet name="<%= file_name %>"/>
|
19
17
|
</append-stylesheets:>
|
20
18
|
<footer:>
|
21
|
-
<a href="#{base_url}/">View Site</a>
|
19
|
+
<a href="#{base_url}/"><t key="hobo.subsite.back_link">View Site</t></a>
|
22
20
|
</footer:>
|
23
21
|
</old-page>
|
24
22
|
</extend>
|
23
|
+
<% end -%>
|
25
24
|
<% if invite_only? -%>
|
26
25
|
|
27
|
-
<extend tag="card" for="
|
26
|
+
<extend tag="card" for="<%= options[:user_resource_name].camelcase %>">
|
28
27
|
<old-card merge>
|
29
28
|
<append-header:><%%= h this.state.titleize %></append-header:>
|
30
29
|
</old-card>
|
31
30
|
</extend>
|
32
|
-
<% end -%>
|
31
|
+
<% end -%>
|
@@ -0,0 +1,72 @@
|
|
1
|
+
require 'bundler/cli'
|
2
|
+
module Hobo
|
3
|
+
class TestFrameworkGenerator < Rails::Generators::NamedBase
|
4
|
+
|
5
|
+
include Generators::Hobo::TestOptions
|
6
|
+
|
7
|
+
FRAMEWORKS = %w[test_unit rspec shoulda rspec_with_shoulda]
|
8
|
+
|
9
|
+
def self.banner
|
10
|
+
"rails generate hobo:test_framework NAME [options]"
|
11
|
+
end
|
12
|
+
|
13
|
+
def initialize(*)
|
14
|
+
super
|
15
|
+
@finalize_hooks = []
|
16
|
+
end
|
17
|
+
|
18
|
+
def setup_framework
|
19
|
+
if FRAMEWORKS.include?(name)
|
20
|
+
eval 'setup_' + name
|
21
|
+
else
|
22
|
+
say "'#{name}' is not supported. You should configure it manually."
|
23
|
+
exit 1
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def fixture_replacement_installation
|
28
|
+
return if options[:fixture_replacement].blank?
|
29
|
+
gem options[:fixture_replacement], :group => :test
|
30
|
+
end
|
31
|
+
|
32
|
+
def finalize_installation
|
33
|
+
# add the block only if it's not the default
|
34
|
+
add_generators_block unless (name == 'test_unit' && options[:fixtures] && options[:fixture_replacement].blank?)
|
35
|
+
invoke Bundler::CLI, :update if options[:update] && @should_update
|
36
|
+
@finalize_hooks.each {|h| h.call }
|
37
|
+
end
|
38
|
+
|
39
|
+
private
|
40
|
+
|
41
|
+
def setup_test_unit
|
42
|
+
end
|
43
|
+
|
44
|
+
def setup_rspec
|
45
|
+
gem 'rspec-rails', '>= 2.5.0', :group => [:test, :development]
|
46
|
+
@should_update = true
|
47
|
+
return unless options[:update]
|
48
|
+
@finalize_hooks << lambda {say "Finalizing rspec installation..."; system 'rails g rspec:install'}
|
49
|
+
end
|
50
|
+
|
51
|
+
def setup_shoulda
|
52
|
+
gem 'shoulda', :group => :test
|
53
|
+
@should_update = true
|
54
|
+
end
|
55
|
+
|
56
|
+
def setup_rspec_with_shoulda
|
57
|
+
setup_rspec
|
58
|
+
setup_shoulda
|
59
|
+
end
|
60
|
+
|
61
|
+
def add_generators_block
|
62
|
+
n = name == 'rspec_with_shoulda' ? 'rspec' : name
|
63
|
+
block = "\n config.generators do |g|"
|
64
|
+
block << "\n g.test_framework :#{n}, :fixtures => #{options[:fixtures].inspect}" if !options[:fixtures] || name != 'test_unit'
|
65
|
+
block << "\n g.fallbacks[:#{n}] = :test_unit" unless name == 'test_unit'
|
66
|
+
block << "\n g.fixture_replacement = :#{options[:fixture_replacement]}" unless options[:fixture_replacement].blank?
|
67
|
+
block << "\n end\n"
|
68
|
+
environment block
|
69
|
+
end
|
70
|
+
|
71
|
+
end
|
72
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module Generators
|
2
|
+
module Hobo
|
3
|
+
TestOptions = classy_module do
|
4
|
+
|
5
|
+
class_option :test_framework, :type => :string,
|
6
|
+
:desc => "Use a specific test framework"
|
7
|
+
|
8
|
+
class_option :fixtures, :type => :boolean,
|
9
|
+
:desc => "Add the fixture option to the test framework", :default => true
|
10
|
+
|
11
|
+
class_option :fixture_replacement, :type => :string,
|
12
|
+
:desc => "Use a specific fixture replacement"
|
13
|
+
|
14
|
+
class_option :update, :type => :boolean,
|
15
|
+
:desc => "Run bundle update to install the missing gems"
|
16
|
+
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
File without changes
|
@@ -0,0 +1,31 @@
|
|
1
|
+
class <%= class_name %>Controller < ApplicationController
|
2
|
+
|
3
|
+
hobo_user_controller
|
4
|
+
|
5
|
+
auto_actions :all, :except => [ :index, :new, :create ]
|
6
|
+
|
7
|
+
# Normally, users should be created via the user lifecycle, except
|
8
|
+
# for the initial user created via the form on the front screen on
|
9
|
+
# first run. This method creates the initial user.
|
10
|
+
def create
|
11
|
+
hobo_create do
|
12
|
+
if valid?
|
13
|
+
self.current_user = this
|
14
|
+
flash[:notice] = t("hobo.messages.you_are_site_admin", :default=>"You are now the site administrator")
|
15
|
+
redirect_to home_page
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
<% if invite_only? -%>
|
20
|
+
|
21
|
+
def do_accept_invitation
|
22
|
+
do_transition_action :accept_invitation do
|
23
|
+
if this.valid?
|
24
|
+
self.current_user = this
|
25
|
+
flash[:notice] = t("hobo.messages.you_signed_up", :default=>"You have signed up")
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
<% end -%>
|
30
|
+
|
31
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module Hobo
|
2
|
+
class UserControllerGenerator < Rails::Generators::NamedBase
|
3
|
+
source_root File.expand_path('../templates', __FILE__)
|
4
|
+
|
5
|
+
# overrides the default
|
6
|
+
argument :name, :type => :string, :default => 'users', :optional => true
|
7
|
+
|
8
|
+
include Generators::Hobo::Controller
|
9
|
+
include Generators::Hobo::InviteOnly
|
10
|
+
|
11
|
+
def self.banner
|
12
|
+
"rails generate hobo:user_controller [NAME=users] [options]"
|
13
|
+
end
|
14
|
+
|
15
|
+
def generate_controller
|
16
|
+
template 'controller.rb.erb', File.join('app/controllers',"#{file_path}_controller.rb")
|
17
|
+
end
|
18
|
+
|
19
|
+
def generate_accept_invitation
|
20
|
+
return unless invite_only?
|
21
|
+
template "accept_invitation.dryml", File.join('app/views', file_path, "accept_invitation.dryml")
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
@@ -1,9 +1,9 @@
|
|
1
|
-
<%%=
|
1
|
+
<%%= @<%= name.underscore -%> %>,
|
2
2
|
|
3
3
|
If you have forgotten your password for <%%= @app_name %>, you can choose
|
4
4
|
a new one by clicking on this link:
|
5
5
|
|
6
|
-
<%%= <%= name -%>_reset_password_url :
|
6
|
+
<%%= <%= name.underscore -%>_reset_password_url :id => @<%= name.underscore -%>, :key => @key %>
|
7
7
|
|
8
8
|
Thank you,
|
9
9
|
|
data/{rails_generators/hobo_user_model → lib/generators/hobo/user_mailer}/templates/invite.erb
RENAMED
@@ -1,8 +1,8 @@
|
|
1
|
-
<%%=
|
1
|
+
<%%= @<%= name.underscore %> %>,
|
2
2
|
|
3
3
|
You have been invited to join <%%= @app_name %>. If you wish to accept, please click on the following link
|
4
4
|
|
5
|
-
<%%=
|
5
|
+
<%%= <%= name.underscore %>_accept_invitation_url :id => @<%= name.underscore %>, :key => @key %>
|
6
6
|
|
7
7
|
Thank you,
|
8
8
|
|
@@ -0,0 +1,25 @@
|
|
1
|
+
class <%= class_name -%>Mailer < ActionMailer::Base
|
2
|
+
default :from => "no-reply@#{host}"
|
3
|
+
|
4
|
+
def forgot_password(<%= name.underscore %>, key)
|
5
|
+
@<%= name.underscore %>, @key = <%= name.underscore %>, key
|
6
|
+
mail( :subject => "#{app_name} -- forgotten password",
|
7
|
+
:to => <%= name.underscore %>.email_address )
|
8
|
+
end
|
9
|
+
|
10
|
+
<% if invite_only? -%>
|
11
|
+
def invite(<%= name.underscore %>, key)
|
12
|
+
@<%= name.underscore %>, @key = <%= name.underscore %>, key
|
13
|
+
mail( :subject => "Invitation to #{app_name}",
|
14
|
+
:to => <%= name.underscore %>.email_address )
|
15
|
+
end
|
16
|
+
|
17
|
+
<% elsif options[:activation_email] %>
|
18
|
+
def activation(<%= name.underscore %>, key)
|
19
|
+
@<%= name.underscore %>, @key = <%= name.underscore %>, key
|
20
|
+
mail( :subject => "#{app_name} -- activate",
|
21
|
+
:to => <%= name.underscore %>.email_address )
|
22
|
+
end
|
23
|
+
|
24
|
+
<% end -%>
|
25
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
module Hobo
|
2
|
+
class UserMailerGenerator < Rails::Generators::NamedBase
|
3
|
+
source_root File.expand_path('../templates', __FILE__)
|
4
|
+
|
5
|
+
# overrides the default
|
6
|
+
argument :name, :type => :string, :default => 'user', :optional => true
|
7
|
+
|
8
|
+
include Generators::Hobo::InviteOnly
|
9
|
+
include Generators::Hobo::ActivationEmail
|
10
|
+
|
11
|
+
def self.banner
|
12
|
+
"rails generate hobo:user_mailer [NAME=user] [options]"
|
13
|
+
end
|
14
|
+
|
15
|
+
# check_class_collision :suffix => 'Mailer'
|
16
|
+
|
17
|
+
def generate_mailer
|
18
|
+
template 'mailer.rb.erb', File.join('app/mailers', "#{file_path}_mailer.rb")
|
19
|
+
end
|
20
|
+
|
21
|
+
def generate_mails
|
22
|
+
mailer_dir = File.join("app/views", class_path[0..-2], "#{file_name.singularize}_mailer")
|
23
|
+
template 'forgot_password.erb', File.join(mailer_dir, "forgot_password.erb")
|
24
|
+
template( 'invite.erb', File.join(mailer_dir, "invite.erb")) if invite_only?
|
25
|
+
template( 'activation.erb', File.join(mailer_dir, "activation.erb")) if options[:activation_email]
|
26
|
+
end
|
27
|
+
|
28
|
+
hook_for :test_framework, :as => :mailer do | instance, mailer |
|
29
|
+
instance.invoke mailer, ["#{instance.name}_mailer"]
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,12 @@
|
|
1
|
+
Description:
|
2
|
+
The model generator creates stubs for a new user model.
|
3
|
+
|
4
|
+
The generator takes a model name as its argument. The
|
5
|
+
model name may be given in CamelCase or under_score and
|
6
|
+
should not be suffixed with 'Model'.
|
7
|
+
|
8
|
+
The generator creates a model class in app/models, invokes
|
9
|
+
the hobo:user_mailer andgenerator the test framework.
|
10
|
+
|
11
|
+
Examples:
|
12
|
+
$ rails generate hobo:user_model User
|
@@ -1,4 +1,3 @@
|
|
1
|
-
class <%= class_name %> < ActiveRecord::Base
|
2
1
|
|
3
2
|
hobo_user_model # Don't put anything above this
|
4
3
|
|
@@ -9,17 +8,22 @@ class <%= class_name %> < ActiveRecord::Base
|
|
9
8
|
timestamps
|
10
9
|
end
|
11
10
|
|
12
|
-
# This gives admin rights to the first sign-up.
|
11
|
+
# This gives admin rights and an :active state to the first sign-up.
|
13
12
|
# Just remove it if you don't want that
|
14
|
-
before_create
|
13
|
+
before_create do |user|
|
14
|
+
if !Rails.env.test? && user.class.count == 0
|
15
|
+
user.administrator = true
|
16
|
+
user.state = "active"
|
17
|
+
end
|
18
|
+
end
|
15
19
|
|
16
20
|
<% if invite_only? -%>
|
17
21
|
def new_password_required_with_invite_only?
|
18
|
-
new_password_required_without_invite_only? ||
|
22
|
+
new_password_required_without_invite_only? || self.class.count==0
|
19
23
|
end
|
20
24
|
alias_method_chain :new_password_required?, :invite_only
|
21
25
|
<% end -%>
|
22
|
-
|
26
|
+
|
23
27
|
# --- Signup lifecycle --- #
|
24
28
|
|
25
29
|
lifecycle do
|
@@ -30,46 +34,64 @@ class <%= class_name %> < ActiveRecord::Base
|
|
30
34
|
|
31
35
|
create :invite,
|
32
36
|
:available_to => "acting_user if acting_user.administrator?",
|
37
|
+
:subsite => "<%= options[:admin_subsite_name] %>",
|
33
38
|
:params => [:name, :email_address],
|
34
39
|
:new_key => true,
|
35
40
|
:become => :invited do
|
36
|
-
|
41
|
+
<%= class_name %>Mailer.invite(self, lifecycle.key).deliver
|
37
42
|
end
|
38
|
-
|
43
|
+
|
39
44
|
transition :accept_invitation, { :invited => :active }, :available_to => :key_holder,
|
40
45
|
:params => [ :password, :password_confirmation ]
|
41
|
-
|
46
|
+
|
47
|
+
<% elsif options[:activation_email] -%>
|
48
|
+
state :inactive, :default => true
|
49
|
+
state :active
|
50
|
+
|
51
|
+
create :signup, :available_to => "Guest",
|
52
|
+
:params => [:name, :email_address, :password, :password_confirmation],
|
53
|
+
:become => :inactive, :new_key => true do
|
54
|
+
<%= class_name %>Mailer.activation(self, lifecycle.key).deliver
|
55
|
+
end
|
56
|
+
|
57
|
+
transition :activate, { :inactive => :active }, :available_to => :key_holder
|
58
|
+
|
59
|
+
transition :request_password_reset, { :inactive => :inactive }, :new_key => true do
|
60
|
+
<%= class_name %>Mailer.activation(self, lifecycle.key).deliver
|
61
|
+
end
|
62
|
+
|
42
63
|
<% else -%>
|
43
64
|
state :active, :default => true
|
44
65
|
|
45
66
|
create :signup, :available_to => "Guest",
|
46
67
|
:params => [:name, :email_address, :password, :password_confirmation],
|
47
68
|
:become => :active
|
48
|
-
|
69
|
+
|
49
70
|
<% end -%>
|
50
71
|
transition :request_password_reset, { :active => :active }, :new_key => true do
|
51
|
-
<%= class_name %>Mailer.
|
72
|
+
<%= class_name %>Mailer.forgot_password(self, lifecycle.key).deliver
|
52
73
|
end
|
53
74
|
|
54
75
|
transition :reset_password, { :active => :active }, :available_to => :key_holder,
|
55
76
|
:params => [ :password, :password_confirmation ]
|
56
77
|
|
57
78
|
end
|
58
|
-
|
59
79
|
|
80
|
+
<% if options[:activation_email] -%>
|
81
|
+
def signed_up?
|
82
|
+
state=="active"
|
83
|
+
end
|
84
|
+
|
85
|
+
<% end -%>
|
60
86
|
# --- Permissions --- #
|
61
87
|
|
62
88
|
def create_permitted?
|
63
|
-
|
64
|
-
|
65
|
-
User.count == 0
|
66
|
-
<% else -%>
|
67
|
-
false
|
68
|
-
<% end -%>
|
89
|
+
# Only the initial admin user can be created
|
90
|
+
self.class.count == 0
|
69
91
|
end
|
70
92
|
|
71
93
|
def update_permitted?
|
72
|
-
acting_user.administrator? ||
|
94
|
+
acting_user.administrator? ||
|
73
95
|
(acting_user == self && only_changed?(:email_address, :crypted_password,
|
74
96
|
:current_password, :password, :password_confirmation))
|
75
97
|
# Note: crypted_password has attr_protected so although it is permitted to change, it cannot be changed
|
@@ -83,5 +105,3 @@ class <%= class_name %> < ActiveRecord::Base
|
|
83
105
|
def view_permitted?(field)
|
84
106
|
true
|
85
107
|
end
|
86
|
-
|
87
|
-
end
|