pageflow 0.11.4 → 12.0.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of pageflow might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +224 -1207
- data/README.md +7 -3
- data/Rakefile +2 -0
- data/admins/pageflow/accounts.rb +27 -8
- data/admins/pageflow/entry.rb +130 -47
- data/admins/pageflow/folder.rb +28 -17
- data/admins/pageflow/membership.rb +58 -6
- data/admins/pageflow/user.rb +105 -98
- data/app/assets/fonts/pageflow/fontawesome-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/fontawesome-webfont.svg +644 -463
- data/app/assets/fonts/pageflow/fontawesome-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/fontawesome-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.svg +2864 -696
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.svg +2572 -613
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.svg +2977 -779
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.woff +0 -0
- data/app/assets/javascripts/pageflow/admin/entries.js +21 -3
- data/app/assets/javascripts/pageflow/audio.js +30 -15
- data/app/assets/javascripts/pageflow/audio/multi_player.js +12 -1
- data/app/assets/javascripts/pageflow/audio_player.js +15 -1
- data/app/assets/javascripts/pageflow/audio_player/rewind_method.js +3 -1
- data/app/assets/javascripts/pageflow/base.js +4 -1
- data/app/assets/javascripts/pageflow/browser.js +3 -0
- data/app/assets/javascripts/pageflow/browser/autoplay_support.js +3 -0
- data/app/assets/javascripts/pageflow/browser/facebook.js +1 -2
- data/app/assets/javascripts/pageflow/browser/ios_platform.js +5 -0
- data/app/assets/javascripts/pageflow/browser/video.js +4 -0
- data/app/assets/javascripts/pageflow/components.js +7 -0
- data/app/assets/javascripts/pageflow/cookies.js +1 -4
- data/app/assets/javascripts/pageflow/dist/react.js +4724 -5808
- data/app/assets/javascripts/pageflow/editor/api.js +201 -161
- data/app/assets/javascripts/pageflow/editor/api/errors.js +80 -0
- data/app/assets/javascripts/pageflow/editor/api/failure.js +9 -0
- data/app/assets/javascripts/pageflow/editor/api/failures.js +25 -2
- data/app/assets/javascripts/pageflow/editor/api/file_type.js +42 -3
- data/app/assets/javascripts/pageflow/editor/api/file_types.js +75 -46
- data/app/assets/javascripts/pageflow/editor/base.js +8 -0
- data/app/assets/javascripts/pageflow/editor/collections/file_types_collection.js +37 -0
- data/app/assets/javascripts/pageflow/editor/collections/files_collection.js +32 -1
- data/app/assets/javascripts/pageflow/editor/collections/mixins/ordered_collection.js +1 -1
- data/app/assets/javascripts/pageflow/editor/collections/multi_collection.js +4 -6
- data/app/assets/javascripts/pageflow/editor/collections/nested_files_collection.js +27 -0
- data/app/assets/javascripts/pageflow/editor/collections/pages_collection.js +21 -1
- data/app/assets/javascripts/pageflow/editor/collections/subset_collection.js +8 -2
- data/app/assets/javascripts/pageflow/editor/controllers/sidebar_controller.js +3 -2
- data/app/assets/javascripts/pageflow/editor/initializers/error_listener.js +10 -5
- data/app/assets/javascripts/pageflow/editor/initializers/routing.js +3 -1
- data/app/assets/javascripts/pageflow/editor/initializers/setup_collections.js +3 -0
- data/app/assets/javascripts/pageflow/editor/initializers/setup_file_types.js +136 -6
- data/app/assets/javascripts/pageflow/editor/initializers/setup_file_uploader.js +10 -0
- data/app/assets/javascripts/pageflow/editor/initializers/setup_hotkeys.js +5 -7
- data/app/assets/javascripts/pageflow/editor/initializers/stylesheet_reloading.js +1 -1
- data/app/assets/javascripts/pageflow/editor/models/configuration.js +1 -0
- data/app/assets/javascripts/pageflow/editor/models/entry.js +34 -26
- data/app/assets/javascripts/pageflow/editor/models/file_configuration.js +10 -0
- data/app/assets/javascripts/pageflow/editor/models/file_reuse.js +23 -0
- data/app/assets/javascripts/pageflow/editor/models/file_uploader.js +69 -0
- data/app/assets/javascripts/pageflow/editor/models/mixins/retryable.js +1 -1
- data/app/assets/javascripts/pageflow/editor/models/page.js +13 -0
- data/app/assets/javascripts/pageflow/editor/models/text_track_file.js +48 -0
- data/app/assets/javascripts/pageflow/editor/models/uploaded_file.js +62 -11
- data/app/assets/javascripts/pageflow/editor/routers/sidebar_router.js +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/confirm_upload.jst.ejs +18 -0
- data/app/assets/javascripts/pageflow/editor/templates/delete_row_table_cell.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/drop_down_button.jst.ejs +0 -2
- data/app/assets/javascripts/pageflow/editor/templates/drop_down_button_item.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/edit_entry.jst.ejs +3 -1
- data/app/assets/javascripts/pageflow/editor/templates/edit_file.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/editor/templates/file_item.jst.ejs +1 -6
- data/app/assets/javascripts/pageflow/editor/templates/file_meta_data_item_value_view.jst.ejs +3 -0
- data/app/assets/javascripts/pageflow/editor/templates/file_settings_dialog.jst.ejs +10 -0
- data/app/assets/javascripts/pageflow/editor/templates/files_blank_slate.jst.ejs +1 -1
- data/app/assets/javascripts/pageflow/editor/templates/filtered_files.jst.ejs +10 -0
- data/app/assets/javascripts/pageflow/{ui → editor}/templates/inputs/file_input.jst.ejs +1 -1
- data/app/assets/javascripts/pageflow/editor/templates/inputs/reference.jst.ejs +2 -2
- data/app/assets/javascripts/pageflow/editor/templates/nested_files.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/table_cell.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/editor/templates/text_tracks.jst.ejs +13 -0
- data/app/assets/javascripts/pageflow/editor/templates/uploadable_files.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/utils/form_data_utils.js +19 -0
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio.js +5 -2
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_image.js +3 -2
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/background.js +35 -0
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/options.js +7 -9
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/video.js +6 -5
- data/app/assets/javascripts/pageflow/editor/views/confirm_upload_view.js +69 -0
- data/app/assets/javascripts/pageflow/editor/views/confirmable_file_item_view.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_list_view.js +9 -0
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_view.js +14 -1
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_view.js +51 -20
- data/app/assets/javascripts/pageflow/editor/views/edit_entry_view.js +21 -2
- data/app/assets/javascripts/pageflow/editor/views/edit_file_view.js +52 -0
- data/app/assets/javascripts/pageflow/editor/views/edit_storyline_view.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/entry_preview_view.js +15 -7
- data/app/assets/javascripts/pageflow/editor/views/file_item_view.js +33 -22
- data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_value_view.js +49 -0
- data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_view.js +16 -5
- data/app/assets/javascripts/pageflow/editor/views/file_settings_dialog_view.js +31 -0
- data/app/assets/javascripts/pageflow/editor/views/files_explorer_view.js +6 -7
- data/app/assets/javascripts/pageflow/editor/views/files_view.js +13 -14
- data/app/assets/javascripts/pageflow/editor/views/filtered_files_view.js +75 -0
- data/app/assets/javascripts/pageflow/editor/views/help_view.js +3 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/file_input_view.js +217 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/page_link_input_view.js +6 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/reference_input_view.js +13 -2
- data/app/assets/javascripts/pageflow/editor/views/list_view.js +24 -14
- data/app/assets/javascripts/pageflow/editor/views/model_thumbnail_view.js +4 -1
- data/app/assets/javascripts/pageflow/editor/views/nested_files_view.js +94 -0
- data/app/assets/javascripts/pageflow/editor/views/page_preview_view.js +7 -2
- data/app/assets/javascripts/pageflow/editor/views/text_file_meta_data_item_value_view.js +25 -0
- data/app/assets/javascripts/pageflow/editor/views/text_tracks_file_meta_data_item_value_view.js +12 -0
- data/app/assets/javascripts/pageflow/editor/views/text_tracks_view.js +65 -0
- data/app/assets/javascripts/pageflow/editor/views/uploadable_files_view.js +56 -0
- data/app/assets/javascripts/pageflow/editor/views/uploader_view.js +13 -10
- data/app/assets/javascripts/pageflow/features.js +8 -12
- data/app/assets/javascripts/pageflow/focus_outline.js +2 -0
- data/app/assets/javascripts/pageflow/media_player/volume_binding.js +2 -0
- data/app/assets/javascripts/pageflow/media_player/volume_fading.js +6 -0
- data/app/assets/javascripts/pageflow/page_type.js +0 -1
- data/app/assets/javascripts/pageflow/phone_landscape_fullscreen.js +34 -0
- data/app/assets/javascripts/pageflow/react.js +4 -0
- data/app/assets/javascripts/pageflow/ready.js +3 -0
- data/app/assets/javascripts/pageflow/seed_entry_data.js +4 -1
- data/app/assets/javascripts/pageflow/slideshow.js +1 -0
- data/app/assets/javascripts/pageflow/slideshow/adjacent_preparer.js +7 -5
- data/app/assets/javascripts/pageflow/slideshow/atmo.js +3 -3
- data/app/assets/javascripts/pageflow/slideshow/hidden_text_indicator_widget.js +4 -2
- data/app/assets/javascripts/pageflow/slideshow/hide_text.js +8 -4
- data/app/assets/javascripts/pageflow/slideshow/lazy_page_widget.js +5 -0
- data/app/assets/javascripts/pageflow/slideshow/scroller_widget.js +11 -18
- data/app/assets/javascripts/pageflow/ui.js +6 -0
- data/app/assets/javascripts/pageflow/ui/templates/inputs/url_display.jst.ejs +7 -0
- data/app/assets/javascripts/pageflow/ui/templates/table.jst.ejs +7 -0
- data/app/assets/javascripts/pageflow/ui/templates/table_blank_slate.jst.ejs +3 -0
- data/app/assets/javascripts/pageflow/ui/utils/i18n_utils.js +97 -2
- data/app/assets/javascripts/pageflow/ui/views/collection_view.js +8 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/check_box_input_view.js +12 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/proxy_url_input_view.js +51 -5
- data/app/assets/javascripts/pageflow/ui/views/inputs/select_input_view.js +80 -2
- data/app/assets/javascripts/pageflow/ui/views/inputs/slider_input_view.js +8 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/text_area_input_view.js +17 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/text_input_view.js +47 -4
- data/app/assets/javascripts/pageflow/ui/views/inputs/url_display_view.js +42 -0
- data/app/assets/javascripts/pageflow/ui/views/inputs/url_input_view.js +20 -2
- data/app/assets/javascripts/pageflow/ui/views/mixins/input_view.js +74 -46
- data/app/assets/javascripts/pageflow/ui/views/table_cells/delete_row_table_cell_view.js +63 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/enum_table_cell_view.js +26 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/icon_table_cell_view.js +40 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/presence_table_cell_view.js +31 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/table_cell_view.js +101 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/table_header_cell_view.js +10 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/text_table_cell_view.js +46 -0
- data/app/assets/javascripts/pageflow/ui/views/table_row_view.js +47 -0
- data/app/assets/javascripts/pageflow/ui/views/table_view.js +47 -0
- data/app/assets/javascripts/pageflow/video_player.js +9 -5
- data/app/assets/javascripts/pageflow/video_player/buffer_underrun_waiting.js +15 -13
- data/app/assets/javascripts/pageflow/video_player/cue_settings_methods.js +33 -0
- data/app/assets/javascripts/pageflow/video_player/dash.js +3 -0
- data/app/assets/javascripts/pageflow/video_player/filter_sources.js +1 -1
- data/app/assets/javascripts/pageflow/video_player/lazy.js +3 -9
- data/app/assets/javascripts/pageflow/video_player/prebuffering.js +11 -2
- data/app/assets/javascripts/pageflow/video_player/use_slim_controls_during_phone_playback.js +16 -0
- data/app/assets/javascripts/pageflow/videojs.js +6 -0
- data/app/assets/javascripts/pageflow/widgets.js +41 -7
- data/app/assets/stylesheets/pageflow/admin.scss +7 -4
- data/app/assets/stylesheets/pageflow/admin/{entries/user_badge_list.scss → badge_list.scss} +6 -9
- data/app/assets/stylesheets/pageflow/admin/embed_code.scss +13 -0
- data/app/assets/stylesheets/pageflow/admin/entries.scss +1 -2
- data/app/assets/stylesheets/pageflow/admin/hint.scss +20 -0
- data/app/assets/stylesheets/pageflow/admin/tooltip_bubble.scss +34 -0
- data/app/assets/stylesheets/pageflow/editor/base.scss +4 -4
- data/app/assets/stylesheets/pageflow/editor/confirm_upload.scss +66 -0
- data/app/assets/stylesheets/pageflow/editor/dialogs.scss +9 -1
- data/app/assets/stylesheets/pageflow/editor/drop_down_button.scss +56 -20
- data/app/assets/stylesheets/pageflow/editor/file_meta_data.scss +26 -6
- data/app/assets/stylesheets/pageflow/editor/file_settings_dialog.scss +32 -0
- data/app/assets/stylesheets/pageflow/editor/files.scss +5 -0
- data/app/assets/stylesheets/pageflow/editor/filtered_files.scss +25 -0
- data/app/assets/stylesheets/pageflow/editor/inputs.scss +2 -1
- data/app/assets/stylesheets/pageflow/editor/inputs/file_input.scss +65 -0
- data/app/assets/stylesheets/pageflow/editor/inputs/reference.scss +2 -2
- data/app/assets/stylesheets/pageflow/editor/text_tracks.scss +39 -0
- data/app/assets/stylesheets/pageflow/entries.scss +1 -0
- data/app/assets/stylesheets/pageflow/mixins/buttons.scss +77 -5
- data/app/assets/stylesheets/pageflow/mixins/icons/fontawesome.scss +3 -1
- data/app/assets/stylesheets/pageflow/page_types.scss +0 -4
- data/app/assets/stylesheets/pageflow/page_types/video.scss +5 -1
- data/app/assets/stylesheets/pageflow/page_types/video/content_hiding.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/base.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/built_in_page_types.scss +0 -2
- data/app/assets/stylesheets/pageflow/themes/default/definitions.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/loading_spinner.scss +31 -12
- data/app/assets/stylesheets/pageflow/themes/default/logo.scss +9 -1
- data/app/assets/stylesheets/pageflow/themes/default/logo/variant/background_image.scss +8 -2
- data/app/assets/stylesheets/pageflow/themes/default/logo/variant/watermark.scss +21 -0
- data/app/assets/stylesheets/pageflow/themes/default/mixins/cue_margins.scss +43 -0
- data/app/assets/stylesheets/pageflow/themes/default/mixins/indicator_typography.scss +7 -3
- data/app/assets/stylesheets/pageflow/themes/default/page.scss +20 -2
- data/app/assets/stylesheets/pageflow/themes/default/player_controls.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/container.scss +8 -6
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/control_bar.scss +18 -3
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/cue_margins.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/custom.scss +14 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/icon_font.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/sprite.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/info_box.scss +2 -2
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/menu_bar.scss +5 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/shared/menu_bar.scss +121 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim.scss +2 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/container.scss +2 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/control_bar.scss +74 -12
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/cue_margins.scss +3 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/info_box.scss +31 -5
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/menu_bar.scss +13 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/quality_menu.scss +116 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/vjs_mapping.scss +13 -3
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/widget_margins.scss +8 -3
- data/app/assets/stylesheets/pageflow/themes/default/text_track_cues.scss +25 -0
- data/app/assets/stylesheets/pageflow/themes/default/variables/widgets.scss +2 -2
- data/app/assets/stylesheets/pageflow/themes/default/video_player/vjs_base.scss +122 -79
- data/app/assets/stylesheets/pageflow/themes/default/video_wrapper.scss +16 -7
- data/app/assets/stylesheets/pageflow/ui.scss +5 -1
- data/app/assets/stylesheets/pageflow/ui/forms.scss +5 -58
- data/app/assets/stylesheets/pageflow/ui/table_cells/delete_row_table_cell.scss +7 -0
- data/app/assets/stylesheets/pageflow/ui/table_cells/icon_table_cell.scss +16 -0
- data/app/assets/stylesheets/pageflow/ui/table_cells/presence_table_cell.scss +8 -0
- data/app/assets/stylesheets/pageflow/ui/table_view.scss +33 -0
- data/app/assets/stylesheets/pageflow/ui/tooltip.scss +1 -1
- data/app/controllers/pageflow/editor/encoding_confirmations_controller.rb +3 -3
- data/app/controllers/pageflow/editor/entry_publications_controller.rb +3 -3
- data/app/controllers/pageflow/editor/files_controller.rb +72 -14
- data/app/controllers/pageflow/editor/widgets_controller.rb +1 -1
- data/app/controllers/pageflow/entries_controller.rb +12 -2
- data/app/controllers/pageflow/files_controller.rb +1 -1
- data/app/helpers/pageflow/admin/entries_helper.rb +17 -0
- data/app/helpers/pageflow/admin/form_helper.rb +1 -1
- data/app/helpers/pageflow/admin/memberships_helper.rb +117 -13
- data/app/helpers/pageflow/common_entry_seed_helper.rb +36 -5
- data/app/helpers/pageflow/embed_code_helper.rb +32 -0
- data/app/helpers/pageflow/entries_helper.rb +1 -1
- data/app/helpers/pageflow/entry_json_seed_helper.rb +6 -16
- data/app/helpers/pageflow/files_helper.rb +5 -2
- data/app/helpers/pageflow/folders_helper.rb +26 -2
- data/app/helpers/pageflow/page_background_asset_helper.rb +8 -0
- data/app/helpers/pageflow/quota_helper.rb +1 -1
- data/app/helpers/pageflow/video_files_helper.rb +0 -5
- data/app/jobs/pageflow/poll_zencoder_job.rb +1 -1
- data/app/jobs/pageflow/process_file_job.rb +18 -0
- data/app/mailers/pageflow/user_mailer.rb +4 -2
- data/app/models/concerns/pageflow/hosted_file.rb +9 -0
- data/app/models/concerns/pageflow/output_source.rb +60 -0
- data/app/models/concerns/pageflow/uploaded_file.rb +33 -5
- data/app/models/pageflow/account.rb +3 -1
- data/app/models/pageflow/audio_file_url_templates.rb +21 -0
- data/app/models/pageflow/draft_entry.rb +19 -9
- data/app/models/pageflow/entry.rb +2 -1
- data/app/models/pageflow/entry_duplicate.rb +2 -2
- data/app/models/pageflow/entry_role_query.rb +81 -0
- data/app/models/pageflow/file_reuse.rb +25 -0
- data/app/models/pageflow/file_usage.rb +7 -1
- data/app/models/pageflow/image_file.rb +7 -1
- data/app/models/pageflow/image_file_url_templates.rb +19 -0
- data/app/models/pageflow/invited_user.rb +2 -0
- data/app/models/pageflow/membership.rb +46 -3
- data/app/models/pageflow/published_entry.rb +2 -2
- data/app/models/pageflow/revision.rb +16 -5
- data/app/models/pageflow/roles.rb +36 -0
- data/app/models/pageflow/text_track_file.rb +45 -0
- data/app/models/pageflow/text_track_file_url_templates.rb +16 -0
- data/app/models/pageflow/thumbnail_file_resolver.rb +22 -2
- data/app/models/pageflow/url_template.rb +13 -0
- data/app/models/pageflow/used_file.rb +21 -0
- data/app/models/pageflow/video_file.rb +72 -27
- data/app/models/pageflow/video_file_url_templates.rb +34 -0
- data/app/policies/pageflow/account_policy.rb +145 -0
- data/app/policies/pageflow/admin/admin_only_tab_policy.rb +16 -0
- data/app/policies/pageflow/admin/entry_tab_policy.rb +25 -0
- data/app/policies/pageflow/application_policy.rb +11 -0
- data/app/policies/pageflow/entry_policy.rb +138 -0
- data/app/policies/pageflow/file_policy.rb +42 -0
- data/app/policies/pageflow/folder_policy.rb +54 -0
- data/app/policies/pageflow/membership_policy.rb +105 -0
- data/app/policies/pageflow/theming_policy.rb +57 -0
- data/app/policies/pageflow/user_policy.rb +69 -0
- data/app/state_machines/pageflow/encoded_file_state_machine.rb +4 -0
- data/app/state_machines/pageflow/image_file_state_machine.rb +5 -1
- data/app/views/admin/entries/_attributes_table.html.arb +21 -2
- data/app/views/admin/entries/_links.html.arb +1 -1
- data/app/views/admin/memberships/_entity_account_input.html.erb +5 -0
- data/app/views/admin/memberships/_entity_entry_input.html.erb +5 -0
- data/app/views/admin/memberships/_form.html.erb +16 -5
- data/app/views/admin/memberships/_role_hint.html.arb +2 -0
- data/app/views/admin/users/_form.html.erb +29 -20
- data/app/views/components/pageflow/admin/add_membership_button_if_needed.rb +62 -0
- data/app/views/components/pageflow/admin/embed_code_field.rb +15 -0
- data/app/views/components/pageflow/admin/entry_user_badge_list.rb +15 -7
- data/app/views/components/pageflow/admin/grouped_folder_list.rb +20 -16
- data/app/views/components/pageflow/admin/members_tab.rb +22 -11
- data/app/views/components/pageflow/admin/membership_role_with_tooltip.rb +21 -0
- data/app/views/components/pageflow/admin/tabs_view.rb +13 -13
- data/app/views/components/pageflow/admin/user_account_badge_list.rb +43 -0
- data/app/views/components/pageflow/admin/user_accounts_tab.rb +46 -0
- data/app/views/components/pageflow/admin/user_entries_tab.rb +50 -0
- data/app/views/components/pageflow/admin/users_tab.rb +32 -4
- data/app/views/layouts/pageflow/application.html.erb +3 -2
- data/app/views/pageflow/config/_editor_seeds.json.jbuilder +15 -2
- data/app/views/pageflow/editor/entries/_entry.json.jbuilder +1 -0
- data/app/views/pageflow/editor/files/_file.json.jbuilder +10 -2
- data/app/views/pageflow/entries/show.css.erb +4 -11
- data/app/views/pageflow/entries/show.json.jbuilder +1 -1
- data/app/views/pageflow/entry_json_seed/_entry.json.jbuilder +19 -0
- data/app/views/pageflow/file_types/_thumbnails.css.erb +1 -1
- data/app/views/pageflow/files/_file.json.jbuilder +12 -0
- data/app/views/pageflow/page_background_asset/_element.html.erb +3 -0
- data/app/views/pageflow/page_types/_page_type.json.jbuilder +7 -0
- data/app/views/pageflow/react/_widget.html.erb +1 -0
- data/app/views/pageflow/react/page.html.erb +6 -0
- data/app/views/pageflow/video_files/_video_file.json.jbuilder +2 -0
- data/config/initializers/admin_resource_tabs.rb +8 -1
- data/config/initializers/features.rb +1 -4
- data/config/initializers/help_entries.rb +2 -1
- data/config/initializers/paperclip.rb +4 -0
- data/config/initializers/zencoder.rb +5 -2
- data/config/locales/de.yml +370 -108
- data/config/locales/en.yml +333 -83
- data/config/routes.rb +18 -10
- data/db/migrate/20150825133449_update_audio_loop_pages_to_use_atmo.rb +24 -0
- data/db/migrate/20160304072911_rename_membership_entry_and_make_polymorphic.rb +19 -0
- data/db/migrate/20160304151327_add_role_to_membership.rb +19 -0
- data/db/migrate/20160504093145_replace_role_and_account_on_user.rb +42 -0
- data/db/migrate/20160531152500_update_users_count.rb +27 -0
- data/db/migrate/20160707125400_add_output_presences_to_video_files.rb +5 -0
- data/db/migrate/20160824115000_add_parent_file_to_video_files.rb +8 -0
- data/db/migrate/20160824115100_add_parent_file_to_audio_files.rb +8 -0
- data/db/migrate/20160824115200_add_parent_file_to_image_files.rb +8 -0
- data/db/migrate/20160929102700_add_configuration_to_files.rb +7 -0
- data/db/migrate/20161007144500_add_text_track_files.rb +31 -0
- data/db/migrate/20161216175734_move_configuration_from_file_to_file_usage.rb +27 -0
- data/db/migrate/20161230144429_add_processed_attachment_to_text_track_files.rb +8 -0
- data/db/migrate/20170222124848_update_video_file_output_presences.rb +12 -0
- data/db/migrate/20170421112300_turn_background_video_pages_into_background_image_pages.rb +22 -0
- data/lib/generators/pageflow/assets/assets_generator.rb +2 -0
- data/lib/generators/pageflow/assets/templates/components.js +4 -0
- data/lib/generators/pageflow/initializer/templates/pageflow.rb +23 -20
- data/lib/generators/pageflow/seeds/templates/seeds.rb +81 -15
- data/lib/pageflow.rb +8 -0
- data/lib/pageflow/ability_mixin.rb +196 -62
- data/lib/pageflow/admin/tab.rb +21 -0
- data/lib/pageflow/admin/tabs.rb +31 -6
- data/lib/pageflow/built_in_file_type.rb +39 -0
- data/lib/pageflow/built_in_page_types_plugin.rb +80 -0
- data/lib/pageflow/configuration.rb +13 -1
- data/lib/pageflow/engine.rb +6 -1
- data/lib/pageflow/file_type.rb +60 -15
- data/lib/pageflow/file_types.rb +20 -2
- data/lib/pageflow/page_type.rb +53 -4
- data/lib/pageflow/page_types.rb +4 -0
- data/lib/pageflow/paperclip_processors/vtt.rb +35 -0
- data/lib/pageflow/react.rb +11 -0
- data/lib/pageflow/react/page_type.rb +26 -0
- data/lib/pageflow/react/widget_type.rb +20 -0
- data/lib/pageflow/seeds.rb +59 -15
- data/lib/pageflow/user_mixin.rb +18 -25
- data/lib/pageflow/version.rb +1 -1
- data/lib/pageflow/zencoder_api.rb +18 -4
- data/lib/pageflow/zencoder_video_output_definition.rb +375 -127
- data/lib/tasks/pageflow_tasks.rake +7 -0
- data/spec/factories/accounts.rb +36 -3
- data/spec/factories/entries.rb +22 -4
- data/spec/factories/invited_user.rb +3 -4
- data/spec/factories/memberships.rb +34 -2
- data/spec/factories/text_track_files.rb +40 -0
- data/spec/factories/users.rb +32 -7
- data/spec/factories/video_files.rb +7 -1
- data/spec/fixtures/sample.srt +12 -0
- data/spec/fixtures/sample.vtt +40 -0
- data/vendor/assets/javascripts/dash.all.min.js +14 -0
- data/vendor/assets/javascripts/polyfills/bind.js +17 -11
- data/vendor/assets/javascripts/videojs-dash.js +302 -0
- data/vendor/assets/javascripts/videojs.js +26804 -0
- metadata +187 -49
- data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/sprite.png +0 -0
- data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/wide.png +0 -0
- data/app/assets/javascripts/pageflow/editor/collections/file_usages_collection.js +0 -21
- data/app/assets/javascripts/pageflow/editor/models/file_usage.js +0 -8
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio_loop.js +0 -20
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_video.js +0 -24
- data/app/assets/javascripts/pageflow/page_types/audio.js +0 -135
- data/app/assets/javascripts/pageflow/page_types/audio_loop.js +0 -102
- data/app/assets/javascripts/pageflow/page_types/background_image.js +0 -44
- data/app/assets/javascripts/pageflow/page_types/background_video.js +0 -137
- data/app/assets/javascripts/pageflow/page_types/video.js +0 -277
- data/app/assets/javascripts/pageflow/ui/views/inputs/file_input_view.js +0 -79
- data/app/assets/javascripts/pageflow/video_player/play_button_patch.js +0 -39
- data/app/assets/javascripts/pageflow/video_player/player_buffered_patch.js +0 -47
- data/app/assets/javascripts/pageflow/video_player/src_from_options_method.js +0 -31
- data/app/assets/stylesheets/pageflow/page_types/audio_loop.scss +0 -18
- data/app/assets/stylesheets/pageflow/page_types/background-video.scss +0 -50
- data/app/controllers/pageflow/editor/file_usages_controller.rb +0 -37
- data/app/jobs/pageflow/process_image_file_job.rb +0 -18
- data/app/views/pageflow/pages/templates/_audio.html.erb +0 -69
- data/app/views/pageflow/pages/templates/_audio_loop.html.erb +0 -34
- data/app/views/pageflow/pages/templates/_background_image.html.erb +0 -24
- data/app/views/pageflow/pages/templates/_background_video.html.erb +0 -32
- data/app/views/pageflow/pages/templates/_video.html.erb +0 -42
- data/lib/pageflow/built_in_page_type.rb +0 -79
@@ -0,0 +1,25 @@
|
|
1
|
+
module Pageflow
|
2
|
+
module Admin
|
3
|
+
class EntryTabPolicy
|
4
|
+
attr_reader :user, :tab, :query
|
5
|
+
|
6
|
+
def initialize(user, tab)
|
7
|
+
@user = user
|
8
|
+
@tab = tab
|
9
|
+
@query = EntryRoleQuery.new(user, tab.resource)
|
10
|
+
end
|
11
|
+
|
12
|
+
def see?
|
13
|
+
if user.admin?
|
14
|
+
true
|
15
|
+
elsif tab.required_account_role
|
16
|
+
query.has_at_least_account_role?(tab.required_account_role)
|
17
|
+
elsif tab.required_role
|
18
|
+
query.has_at_least_role?(tab.required_role)
|
19
|
+
else
|
20
|
+
!tab.admin_only?
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,138 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class EntryPolicy < ApplicationPolicy
|
3
|
+
class Scope < Scope
|
4
|
+
attr_reader :user, :scope, :query
|
5
|
+
|
6
|
+
def initialize(user, scope)
|
7
|
+
@user = user
|
8
|
+
@scope = scope
|
9
|
+
@query = EntryRoleQuery::Scope.new(user, scope)
|
10
|
+
end
|
11
|
+
|
12
|
+
def resolve
|
13
|
+
if user.admin?
|
14
|
+
scope.all
|
15
|
+
else
|
16
|
+
query.with_role_at_least(:previewer)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def editor_or_above
|
21
|
+
query.with_role_at_least(:editor)
|
22
|
+
end
|
23
|
+
|
24
|
+
def publisher_or_above
|
25
|
+
query.with_role_at_least(:publisher)
|
26
|
+
end
|
27
|
+
|
28
|
+
def member_addable
|
29
|
+
publisher_or_above
|
30
|
+
end
|
31
|
+
|
32
|
+
def manager_or_above
|
33
|
+
query.with_role_at_least(:manager)
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
attr_reader :user, :query
|
38
|
+
|
39
|
+
def initialize(user, entry)
|
40
|
+
@user = user
|
41
|
+
@entry = entry
|
42
|
+
@query = EntryRoleQuery.new(user, entry)
|
43
|
+
end
|
44
|
+
|
45
|
+
def record
|
46
|
+
@entry
|
47
|
+
end
|
48
|
+
|
49
|
+
def preview?
|
50
|
+
query.has_at_least_role?(:previewer)
|
51
|
+
end
|
52
|
+
|
53
|
+
def read?
|
54
|
+
preview?
|
55
|
+
end
|
56
|
+
|
57
|
+
def use_files?
|
58
|
+
preview?
|
59
|
+
end
|
60
|
+
|
61
|
+
def edit?
|
62
|
+
query.has_at_least_role?(:editor)
|
63
|
+
end
|
64
|
+
|
65
|
+
def confirm_encoding?
|
66
|
+
edit?
|
67
|
+
end
|
68
|
+
|
69
|
+
def edit_outline?
|
70
|
+
edit?
|
71
|
+
end
|
72
|
+
|
73
|
+
def index_widgets_for?
|
74
|
+
edit?
|
75
|
+
end
|
76
|
+
|
77
|
+
def restore?
|
78
|
+
edit?
|
79
|
+
end
|
80
|
+
|
81
|
+
def snapshot?
|
82
|
+
edit?
|
83
|
+
end
|
84
|
+
|
85
|
+
def publish?
|
86
|
+
query.has_at_least_role?(:publisher)
|
87
|
+
end
|
88
|
+
|
89
|
+
def create?
|
90
|
+
publish? && AccountPolicy::Scope.new(user, Account).entry_creatable.any?
|
91
|
+
end
|
92
|
+
|
93
|
+
def duplicate?
|
94
|
+
publish?
|
95
|
+
end
|
96
|
+
|
97
|
+
def manage?
|
98
|
+
user.admin? ||
|
99
|
+
query.has_at_least_role?(:manager)
|
100
|
+
end
|
101
|
+
|
102
|
+
def add_member_to?
|
103
|
+
manage?
|
104
|
+
end
|
105
|
+
|
106
|
+
def edit_role_on?
|
107
|
+
manage?
|
108
|
+
end
|
109
|
+
|
110
|
+
def destroy_membership_on?
|
111
|
+
manage?
|
112
|
+
end
|
113
|
+
|
114
|
+
def publish_on_account_of?
|
115
|
+
query.has_at_least_account_role?(:publisher)
|
116
|
+
end
|
117
|
+
|
118
|
+
def update_account_on?
|
119
|
+
publish_on_account_of?
|
120
|
+
end
|
121
|
+
|
122
|
+
def update_theming_on?
|
123
|
+
publish_on_account_of?
|
124
|
+
end
|
125
|
+
|
126
|
+
def manage_account_of?
|
127
|
+
query.has_at_least_account_role?(:manager)
|
128
|
+
end
|
129
|
+
|
130
|
+
def update_feature_configuration_on?
|
131
|
+
manage_account_of?
|
132
|
+
end
|
133
|
+
|
134
|
+
def destroy?
|
135
|
+
manage_account_of?
|
136
|
+
end
|
137
|
+
end
|
138
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class FilePolicy < ApplicationPolicy
|
3
|
+
def initialize(user, file)
|
4
|
+
@user = user
|
5
|
+
@file = file
|
6
|
+
end
|
7
|
+
|
8
|
+
def manage?
|
9
|
+
if @file.parent_file
|
10
|
+
can_edit_any_entry_using_file?(@file.parent_file)
|
11
|
+
else
|
12
|
+
can_edit_any_entry_using_file?(@file)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
def use?
|
17
|
+
can_preview_any_entry_using_file?
|
18
|
+
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
def can_preview_any_entry_using_file?
|
23
|
+
previewer_of_any_entry_using_file_or_its_account?(@user, @file)
|
24
|
+
end
|
25
|
+
|
26
|
+
def previewer_of_any_entry_using_file_or_its_account?(user, file)
|
27
|
+
entries_user_is_previewer_or_above_on = EntryPolicy::Scope
|
28
|
+
.new(user, Entry).resolve
|
29
|
+
(entries_user_is_previewer_or_above_on.map(&:id) & file.using_entry_ids).any?
|
30
|
+
end
|
31
|
+
|
32
|
+
def can_edit_any_entry_using_file?(file)
|
33
|
+
editor_of_any_entry_using_file_or_its_account?(@user, file)
|
34
|
+
end
|
35
|
+
|
36
|
+
def editor_of_any_entry_using_file_or_its_account?(user, file)
|
37
|
+
entries_user_is_editor_or_above_on = EntryPolicy::Scope
|
38
|
+
.new(user, Entry).editor_or_above
|
39
|
+
(entries_user_is_editor_or_above_on.map(&:id) & file.using_entry_ids).any?
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class FolderPolicy < ApplicationPolicy
|
3
|
+
class Scope < Scope
|
4
|
+
attr_reader :user, :scope
|
5
|
+
|
6
|
+
def initialize(user, scope)
|
7
|
+
@user = user
|
8
|
+
@scope = scope
|
9
|
+
end
|
10
|
+
|
11
|
+
def resolve
|
12
|
+
if user.admin?
|
13
|
+
scope.all
|
14
|
+
else
|
15
|
+
scope.where('account_id IN (?) OR id IN (?)',
|
16
|
+
accounts_where_user_is_at_least_previewer(user).map(&:id),
|
17
|
+
user.entries.map(&:folder_id))
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
private
|
22
|
+
|
23
|
+
def accounts_where_user_is_at_least_previewer(user)
|
24
|
+
user.accounts.joins(sanitize_sql_array([
|
25
|
+
'LEFT OUTER JOIN pageflow_memberships as pageflow_memberships_2 ON ' \
|
26
|
+
'pageflow_memberships_2.user_id = :user_id AND ' \
|
27
|
+
'pageflow_memberships_2.entity_type = "Pageflow::Account" AND ' \
|
28
|
+
'pageflow_memberships_2.entity_id = pageflow_accounts.id AND ' \
|
29
|
+
'pageflow_memberships_2.role IN ("previewer", "editor", "publisher", "manager")',
|
30
|
+
user_id: user.id])).where('pageflow_memberships_2.entity_id IS NOT NULL')
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def initialize(user, folder)
|
35
|
+
@user = user
|
36
|
+
@folder = folder
|
37
|
+
end
|
38
|
+
|
39
|
+
def manage?
|
40
|
+
allows?(%w(publisher manager))
|
41
|
+
end
|
42
|
+
|
43
|
+
def show_account_selection_on?
|
44
|
+
(@user.admin? && Account.all.size > 1) ||
|
45
|
+
@user.memberships.as_publisher_or_above.on_accounts.size > 1
|
46
|
+
end
|
47
|
+
|
48
|
+
private
|
49
|
+
|
50
|
+
def allows?(roles)
|
51
|
+
@user.memberships.where(role: roles, entity: @folder.account).any?
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
@@ -0,0 +1,105 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class MembershipPolicy < ApplicationPolicy
|
3
|
+
class Scope < Scope
|
4
|
+
attr_reader :user, :scope
|
5
|
+
|
6
|
+
def initialize(user, scope)
|
7
|
+
@user = user
|
8
|
+
@scope = scope
|
9
|
+
end
|
10
|
+
|
11
|
+
def indexable
|
12
|
+
if user.admin?
|
13
|
+
scope.all
|
14
|
+
else
|
15
|
+
scope.where(permissions_appropriate).where(membership_is_present)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
def permissions_appropriate
|
22
|
+
sanitize_sql_array(['pageflow_memberships.entity_type = "Pageflow::Account" AND ' \
|
23
|
+
'pageflow_memberships.entity_id IN (:managed_account_ids) OR ' \
|
24
|
+
'pageflow_memberships.entity_type = "Pageflow::Entry" AND ' \
|
25
|
+
'pageflow_memberships.entity_id IN (:common_entry_ids) OR '\
|
26
|
+
'pageflow_memberships.user_id = :user_id',
|
27
|
+
managed_account_ids: managed_account_ids,
|
28
|
+
common_entry_ids: common_entry_ids,
|
29
|
+
user_id: @user.id])
|
30
|
+
end
|
31
|
+
|
32
|
+
def managed_account_ids
|
33
|
+
user.memberships.on_accounts.where(role: 'manager').map(&:entity_id)
|
34
|
+
end
|
35
|
+
|
36
|
+
def common_entry_ids
|
37
|
+
EntryPolicy::Scope.new(user, Entry).resolve.map(&:id)
|
38
|
+
end
|
39
|
+
|
40
|
+
def membership_is_present
|
41
|
+
'pageflow_memberships.entity_id IS NOT NULL'
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def initialize(user, membership)
|
46
|
+
@user = user
|
47
|
+
@membership = membership
|
48
|
+
end
|
49
|
+
|
50
|
+
def create?
|
51
|
+
if @membership.entity_type == 'Pageflow::Account'
|
52
|
+
create_for_account?
|
53
|
+
else
|
54
|
+
create_for_entry?
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
def edit_role?
|
59
|
+
if @membership.entity_type == 'Pageflow::Account'
|
60
|
+
edit_role_on_account?
|
61
|
+
else
|
62
|
+
edit_role_on_entry?
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
def destroy?
|
67
|
+
if @membership.entity_type == 'Pageflow::Account'
|
68
|
+
destroy_for_account?
|
69
|
+
else
|
70
|
+
destroy_for_entry?
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
private
|
75
|
+
|
76
|
+
def create_for_entry?
|
77
|
+
EntryPolicy.new(@user, @membership.entity).add_member_to? &&
|
78
|
+
@membership.user.accounts.include?(@membership.entity.account)
|
79
|
+
end
|
80
|
+
|
81
|
+
def create_for_account?
|
82
|
+
AccountPolicy.new(@user, @membership.entity).add_member_to?
|
83
|
+
end
|
84
|
+
|
85
|
+
def edit_role_on_entry?
|
86
|
+
@user.admin? ||
|
87
|
+
EntryPolicy.new(@user, @membership.entity).edit_role_on?
|
88
|
+
end
|
89
|
+
|
90
|
+
def edit_role_on_account?
|
91
|
+
@user.admin? ||
|
92
|
+
AccountPolicy.new(@user, @membership.entity).edit_role_on?
|
93
|
+
end
|
94
|
+
|
95
|
+
def destroy_for_entry?
|
96
|
+
@user.admin? ||
|
97
|
+
EntryPolicy.new(@user, @membership.entity).destroy_membership_on?
|
98
|
+
end
|
99
|
+
|
100
|
+
def destroy_for_account?
|
101
|
+
@user.admin? ||
|
102
|
+
AccountPolicy.new(@user, @membership.entity).destroy_membership_on?
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
@@ -0,0 +1,57 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class ThemingPolicy < ApplicationPolicy
|
3
|
+
class Scope < Scope
|
4
|
+
attr_reader :user, :scope
|
5
|
+
|
6
|
+
def initialize(user, scope)
|
7
|
+
@user = user
|
8
|
+
@scope = scope
|
9
|
+
end
|
10
|
+
|
11
|
+
def themings_allowed_for(accounts)
|
12
|
+
if user.admin?
|
13
|
+
scope.all
|
14
|
+
else
|
15
|
+
accounts_ids = accounts.try(:id) || accounts.try(:length) && accounts.map(&:id)
|
16
|
+
scope.joins(publisher_memberships_for_accounts(user, accounts_ids))
|
17
|
+
.where(membership_is_present)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
private
|
22
|
+
|
23
|
+
def publisher_memberships_for_accounts(user, accounts_ids)
|
24
|
+
sanitize_sql_array(['LEFT OUTER JOIN pageflow_memberships ON ' \
|
25
|
+
'pageflow_memberships.user_id = :user_id AND ' \
|
26
|
+
'pageflow_themings.account_id IN (:accounts_ids) AND ' \
|
27
|
+
'pageflow_memberships.entity_id IN (:accounts_ids) AND ' \
|
28
|
+
'pageflow_memberships.entity_type = "Pageflow::Account" AND ' \
|
29
|
+
'pageflow_memberships.role IN ("publisher", "manager")',
|
30
|
+
user_id: user.id, accounts_ids: accounts_ids])
|
31
|
+
end
|
32
|
+
|
33
|
+
def membership_is_present
|
34
|
+
'pageflow_memberships.entity_id IS NOT NULL'
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
def initialize(user, theming)
|
39
|
+
@user = user
|
40
|
+
@theming = theming
|
41
|
+
end
|
42
|
+
|
43
|
+
def edit?
|
44
|
+
allows?(%w(publisher manager))
|
45
|
+
end
|
46
|
+
|
47
|
+
def index_widgets_for?
|
48
|
+
@user.admin?
|
49
|
+
end
|
50
|
+
|
51
|
+
private
|
52
|
+
|
53
|
+
def allows?(roles)
|
54
|
+
@user.memberships.where(role: roles, entity: @theming.account).any?
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
@@ -0,0 +1,69 @@
|
|
1
|
+
module Pageflow
|
2
|
+
class UserPolicy < ApplicationPolicy
|
3
|
+
class Scope < Scope
|
4
|
+
attr_reader :user, :scope
|
5
|
+
|
6
|
+
def initialize(user, scope)
|
7
|
+
@user = user
|
8
|
+
@scope = scope
|
9
|
+
end
|
10
|
+
|
11
|
+
def resolve
|
12
|
+
if user.admin?
|
13
|
+
scope.all
|
14
|
+
else
|
15
|
+
manager_accounts_ids = AccountPolicy::Scope
|
16
|
+
.new(@user, Account).member_addable.map(&:id)
|
17
|
+
|
18
|
+
scope.joins(:memberships)
|
19
|
+
.where('pageflow_memberships.entity_type = "Pageflow::Account"')
|
20
|
+
.where(membership_in_managed_account(manager_accounts_ids)).distinct
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def membership_in_managed_account(accounts_ids)
|
27
|
+
sanitize_sql_array(['pageflow_memberships.entity_id IN (:accounts_ids)',
|
28
|
+
accounts_ids: accounts_ids])
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def initialize(user, managed_user)
|
33
|
+
@user = user
|
34
|
+
@managed_user = managed_user
|
35
|
+
end
|
36
|
+
|
37
|
+
def create?
|
38
|
+
index?
|
39
|
+
end
|
40
|
+
|
41
|
+
def index?
|
42
|
+
@user.memberships.on_accounts.where(role: 'manager').any?
|
43
|
+
end
|
44
|
+
|
45
|
+
def read?
|
46
|
+
manager_accounts = AccountPolicy::Scope
|
47
|
+
.new(@user, Account).member_addable
|
48
|
+
managed_user_accounts = AccountPolicy::Scope
|
49
|
+
.new(@managed_user, Account).resolve
|
50
|
+
(manager_accounts & managed_user_accounts).any?
|
51
|
+
end
|
52
|
+
|
53
|
+
def redirect_to_user?
|
54
|
+
read?
|
55
|
+
end
|
56
|
+
|
57
|
+
def admin?
|
58
|
+
@user.admin?
|
59
|
+
end
|
60
|
+
|
61
|
+
def set_admin?
|
62
|
+
admin?
|
63
|
+
end
|
64
|
+
|
65
|
+
def delete_own_user?
|
66
|
+
Pageflow.config.authorize_user_deletion.call(@managed_user) == true
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|