browsercms 3.5.7 → 4.0.0.alpha
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/COPYRIGHT.txt +2 -1
- data/README.markdown +3 -3
- data/app/assets/fonts/icomoon.dev.svg +61 -0
- data/app/assets/fonts/icomoon.eot +0 -0
- data/app/assets/fonts/icomoon.svg +61 -0
- data/app/assets/fonts/icomoon.ttf +0 -0
- data/app/assets/fonts/icomoon.woff +0 -0
- data/app/assets/images/ckeditor/plugins/delete_content/icons/deletecontent.png +0 -0
- data/app/assets/images/ckeditor/plugins/edit_content/icons/editcontent.png +0 -0
- data/app/assets/images/ckeditor/plugins/move_content/icons/movecontentdown.png +0 -0
- data/app/assets/images/ckeditor/plugins/move_content/icons/movecontentup.png +0 -0
- data/app/assets/images/cms/arrow-down.png +0 -0
- data/app/assets/images/cms/arrow-up.png +0 -0
- data/app/assets/images/cms/cogs.png +0 -0
- data/app/assets/images/cms/dashboard/home.png +0 -0
- data/app/assets/images/cms/home.png +0 -0
- data/app/assets/images/cms/logo.png +0 -0
- data/app/assets/images/cms/pencil.png +0 -0
- data/app/assets/images/cms/plus.png +0 -0
- data/app/assets/images/cms/user.png +0 -0
- data/app/assets/javascripts/bcms/ckeditor_inline.js +23 -0
- data/app/assets/javascripts/bcms/ckeditor_standard_config.js +1 -1
- data/app/assets/javascripts/ckeditor/plugins/delete_content/plugin.js +36 -0
- data/app/assets/javascripts/ckeditor/plugins/edit_content/plugin.js +24 -0
- data/app/assets/javascripts/ckeditor/plugins/move_content/plugin.js +25 -0
- data/app/assets/javascripts/cms/ajax.js +60 -0
- data/app/assets/javascripts/cms/application.js +6 -1
- data/app/assets/javascripts/cms/attachment_manager.js.erb +3 -10
- data/app/assets/javascripts/cms/content_library.js +31 -12
- data/app/assets/javascripts/cms/core_library.js.erb +68 -36
- data/app/assets/javascripts/cms/form_builder.js +250 -0
- data/app/assets/javascripts/cms/namespace.js +2 -0
- data/app/assets/javascripts/cms/new_content_button.js +27 -0
- data/app/assets/javascripts/cms/page_editor.js +188 -0
- data/app/assets/javascripts/cms/page_toolbar.js +13 -0
- data/app/assets/javascripts/cms/site.js +2 -0
- data/app/assets/javascripts/cms/sitemap.js +219 -0
- data/app/assets/javascripts/cms/toolbar.js +17 -1
- data/app/assets/javascripts/cms/user.js +40 -0
- data/app/assets/javascripts/jquery.exists.js +5 -0
- data/app/assets/javascripts/jquery.taglist.js +37 -23
- data/app/assets/stylesheets/cms/_assets.css.scss +55 -0
- data/app/assets/stylesheets/cms/_base.css.scss +42 -0
- data/app/assets/stylesheets/cms/_cms-buttons.css.scss +73 -0
- data/app/assets/stylesheets/cms/_cms-forms.css.scss +70 -0
- data/app/assets/stylesheets/cms/_colors.css.scss +20 -0
- data/app/assets/stylesheets/cms/_dashboard.css.scss +25 -0
- data/app/assets/stylesheets/cms/_glyph.css.scss +60 -0
- data/app/assets/stylesheets/cms/_main-area.css.scss +62 -0
- data/app/assets/stylesheets/cms/_nav.css.scss +197 -0
- data/app/assets/stylesheets/cms/_sidebar.css.scss +64 -0
- data/app/assets/stylesheets/cms/_sitemap.css.scss +196 -0
- data/app/assets/stylesheets/cms/_submenu.css.scss +48 -0
- data/app/assets/stylesheets/cms/application.css.scss +49 -0
- data/app/assets/stylesheets/cms/core.css.scss +96 -0
- data/app/assets/stylesheets/cms/default-forms.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/_animation.css.scss +2 -0
- data/app/assets/stylesheets/cms/includes/_rem.css.scss +120 -0
- data/app/assets/stylesheets/cms/includes/animation/_animate.css.scss +31 -0
- data/app/assets/stylesheets/cms/includes/animation/_core.css.scss +127 -0
- data/app/assets/stylesheets/cms/includes/animation/_shared.css.scss +22 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_attention-seekers.css.scss +152 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_bouncing.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_classes.css.scss +21 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_fading.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_flippers.css.scss +87 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_lightspeed.css.scss +24 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_rotating.css.scss +3 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/_specials.css.scss +42 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/bouncing/_bouncing-entrances.css.scss +68 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/bouncing/_bouncing-exits.css.scss +60 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/fading/_fading-entrances.css.scss +86 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/fading/_fading-exits.css.scss +86 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/rotating/_rotating-entrances.css.scss +58 -0
- data/app/assets/stylesheets/cms/includes/animation/animate/rotating/_rotating-exits.css.scss +58 -0
- data/app/assets/stylesheets/cms/page_content_editing.css.scss +4 -0
- data/app/assets/stylesheets/cms/page_editor.css.scss +4 -0
- data/app/assets/stylesheets/cms/style.css.scss +138 -0
- data/app/assets/stylesheets/cms/styles/_alerts.css.scss +150 -0
- data/app/assets/stylesheets/cms/styles/_base-grid.css.scss +299 -0
- data/app/assets/stylesheets/cms/styles/_buttons.css.scss +247 -0
- data/app/assets/stylesheets/cms/styles/_dropdown.css.scss +155 -0
- data/app/assets/stylesheets/cms/styles/_forms.css.scss +728 -0
- data/app/assets/stylesheets/cms/styles/_glyph.css.scss +86 -0
- data/app/assets/stylesheets/cms/styles/_images.css.scss +75 -0
- data/app/assets/stylesheets/cms/styles/_lists.css.scss +115 -0
- data/app/assets/stylesheets/cms/styles/_modal.css.scss +174 -0
- data/app/assets/stylesheets/cms/styles/_progress.css.scss +43 -0
- data/app/assets/stylesheets/cms/styles/_tables.css.scss +141 -0
- data/app/assets/stylesheets/cms/styles/_text.css.scss +134 -0
- data/app/controllers/cms/application_controller.rb +3 -68
- data/app/controllers/cms/attachments_controller.rb +5 -5
- data/app/controllers/cms/base_controller.rb +20 -13
- data/app/controllers/cms/cache_controller.rb +16 -17
- data/app/controllers/cms/category_types_controller.rb +6 -1
- data/app/controllers/cms/connectors_controller.rb +12 -7
- data/app/controllers/cms/content_block_controller.rb +128 -71
- data/app/controllers/cms/content_controller.rb +54 -56
- data/app/controllers/cms/dashboard_controller.rb +5 -6
- data/app/controllers/cms/dynamic_views_controller.rb +12 -9
- data/app/controllers/cms/email_messages_controller.rb +18 -13
- data/app/controllers/cms/form_entries_controller.rb +119 -0
- data/app/controllers/cms/form_fields_controller.rb +74 -0
- data/app/controllers/cms/forms_controller.rb +35 -0
- data/app/controllers/cms/groups_controller.rb +13 -16
- data/app/controllers/cms/html_blocks_controller.rb +2 -2
- data/app/controllers/cms/inline_content_controller.rb +48 -0
- data/app/controllers/cms/links_controller.rb +58 -46
- data/app/controllers/cms/page_components_controller.rb +20 -0
- data/app/controllers/cms/page_routes_controller.rb +44 -40
- data/app/controllers/cms/pages_controller.rb +111 -97
- data/app/controllers/cms/passwords_controller.rb +17 -0
- data/app/controllers/cms/portlet_controller.rb +0 -1
- data/app/controllers/cms/portlets_controller.rb +20 -27
- data/app/controllers/cms/redirects_controller.rb +13 -9
- data/app/controllers/cms/resource_controller.rb +15 -4
- data/app/controllers/cms/routes_controller.rb +2 -4
- data/app/controllers/cms/section_nodes_controller.rb +6 -37
- data/app/controllers/cms/sections_controller.rb +13 -8
- data/app/controllers/cms/sessions_controller.rb +8 -66
- data/app/controllers/cms/sites/passwords_controller.rb +27 -0
- data/app/controllers/cms/sites/sessions_controller.rb +20 -0
- data/app/controllers/cms/tags_controller.rb +12 -12
- data/app/controllers/cms/tasks_controller.rb +45 -46
- data/app/controllers/cms/user_controller.rb +8 -0
- data/app/controllers/cms/users_controller.rb +91 -68
- data/app/helpers/cms/application_helper.rb +58 -52
- data/app/helpers/cms/content_block_helper.rb +8 -7
- data/app/helpers/cms/form_tag_helper.rb +21 -25
- data/app/helpers/cms/menu_helper.rb +1 -3
- data/app/helpers/cms/mobile_helper.rb +12 -2
- data/app/helpers/cms/nav_menu_helper.rb +23 -0
- data/app/helpers/cms/page_helper.rb +72 -30
- data/app/helpers/cms/path_helper.rb +46 -70
- data/app/helpers/cms/rendering_helper.rb +68 -12
- data/app/helpers/cms/section_nodes_helper.rb +92 -31
- data/app/helpers/cms/sites/authentication_helper.rb +25 -0
- data/app/helpers/cms/sites/devise_shim_helper.rb +31 -0
- data/app/helpers/cms/template_support.rb +1 -7
- data/app/helpers/cms/ui_elements_helper.rb +147 -6
- data/app/helpers/forgot_password_portlet_helper.rb +9 -0
- data/app/helpers/login_portlet_helper.rb +10 -0
- data/app/inputs/attachments_input.rb +14 -0
- data/app/inputs/cms_text_area_input.rb +10 -0
- data/app/inputs/cms_text_field_input.rb +29 -0
- data/app/inputs/date_picker_input.rb +8 -0
- data/app/inputs/file_picker_input.rb +75 -0
- data/app/inputs/path_input.rb +18 -0
- data/app/inputs/tag_list_input.rb +3 -0
- data/app/inputs/template_editor_input.rb +24 -0
- data/app/inputs/text_editor_input.rb +19 -0
- data/app/models/cms/abstract_file_block.rb +10 -6
- data/app/models/cms/attachment.rb +20 -27
- data/app/models/cms/category.rb +17 -7
- data/app/models/cms/category_type.rb +8 -4
- data/app/models/cms/connector.rb +32 -20
- data/app/models/cms/content.rb +31 -0
- data/app/models/cms/content_type.rb +114 -62
- data/app/models/cms/dynamic_view.rb +19 -45
- data/app/models/cms/email_message.rb +32 -2
- data/app/models/cms/external_user.rb +60 -0
- data/app/models/cms/file_block.rb +1 -0
- data/app/models/cms/form.rb +47 -0
- data/app/models/cms/form_entry.rb +71 -0
- data/app/models/cms/form_field.rb +78 -0
- data/app/models/cms/group.rb +19 -9
- data/app/models/cms/group_permission.rb +1 -1
- data/app/models/cms/group_section.rb +1 -1
- data/app/models/cms/group_type.rb +5 -5
- data/app/models/cms/group_type_permission.rb +1 -1
- data/app/models/cms/html_block.rb +14 -19
- data/app/models/cms/image_block.rb +1 -0
- data/app/models/cms/link.rb +8 -6
- data/app/models/cms/page.rb +156 -59
- data/app/models/cms/page_component.rb +43 -0
- data/app/models/cms/page_partial.rb +16 -8
- data/app/models/cms/page_route.rb +1 -1
- data/app/models/cms/page_route_condition.rb +1 -1
- data/app/models/cms/page_route_option.rb +1 -1
- data/app/models/cms/page_route_requirement.rb +1 -1
- data/app/models/cms/page_template.rb +14 -9
- data/app/models/cms/permission.rb +4 -2
- data/app/models/cms/persistent_user.rb +208 -0
- data/app/models/cms/portlet.rb +56 -9
- data/app/models/cms/redirect.rb +1 -1
- data/app/models/cms/search_filter.rb +18 -0
- data/app/models/cms/section.rb +39 -28
- data/app/models/cms/section_node.rb +32 -5
- data/app/models/cms/site.rb +3 -3
- data/app/models/cms/tag.rb +14 -12
- data/app/models/cms/tagging.rb +2 -2
- data/app/models/cms/task.rb +14 -21
- data/app/models/cms/templates.rb +1 -2
- data/app/models/cms/user.rb +21 -160
- data/app/models/cms/user_group_membership.rb +2 -2
- data/app/portlets/deprecated_placeholder.rb +12 -0
- data/app/portlets/dynamic_portlet.rb +1 -1
- data/app/portlets/email_page_portlet.rb +10 -3
- data/app/portlets/forgot_password_portlet.rb +9 -28
- data/app/portlets/login_portlet.rb +8 -5
- data/app/portlets/tag_cloud_portlet.rb +3 -1
- data/app/presenters/cms/user_presenter.rb +24 -0
- data/app/views/cms/application/_add_content_modal.html.erb +3 -0
- data/app/views/cms/application/_buttons.html.erb +7 -0
- data/app/views/cms/{shared → application}/_exception.html.erb +0 -0
- data/app/views/cms/application/_form_errors.html.erb +7 -0
- data/app/views/cms/application/_form_with_buttons.html.erb +10 -0
- data/app/views/cms/application/_main_content.html.erb +3 -0
- data/app/views/cms/application/_main_with_sidebar.html.erb +8 -0
- data/app/views/cms/application/_mobile_toolbar.html.erb +16 -0
- data/app/views/cms/application/_page_title.html.erb +5 -0
- data/app/views/cms/application/_pagination.html.erb +26 -0
- data/app/views/cms/application/_row.html.erb +1 -0
- data/app/views/cms/application/_save_buttons.html.erb +7 -0
- data/app/views/cms/application/_sidebar_layout.html.erb +3 -0
- data/app/views/cms/application/_version.html.erb +23 -0
- data/app/views/cms/{shared → application}/_version_conflict_diff.html.erb +0 -0
- data/app/views/cms/{shared → application}/_version_conflict_error.html.erb +0 -0
- data/app/views/cms/attachments/_attachment_manager.html.erb +22 -0
- data/app/views/cms/attachments/_no_attachments_defined.html.erb +1 -0
- data/app/views/cms/cache/show.html.erb +5 -10
- data/app/views/cms/categories/_form.html.erb +15 -24
- data/app/views/cms/category_types/_form.html.erb +1 -1
- data/app/views/cms/connectors/new.html.erb +33 -64
- data/app/views/cms/content/editing_frame.html.erb +1 -0
- data/app/views/cms/content/no_page.html.erb +9 -27
- data/app/views/cms/content/show.html.erb +14 -15
- data/app/views/cms/content_block/_block_form.html.erb +15 -0
- data/app/views/cms/content_block/_buttonbar.html.erb +29 -0
- data/app/views/cms/content_block/_buttons.html.erb +13 -0
- data/app/views/cms/content_block/_hidden_fields.html.erb +13 -0
- data/app/views/cms/content_block/_sidebar.html.erb +35 -0
- data/app/views/cms/content_block/edit.html.erb +3 -0
- data/app/views/cms/content_block/index.html.erb +87 -0
- data/app/views/cms/content_block/new.html.erb +3 -0
- data/app/views/cms/content_block/render_block_in_main_container.html.erb +10 -0
- data/app/views/cms/content_block/show.html.erb +1 -0
- data/app/views/cms/content_block/show_in_isolation.html.erb +15 -0
- data/app/views/cms/content_block/versions.html.erb +24 -0
- data/app/views/cms/dashboard/_page_drafts.html.erb +12 -22
- data/app/views/cms/dashboard/_tasks.html.erb +32 -45
- data/app/views/cms/dashboard/index.html.erb +11 -13
- data/app/views/cms/dynamic_views/_form.html.erb +8 -10
- data/app/views/cms/dynamic_views/edit.html.erb +2 -3
- data/app/views/cms/dynamic_views/index.html.erb +22 -44
- data/app/views/cms/dynamic_views/new.html.erb +2 -3
- data/app/views/cms/email_messages/index.html.erb +31 -34
- data/app/views/cms/email_messages/show.html.erb +45 -52
- data/app/views/cms/file_blocks/_form.html.erb +2 -4
- data/app/views/cms/form_entries/_buttons.html.erb +2 -0
- data/app/views/cms/form_entries/_form.html.erb +7 -0
- data/app/views/cms/form_entries/_internal_form.html.erb +9 -0
- data/app/views/cms/form_entries/edit.html.erb +5 -0
- data/app/views/cms/form_entries/error.html.erb +3 -0
- data/app/views/cms/form_entries/index.html.erb +4 -0
- data/app/views/cms/form_entries/new.html.erb +5 -0
- data/app/views/cms/form_entries/show.html.erb +13 -0
- data/app/views/cms/form_entries/submit.html.erb +1 -0
- data/app/views/cms/form_fields/_form.html.erb +8 -0
- data/app/views/cms/form_fields/_select.html.erb +3 -0
- data/app/views/cms/form_fields/_text_area.html.erb +3 -0
- data/app/views/cms/form_fields/_text_field.html.erb +3 -0
- data/app/views/cms/form_fields/edit.html.erb +0 -0
- data/app/views/cms/form_fields/new.html.erb +26 -0
- data/app/views/cms/form_fields/preview.html.erb +16 -0
- data/app/views/cms/forms/_form.html.erb +66 -0
- data/app/views/cms/forms/render.html.erb +15 -0
- data/app/views/cms/forms/show.html.erb +6 -0
- data/app/views/cms/groups/_form.html.erb +32 -38
- data/app/views/cms/groups/_permissions.html.erb +11 -34
- data/app/views/cms/groups/_sections.html.erb +11 -17
- data/app/views/cms/groups/edit.html.erb +1 -3
- data/app/views/cms/groups/index.html.erb +10 -32
- data/app/views/cms/groups/new.html.erb +2 -4
- data/app/views/cms/html_blocks/_form.html.erb +2 -2
- data/app/views/cms/html_blocks/render.html.erb +1 -1
- data/app/views/cms/image_blocks/_form.html.erb +3 -3
- data/app/views/cms/links/_form.html.erb +6 -11
- data/app/views/cms/links/edit.html.erb +3 -12
- data/app/views/cms/links/new.html.erb +4 -13
- data/app/views/cms/page_components/_content.html.erb +18 -0
- data/app/views/cms/page_components/new.html.erb +12 -0
- data/app/views/cms/page_routes/_form.html.erb +11 -10
- data/app/views/cms/page_routes/edit.html.erb +2 -3
- data/app/views/cms/page_routes/index.html.erb +25 -48
- data/app/views/cms/page_routes/new.html.erb +2 -3
- data/app/views/cms/pages/_edit_content.html.erb +28 -0
- data/app/views/cms/pages/_form.html.erb +20 -37
- data/app/views/cms/pages/_main_form.html.erb +23 -0
- data/app/views/cms/pages/_simple_container.html.erb +8 -0
- data/app/views/cms/pages/edit.html.erb +2 -23
- data/app/views/cms/pages/new.html.erb +2 -16
- data/app/views/cms/pages/versions.html.erb +18 -87
- data/app/views/cms/redirects/_form.html.erb +6 -14
- data/app/views/cms/redirects/edit.html.erb +2 -3
- data/app/views/cms/redirects/index.html.erb +24 -50
- data/app/views/cms/redirects/new.html.erb +2 -3
- data/app/views/cms/routes/index.html.erb +15 -20
- data/app/views/cms/section_nodes/_children.html.erb +3 -0
- data/app/views/cms/section_nodes/_row_buttons.html.erb +11 -0
- data/app/views/cms/section_nodes/_section_node.html.erb +24 -10
- data/app/views/cms/section_nodes/_sitemap_buttons.html.erb +47 -0
- data/app/views/cms/section_nodes/_status.html.erb +5 -0
- data/app/views/cms/section_nodes/show.html.erb +9 -0
- data/app/views/cms/sections/_buttons.html.erb +6 -0
- data/app/views/cms/sections/_form.html.erb +22 -49
- data/app/views/cms/sections/edit.html.erb +3 -8
- data/app/views/cms/sections/new.html.erb +4 -20
- data/app/views/cms/sessions/new.html.erb +16 -31
- data/app/views/cms/shared/access_denied.html.erb +1 -2
- data/app/views/cms/shared/error.html.erb +5 -5
- data/app/views/cms/sites/_flash.html.erb +8 -0
- data/app/views/cms/sites/passwords/new.html.erb +2 -0
- data/app/views/cms/sites/sessions/new.html.erb +2 -0
- data/app/views/cms/tags/_form.html.erb +1 -1
- data/app/views/cms/tags/render.html.erb +0 -1
- data/app/views/cms/tasks/new.html.erb +18 -32
- data/app/views/cms/toolbar/_new_pages_menu.html.erb +10 -0
- data/app/views/cms/users/_form.html.erb +8 -11
- data/app/views/cms/users/_password.html.erb +2 -8
- data/app/views/cms/users/_user_fields.html.erb +7 -20
- data/app/views/cms/users/change_password.html.erb +12 -21
- data/app/views/cms/users/edit.html.erb +1 -15
- data/app/views/cms/users/index.html.erb +61 -58
- data/app/views/cms/users/new.html.erb +1 -12
- data/app/views/devise/confirmations/new.html.erb +16 -0
- data/app/views/devise/mailer/confirmation_instructions.html.erb +5 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +8 -0
- data/app/views/devise/mailer/unlock_instructions.html.erb +7 -0
- data/app/views/devise/passwords/edit.html.erb +19 -0
- data/app/views/devise/passwords/new.html.erb +15 -0
- data/app/views/devise/registrations/edit.html.erb +28 -0
- data/app/views/devise/registrations/new.html.erb +18 -0
- data/app/views/devise/shared/_links.erb +25 -0
- data/app/views/devise/unlocks/new.html.erb +16 -0
- data/app/views/layouts/cms/_content_types.html.erb +13 -0
- data/app/views/layouts/cms/_footer.erb +2 -2
- data/app/views/layouts/cms/_head.html.erb +8 -18
- data/app/views/layouts/cms/_main_menu.html.erb +78 -0
- data/app/views/layouts/cms/application.html.erb +19 -24
- data/app/views/layouts/cms/content_page.html.erb +5 -0
- data/app/views/layouts/cms/page_editor.html.erb +90 -0
- data/app/views/portlets/deprecated_placeholders/_form.html.erb +1 -0
- data/app/views/portlets/deprecated_placeholders/render.html.erb +8 -0
- data/app/views/portlets/dynamic/_form.html.erb +3 -3
- data/app/views/portlets/email_page/_form.html.erb +5 -6
- data/app/views/portlets/forgot_password/_form.html.erb +2 -3
- data/app/views/portlets/forgot_password/render.html.erb +2 -14
- data/app/views/portlets/login/_form.html.erb +4 -6
- data/app/views/portlets/login/render.html.erb +8 -27
- data/app/views/portlets/portlets/_form.html.erb +7 -6
- data/app/views/portlets/tag_cloud/_form.html.erb +4 -4
- data/app/views/tests/pretend/open_with_layout.html.erb +1 -1
- data/bin/bcms +13 -16
- data/config/routes.rb +58 -29
- data/db/browsercms.seeds.rb +0 -6
- data/db/migrate/{20080815014337_browsercms_3_0_0.rb → 20080815014337_browsercms300.rb} +94 -73
- data/db/migrate/20130327184912_browsercms400.rb +90 -0
- data/db/migrate/20131206214021_devise_create_users.rb +47 -0
- data/db/migrate/20131211223908_kill_reset_password.rb +5 -0
- data/db/migrate/20131218222005_create_cms_external_users.rb +10 -0
- data/doc/features/design_integration.md +45 -0
- data/doc/features/external_user.md +7 -0
- data/doc/features/form_builder.md +40 -0
- data/doc/features/simple_form_refactor.md +60 -0
- data/doc/release_notes.md +224 -10
- data/lib/acts_as_list.rb +72 -71
- data/lib/browsercms.rb +41 -1
- data/lib/cms/acts/content_block.rb +12 -2
- data/lib/cms/acts/content_page.rb +3 -4
- data/lib/cms/admin_tab.rb +15 -0
- data/lib/cms/attachments/configuration.rb +1 -1
- data/lib/cms/authentication/controller.rb +83 -177
- data/lib/cms/authentication/test_password_strategy.rb +19 -0
- data/lib/cms/behaviors.rb +1 -0
- data/lib/cms/behaviors/archiving.rb +2 -2
- data/lib/cms/behaviors/attaching.rb +21 -45
- data/lib/cms/behaviors/connecting.rb +14 -4
- data/lib/cms/behaviors/dynamic_attributes.rb +3 -3
- data/lib/cms/behaviors/hiding.rb +2 -2
- data/lib/cms/behaviors/namespacing.rb +6 -36
- data/lib/cms/behaviors/publishing.rb +92 -45
- data/lib/cms/behaviors/rendering.rb +15 -7
- data/lib/cms/behaviors/searching.rb +5 -4
- data/lib/cms/behaviors/soft_deleting.rb +13 -16
- data/lib/cms/behaviors/taggable.rb +17 -10
- data/lib/cms/behaviors/versioning.rb +12 -16
- data/lib/cms/commands/to_version400.rb +10 -0
- data/lib/cms/concerns.rb +7 -0
- data/lib/cms/concerns/can_be_addressable.rb +326 -0
- data/lib/cms/concerns/has_content_type.rb +46 -0
- data/lib/cms/concerns/ignores_publishing.rb +9 -0
- data/lib/cms/configuration.rb +14 -4
- data/lib/cms/configuration/configurable_template.rb +24 -0
- data/lib/cms/configuration/devise.rb +256 -0
- data/lib/cms/configure_simple_form.rb +142 -0
- data/lib/cms/configure_simple_form_bootstrap.rb +49 -0
- data/lib/cms/content_filter.rb +18 -0
- data/lib/cms/content_page.rb +77 -0
- data/lib/cms/content_rendering_support.rb +25 -16
- data/lib/cms/controllers/admin_controller.rb +78 -0
- data/lib/cms/data_loader.rb +30 -11
- data/lib/cms/default_accessible.rb +6 -6
- data/lib/cms/domain_support.rb +0 -4
- data/lib/cms/engine.rb +52 -20
- data/lib/cms/engine_helper.rb +41 -51
- data/{app/controllers → lib}/cms/error_handling.rb +11 -5
- data/lib/cms/extensions.rb +2 -1
- data/lib/cms/extensions/active_model/name.rb +13 -0
- data/lib/cms/extensions/active_record/connection_adapters/abstract/schema_statements.rb +49 -89
- data/lib/cms/extensions/hash.rb +0 -12
- data/lib/cms/form_builder/content_block_form_builder.rb +45 -0
- data/lib/cms/form_builder/default_input.rb +13 -0
- data/lib/cms/form_builder/deprecated_inputs.rb +40 -0
- data/lib/cms/form_builder/workflow_buttons.rb +38 -0
- data/lib/cms/module.rb +1 -7
- data/lib/cms/polymorphic_single_table_inheritance.rb +19 -0
- data/lib/cms/publish_workflow.rb +26 -0
- data/lib/cms/responders/content_responder.rb +14 -0
- data/lib/cms/route_extensions.rb +112 -20
- data/lib/cms/version.rb +1 -1
- data/lib/generators/browser_cms/demo_site/templates/demo.seeds.rb +0 -2
- data/lib/generators/cms/content_block/content_block_generator.rb +19 -46
- data/lib/generators/cms/content_block/templates/_form.html.erb +22 -28
- data/lib/generators/cms/project/templates/devise.rb.erb +7 -0
- metadata +383 -150
- data/app/assets/javascripts/cms/sitemap.js.erb +0 -464
- data/app/assets/stylesheets/browsercms/application.css +0 -7
- data/app/assets/stylesheets/cms/administration.css.erb +0 -91
- data/app/assets/stylesheets/cms/application.css.erb +0 -171
- data/app/assets/stylesheets/cms/attachment_manager.css.scss +0 -28
- data/app/assets/stylesheets/cms/block.css +0 -26
- data/app/assets/stylesheets/cms/buttons.css.erb +0 -120
- data/app/assets/stylesheets/cms/content_library.css.erb +0 -139
- data/app/assets/stylesheets/cms/content_types.css +0 -4
- data/app/assets/stylesheets/cms/dashboard.css.erb +0 -118
- data/app/assets/stylesheets/cms/data_table.css.erb.erb +0 -156
- data/app/assets/stylesheets/cms/date_picker.css.erb +0 -82
- data/app/assets/stylesheets/cms/form_layout.css.erb +0 -282
- data/app/assets/stylesheets/cms/login.css.erb +0 -78
- data/app/assets/stylesheets/cms/menu.css.erb +0 -116
- data/app/assets/stylesheets/cms/nav.css.erb +0 -99
- data/app/assets/stylesheets/cms/page_toolbar.css.erb +0 -135
- data/app/assets/stylesheets/cms/reset.css +0 -46
- data/app/assets/stylesheets/cms/selectbox.css.erb +0 -56
- data/app/assets/stylesheets/cms/sitemap.css.erb +0 -390
- data/app/assets/stylesheets/cms/taglist.css +0 -18
- data/app/controllers/application_controller.rb +0 -14
- data/app/controllers/cms/content_types_controller.rb +0 -9
- data/app/helpers/application_helper.rb +0 -5
- data/app/helpers/cms/form_builder.rb +0 -241
- data/app/models/cms/content_type_group.rb +0 -15
- data/app/models/cms/forgot_password_mailer.rb +0 -14
- data/app/portlets/reset_password_portlet.rb +0 -28
- data/app/views/cms/blocks/_hidden_fields.html.erb +0 -10
- data/app/views/cms/blocks/_toolbar.html.erb +0 -9
- data/app/views/cms/blocks/_toolbar_for_collection.html.erb +0 -23
- data/app/views/cms/blocks/_toolbar_for_member.html.erb +0 -36
- data/app/views/cms/blocks/edit.html.erb +0 -28
- data/app/views/cms/blocks/index.html.erb +0 -86
- data/app/views/cms/blocks/new.html.erb +0 -19
- data/app/views/cms/blocks/show.html.erb +0 -43
- data/app/views/cms/blocks/usages.html.erb +0 -44
- data/app/views/cms/blocks/versions.html.erb +0 -90
- data/app/views/cms/content_types/index.html.erb +0 -14
- data/app/views/cms/form_builder/_cms_attachment_manager.html.erb +0 -27
- data/app/views/cms/form_builder/_cms_check_box.html.erb +0 -7
- data/app/views/cms/form_builder/_cms_date_picker.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_datetime_select.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_drop_down.html.erb +0 -12
- data/app/views/cms/form_builder/_cms_fancy_drop_down.html.erb +0 -9
- data/app/views/cms/form_builder/_cms_file_field.html.erb +0 -28
- data/app/views/cms/form_builder/_cms_instructions.html.erb +0 -4
- data/app/views/cms/form_builder/_cms_tag_list.html.erb +0 -15
- data/app/views/cms/form_builder/_cms_template_editor.html.erb +0 -9
- data/app/views/cms/form_builder/_cms_text_area.html.erb +0 -10
- data/app/views/cms/form_builder/_cms_text_editor.html.erb +0 -19
- data/app/views/cms/form_builder/_cms_text_field.html.erb +0 -12
- data/app/views/cms/links/destroy.js.rjs +0 -2
- data/app/views/cms/page_routes/show.html.erb +0 -10
- data/app/views/cms/pages/_edit_connector.html.erb +0 -19
- data/app/views/cms/pages/_edit_container.html.erb +0 -11
- data/app/views/cms/section_nodes/_link.html.erb +0 -14
- data/app/views/cms/section_nodes/_node.html.erb +0 -44
- data/app/views/cms/section_nodes/_page.html.erb +0 -20
- data/app/views/cms/section_nodes/_section.html.erb +0 -28
- data/app/views/cms/section_nodes/index.html.erb +0 -43
- data/app/views/cms/sections/_page.html.erb +0 -4
- data/app/views/cms/sections/_section.html.erb +0 -8
- data/app/views/cms/sections/destroy.js.rjs +0 -2
- data/app/views/cms/sections/index.html.erb +0 -23
- data/app/views/cms/shared/_admin_sidebar.html.erb +0 -36
- data/app/views/cms/shared/_pagination.html.erb +0 -31
- data/app/views/cms/toolbar/_mobile_toggle.html.erb +0 -33
- data/app/views/cms/toolbar/index.html.erb +0 -1
- data/app/views/cms/users/_groups.html.erb +0 -12
- data/app/views/cms/users/_toolbar.html.erb +0 -24
- data/app/views/cms/users/show.html.erb +0 -50
- data/app/views/layouts/_cms_toolbar.html.erb +0 -54
- data/app/views/layouts/_page_toolbar.html.erb +0 -119
- data/app/views/layouts/cms/administration.html.erb +0 -51
- data/app/views/layouts/cms/content_library.html.erb +0 -96
- data/app/views/layouts/cms/dashboard.html.erb +0 -16
- data/app/views/layouts/cms/login.html.erb +0 -31
- data/app/views/layouts/cms/section_nodes.html.erb +0 -20
- data/app/views/layouts/cms/toolbar.html.erb +0 -23
- data/app/views/portlets/reset_password/_form.html.erb +0 -3
- data/app/views/portlets/reset_password/render.html.erb +0 -22
- data/bin/bcms-upgrade +0 -332
- data/db/migrate/20091109175123_browsercms_3_0_5.rb +0 -9
- data/db/migrate/20100117144038_browsercms314.rb +0 -20
- data/db/migrate/20100117144039_browsercms315.rb +0 -95
- data/db/migrate/20100705083859_browsercms_3_3_0.rb +0 -56
- data/db/migrate/20111130221145_browsercms340.rb +0 -56
- data/db/migrate/20120329144406_browsercms350.rb +0 -32
- data/db/migrate/20120717182827_browsercms353.rb +0 -19
- data/db/migrate/20120813180110_browsercms354.rb +0 -9
- data/lib/cms/addressable.rb +0 -93
- data/lib/cms/authentication/model.rb +0 -116
- data/lib/cms/behaviors/pagination.rb +0 -212
- data/lib/cms/upgrades/v3_4_0.rb +0 -31
- data/lib/cms/upgrades/v3_5_0.rb +0 -227
data/app/models/cms/redirect.rb
CHANGED
@@ -0,0 +1,18 @@
|
|
1
|
+
module Cms
|
2
|
+
# Captures values for the search form.
|
3
|
+
class SearchFilter
|
4
|
+
include ::ActiveModel::Model
|
5
|
+
|
6
|
+
attr_accessor :model_class, :term
|
7
|
+
|
8
|
+
def self.build(params_hash, model_class)
|
9
|
+
model = self.new(params_hash)
|
10
|
+
model.model_class = model_class
|
11
|
+
model
|
12
|
+
end
|
13
|
+
|
14
|
+
def path
|
15
|
+
model_class
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
data/app/models/cms/section.rb
CHANGED
@@ -2,36 +2,42 @@ module Cms
|
|
2
2
|
class Section < ActiveRecord::Base
|
3
3
|
flush_cache_on_change
|
4
4
|
|
5
|
+
is_addressable no_dynamic_path: true, destroy_if: :deletable?
|
6
|
+
# Cannot use dependent => :destroy to do this. Ancestry's callbacks trigger before the before_destroy callback.
|
7
|
+
# So sections would always get deleted since deletable? would return true
|
8
|
+
after_destroy :destroy_node
|
9
|
+
before_destroy :deletable?
|
5
10
|
|
6
|
-
|
7
|
-
#The node that links this section to its parent
|
8
|
-
has_one :section_node, :class_name => 'Cms::SectionNode', :as => :node, :inverse_of => :node
|
9
11
|
SECTION = "Cms::Section"
|
10
12
|
PAGE = "Cms::Page"
|
11
13
|
LINK = "Cms::Link"
|
12
14
|
VISIBLE_NODE_TYPES = [SECTION, PAGE, LINK]
|
15
|
+
HIDDEN_NODE_TYPES = "Cms::Attachment"
|
13
16
|
|
14
|
-
|
15
|
-
|
17
|
+
extend DefaultAccessible
|
18
|
+
# @override
|
19
|
+
def self.permitted_params
|
20
|
+
super + [:allow_groups, group_ids: []]
|
21
|
+
end
|
16
22
|
|
17
|
-
|
18
|
-
|
23
|
+
has_many :group_sections, :class_name => 'Cms::GroupSection'
|
24
|
+
has_many :groups, :through => :group_sections, :class_name => 'Cms::Group'
|
19
25
|
|
26
|
+
scope :root, -> { where(['root = ?', true]) }
|
27
|
+
scope :system, -> { where({:name => 'system'}) }
|
28
|
+
scope :hidden, -> { where({:hidden => true}) }
|
29
|
+
scope :not_hidden, -> { where({:hidden => false}) }
|
20
30
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
before_destroy :deletable?
|
31
|
+
def self.named(name)
|
32
|
+
where(["#{table_name}.name = ?", name])
|
33
|
+
end
|
25
34
|
|
26
|
-
|
27
|
-
|
35
|
+
def self.with_path(path)
|
36
|
+
where(["#{table_name}.path = ?", path])
|
37
|
+
end
|
28
38
|
|
29
|
-
scope :
|
30
|
-
scope :
|
31
|
-
scope :hidden, :conditions => {:hidden => true}
|
32
|
-
scope :not_hidden, :conditions => {:hidden => false}
|
33
|
-
scope :named, lambda { |name| {:conditions => ["#{table_name}.name = ?", name]} }
|
34
|
-
scope :with_path, lambda { |path| {:conditions => ["#{table_name}.path = ?", path]} }
|
39
|
+
#scope :named, lambda { |name| {-> {where( ["#{table_name}.name = ?", name]} } )}
|
40
|
+
#scope :with_path, lambda { |path| {-> {where( ["#{table_name}.path = ?", path]} } )}
|
35
41
|
|
36
42
|
validates_presence_of :name, :path
|
37
43
|
|
@@ -84,11 +90,11 @@ module Cms
|
|
84
90
|
end
|
85
91
|
|
86
92
|
def self.sitemap
|
87
|
-
SectionNode.
|
93
|
+
SectionNode.not_of_type(HIDDEN_NODE_TYPES).fetch_nodes.arrange(:order => :position)
|
88
94
|
end
|
89
95
|
|
90
96
|
def visible_child_nodes(options={})
|
91
|
-
children = child_nodes.of_type(VISIBLE_NODE_TYPES).fetch_nodes.in_order.
|
97
|
+
children = child_nodes.of_type(VISIBLE_NODE_TYPES).fetch_nodes.in_order.to_a
|
92
98
|
visible_children = children.select { |sn| sn.visible? }
|
93
99
|
options[:limit] ? visible_children[0...options[:limit]] : visible_children
|
94
100
|
end
|
@@ -137,11 +143,6 @@ module Cms
|
|
137
143
|
!root? && empty?
|
138
144
|
end
|
139
145
|
|
140
|
-
# Callback to clean up related nodes
|
141
|
-
def destroy_node
|
142
|
-
node.destroy
|
143
|
-
end
|
144
|
-
|
145
146
|
def editable_by_group?(group)
|
146
147
|
group.editable_by_section(self)
|
147
148
|
end
|
@@ -166,9 +167,10 @@ module Cms
|
|
166
167
|
current_section
|
167
168
|
end
|
168
169
|
|
169
|
-
#The first page that is a
|
170
|
+
#The first page that is a descendent of this section
|
170
171
|
def first_page_or_link
|
171
|
-
|
172
|
+
types = Cms::ContentType.addressable.collect(&:name).push(LINK).push(PAGE)
|
173
|
+
section_node = child_nodes.of_type(types).fetch_nodes.in_order.first
|
172
174
|
return section_node.node if section_node
|
173
175
|
sections.each do |s|
|
174
176
|
node = s.first_page_or_link
|
@@ -209,5 +211,14 @@ module Cms
|
|
209
211
|
self.groups = Cms::Group.all
|
210
212
|
end
|
211
213
|
end
|
214
|
+
|
215
|
+
# Sections are accessible to guests if they marked as such. Variables are passed in for performance reasons
|
216
|
+
# since this gets called 'MANY' times on the sitemap.
|
217
|
+
#
|
218
|
+
# @param [Array<Section>] public_sections
|
219
|
+
# @param [Section] parent
|
220
|
+
def accessible_to_guests?(public_sections, parent)
|
221
|
+
public_sections.include?(self)
|
222
|
+
end
|
212
223
|
end
|
213
224
|
end
|
@@ -1,9 +1,10 @@
|
|
1
1
|
require 'ancestry'
|
2
2
|
|
3
3
|
class Cms::SectionNode < ActiveRecord::Base
|
4
|
-
attr_accessible :node, :section, :parent, :node_id, :node_type
|
5
4
|
has_ancestry
|
6
5
|
|
6
|
+
validates :slug, uniqueness: { scope: :node_type }, unless: lambda { |sn| sn.slug.blank?}
|
7
|
+
|
7
8
|
# This is the parent section for this node
|
8
9
|
# For backwards compatiblity
|
9
10
|
def parent_section
|
@@ -26,9 +27,31 @@ class Cms::SectionNode < ActiveRecord::Base
|
|
26
27
|
ancestry ? "ancestry = '#{ancestry}'" : 'ancestry IS NULL'
|
27
28
|
end
|
28
29
|
|
29
|
-
|
30
|
-
|
31
|
-
|
30
|
+
|
31
|
+
class << self
|
32
|
+
def of_type(types)
|
33
|
+
where(["#{table_name}.node_type IN (?)", types])
|
34
|
+
end
|
35
|
+
|
36
|
+
def in_order
|
37
|
+
order("position asc")
|
38
|
+
end
|
39
|
+
|
40
|
+
def fetch_nodes
|
41
|
+
includes(:node)
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
# Return all section nodes which are not of the given type (i.e. class name)
|
46
|
+
# @param [String] klass A specific class name that should be excluded.
|
47
|
+
def self.not_of_type(klass)
|
48
|
+
where("#{table_name}.node_type NOT IN (?)", klass)
|
49
|
+
end
|
50
|
+
|
51
|
+
# Determines if this node is the homepage of the site.
|
52
|
+
def home?
|
53
|
+
page? && node.home?
|
54
|
+
end
|
32
55
|
|
33
56
|
def visible?
|
34
57
|
return false unless node
|
@@ -52,6 +75,10 @@ class Cms::SectionNode < ActiveRecord::Base
|
|
52
75
|
node_type == 'Cms::Page'
|
53
76
|
end
|
54
77
|
|
78
|
+
def link?
|
79
|
+
node_type == 'Cms::Link'
|
80
|
+
end
|
81
|
+
|
55
82
|
# @param [Section] section
|
56
83
|
# @param [Integer] position
|
57
84
|
def move_to(section, position)
|
@@ -68,7 +95,7 @@ class Cms::SectionNode < ActiveRecord::Base
|
|
68
95
|
#This helps prevent the position from getting out of whack
|
69
96
|
#If you pass in a really high number for position,
|
70
97
|
#this just corrects it to the right number
|
71
|
-
node_count =Cms::SectionNode.
|
98
|
+
node_count = Cms::SectionNode.where({:ancestry => ancestry}).count
|
72
99
|
position = node_count if position > node_count
|
73
100
|
end
|
74
101
|
|
data/app/models/cms/site.rb
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
module Cms
|
2
2
|
class Site < ActiveRecord::Base
|
3
3
|
|
4
|
-
|
4
|
+
#attr_accessible :name, :domain
|
5
5
|
|
6
6
|
validates_uniqueness_of :domain
|
7
7
|
|
@@ -10,12 +10,12 @@ module Cms
|
|
10
10
|
before_save :unset_default
|
11
11
|
after_save :set_default
|
12
12
|
|
13
|
-
scope :default,
|
13
|
+
scope :default, -> {where(:the_default => true)}
|
14
14
|
|
15
15
|
def self.find_by_domain(domain)
|
16
16
|
d = domain.clone
|
17
17
|
strip_www!(d)
|
18
|
-
if site =
|
18
|
+
if site = where(:domain => d).first
|
19
19
|
site
|
20
20
|
else
|
21
21
|
default.first
|
data/app/models/cms/tag.rb
CHANGED
@@ -2,25 +2,27 @@ module Cms
|
|
2
2
|
class Tag < ActiveRecord::Base
|
3
3
|
|
4
4
|
has_many :taggings, :class_name => 'Cms::Tagging'
|
5
|
-
|
5
|
+
extend DefaultAccessible
|
6
|
+
include Concerns::IgnoresPublishing
|
6
7
|
|
7
8
|
validates_uniqueness_of :name
|
8
9
|
|
9
10
|
attr_accessor :size
|
10
11
|
is_searchable
|
11
|
-
|
12
|
+
has_content_type :module => :categorization
|
12
13
|
|
13
|
-
|
14
|
+
def self.named(tag)
|
15
|
+
where(name: tag)
|
16
|
+
end
|
17
|
+
|
18
|
+
# Returns an array of tags with a #count attribute
|
14
19
|
#
|
15
20
|
# @return [Array] Each element of the area contains [Id (Integer), Name (String), count (Integer)] (with Sqlite3 anyway)
|
16
|
-
def self.counts(
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
:order => "count desc, #{Tag.table_name}.name"}) do
|
22
|
-
all(options)
|
23
|
-
end
|
21
|
+
def self.counts()
|
22
|
+
select("#{table_name}.id, #{table_name}.name, count(#{table_name}.id) as count")
|
23
|
+
.joins(:taggings)
|
24
|
+
.group("#{table_name}.id, #{table_name}.name")
|
25
|
+
.order("count desc, #{table_name}.name")
|
24
26
|
end
|
25
27
|
|
26
28
|
# Returns an array of tags with a size attribute
|
@@ -30,7 +32,7 @@ module Cms
|
|
30
32
|
def self.cloud(options={})
|
31
33
|
sizes = (options.delete(:sizes) || 5) - 1
|
32
34
|
sizes = 1 if sizes < 1
|
33
|
-
tags = counts(
|
35
|
+
tags = counts.limit(sizes)
|
34
36
|
return [] if tags.blank?
|
35
37
|
|
36
38
|
min = nil
|
data/app/models/cms/tagging.rb
CHANGED
@@ -3,8 +3,8 @@ module Cms
|
|
3
3
|
belongs_to :tag, :class_name => 'Cms::Tag'
|
4
4
|
belongs_to :taggable, :polymorphic => true, :class_name => 'Cms::Taggable', :foreign_type => 'taggable_type'
|
5
5
|
|
6
|
-
|
7
|
-
|
6
|
+
extend DefaultAccessible
|
7
|
+
#attr_accessible :tag, :taggable
|
8
8
|
|
9
9
|
def content_type
|
10
10
|
Cms::ContentType.first(:conditions => {:name => taggable_type})
|
data/app/models/cms/task.rb
CHANGED
@@ -8,17 +8,21 @@ module Cms
|
|
8
8
|
belongs_to :assigned_to, :class_name => 'Cms::User'
|
9
9
|
belongs_to :page, :class_name => 'Cms::Page'
|
10
10
|
|
11
|
-
|
12
|
-
attr_accessible :assigned_by, :assigned_to, :page
|
11
|
+
extend DefaultAccessible
|
13
12
|
|
14
13
|
after_create :mark_other_tasks_for_the_same_page_as_complete
|
15
14
|
after_create :send_email
|
16
15
|
|
17
|
-
scope :complete,
|
18
|
-
scope :incomplete,
|
16
|
+
scope :complete, ->{ where( ["completed_at is not null"])}
|
17
|
+
scope :incomplete, ->{ where( ["completed_at is null"])}
|
19
18
|
|
20
|
-
|
21
|
-
|
19
|
+
def self.for_page(p)
|
20
|
+
where(["page_id = ?", p])
|
21
|
+
end
|
22
|
+
|
23
|
+
def self.other_than(t)
|
24
|
+
where( ["id != ?", t.id])
|
25
|
+
end
|
22
26
|
|
23
27
|
validates_presence_of :assigned_by_id, :message => "is required"
|
24
28
|
validates_presence_of :assigned_to_id, :message => "is required"
|
@@ -36,30 +40,19 @@ module Cms
|
|
36
40
|
|
37
41
|
protected
|
38
42
|
def mark_other_tasks_for_the_same_page_as_complete
|
39
|
-
self.class.for_page(self.page_id.to_i).other_than(self).incomplete.
|
43
|
+
self.class.for_page(self.page_id.to_i).other_than(self).incomplete.to_a.each do |t|
|
40
44
|
t.mark_as_complete!
|
41
45
|
end
|
42
46
|
end
|
43
47
|
|
44
48
|
def send_email
|
45
|
-
|
46
|
-
#For now we'll say just don't send an email and log that as a warning
|
47
|
-
if assigned_by.email.blank?
|
48
|
-
logger.warn "Can't send email for task because assigned by user #{assigned_by.login}:#{assigned_by.id} has no email address"
|
49
|
-
elsif assigned_to.email.blank?
|
49
|
+
if assigned_to.email.blank?
|
50
50
|
logger.warn "Can't send email for task because assigned to user #{assigned_to.login}:#{assigned_to.id} has no email address"
|
51
51
|
else
|
52
|
-
|
53
|
-
if domain =~ /^www/
|
54
|
-
host = domain.sub(/^www\./, "#{cms_domain_prefix}.")
|
55
|
-
else
|
56
|
-
host = "#{cms_domain_prefix}.#{domain}"
|
57
|
-
end
|
58
|
-
email = Cms::EmailMessage.create(
|
59
|
-
:sender => assigned_by.email,
|
52
|
+
Cms::EmailMessage.create(
|
60
53
|
:recipients => assigned_to.email,
|
61
54
|
:subject => "Page '#{page.name}' has been assigned to you",
|
62
|
-
:body => "
|
55
|
+
:body => "#{Cms::EmailMessage.absolute_cms_url(page.path)}\n\n#{comment}"
|
63
56
|
)
|
64
57
|
end
|
65
58
|
true #don't accidently return false and halt the chain
|
data/app/models/cms/templates.rb
CHANGED
@@ -16,11 +16,10 @@ module Cms
|
|
16
16
|
<%= yield :html_head %>
|
17
17
|
</head>
|
18
18
|
<body style="margin: 0; padding: 0; text-align: center;">
|
19
|
-
<%= cms_toolbar %>
|
20
19
|
<div id="wrapper" style="width: 700px; margin: 0 auto; text-align: left; padding: 30px">
|
21
20
|
Breadcrumbs: <%= render_breadcrumbs %>
|
22
21
|
Main Menu: <%= render_menu %>
|
23
|
-
<h1><%=
|
22
|
+
<h1><%= page_header %></h1>
|
24
23
|
<%= container :main %>
|
25
24
|
</div>
|
26
25
|
</body>
|
data/app/models/cms/user.rb
CHANGED
@@ -1,173 +1,34 @@
|
|
1
|
-
require 'digest/sha1'
|
2
|
-
|
3
1
|
module Cms
|
4
|
-
class User < ActiveRecord::Base
|
5
|
-
|
6
|
-
include Cms::Authentication::Model
|
7
|
-
|
8
|
-
validates_presence_of :login
|
9
|
-
#validates_length_of :login, :within => 3..40
|
10
|
-
validates_uniqueness_of :login, :case_sensitive => false
|
11
|
-
validates_format_of :login, :with => /\A\w[\w\.\-_@]+\z/, :message => "use only letters, numbers, and .-_@ please."
|
12
|
-
|
13
|
-
validates_presence_of :email
|
14
|
-
#validates_length_of :email, :within => 6..100 #r@a.wk
|
15
|
-
#validates_uniqueness_of :email, :case_sensitive => false
|
16
|
-
validates_format_of :email, :with => /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i, :message => "should be an email address, ex. xx@xx.com"
|
17
|
-
attr_accessible :login, :email, :name, :first_name, :last_name, :password, :password_confirmation, :expires_at
|
18
2
|
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
def self.current=(user)
|
33
|
-
Thread.current[:cms_user] = user
|
34
|
-
end
|
35
|
-
|
36
|
-
def self.guest(options = {})
|
37
|
-
Cms::GuestUser.new(options)
|
38
|
-
end
|
39
|
-
|
40
|
-
def guest?
|
41
|
-
!!@guest
|
42
|
-
end
|
43
|
-
|
44
|
-
# Determines if this user should have access to the CMS administration tools. Can be overridden by specific users (like GuestUser)
|
45
|
-
# which may not need to check the database for that information.
|
46
|
-
def cms_access?
|
47
|
-
groups.cms_access.count > 0
|
48
|
-
end
|
49
|
-
|
50
|
-
def disable
|
51
|
-
if self.class.count(:conditions => ["expires_at is null and id != ?", id]) > 0
|
52
|
-
self.expires_at = Time.now - 2.minutes
|
53
|
-
else
|
54
|
-
false
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
def disable!
|
59
|
-
unless disable
|
60
|
-
raise "You must have at least 1 enabled user"
|
3
|
+
# Represents a CMS users that is managed through the CMS UI.
|
4
|
+
class User < PersistentUser
|
5
|
+
include Devise::Models::Validatable
|
6
|
+
include Devise::Models::Recoverable
|
7
|
+
|
8
|
+
class << self
|
9
|
+
# Change a given user's password.
|
10
|
+
#
|
11
|
+
# @param [String] login
|
12
|
+
# @param [String] new_password
|
13
|
+
def change_password(login, new_password)
|
14
|
+
find_by_login(login).change_password(new_password)
|
61
15
|
end
|
62
|
-
save!
|
63
|
-
end
|
64
|
-
|
65
|
-
def expired?
|
66
|
-
expires_at && expires_at <= Time.now
|
67
|
-
end
|
68
|
-
|
69
|
-
def enable
|
70
|
-
self.expires_at = nil
|
71
|
-
end
|
72
|
-
|
73
|
-
def enable!
|
74
|
-
enable
|
75
|
-
save!
|
76
|
-
end
|
77
|
-
|
78
|
-
def full_name
|
79
|
-
[first_name, last_name].reject { |e| e.nil? }.join(" ")
|
80
|
-
end
|
81
16
|
|
82
|
-
|
83
|
-
|
84
|
-
end
|
85
|
-
|
86
|
-
def full_name_or_login
|
87
|
-
if full_name.strip.blank?
|
88
|
-
login
|
89
|
-
else
|
90
|
-
full_name
|
17
|
+
def permitted_params
|
18
|
+
super + [:password, :password_confirmation]
|
91
19
|
end
|
92
20
|
end
|
93
21
|
|
94
|
-
#
|
95
|
-
|
96
|
-
|
97
|
-
expires_at ? (expires_at.strftime '%m/%d/%Y') : nil
|
98
|
-
end
|
99
|
-
|
100
|
-
def permissions
|
101
|
-
@permissions ||= Cms::Permission.find(:all, :include => {:groups => :users}, :conditions => ["#{User.table_name}.id = ?", id])
|
22
|
+
# Change this User's password to a new value.
|
23
|
+
def change_password(new_password)
|
24
|
+
update(:password => new_password, :password_confirmation => new_password)
|
102
25
|
end
|
103
26
|
|
104
|
-
|
105
|
-
@viewable_sections ||= Cms::Section.find(:all, :include => {:groups => :users}, :conditions => ["#{User.table_name}.id = ?", id])
|
106
|
-
end
|
107
|
-
|
108
|
-
def modifiable_sections
|
109
|
-
@modifiable_sections ||= Cms::Section.find(:all, :include => {:groups => [:group_type, :users]}, :conditions => ["#{Cms::User.table_name}.id = ? and #{GroupType.table_name}.cms_access = ?", id, true])
|
110
|
-
end
|
111
|
-
|
112
|
-
# Expects a list of names of Permissions
|
113
|
-
# true if the user has any of the permissions
|
114
|
-
def able_to?(*required_permissions)
|
115
|
-
perms = required_permissions.map(&:to_sym)
|
116
|
-
permissions.any? do |p|
|
117
|
-
perms.include?(p.name.to_sym)
|
118
|
-
end
|
119
|
-
end
|
120
|
-
|
121
|
-
# Determine if this user has permission to view the specific object. Permissions
|
122
|
-
# are always tied to a specific section. This method can take different input parameters
|
123
|
-
# and will attempt to determine the relevant section to check.
|
124
|
-
# Expects object to be of type:
|
125
|
-
# 1. Section - Will check the user's groups to see if any of those groups can view this section.
|
126
|
-
# 2. Path - Will look up the section based on the path, then check it. (Note that section paths are not currently unique, so this will check the first one it finds).
|
127
|
-
# 3. Other - Assumes it has a section attribute and will call that and check the return value.
|
27
|
+
# By default, Users are coming from the the CMS database (cms_users). All Cms::User class have have the same source.
|
128
28
|
#
|
129
|
-
#
|
130
|
-
|
131
|
-
|
132
|
-
section = object
|
133
|
-
if object.is_a?(String)
|
134
|
-
section = Cms::Section.find_by_path(object)
|
135
|
-
raise ActiveRecord::RecordNotFound.new("Could not find section with path = '#{object}'") unless section
|
136
|
-
elsif !object.is_a?(Cms::Section)
|
137
|
-
section = object.section
|
138
|
-
end
|
139
|
-
viewable_sections.include?(section) || cms_access?
|
140
|
-
end
|
141
|
-
|
142
|
-
def able_to_modify?(object)
|
143
|
-
case object
|
144
|
-
when Cms::Section
|
145
|
-
modifiable_sections.include?(object)
|
146
|
-
when Cms::Page, Cms::Link
|
147
|
-
modifiable_sections.include?(object.section)
|
148
|
-
else
|
149
|
-
if object.class.respond_to?(:connectable?) && object.class.connectable?
|
150
|
-
object.connected_pages.all? { |page| able_to_modify?(page) }
|
151
|
-
else
|
152
|
-
true
|
153
|
-
end
|
154
|
-
end
|
155
|
-
end
|
156
|
-
|
157
|
-
# Expects node to be a Section, Page or Link
|
158
|
-
# Returns true if the specified node, or any of its ancestor sections, is editable by any of
|
159
|
-
# the user's 'CMS User' groups.
|
160
|
-
def able_to_edit?(object)
|
161
|
-
able_to?(:edit_content) && able_to_modify?(object)
|
162
|
-
end
|
163
|
-
|
164
|
-
def able_to_publish?(object)
|
165
|
-
able_to?(:publish_content) && able_to_modify?(object)
|
29
|
+
# @override #source The otherwise persistent attribute.
|
30
|
+
def source
|
31
|
+
"CMS Users"
|
166
32
|
end
|
167
|
-
|
168
|
-
def able_to_edit_or_publish_content?
|
169
|
-
able_to?(:edit_content, :publish_content)
|
170
|
-
end
|
171
|
-
|
172
33
|
end
|
173
34
|
end
|