your_platform 0.0.1 → 0.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/README.md +39 -11
- data/Rakefile +15 -1
- data/app/assets/images/file.png +0 -0
- data/app/assets/images/img/excel2013_file_128.png +0 -0
- data/app/assets/images/img/excel2013_file_bw_107.png +0 -0
- data/app/assets/images/img/excel2013_file_bw_semitransparent_107.png +0 -0
- data/app/assets/images/img/glyphicons-halflings-white.png +0 -0
- data/app/assets/images/img/glyphicons-halflings.png +0 -0
- data/app/assets/images/img/gmaps_yellow_marker.png +0 -0
- data/app/assets/images/img/gmaps_yellow_marker_38.png +0 -0
- data/app/assets/images/markdown_help.png +0 -0
- data/app/assets/images/your_platform/breadcrumb-sep.png +0 -0
- data/app/assets/javascripts/app-ng.js.coffee +5 -0
- data/app/assets/javascripts/attachments.js +2 -0
- data/app/assets/javascripts/controllers-ng/bookmark_list_controller.js.coffee +30 -0
- data/app/assets/javascripts/controllers-ng/box_controller.js.coffee +37 -0
- data/app/assets/javascripts/controllers-ng/profile_angular.js.coffee +151 -0
- data/app/assets/javascripts/directives-ng/box_directive.js.coffee +91 -0
- data/app/assets/javascripts/directives-ng/star_tool_directive.js.coffee +111 -0
- data/app/assets/javascripts/filters-ng/some_filter.js.coffee +0 -0
- data/app/assets/javascripts/jquery.appear-1.1.1.js +138 -0
- data/app/assets/javascripts/make-js-more-like-ruby.js.coffee +32 -0
- data/app/assets/javascripts/mercury.js +456 -0
- data/app/assets/javascripts/models-ng/bookmark.js.coffee +28 -0
- data/app/assets/javascripts/services-ng/current_user_bookmarks.js.coffee +39 -0
- data/app/assets/javascripts/your_platform.js +27 -0
- data/app/assets/javascripts/your_platform/address_labels.js.coffee +40 -0
- data/app/assets/javascripts/your_platform/attachments.js.coffee +61 -0
- data/app/assets/javascripts/your_platform/auto-completion.js.coffee +90 -0
- data/app/assets/javascripts/your_platform/best_in_place.js.coffee +8 -0
- data/app/assets/javascripts/your_platform/best_in_place_hyperlinks.js.coffee +25 -0
- data/app/assets/javascripts/your_platform/best_in_place_tab_key.js.coffee +28 -0
- data/app/assets/javascripts/your_platform/boxes.js.coffee +11 -0
- data/app/assets/javascripts/your_platform/change_password.js.coffee +22 -0
- data/app/assets/javascripts/your_platform/close_dropdowns.js.coffee +18 -0
- data/app/assets/javascripts/your_platform/copy_to_clipboard.js.coffee +6 -0
- data/app/assets/javascripts/your_platform/datatables.coffee +112 -0
- data/app/assets/javascripts/your_platform/datepicker_settings.js.coffee +16 -0
- data/app/assets/javascripts/your_platform/edit_tools.js.coffee +19 -0
- data/app/assets/javascripts/your_platform/editable_dbl_click.js.coffee +42 -0
- data/app/assets/javascripts/your_platform/events.js.coffee +126 -0
- data/app/assets/javascripts/your_platform/fix_textarea.js.coffee +11 -0
- data/app/assets/javascripts/your_platform/galleria.js.coffee +112 -0
- data/app/assets/javascripts/your_platform/groups.js.coffee +36 -0
- data/app/assets/javascripts/your_platform/hidden.js.coffee +5 -0
- data/app/assets/javascripts/your_platform/links_to_external_sites.js.coffee +12 -0
- data/app/assets/javascripts/your_platform/maps.js.coffee +13 -0
- data/app/assets/javascripts/your_platform/may_need_review.js.coffee +10 -0
- data/app/assets/javascripts/your_platform/navable_title_rename.js.coffee +17 -0
- data/app/assets/javascripts/your_platform/officers.js.coffee +35 -0
- data/app/assets/javascripts/your_platform/popovers.js.coffee +38 -0
- data/app/assets/javascripts/your_platform/posts.js.coffee +58 -0
- data/app/assets/javascripts/your_platform/profile_fields.js.coffee +61 -0
- data/app/assets/javascripts/your_platform/search.js.coffee +26 -0
- data/app/assets/javascripts/your_platform/tooltips.js.coffee +10 -0
- data/app/assets/javascripts/your_platform/turbolinks_loading_spinner.js.coffee +83 -0
- data/app/assets/javascripts/your_platform/user_avatars.js.coffee +33 -0
- data/app/assets/javascripts/your_platform/user_group_memberships.js.coffee +11 -0
- data/app/assets/javascripts/your_platform/user_settings.js.coffee +18 -0
- data/app/assets/javascripts/your_platform/users_new.js.coffee +54 -0
- data/app/assets/stylesheets/bootstrap_layout.css.sass +3 -0
- data/app/assets/stylesheets/bootstrap_layout/attachments.css.sass +3 -0
- data/app/assets/stylesheets/bootstrap_layout/boxes.css.sass +11 -0
- data/app/assets/stylesheets/bootstrap_layout/breadcrumb.css.sass +25 -0
- data/app/assets/stylesheets/bootstrap_layout/category_indicator.css.sass +5 -0
- data/app/assets/stylesheets/bootstrap_layout/footer.css.sass +14 -0
- data/app/assets/stylesheets/bootstrap_layout/galleria.css.sass +8 -0
- data/app/assets/stylesheets/bootstrap_layout/header_bar.css.sass +11 -0
- data/app/assets/stylesheets/bootstrap_layout/headings.css.sass +10 -0
- data/app/assets/stylesheets/bootstrap_layout/logged_in_bar.css.sass +40 -0
- data/app/assets/stylesheets/bootstrap_layout/logo.css.sass +2 -0
- data/app/assets/stylesheets/bootstrap_layout/modal_fix.css.sass +8 -0
- data/app/assets/stylesheets/bootstrap_layout/profiles.css.sass +10 -0
- data/app/assets/stylesheets/bootstrap_layout/session_bar.css.sass +60 -0
- data/app/assets/stylesheets/bootstrap_layout/stars.css.sass +4 -0
- data/app/assets/stylesheets/bootstrap_layout/turbolinks_progress_bar.css.sass +3 -0
- data/app/assets/stylesheets/bootstrap_layout/vertical_menu.css.sass +15 -0
- data/app/assets/stylesheets/bootstrap_setup.css.sass +4 -0
- data/app/assets/stylesheets/your_platform.css.sass +11 -0
- data/app/assets/stylesheets/your_platform/address_labels_modal.css.sass +8 -0
- data/app/assets/stylesheets/your_platform/attachments.css.sass +75 -0
- data/app/assets/stylesheets/your_platform/authorization_info.css.sass +16 -0
- data/app/assets/stylesheets/your_platform/auto-completion.css.sass +3 -0
- data/app/assets/stylesheets/your_platform/center.css.sass +14 -0
- data/app/assets/stylesheets/your_platform/change_password.css.sass +13 -0
- data/app/assets/stylesheets/your_platform/corporate_vita.css.sass +2 -0
- data/app/assets/stylesheets/your_platform/datatables.css.sass +23 -0
- data/app/assets/stylesheets/your_platform/datepicker.css.sass +2 -0
- data/app/assets/stylesheets/your_platform/dropdowns.css.sass +8 -0
- data/app/assets/stylesheets/your_platform/events.css.sass +68 -0
- data/app/assets/stylesheets/your_platform/forms.css.sass +25 -0
- data/app/assets/stylesheets/your_platform/galleria.css.sass +12 -0
- data/app/assets/stylesheets/your_platform/groups.css.sass +8 -0
- data/app/assets/stylesheets/your_platform/groups_table.css.sass +8 -0
- data/app/assets/stylesheets/your_platform/hidden.css.sass +3 -0
- data/app/assets/stylesheets/your_platform/images.css.sass +50 -0
- data/app/assets/stylesheets/your_platform/last_activities.css.sass +17 -0
- data/app/assets/stylesheets/your_platform/latest_members.css.sass +7 -0
- data/app/assets/stylesheets/your_platform/login.css.sass +4 -0
- data/app/assets/stylesheets/your_platform/maps.css.sass +22 -0
- data/app/assets/stylesheets/your_platform/markdown_help.css.sass +5 -0
- data/app/assets/stylesheets/your_platform/may_need_review.css.sass +3 -0
- data/app/assets/stylesheets/your_platform/pages.css.sass +12 -0
- data/app/assets/stylesheets/your_platform/password_strength.css.sass +73 -0
- data/app/assets/stylesheets/your_platform/picture_attachments.css.sass +7 -0
- data/app/assets/stylesheets/your_platform/popovers.css.sass +13 -0
- data/app/assets/stylesheets/your_platform/posts.css.sass +32 -0
- data/app/assets/stylesheets/your_platform/profiles.css.sass +153 -0
- data/app/assets/stylesheets/your_platform/search_preview.css.sass +4 -0
- data/app/assets/stylesheets/your_platform/star_tool.css.sass +2 -0
- data/app/assets/stylesheets/your_platform/tooltips.css.sass +7 -0
- data/app/assets/stylesheets/your_platform/turbolinks_loading_spinner.css.sass +3 -0
- data/app/assets/stylesheets/your_platform/user_avatars.css.sass +8 -0
- data/app/assets/stylesheets/your_platform/user_group_memberships.css.sass +4 -0
- data/app/assets/stylesheets/your_platform/vertical_nav.css.sass +7 -0
- data/app/controllers/activities_controller.rb +6 -0
- data/app/controllers/application_controller.rb +236 -0
- data/app/controllers/attachments_controller.rb +97 -0
- data/app/controllers/blog_posts_controller.rb +50 -0
- data/app/controllers/bookmarks_controller.rb +33 -0
- data/app/controllers/corporations_controller.rb +22 -0
- data/app/controllers/errors_controller.rb +27 -0
- data/app/controllers/events_controller.rb +262 -0
- data/app/controllers/groups_controller.rb +257 -0
- data/app/controllers/officers_controller.rb +28 -0
- data/app/controllers/pages_controller.rb +67 -0
- data/app/controllers/posts_controller.rb +81 -0
- data/app/controllers/profile_fields_controller.rb +132 -0
- data/app/controllers/root_controller.rb +35 -0
- data/app/controllers/search_controller.rb +149 -0
- data/app/controllers/sessions_controller.rb +21 -0
- data/app/controllers/setup_controller.rb +80 -0
- data/app/controllers/statistics_controller.rb +38 -0
- data/app/controllers/status_group_memberships_controller.rb +28 -0
- data/app/controllers/terms_of_use_controller.rb +35 -0
- data/app/controllers/user_accounts_controller.rb +55 -0
- data/app/controllers/user_group_memberships_controller.rb +75 -0
- data/app/controllers/user_settings_controller.rb +57 -0
- data/app/controllers/users_controller.rb +125 -0
- data/app/controllers/workflows_controller.rb +19 -0
- data/app/helpers/application_helper.rb +25 -0
- data/app/helpers/attachments_helper.rb +2 -0
- data/app/helpers/auto_completion_helper.rb +33 -0
- data/app/helpers/avatar_helper.rb +70 -0
- data/app/helpers/bookmarks_helper.rb +22 -0
- data/app/helpers/box_helper.rb +56 -0
- data/app/helpers/breadcrumbs_helper.rb +62 -0
- data/app/helpers/corporate_vita_helper.rb +34 -0
- data/app/helpers/events_helper.rb +28 -0
- data/app/helpers/flash_helper.rb +60 -0
- data/app/helpers/footer_helper.rb +13 -0
- data/app/helpers/galleria_helper.rb +13 -0
- data/app/helpers/groups_helper.rb +66 -0
- data/app/helpers/horizontal_nav_helper.rb +11 -0
- data/app/helpers/i18n_helper.rb +10 -0
- data/app/helpers/icon_helper.rb +35 -0
- data/app/helpers/mailer_helper.rb +7 -0
- data/app/helpers/map_helper.rb +26 -0
- data/app/helpers/markdown_helper.rb +22 -0
- data/app/helpers/markup_helper.rb +25 -0
- data/app/helpers/officers_helper.rb +13 -0
- data/app/helpers/password_helper.rb +23 -0
- data/app/helpers/profile_field_helper.rb +40 -0
- data/app/helpers/profile_helper.rb +69 -0
- data/app/helpers/quick_link_helper.rb +53 -0
- data/app/helpers/special_pages_helper.rb +9 -0
- data/app/helpers/structureable_helper.rb +11 -0
- data/app/helpers/sublime_helper.rb +16 -0
- data/app/helpers/title_helper.rb +52 -0
- data/app/helpers/tool_buttons_helper.rb +74 -0
- data/app/helpers/unicode_helper.rb +9 -0
- data/app/helpers/users_helper.rb +13 -0
- data/app/helpers/vertical_nav_helper.rb +84 -0
- data/app/helpers/workflows_helper.rb +37 -0
- data/app/mailers/event_mailer.rb +13 -0
- data/app/mailers/post_mailer.rb +11 -0
- data/app/mailers/user_account_mailer.rb +17 -0
- data/app/models/ability.rb +321 -0
- data/app/models/active_record_associations_patches.rb +26 -0
- data/app/models/active_record_cache_extension.rb +152 -0
- data/app/models/active_record_find_by_extension.rb +20 -0
- data/app/models/active_record_json_url_extension.rb +51 -0
- data/app/models/active_record_metric_events_extension.rb +22 -0
- data/app/models/active_record_read_only_extension.rb +35 -0
- data/app/models/active_record_update_attributes_bip_extension.rb +24 -0
- data/app/models/address_label.rb +50 -0
- data/app/models/app_version.rb +49 -0
- data/app/models/array.rb +15 -0
- data/app/models/attachment.rb +76 -0
- data/app/models/bashpass_password.rb +32 -0
- data/app/models/blog_post.rb +2 -0
- data/app/models/bookmark.rb +67 -0
- data/app/models/cache_additions.rb +15 -0
- data/app/models/cache_store_extension.rb +78 -0
- data/app/models/concerns/user_avatar.rb +16 -0
- data/app/models/concerns/user_corporations.rb +44 -0
- data/app/models/concerns/user_date_of_birth.rb +74 -0
- data/app/models/concerns/user_profile.rb +102 -0
- data/app/models/corporation.rb +80 -0
- data/app/models/dag_link.rb +29 -0
- data/app/models/event.rb +235 -0
- data/app/models/flag.rb +18 -0
- data/app/models/flagable.rb +62 -0
- data/app/models/geo_location.rb +92 -0
- data/app/models/group.rb +224 -0
- data/app/models/group_mixins/corporations.rb +141 -0
- data/app/models/group_mixins/developers.rb +41 -0
- data/app/models/group_mixins/everyone.rb +72 -0
- data/app/models/group_mixins/guests.rb +61 -0
- data/app/models/group_mixins/hidden_users.rb +43 -0
- data/app/models/group_mixins/import.rb +321 -0
- data/app/models/group_mixins/memberships.rb +207 -0
- data/app/models/group_mixins/officers.rb +47 -0
- data/app/models/group_mixins/roles.rb +41 -0
- data/app/models/horizontal_nav.rb +32 -0
- data/app/models/last_seen_activity.rb +10 -0
- data/app/models/list_export.rb +359 -0
- data/app/models/may_need_review.rb +54 -0
- data/app/models/metric_logger.rb +83 -0
- data/app/models/nav_node.rb +169 -0
- data/app/models/navable.rb +46 -0
- data/app/models/object_to_b_extension.rb +12 -0
- data/app/models/page.rb +212 -0
- data/app/models/password.rb +28 -0
- data/app/models/post.rb +199 -0
- data/app/models/profile.rb +36 -0
- data/app/models/profile_field.rb +196 -0
- data/app/models/profile_field_mixins/has_child_profile_fields.rb +114 -0
- data/app/models/profile_field_types/about.rb +9 -0
- data/app/models/profile_field_types/academic_degree.rb +10 -0
- data/app/models/profile_field_types/address.rb +88 -0
- data/app/models/profile_field_types/bank_account.rb +12 -0
- data/app/models/profile_field_types/competence.rb +7 -0
- data/app/models/profile_field_types/custom.rb +12 -0
- data/app/models/profile_field_types/date.rb +14 -0
- data/app/models/profile_field_types/description.rb +15 -0
- data/app/models/profile_field_types/email.rb +20 -0
- data/app/models/profile_field_types/employment.rb +24 -0
- data/app/models/profile_field_types/general.rb +9 -0
- data/app/models/profile_field_types/homepage.rb +19 -0
- data/app/models/profile_field_types/name_surrounding.rb +11 -0
- data/app/models/profile_field_types/organization.rb +24 -0
- data/app/models/profile_field_types/phone.rb +37 -0
- data/app/models/profile_field_types/professional_category.rb +8 -0
- data/app/models/profile_field_types/study.rb +18 -0
- data/app/models/profile_section.rb +49 -0
- data/app/models/profileable.rb +58 -0
- data/app/models/profileable_mixins/address.rb +118 -0
- data/app/models/relationship.rb +78 -0
- data/app/models/role.rb +164 -0
- data/app/models/setting.rb +9 -0
- data/app/models/status_group.rb +28 -0
- data/app/models/status_group_membership.rb +189 -0
- data/app/models/status_group_membership_info.rb +54 -0
- data/app/models/structureable.rb +164 -0
- data/app/models/structureable_mixins/has_special_groups.rb +127 -0
- data/app/models/structureable_mixins/roles.rb +275 -0
- data/app/models/user.rb +878 -0
- data/app/models/user_account.rb +162 -0
- data/app/models/user_alias.rb +112 -0
- data/app/models/user_group_membership.rb +300 -0
- data/app/models/user_group_membership_mixins/validity_range.rb +206 -0
- data/app/models/user_group_membership_mixins/validity_range_for_indirect_memberships.rb +160 -0
- data/app/models/user_mixins/identification.rb +36 -0
- data/app/models/user_mixins/memberships.rb +75 -0
- data/app/models/workflow.rb +40 -0
- data/app/models/workflow_kit/add_to_group_brick.rb +21 -0
- data/app/models/workflow_kit/destroy_account_and_end_memberships_if_needed_brick.rb +19 -0
- data/app/models/workflow_kit/last_membership_needs_review_brick.rb +19 -0
- data/app/models/workflow_kit/mark_as_deceased_brick.rb +17 -0
- data/app/models/workflow_kit/remove_from_group_brick.rb +27 -0
- data/app/models/workflow_kit/test_brick.rb +13 -0
- data/app/pdfs/address_labels_pdf.rb +157 -0
- data/app/presenters/base_presenter.rb +52 -0
- data/app/presenters/horizontal_nav_presenter.rb +106 -0
- data/app/uploaders/attachment_uploader.rb +148 -0
- data/app/views/activities/index.html.haml +25 -0
- data/app/views/attachments/_attachment.html.haml +20 -0
- data/app/views/attachments/_description.html.haml +11 -0
- data/app/views/attachments/_documents.html.haml +17 -0
- data/app/views/attachments/_drop_field.html.haml +46 -0
- data/app/views/attachments/_picture.html.haml +2 -0
- data/app/views/attachments/_pictures.html.haml +10 -0
- data/app/views/attachments/_video.html.haml +8 -0
- data/app/views/attachments/create.js.erb +1 -0
- data/app/views/attachments/destroy.js.erb +1 -0
- data/app/views/blog_posts/create.js.erb +17 -0
- data/app/views/bookmarks/_list.html.haml +7 -0
- data/app/views/bookmarks/update.js.erb +4 -0
- data/app/views/devise/mailer/reset_password_instructions.html.haml +8 -0
- data/app/views/devise/passwords/edit.html.haml +1 -0
- data/app/views/devise/passwords/new.html.haml +12 -0
- data/app/views/devise/registrations/edit.html.haml +1 -0
- data/app/views/devise/sessions/new.html.haml +14 -0
- data/app/views/devise/shared/_links.haml +26 -0
- data/app/views/errors/show.html.haml +5 -0
- data/app/views/errors/unauthorized.html.haml +7 -0
- data/app/views/event_mailer/invitation_email.html.erb +63 -0
- data/app/views/events/_event_details.html.haml +54 -0
- data/app/views/events/_events_lis.html.haml +29 -0
- data/app/views/events/_invitation_text.html.erb +8 -0
- data/app/views/events/_pictures.html.haml +5 -0
- data/app/views/events/_public_index.html.haml +16 -0
- data/app/views/events/index.html.haml +24 -0
- data/app/views/events/show.html.haml +50 -0
- data/app/views/groups/_address_labels_modal.html.haml +27 -0
- data/app/views/groups/_export_button.html.haml +66 -0
- data/app/views/groups/_group_list.html.haml +25 -0
- data/app/views/groups/_member_avatars.html.haml +4 -0
- data/app/views/groups/_member_list.html.haml +15 -0
- data/app/views/groups/index.html.erb +11 -0
- data/app/views/groups/index_mine.html.haml +7 -0
- data/app/views/groups/show.html.haml +79 -0
- data/app/views/last_seen_activities/_index.html.haml +19 -0
- data/app/views/layouts/_add_structureable_additions.html.haml +15 -0
- data/app/views/layouts/_box.html.haml +16 -0
- data/app/views/layouts/_help_button.html.haml +1 -0
- data/app/views/layouts/_role_preview_switcher.html.haml +20 -0
- data/app/views/layouts/_session_bar_avatar.html.haml +1 -0
- data/app/views/layouts/_vertical_nav.html.haml +5 -0
- data/app/views/layouts/bootstrap.html.haml +146 -0
- data/app/views/layouts/mercury.html.erb +23 -0
- data/app/views/officers/_history_notice.html.haml +4 -0
- data/app/views/officers/_officers_box.html.haml +33 -0
- data/app/views/officers/_officers_group_entry.html.haml +45 -0
- data/app/views/pages/_attachments.html.haml +21 -0
- data/app/views/pages/_page.html.haml +28 -0
- data/app/views/pages/_pictures.html.haml +2 -0
- data/app/views/pages/_videos.html.erb +8 -0
- data/app/views/pages/show.html.haml +39 -0
- data/app/views/post_mailer/post_email.html.erb +17 -0
- data/app/views/posts/_new_post_template_text.html.haml +6 -0
- data/app/views/posts/_post.html.haml +13 -0
- data/app/views/posts/_post_quote.html.haml +18 -0
- data/app/views/posts/_posts.html.haml +6 -0
- data/app/views/posts/index.html.haml +9 -0
- data/app/views/posts/new.html.haml +42 -0
- data/app/views/posts/show.html.haml +8 -0
- data/app/views/profile_fields/_postal_address_flag_switch.html.haml +21 -0
- data/app/views/profile_fields/_profile_field.html.haml +41 -0
- data/app/views/profile_fields/create.js.erb +26 -0
- data/app/views/profile_fields/destroy.js.erb +3 -0
- data/app/views/profiles/_add_profile_field_button.html.haml +15 -0
- data/app/views/profiles/_profile_section_ul.html.haml +8 -0
- data/app/views/profiles/_section.html.haml +28 -0
- data/app/views/profiles/_send_group_message_button.html.haml +4 -0
- data/app/views/root/_latest_members_box.html.haml +19 -0
- data/app/views/root/_start_page_elements.html.haml +0 -0
- data/app/views/root/_what_is_new.html.haml +21 -0
- data/app/views/search/_preview_blog_post.html.haml +1 -0
- data/app/views/search/_preview_corporation.html.haml +5 -0
- data/app/views/search/_preview_group.html.haml +4 -0
- data/app/views/search/_preview_page.html.haml +11 -0
- data/app/views/search/_preview_user.html.haml +14 -0
- data/app/views/search/index.html.haml +42 -0
- data/app/views/setup/index.html.haml +56 -0
- data/app/views/shared/_add_structureable.html.haml +22 -0
- data/app/views/shared/_authorization_info.html.haml +22 -0
- data/app/views/shared/_flags.html.haml +5 -0
- data/app/views/shared/_markdown_help.html.haml +4 -0
- data/app/views/shared/_search_box.html.haml +2 -0
- data/app/views/shared/_upcoming_events.html.haml +33 -0
- data/app/views/statistics/index.html.haml +16 -0
- data/app/views/statistics/show.html.haml +13 -0
- data/app/views/terms_of_use/_checkbox.html.haml +1 -0
- data/app/views/terms_of_use/_terms.html.haml +1 -0
- data/app/views/terms_of_use/index.html.haml +19 -0
- data/app/views/user_account_mailer/welcome_email.html.erb +32 -0
- data/app/views/user_accounts/_change_password.html.haml +149 -0
- data/app/views/user_accounts/_user_account.html.haml +39 -0
- data/app/views/user_group_memberships/_list_item.html.haml +9 -0
- data/app/views/user_group_memberships/_memberships_table.html.haml +56 -0
- data/app/views/user_group_memberships/_new.html.haml +18 -0
- data/app/views/user_group_memberships/create.js.erb +9 -0
- data/app/views/user_group_memberships/index.html.haml +5 -0
- data/app/views/user_settings/show.html.haml +36 -0
- data/app/views/users/_avatar.html.haml +16 -0
- data/app/views/users/_communication_box.html.haml +8 -0
- data/app/views/users/_corporate_vita.html.haml +23 -0
- data/app/views/users/_dead_badge.html.haml +3 -0
- data/app/views/users/_deceased_modal.html.haml +24 -0
- data/app/views/users/_hidden_badge.html.haml +4 -0
- data/app/views/users/_hidden_flag_switch.html.haml +20 -0
- data/app/views/users/_special_general_info_fields.html.haml +10 -0
- data/app/views/users/_user_corporation_attribute.html.haml +6 -0
- data/app/views/users/_user_name_attribute.html.haml +4 -0
- data/app/views/users/_user_title.html.haml +5 -0
- data/app/views/users/_workflow_triggers.html.haml +23 -0
- data/app/views/users/new.html.haml +55 -0
- data/app/views/users/show.html.haml +79 -0
- data/config/environment.rb +5 -0
- data/config/initializers/active_record_cache_extension.rb +1 -0
- data/config/initializers/active_record_find_by_extension.rb +1 -0
- data/config/initializers/active_record_flagable_extension.rb +2 -0
- data/config/initializers/active_record_json_url_extension.rb +1 -0
- data/config/initializers/active_record_may_need_review_extension.rb +2 -0
- data/config/initializers/active_record_metric_events_extension.rb +1 -0
- data/config/initializers/active_record_navable_extension.rb +6 -0
- data/config/initializers/active_record_profileable_extension.rb +4 -0
- data/config/initializers/active_record_read_only_extension.rb +1 -0
- data/config/initializers/active_record_structureable_extension.rb +3 -0
- data/config/initializers/active_record_update_attributes_bip_extension.rb +1 -0
- data/config/initializers/array_extension.rb +1 -0
- data/config/initializers/best_in_place_display_definitions.rb +31 -0
- data/config/initializers/cache_store_extension.rb +1 -0
- data/config/initializers/devise.rb +240 -0
- data/config/initializers/fnordmetric.rb +14 -0
- data/config/initializers/formtastic.rb +76 -0
- data/config/initializers/group_type_column_patches.rb +11 -0
- data/config/initializers/mime_types.rb +1 -0
- data/config/initializers/mini_profiler.rb +32 -0
- data/config/initializers/object_to_b_extension.rb +1 -0
- data/config/initializers/refile.rb +22 -0
- data/config/initializers/sidekiq.rb +12 -0
- data/config/locales/attachments/de.yml +33 -0
- data/config/locales/bookmarks/de.yml +3 -0
- data/config/locales/bookmarks/en.yml +3 -0
- data/config/locales/common_expressions/de.yml +5 -0
- data/config/locales/common_expressions/en.yml +5 -0
- data/config/locales/companies/de.yml +4 -0
- data/config/locales/companies/en.yml +4 -0
- data/config/locales/de.yml +30 -0
- data/config/locales/devise/de.yml +60 -0
- data/config/locales/devise/en.yml +62 -0
- data/config/locales/en.yml +25 -0
- data/config/locales/events/de.yml +34 -0
- data/config/locales/events/en.yml +34 -0
- data/config/locales/forms/de.yml +3 -0
- data/config/locales/groups/de.yml +56 -0
- data/config/locales/groups/en.yml +47 -0
- data/config/locales/officers/de.yml +10 -0
- data/config/locales/pages/de.yml +15 -0
- data/config/locales/pages/en.yml +14 -0
- data/config/locales/pagination/de.yml +6 -0
- data/config/locales/pagination/en.yml +5 -0
- data/config/locales/password_strength/de.yml +9 -0
- data/config/locales/password_strength/en.yml +9 -0
- data/config/locales/posts/de.yml +9 -0
- data/config/locales/profile_fields/de.yml +78 -0
- data/config/locales/profile_fields/en.yml +22 -0
- data/config/locales/profiles/de.yml +47 -0
- data/config/locales/profiles/en.yml +44 -0
- data/config/locales/roles/de.yml +9 -0
- data/config/locales/root/de.yml +3 -0
- data/config/locales/root/en.yml +3 -0
- data/config/locales/search/de.yml +11 -0
- data/config/locales/search/en.yml +11 -0
- data/config/locales/sessions/de.yml +37 -0
- data/config/locales/sessions/en.yml +37 -0
- data/config/locales/setup/de.yml +26 -0
- data/config/locales/setup/en.yml +26 -0
- data/config/locales/statistics/de.yml +6 -0
- data/config/locales/terms_of_use/de.yml +6 -0
- data/config/locales/tools/de.yml +9 -0
- data/config/locales/tools/en.yml +9 -0
- data/config/locales/user_accounts/de.yml +16 -0
- data/config/locales/user_accounts/en.yml +13 -0
- data/config/locales/user_settings/de.yml +9 -0
- data/config/locales/users/de.yml +82 -0
- data/config/locales/users/en.yml +51 -0
- data/config/locales/workflows/de.yml +4 -0
- data/config/locales/workflows/en.yml +4 -0
- data/config/routes.rb +104 -0
- data/db/migrate/20120403002734_create_users.rb +12 -0
- data/db/migrate/20120403011601_create_profile_fields.rb +11 -0
- data/db/migrate/20120403161549_remove_user_email_column.rb +5 -0
- data/db/migrate/20120405222050_encrypt_password.rb +8 -0
- data/db/migrate/20120425161138_create_dag_links.rb +14 -0
- data/db/migrate/20120425162644_create_pages.rb +10 -0
- data/db/migrate/20120426023322_create_groups.rb +9 -0
- data/db/migrate/20120426090436_create_nav_nodes.rb +18 -0
- data/db/migrate/20120427021934_create_user_accounts.rb +12 -0
- data/db/migrate/20120427044338_add_foreign_key_to_user_accounts.rb +7 -0
- data/db/migrate/20120427150156_add_group_token.rb +8 -0
- data/db/migrate/20120507165551_make_profile_fields_polymorphic.rb +11 -0
- data/db/migrate/20120508130729_add_profile_field_acts_as_tree.rb +9 -0
- data/db/migrate/20120508152233_change_profile_field_value_to_text.rb +9 -0
- data/db/migrate/20120508201550_add_group_internal_token.rb +11 -0
- data/db/migrate/20120511090234_create_workflows.rb +9 -0
- data/db/migrate/20120701115059_add_password_digest_to_user_accounts.rb +5 -0
- data/db/migrate/20120710193308_remove_salt_from_user_accounts.rb +5 -0
- data/db/migrate/20120713102445_add_deleted_at_to_dag_links.rb +5 -0
- data/db/migrate/20120722005022_create_workflow_kit_workflows.workflow_kit.rb +11 -0
- data/db/migrate/20120722005023_create_workflow_kit_steps.workflow_kit.rb +12 -0
- data/db/migrate/20120722005024_create_workflow_kit_parameters.workflow_kit.rb +12 -0
- data/db/migrate/20120723165226_add_female_to_users.rb +5 -0
- data/db/migrate/20120811140509_create_flags.rb +11 -0
- data/db/migrate/20120814100529_create_attachments.rb +13 -0
- data/db/migrate/20120815205610_add_content_type_and_file_size_to_attachments.rb +6 -0
- data/db/migrate/20130118220014_add_relationships_table_without_dag.rb +10 -0
- data/db/migrate/20130207214331_create_events.rb +12 -0
- data/db/migrate/20130208215253_create_status_group_membership_infos.rb +11 -0
- data/db/migrate/20130220184943_create_stars.rb +11 -0
- data/db/migrate/20130309193623_add_devise_to_user_accounts.rb +72 -0
- data/db/migrate/20130310003840_rename_stars_to_bookmarks.rb +9 -0
- data/db/migrate/20130310004622_fix_column_names_for_bookmarks.rb +6 -0
- data/db/migrate/20130313211414_create_geo_infos.rb +13 -0
- data/db/migrate/20130313234131_create_geo_locations.rb +16 -0
- data/db/migrate/20130314011638_drop_geo_infos.rb +5 -0
- data/db/migrate/20130315072759_add_invalid_to_geo_location.rb +5 -0
- data/db/migrate/20130315073149_exchange_invalid_for_queried_at_in_geo_location.rb +8 -0
- data/db/migrate/20130320003051_add_redirect_to_to_page.rb +5 -0
- data/db/migrate/20130329231657_create_posts.rb +15 -0
- data/db/migrate/20130404223735_add_entire_message_to_posts.rb +5 -0
- data/db/migrate/20130409192959_add_author_to_page.rb +5 -0
- data/db/migrate/20130908011215_add_type_to_pages.rb +5 -0
- data/db/migrate/20131115114715_validity_range_for_dag_links.rb +16 -0
- data/db/migrate/20140611170430_create_activities.rb +23 -0
- data/db/migrate/20140808223512_create_last_seen_activities.rb +12 -0
- data/db/migrate/20141008101744_add_location_to_events.rb +5 -0
- data/db/migrate/20141010130344_add_publish_on_website_to_events.rb +6 -0
- data/db/migrate/20141010134227_add_auth_token_to_user_accounts.rb +5 -0
- data/db/migrate/20141018143323_add_accepted_terms_to_users.rb +6 -0
- data/db/migrate/20141018221659_add_author_to_attachments.rb +5 -0
- data/db/migrate/20141102223954_add_body_to_groups.rb +5 -0
- data/db/migrate/20141110193830_create_settings.rb +17 -0
- data/db/migrate/20141202140522_add_indices.rb +6 -0
- data/db/migrate/20141209161946_add_keys.rb +20 -0
- data/db/migrate/20150127013809_add_incognito_to_users.rb +5 -0
- data/db/migrate/20150129194501_add_indices_for_polymorphic_references.rb +13 -0
- data/db/migrate/20150304192448_add_type_to_groups.rb +5 -0
- data/db/migrate/20150313221004_add_avatar_id_to_users.rb +5 -0
- data/lib/best_in_place/controller_extensions.rb +25 -0
- data/lib/best_in_place/helper.rb +127 -0
- data/lib/tasks/db_bootstrap.rake +37 -0
- data/lib/tasks/your_platform_tasks.rake +4 -0
- data/lib/templates/erb/scaffold/_form.html.erb +11 -0
- data/lib/your_platform.rb +6 -2
- data/lib/your_platform/engine.rb +127 -0
- data/lib/your_platform/version.rb +1 -1
- data/spec/factories/attachment.rb +12 -0
- data/spec/factories/blog_post.rb +10 -0
- data/spec/factories/company.rb +7 -0
- data/spec/factories/corporation.rb +20 -0
- data/spec/factories/event.rb +13 -0
- data/spec/factories/group.rb +36 -0
- data/spec/factories/html_email.eml +1059 -0
- data/spec/factories/mail_message.rb +30 -0
- data/spec/factories/page.rb +10 -0
- data/spec/factories/relationship.rb +13 -0
- data/spec/factories/status_group_membership.rb +21 -0
- data/spec/factories/user.rb +97 -0
- data/spec/factories/workflow.rb +44 -0
- data/spec/features/blog_post_spec.rb +46 -0
- data/spec/features/corporate_vita_events_spec.rb +114 -0
- data/spec/features/corporate_vita_spec.rb +258 -0
- data/spec/features/edit_mode_after_clicking_a_link_spec.rb +20 -0
- data/spec/features/events_spec.rb +356 -0
- data/spec/features/group_export_spec.rb +19 -0
- data/spec/features/group_post_spec.rb +89 -0
- data/spec/features/groups_of_groups_page_spec.rb +67 -0
- data/spec/features/groups_page_spec.rb +66 -0
- data/spec/features/groups_table_spec.rb +32 -0
- data/spec/features/help_page_spec.rb +22 -0
- data/spec/features/intranet_root_page_spec.rb +18 -0
- data/spec/features/locales_spec.rb +36 -0
- data/spec/features/maps_spec.rb +53 -0
- data/spec/features/mini_profiler_spec.rb +37 -0
- data/spec/features/officers_spec.rb +61 -0
- data/spec/features/page_redirects_spec.rb +23 -0
- data/spec/features/page_spec.rb +20 -0
- data/spec/features/postal_address_flag_spec.rb +46 -0
- data/spec/features/relationships_on_user_page_spec.rb +78 -0
- data/spec/features/review_membership_spec.rb +44 -0
- data/spec/features/search_field_spec.rb +121 -0
- data/spec/features/setup_spec.rb +63 -0
- data/spec/features/user_change_date_of_birth_spec.rb +26 -0
- data/spec/features/vertical_nav_spec.rb +27 -0
- data/spec/features/what_is_new_box_spec.rb +33 -0
- data/spec/helpers/attachments_helper_spec.rb +15 -0
- data/spec/models/ability_spec.rb +93 -0
- data/spec/models/active_record_cache_extension_spec.rb +177 -0
- data/spec/models/active_record_find_by_extension_spec.rb +26 -0
- data/spec/models/active_record_json_url_extension_spec.rb +79 -0
- data/spec/models/address_label_spec.rb +144 -0
- data/spec/models/app_version_spec.rb +38 -0
- data/spec/models/attachment_spec.rb +5 -0
- data/spec/models/bookmark_spec.rb +70 -0
- data/spec/models/concerns/user_corporations_spec.rb +71 -0
- data/spec/models/corporation_spec.rb +128 -0
- data/spec/models/dag_link_spec.rb +48 -0
- data/spec/models/event_spec.rb +267 -0
- data/spec/models/flag_spec.rb +20 -0
- data/spec/models/flagable_spec.rb +55 -0
- data/spec/models/geo_location_spec.rb +126 -0
- data/spec/models/group_mixins/corporations_spec.rb +95 -0
- data/spec/models/group_mixins/everyone_spec.rb +64 -0
- data/spec/models/group_mixins/guests_spec.rb +75 -0
- data/spec/models/group_mixins/hidden_users_spec.rb +21 -0
- data/spec/models/group_mixins/import_spec.rb +93 -0
- data/spec/models/group_mixins/memberships_spec.rb +303 -0
- data/spec/models/group_mixins/officers_spec.rb +63 -0
- data/spec/models/group_mixins/roles_spec.rb +46 -0
- data/spec/models/group_spec.rb +341 -0
- data/spec/models/list_export_spec.rb +155 -0
- data/spec/models/may_need_review_spec.rb +114 -0
- data/spec/models/nav_node_spec.rb +277 -0
- data/spec/models/navable_spec.rb +54 -0
- data/spec/models/page_spec.rb +185 -0
- data/spec/models/post_spec.rb +271 -0
- data/spec/models/profile_field_mixins/has_child_profile_fields_spec.rb +73 -0
- data/spec/models/profile_field_spec.rb +482 -0
- data/spec/models/profile_section_spec.rb +89 -0
- data/spec/models/profile_spec.rb +74 -0
- data/spec/models/profileable_mixins/adress_spec.rb +93 -0
- data/spec/models/profileable_spec.rb +152 -0
- data/spec/models/relationship_spec.rb +113 -0
- data/spec/models/status_group_membership_spec.rb +350 -0
- data/spec/models/status_group_spec.rb +103 -0
- data/spec/models/structureable_mixins/has_special_groups_spec.rb +479 -0
- data/spec/models/structureable_mixins/roles_spec.rb +517 -0
- data/spec/models/structureable_spec.rb +128 -0
- data/spec/models/user_account_spec.rb +142 -0
- data/spec/models/user_alias_spec.rb +57 -0
- data/spec/models/user_group_membership_mixins/validity_range_for_indirect_memberships_spec.rb +291 -0
- data/spec/models/user_group_membership_mixins/validity_range_spec.rb +293 -0
- data/spec/models/user_group_membership_spec.rb +428 -0
- data/spec/models/user_mixins/identification_spec.rb +27 -0
- data/spec/models/user_mixins/memberships_spec.rb +138 -0
- data/spec/models/user_spec.rb +1794 -0
- data/spec/old_yp_spec_helper.rb +46 -0
- data/spec/spec_helper.rb +350 -0
- data/spec/support/auto_complete.rb +22 -0
- data/spec/support/capybara/flash_helpers.rb +37 -0
- data/spec/support/capybara/profile_steps.rb +73 -0
- data/spec/support/capybara/session_steps.rb +53 -0
- data/spec/support/capybara/user_account_helpers.rb +15 -0
- data/spec/support/debug.rb +8 -0
- data/spec/support/devise-controller_macros.rb +15 -0
- data/spec/support/geocoder/stubs.rb +60 -0
- data/spec/support/press_enter.rb +15 -0
- data/spec/support/time_travel.rb +9 -0
- data/spec/support/uploads/image-upload.png +0 -0
- data/spec/support/uploads/pdf-upload.pdf +0 -0
- data/spec/support/wait_for_ajax.rb +39 -0
- data/spec/support/wait_for_cache.rb +7 -0
- data/spec/uploaders/attachment_uploader_spec.rb +47 -0
- data/vendor/assets/images/flags.png +0 -0
- data/vendor/assets/images/galleria/classic-loader.gif +0 -0
- data/vendor/assets/images/galleria/classic-map.png +0 -0
- data/vendor/assets/javascripts/best_in_place_datetime.js.coffee +45 -0
- data/vendor/assets/javascripts/galleria-classic.js +100 -0
- data/vendor/assets/javascripts/galleria.js +6919 -0
- data/vendor/assets/javascripts/gmaps4rails.js +2 -0
- data/vendor/assets/javascripts/gmaps4rails/all.js +1 -0
- data/vendor/assets/javascripts/gmaps4rails/base.coffee +1 -0
- data/vendor/assets/javascripts/gmaps4rails/base/common.coffee +43 -0
- data/vendor/assets/javascripts/gmaps4rails/base/configuration.coffee +7 -0
- data/vendor/assets/javascripts/gmaps4rails/base/gmaps.coffee +13 -0
- data/vendor/assets/javascripts/gmaps4rails/base/interfaces/basic_interface.coffee +15 -0
- data/vendor/assets/javascripts/gmaps4rails/base/interfaces/controller_interface.coffee +15 -0
- data/vendor/assets/javascripts/gmaps4rails/base/interfaces/map_interface.coffee +27 -0
- data/vendor/assets/javascripts/gmaps4rails/base/interfaces/marker_interface.coffee +15 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main.coffee +124 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main_controller_extensions/circle_controller.coffee +29 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main_controller_extensions/kml_controller.coffee +5 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main_controller_extensions/marker_controller.coffee +76 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main_controller_extensions/polygon_controller.coffee +29 -0
- data/vendor/assets/javascripts/gmaps4rails/base/main_controller_extensions/polyline_controller.coffee +29 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/circle.coffee +12 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/kml.coffee +8 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/map.coffee +62 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/marker.coffee +24 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/polygon.coffee +11 -0
- data/vendor/assets/javascripts/gmaps4rails/base/objects/polyline.coffee +11 -0
- data/vendor/assets/javascripts/gmaps4rails/bing.coffee +1 -0
- data/vendor/assets/javascripts/gmaps4rails/bing/main.coffee +29 -0
- data/vendor/assets/javascripts/gmaps4rails/bing/objects/map.coffee +63 -0
- data/vendor/assets/javascripts/gmaps4rails/bing/objects/marker.coffee +78 -0
- data/vendor/assets/javascripts/gmaps4rails/bing/shared.coffee +20 -0
- data/vendor/assets/javascripts/gmaps4rails/google.coffee +1 -0
- data/vendor/assets/javascripts/gmaps4rails/google/main.coffee +47 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/circle.coffee +38 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/kml.coffee +16 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/map.coffee +71 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/marker.coffee +114 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/polygon.coffee +38 -0
- data/vendor/assets/javascripts/gmaps4rails/google/objects/polyline.coffee +49 -0
- data/vendor/assets/javascripts/gmaps4rails/google/shared.coffee +27 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers.coffee +1 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers/main.coffee +138 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers/objects/map.coffee +49 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers/objects/marker.coffee +68 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers/objects/polyline.coffee +39 -0
- data/vendor/assets/javascripts/gmaps4rails/openlayers/shared.coffee +19 -0
- data/vendor/assets/javascripts/jquery-ui-timepicker-addon.js +2223 -0
- data/vendor/assets/javascripts/jquery-ui-timepicker-de.js +26 -0
- data/vendor/assets/javascripts/jquery.ui.datepicker-de.js +23 -0
- data/vendor/assets/javascripts/password_strength.js +149 -0
- data/vendor/assets/javascripts/zxcvbn.js +43 -0
- data/vendor/assets/stylesheets/flags.css.scss +259 -0
- data/vendor/assets/stylesheets/galleria-classic.css.scss +239 -0
- data/vendor/assets/stylesheets/gmaps4rails.css +24 -0
- data/vendor/assets/stylesheets/mercury.css +24 -0
- data/vendor/scripts/bashpass/README.md +29 -0
- data/vendor/scripts/bashpass/bashpass +124 -0
- data/vendor/scripts/bashpass/bashpass-APACHE-LICENSE +201 -0
- data/vendor/scripts/bashpass/german.dic +40794 -0
- metadata +1540 -16
- data/.gitignore +0 -17
- data/Gemfile +0 -4
- data/LICENSE.txt +0 -4
- data/your_platform.gemspec +0 -19
@@ -0,0 +1,517 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
unless ActiveRecord::Migration.table_exists? :my_structureables
|
4
|
+
ActiveRecord::Migration.create_table :my_structureables do |t|
|
5
|
+
t.string :name
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
describe StructureableMixins::Roles do
|
10
|
+
|
11
|
+
before do
|
12
|
+
class MyStructureable < ActiveRecord::Base
|
13
|
+
attr_accessible :name
|
14
|
+
is_structureable( ancestor_class_names: %w(MyStructureable Group),
|
15
|
+
descendant_class_names: %w(MyStructureable Group User) )
|
16
|
+
end
|
17
|
+
|
18
|
+
@my_structureable = MyStructureable.create( name: "My Structureable" )
|
19
|
+
end
|
20
|
+
|
21
|
+
|
22
|
+
# Admins
|
23
|
+
# ==========================================================================================
|
24
|
+
|
25
|
+
describe "#admins_parent" do
|
26
|
+
subject { @my_structureable.admins_parent }
|
27
|
+
it { should == @my_structureable.find_admins_parent_group }
|
28
|
+
end
|
29
|
+
|
30
|
+
describe "#admins_parent!" do
|
31
|
+
subject { @my_structureable.admins_parent! }
|
32
|
+
describe "for the group not existing" do
|
33
|
+
it "should raise an error" do
|
34
|
+
expect { subject }.to raise_error
|
35
|
+
end
|
36
|
+
end
|
37
|
+
describe "for the group existing" do
|
38
|
+
before { @admins_parent_group = @my_structureable.find_or_create_admins_parent_group }
|
39
|
+
it { should == @admins_parent_group }
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
describe "#find_admins_parent_group" do
|
44
|
+
subject { @my_structureable.find_admins_parent_group }
|
45
|
+
context "if existent" do
|
46
|
+
before { @admins_parent_group = @my_structureable.find_or_create_admins_parent_group }
|
47
|
+
it "should return the existant group" do
|
48
|
+
subject.should == @admins_parent_group
|
49
|
+
end
|
50
|
+
end
|
51
|
+
context "if absent" do
|
52
|
+
it { should == nil }
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
describe "#create_admins_parent_group" do
|
57
|
+
subject { @my_structureable.create_admins_parent_group }
|
58
|
+
context "if existant" do
|
59
|
+
before { @my_structureable.create_admins_parent_group }
|
60
|
+
it "should raise an error" do
|
61
|
+
expect { subject }.to raise_error
|
62
|
+
end
|
63
|
+
end
|
64
|
+
context "if absent" do
|
65
|
+
it "create the group" do
|
66
|
+
@my_structureable.find_admins_parent_group.should == nil
|
67
|
+
@admins_parent_group = subject
|
68
|
+
@my_structureable.find_admins_parent_group.should == @admins_parent_group
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
describe "#admins" do
|
74
|
+
subject { @my_structureable.admins }
|
75
|
+
context "if the admins_parent_group exists" do
|
76
|
+
before { @my_structureable.find_or_create_admins_parent_group }
|
77
|
+
it { should == [] }
|
78
|
+
end
|
79
|
+
context "if admin users exist" do
|
80
|
+
before do
|
81
|
+
@admin_user = create( :user )
|
82
|
+
@my_structureable.admins_parent.child_users << @admin_user
|
83
|
+
end
|
84
|
+
it "should return an array of admin users" do
|
85
|
+
subject.should == [ @admin_user ]
|
86
|
+
end
|
87
|
+
end
|
88
|
+
context "if the admins-parent group does not exist" do
|
89
|
+
it "should return an empty array" do
|
90
|
+
subject.should == []
|
91
|
+
end
|
92
|
+
end
|
93
|
+
end
|
94
|
+
|
95
|
+
describe "#admins_of_self_and_ancestors" do
|
96
|
+
subject { @my_structureable.admins_of_self_and_ancestors }
|
97
|
+
before do
|
98
|
+
# ATTENTION: For cache deletion, the `descendants` method is called
|
99
|
+
# on the ancestors.
|
100
|
+
# Since the ancestor classes are not patched to include the
|
101
|
+
# `MyStructureable` as descendants,
|
102
|
+
# they are not included in the cache deletion process. To test cache
|
103
|
+
# deletion properly,
|
104
|
+
# we can't use `MyStructureable`. Therefore, we use a `Group` here
|
105
|
+
# instead.
|
106
|
+
#
|
107
|
+
@my_structureable = create :group, name: "My Structureable"
|
108
|
+
|
109
|
+
# @ancestor1 -> admin1
|
110
|
+
# |------- @ancestor2 -> admin2
|
111
|
+
# | |------- @my_structureable -> my_admin
|
112
|
+
# |
|
113
|
+
# |------- @no_ancestor -> other_admin
|
114
|
+
#
|
115
|
+
@ancestor2 = @my_structureable.parent_groups.create name: 'Ancestor 2'
|
116
|
+
@ancestor1 = @ancestor2.parent_groups.create name: 'Ancestor 1'
|
117
|
+
@no_ancestor = @ancestor1.child_groups.create name: 'No Ancestor'
|
118
|
+
|
119
|
+
@admin1 = create :user
|
120
|
+
@admin2 = create :user
|
121
|
+
@my_admin = create :user
|
122
|
+
@other_admin = create :user
|
123
|
+
|
124
|
+
@ancestor1.admins << @admin1
|
125
|
+
@ancestor2.admins << @admin2
|
126
|
+
@my_structureable.admins << @my_admin
|
127
|
+
@no_ancestor.admins << @other_admin
|
128
|
+
|
129
|
+
@my_structureable.reload
|
130
|
+
end
|
131
|
+
it "should include the ancestors' admins" do
|
132
|
+
subject.should include @admin1
|
133
|
+
subject.should include @admin2
|
134
|
+
end
|
135
|
+
it "should include the own direct admins" do
|
136
|
+
subject.should include @my_admin
|
137
|
+
end
|
138
|
+
it "should not include admins that are neither direct admins nor ancestors' admins" do
|
139
|
+
subject.should_not include @other_admin
|
140
|
+
end
|
141
|
+
describe "(caching)" do
|
142
|
+
describe "after changing an ancestor's admins" do
|
143
|
+
before do
|
144
|
+
@my_structureable.admins_of_self_and_ancestors # creates the cache
|
145
|
+
@ancestor1.admins.destroy(@admin1)
|
146
|
+
wait_for_cache
|
147
|
+
@my_structureable.reload
|
148
|
+
end
|
149
|
+
it "should refresh the cached value" do
|
150
|
+
subject.should_not include @admin1
|
151
|
+
subject.should include @admin2, @my_admin
|
152
|
+
end
|
153
|
+
specify "the admin should still be in the database after calling destroy on the association" do
|
154
|
+
User.find(@admin1.id).should be_present
|
155
|
+
end
|
156
|
+
end
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
160
|
+
describe "#find_admins" do
|
161
|
+
subject { @my_structureable.admins }
|
162
|
+
context "if the admins_parent_group exists" do
|
163
|
+
before { @my_structureable.create_admins_parent_group }
|
164
|
+
it { should == [] }
|
165
|
+
end
|
166
|
+
context "if admin users exist" do
|
167
|
+
before do
|
168
|
+
@admin_user = create( :user )
|
169
|
+
@my_structureable.admins_parent.child_users << @admin_user
|
170
|
+
end
|
171
|
+
it "should return an array of admin users" do
|
172
|
+
subject.should == [ @admin_user ]
|
173
|
+
end
|
174
|
+
end
|
175
|
+
context "if the admins-parent group does not exist" do
|
176
|
+
it "should return an empty array" do
|
177
|
+
subject.should == []
|
178
|
+
end
|
179
|
+
end
|
180
|
+
end
|
181
|
+
|
182
|
+
describe "#cached(:find_admins)" do
|
183
|
+
before do
|
184
|
+
@group = create(:group)
|
185
|
+
end
|
186
|
+
subject { @group.cached(:find_admins) }
|
187
|
+
context "if the admins-parent group does not exist" do
|
188
|
+
before do
|
189
|
+
@group.cached(:find_admins)
|
190
|
+
end
|
191
|
+
it { should == @group.find_admins }
|
192
|
+
end
|
193
|
+
context "if the admins_parent_group exists" do
|
194
|
+
before do
|
195
|
+
@group.find_or_create_admins_parent_group
|
196
|
+
@group.cached(:find_admins)
|
197
|
+
end
|
198
|
+
it { should == @group.find_admins }
|
199
|
+
end
|
200
|
+
context "if an admin users exists" do
|
201
|
+
before do
|
202
|
+
@group.find_or_create_admins_parent_group
|
203
|
+
admin_user = create(:user)
|
204
|
+
@group.admins_parent << admin_user
|
205
|
+
@group.cached(:find_admins)
|
206
|
+
end
|
207
|
+
it { should == @group.find_admins }
|
208
|
+
end
|
209
|
+
context "if new admin is added via group" do
|
210
|
+
before do
|
211
|
+
@group.find_or_create_admins_parent_group
|
212
|
+
admin_user = create(:user)
|
213
|
+
@group.cached(:find_admins)
|
214
|
+
wait_for_cache
|
215
|
+
|
216
|
+
@group.admins_parent << admin_user
|
217
|
+
@group.reload
|
218
|
+
end
|
219
|
+
it { should == @group.find_admins }
|
220
|
+
end
|
221
|
+
context "if new admin is added via child_users" do
|
222
|
+
before do
|
223
|
+
@group.find_or_create_admins_parent_group
|
224
|
+
admin_user = create(:user)
|
225
|
+
@group.cached(:find_admins)
|
226
|
+
wait_for_cache
|
227
|
+
|
228
|
+
@group.admins_parent.child_users << admin_user
|
229
|
+
@group.reload
|
230
|
+
end
|
231
|
+
it { should == @group.find_admins }
|
232
|
+
end
|
233
|
+
end
|
234
|
+
|
235
|
+
describe "#admins <<" do
|
236
|
+
before { @admin_user = create( :user ) }
|
237
|
+
subject { @my_structureable.admins << @admin_user }
|
238
|
+
context "for the admin group existing" do
|
239
|
+
before { @my_structureable.find_or_create_admins_parent_group }
|
240
|
+
it "should add the user to the admins of the structureable object" do
|
241
|
+
@my_structureable.admins.should_not include @admin_user
|
242
|
+
subject
|
243
|
+
@my_structureable.admins.should include @admin_user
|
244
|
+
end
|
245
|
+
it "should add the user to the group, not only the array" do
|
246
|
+
subject
|
247
|
+
@my_structureable.admins_parent.child_users.should include @admin_user
|
248
|
+
end
|
249
|
+
end
|
250
|
+
context "for the admin group not existing" do
|
251
|
+
it "should create it" do
|
252
|
+
@my_structureable.find_admins_parent_group.should == nil
|
253
|
+
subject
|
254
|
+
@my_structureable.find_admins_parent_group.should be_kind_of Group
|
255
|
+
end
|
256
|
+
it "should add the user to the admins of the structureable object" do
|
257
|
+
@my_structureable.find_admins_parent_group.should == nil
|
258
|
+
subject
|
259
|
+
@my_structureable.admins.should include @admin_user
|
260
|
+
end
|
261
|
+
end
|
262
|
+
end
|
263
|
+
|
264
|
+
# Main Admins
|
265
|
+
# ==========================================================================================
|
266
|
+
|
267
|
+
describe "#main_admins_parent" do
|
268
|
+
subject { @my_structureable.main_admins_parent }
|
269
|
+
it { should be_kind_of Group }
|
270
|
+
it "should have the admins_parent as parent group" do
|
271
|
+
@admins_parent = @my_structureable.admins_parent
|
272
|
+
subject.parent_groups.should include @admins_parent
|
273
|
+
end
|
274
|
+
specify "users of this group should also be members of the admins_parent_group" do
|
275
|
+
@user = create( :user )
|
276
|
+
@my_structureable.main_admins_parent.child_users << @user
|
277
|
+
@user.ancestor_groups.should include( @my_structureable.admins_parent,
|
278
|
+
@my_structureable.main_admins_parent )
|
279
|
+
end
|
280
|
+
end
|
281
|
+
|
282
|
+
describe "main_admins" do
|
283
|
+
before { @admin_user = create( :user ) }
|
284
|
+
subject { @my_structureable.main_admins }
|
285
|
+
context "for the main_admins_parent_group existing" do
|
286
|
+
before { @my_structureable.create_main_admins_parent_group }
|
287
|
+
it "should not list users that are no admins" do
|
288
|
+
@regular_user = create( :user )
|
289
|
+
subject.should_not include @regular_user
|
290
|
+
end
|
291
|
+
it "should list main_admins added directly to the dag" do
|
292
|
+
@my_structureable.main_admins_parent.should be_kind_of Group
|
293
|
+
@my_structureable.main_admins_parent.child_users << @admin_user
|
294
|
+
subject.should include @admin_user
|
295
|
+
end
|
296
|
+
it "should list main_admins added by 'main_admins << user'" do
|
297
|
+
@my_structureable.main_admins << @admin_user
|
298
|
+
subject.should include @admin_user
|
299
|
+
end
|
300
|
+
it "should not list the admins that are no main admins" do
|
301
|
+
@my_structureable.admins << @admin_user
|
302
|
+
subject.should_not include @admin_user
|
303
|
+
end
|
304
|
+
end
|
305
|
+
context "for the main_admins_parent_group missing" do
|
306
|
+
it "should still return an empty array" do
|
307
|
+
subject.should == []
|
308
|
+
end
|
309
|
+
end
|
310
|
+
end
|
311
|
+
|
312
|
+
describe "#main_admins <<" do
|
313
|
+
before { @admin_user = create( :user ) }
|
314
|
+
subject { @my_structureable.main_admins << @admin_user }
|
315
|
+
context "for the admin group existing" do
|
316
|
+
before { @my_structureable.create_main_admins_parent_group }
|
317
|
+
it "should add the user to the main admins of the structureable object" do
|
318
|
+
@my_structureable.main_admins.should_not include @admin_user
|
319
|
+
subject
|
320
|
+
@my_structureable.main_admins.should include @admin_user
|
321
|
+
end
|
322
|
+
end
|
323
|
+
context "for the admin group not existing" do
|
324
|
+
it "should create the admin group and add the user to the main admins of the structureable object" do
|
325
|
+
@my_structureable.main_admins.should == []
|
326
|
+
subject
|
327
|
+
@my_structureable.main_admins.should include @admin_user
|
328
|
+
end
|
329
|
+
end
|
330
|
+
end
|
331
|
+
|
332
|
+
|
333
|
+
# Structures
|
334
|
+
# ==========================================================================================
|
335
|
+
#
|
336
|
+
# my_structureable
|
337
|
+
# |----- officers_parent
|
338
|
+
# |---------- admins_parent
|
339
|
+
# |------------ main_admins_parent
|
340
|
+
#
|
341
|
+
# Every admin is also an officer.
|
342
|
+
# Every main_admin is also an admin and also an officer.
|
343
|
+
#
|
344
|
+
|
345
|
+
describe "structures: " do
|
346
|
+
before { @user = create(:user) }
|
347
|
+
specify "each admin should also be an officer" do
|
348
|
+
@my_structureable.admins << @user
|
349
|
+
@user.should be_in @my_structureable.admins
|
350
|
+
@user.should be_in @my_structureable.officers
|
351
|
+
end
|
352
|
+
specify "each main_admin should also be an admin and also be an officer" do
|
353
|
+
@my_structureable.main_admins << @user
|
354
|
+
@user.should be_in @my_structureable.main_admins
|
355
|
+
@user.should be_in @my_structureable.admins
|
356
|
+
@user.should be_in @my_structureable.officers
|
357
|
+
end
|
358
|
+
end
|
359
|
+
|
360
|
+
|
361
|
+
|
362
|
+
# Complex Structures
|
363
|
+
# ------------------------------------------------------------------------------------------
|
364
|
+
#
|
365
|
+
# group1
|
366
|
+
# |----- :officers_parent
|
367
|
+
# | |--------------- :admins_parent
|
368
|
+
# | |---------- :main_admins_parent
|
369
|
+
# |----- group2
|
370
|
+
# |---- :officers_parent
|
371
|
+
# |------------ :admins_parent
|
372
|
+
# |------------- :main_admins_parent
|
373
|
+
#
|
374
|
+
describe "complex structures: " do
|
375
|
+
before do
|
376
|
+
@group1 = create(:group)
|
377
|
+
@group2 = create(:group); @group2.parent_groups << @group1
|
378
|
+
@user = create(:user)
|
379
|
+
end
|
380
|
+
specify "an admin of group2 should not be considered an admin of group1" do
|
381
|
+
@group1.admins.should == []
|
382
|
+
@group2.admins << @user
|
383
|
+
@group2.admins.should include @user
|
384
|
+
@group1.admins.should == []
|
385
|
+
end
|
386
|
+
describe "for the sub group's officers_parent being created first" do
|
387
|
+
before { @sub_group_officers_parent = @group2.create_officers_parent_group }
|
388
|
+
specify "the parent group's officers_parent should not refer to the sub group's officers_parent" do
|
389
|
+
@group2.find_officers_parent_group.should == @sub_group_officers_parent
|
390
|
+
@group1.find_officers_parent_group.should_not == @sub_group_officers_parent
|
391
|
+
@group1.find_officers_parent_group.should == nil
|
392
|
+
end
|
393
|
+
end
|
394
|
+
describe "for the sub group's admins_parent beging created first" do
|
395
|
+
before do
|
396
|
+
@sub_group_admins_parent_group = @group2.find_or_create_admins_parent_group
|
397
|
+
@sub_group_admins_parent_group.update_attributes( name: "group2.admins_parent" )
|
398
|
+
end
|
399
|
+
specify "the parent group's admins_parent should not refer to the sub group's admins_parent (Bug Fix!)" do
|
400
|
+
@group2.find_admins_parent_group.should == @sub_group_admins_parent_group
|
401
|
+
@group1.find_admins_parent_group.should_not == @sub_group_admins_parent_group
|
402
|
+
@group1.find_admins_parent_group.should == nil
|
403
|
+
end
|
404
|
+
end
|
405
|
+
end
|
406
|
+
|
407
|
+
|
408
|
+
# Preventing Officers Cascades
|
409
|
+
# ------------------------------------------------------------------------------------------
|
410
|
+
#
|
411
|
+
# group1
|
412
|
+
# |----- :officers_parent
|
413
|
+
# |--------------- :admins_parent
|
414
|
+
# | |---------- :officers_parent <---- forbidden
|
415
|
+
# |
|
416
|
+
# |----- :officers_parent <------------------------------- forbidden
|
417
|
+
# |
|
418
|
+
# |----- :public_relations_officer
|
419
|
+
# |
|
420
|
+
# |----- :officers_parent <-------------- forbidden
|
421
|
+
#
|
422
|
+
#
|
423
|
+
describe "preventing officer cascades: " do
|
424
|
+
before do
|
425
|
+
@group1 = create :group
|
426
|
+
@officers_parent = @group1.officers_parent
|
427
|
+
@admins_parent = @group1.admins_parent
|
428
|
+
@public_relations_officer = @officers_parent.child_groups.create
|
429
|
+
end
|
430
|
+
specify "it should not be possible to create an officers_parent under the admins parent" do
|
431
|
+
@admins_parent.officers_parent.should == nil
|
432
|
+
@admins_parent.create_officers_parent_group.should == nil
|
433
|
+
@admins_parent.reload.children.should == []
|
434
|
+
end
|
435
|
+
specify "it should not be possible to create an offiers_parent under the officers_parent" do
|
436
|
+
@officers_parent.officers_parent.should == nil
|
437
|
+
@officers_parent.create_officers_parent_group.should == nil
|
438
|
+
@officers_parent.reload.children.should == [@admins_parent, @public_relations_officer]
|
439
|
+
end
|
440
|
+
specify "it should not be possible to create an officers_parent under another officers group" do
|
441
|
+
@public_relations_officer.officers_parent.should == nil
|
442
|
+
@public_relations_officer.create_officers_parent_group.should == nil
|
443
|
+
@public_relations_officer.reload.children.should == []
|
444
|
+
end
|
445
|
+
specify "calling #admins should not create forbidden officers_parent groups" do
|
446
|
+
@admins_parent.admins
|
447
|
+
@admins_parent.reload.children.should == []
|
448
|
+
@officers_parent.admins
|
449
|
+
@officers_parent.reload.children.should == [@admins_parent, @public_relations_officer]
|
450
|
+
@public_relations_officer.admins
|
451
|
+
@public_relations_officer.reload.children.should == []
|
452
|
+
end
|
453
|
+
end
|
454
|
+
|
455
|
+
|
456
|
+
# Officers
|
457
|
+
# ==========================================================================================
|
458
|
+
|
459
|
+
describe "officers_parent_group" do
|
460
|
+
before do
|
461
|
+
@container_group = create( :group )
|
462
|
+
@container_subgroup = create( :group ) # this is to test if subgroup's officers are listed as well
|
463
|
+
@container_subgroup.parent_groups << @container_group
|
464
|
+
@officers_parent = @container_group.create_officers_parent_group
|
465
|
+
@subgroup_officers_parent = @container_subgroup.create_officers_parent_group
|
466
|
+
@officer1 = create( :group ); @officer1.parent_groups << @officers_parent
|
467
|
+
@officer2 = create( :group ); @officer2.parent_groups << @subgroup_officers_parent
|
468
|
+
@officer1_user = create( :user ); @officer1.child_users << @officer1_user
|
469
|
+
@officer2_user = create( :user ); @officer2.child_users << @officer2_user
|
470
|
+
@container_group.reload
|
471
|
+
@container_subgroup.reload
|
472
|
+
@officers_parent.reload
|
473
|
+
@subgroup_officers_parent.reload
|
474
|
+
end
|
475
|
+
|
476
|
+
describe "#create_officers_parent_group" do
|
477
|
+
it "should create the officers_parent_group" do
|
478
|
+
@officers_parent.has_flag?( :officers_parent ).should be_true
|
479
|
+
@officers_parent.parent_groups.should include( @container_group )
|
480
|
+
end
|
481
|
+
end
|
482
|
+
|
483
|
+
describe "#find_officers_parent_group" do
|
484
|
+
subject { @container_group.find_officers_parent_group }
|
485
|
+
it "should find the officers_parent_group" do
|
486
|
+
subject.should == @officers_parent
|
487
|
+
subject.has_flag?( :officers_parent ).should be_true
|
488
|
+
end
|
489
|
+
end
|
490
|
+
|
491
|
+
describe "#find_officers_groups" do
|
492
|
+
subject { @container_group.find_officers_groups }
|
493
|
+
it "should find the officers of the container group" do
|
494
|
+
subject.should include( @officer1 )
|
495
|
+
end
|
496
|
+
it "should not find the officers of the container group's subgroups" do
|
497
|
+
subject.should_not include( @officer2 )
|
498
|
+
end
|
499
|
+
end
|
500
|
+
|
501
|
+
subject { @container_group }
|
502
|
+
its( :officers_parent ) { should == @officers_parent }
|
503
|
+
its( :officers_parent! ) { should == @officers_parent }
|
504
|
+
|
505
|
+
describe "#officers" do
|
506
|
+
subject { @container_group.officers }
|
507
|
+
it "should list the users that are officers" do
|
508
|
+
subject.should include @officer1_user
|
509
|
+
end
|
510
|
+
it "should also list the officers of the sub-groups of this group" do
|
511
|
+
subject.should include @officer2_user
|
512
|
+
end
|
513
|
+
end
|
514
|
+
|
515
|
+
end
|
516
|
+
|
517
|
+
end
|