biovision-base 0.22.180920.0 → 0.34.190331.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +5 -21
- data/app/assets/images/biovision/base/icons/apply.svg +4 -0
- data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
- data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
- data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
- data/app/assets/images/biovision/base/icons/settings.svg +41 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
- data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
- data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
- data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
- data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
- data/app/assets/javascripts/biovision/base/biovision.js +780 -461
- data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
- data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
- data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
- data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
- data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
- data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
- data/app/assets/stylesheets/biovision/base/default.scss +6 -6
- data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
- data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
- data/app/controllers/admin/editable_pages_controller.rb +6 -4
- data/app/controllers/admin/privileges_controller.rb +2 -3
- data/app/controllers/admin/settings_controller.rb +52 -0
- data/app/controllers/admin/simple_blocks_controller.rb +28 -0
- data/app/controllers/admin/users_controller.rb +1 -1
- data/app/controllers/agents_controller.rb +4 -4
- data/app/controllers/authentication_controller.rb +28 -6
- data/app/controllers/browsers_controller.rb +4 -4
- data/app/controllers/concerns/authentication.rb +8 -5
- data/app/controllers/concerns/entity_priority.rb +3 -0
- data/app/controllers/concerns/lockable_entity.rb +6 -3
- data/app/controllers/concerns/removable_image.rb +4 -5
- data/app/controllers/concerns/toggleable_entity.rb +4 -5
- data/app/controllers/editable_pages_controller.rb +14 -8
- data/app/controllers/fallback_controller.rb +7 -2
- data/app/controllers/feedback_requests_controller.rb +23 -8
- data/app/controllers/metrics_controller.rb +3 -3
- data/app/controllers/my/profiles_controller.rb +32 -15
- data/app/controllers/privilege_groups_controller.rb +4 -4
- data/app/controllers/privileges_controller.rb +7 -26
- data/app/controllers/simple_blocks_controller.rb +63 -0
- data/app/controllers/stored_values_controller.rb +4 -4
- data/app/controllers/tokens_controller.rb +4 -4
- data/app/controllers/users_controller.rb +8 -3
- data/app/helpers/biovision_users_helper.rb +60 -21
- data/app/helpers/editable_pages_helper.rb +22 -0
- data/app/helpers/languages_helper.rb +3 -0
- data/app/helpers/simple_image_helper.rb +66 -0
- data/app/mailers/application_mailer.rb +0 -2
- data/app/mailers/code_sender.rb +13 -2
- data/app/mailers/feedback_mailer.rb +5 -2
- data/app/mailers/user_mailer.rb +6 -1
- data/app/models/biovision_component.rb +43 -0
- data/app/models/biovision_parameter.rb +34 -0
- data/app/models/code.rb +22 -7
- data/app/models/code_type.rb +9 -1
- data/app/models/concerns/flat_priority.rb +50 -0
- data/app/models/concerns/nested_priority.rb +58 -0
- data/app/models/concerns/required_unique_slug.rb +5 -2
- data/app/models/editable_page.rb +49 -37
- data/app/models/foreign_site.rb +5 -3
- data/app/models/language.rb +15 -37
- data/app/models/metric.rb +2 -4
- data/app/models/privilege.rb +23 -45
- data/app/models/privilege_group.rb +6 -1
- data/app/models/simple_block.rb +66 -0
- data/app/models/user.rb +29 -26
- data/app/models/user_privilege.rb +1 -1
- data/app/services/biovision/components/base_component.rb +115 -0
- data/app/services/biovision/components/registration_component.rb +98 -0
- data/app/services/code_manager.rb +4 -1
- data/app/services/code_manager/confirmation.rb +8 -4
- data/app/services/code_manager/invitation.rb +9 -5
- data/app/services/code_manager/recovery.rb +9 -6
- data/app/services/user_manager.rb +5 -4
- data/app/services/user_profile_handler.rb +38 -11
- data/app/uploaders/avatar_uploader.rb +5 -1
- data/app/uploaders/editable_page_image_uploader.rb +4 -6
- data/app/uploaders/media_file_uploader.rb +6 -4
- data/app/uploaders/media_snapshot_uploader.rb +6 -2
- data/app/uploaders/simple_file_uploader.rb +12 -0
- data/app/uploaders/simple_image_uploader.rb +75 -0
- data/app/views/about/editable.html.erb +1 -1
- data/app/views/admin/agents/_filter.html.erb +1 -1
- data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
- data/app/views/admin/editable_pages/index.html.erb +8 -1
- data/app/views/admin/editable_pages/show.html.erb +21 -17
- data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
- data/app/views/admin/index/_biovision_base.html.erb +5 -7
- data/app/views/admin/index/_components.html.erb +9 -0
- data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
- data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
- data/app/views/admin/index/index.html.erb +2 -0
- data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
- data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
- data/app/views/admin/privileges/index.html.erb +6 -1
- data/app/views/admin/privileges/show.html.erb +31 -18
- data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
- data/app/views/admin/settings/component/_parameters.html.erb +37 -0
- data/app/views/admin/settings/component/_setting.html.erb +18 -0
- data/app/views/admin/settings/component/_settings.html.erb +31 -0
- data/app/views/admin/settings/index.html.erb +27 -0
- data/app/views/admin/settings/show.html.erb +42 -0
- data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
- data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
- data/app/views/admin/simple_blocks/index.html.erb +21 -0
- data/app/views/admin/simple_blocks/show.html.erb +51 -0
- data/app/views/admin/tokens/_filter.html.erb +1 -1
- data/app/views/admin/users/_filter.html.erb +1 -1
- data/app/views/admin/users/entity/_privilege.html.erb +12 -21
- data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
- data/app/views/admin/users/privileges.html.erb +9 -1
- data/app/views/admin/users/search.jbuilder +3 -3
- data/app/views/admin/users/show.html.erb +11 -6
- data/app/views/agents/_filter.html.erb +22 -22
- data/app/views/agents/_form.html.erb +25 -29
- data/app/views/application/forbidden.html.erb +9 -0
- data/app/views/application/forbidden.jbuilder +3 -0
- data/app/views/authentication/_form.html.erb +13 -13
- data/app/views/browsers/_form.html.erb +21 -25
- data/app/views/editable_blocks/_entity.html.erb +4 -1
- data/app/views/editable_pages/_form.html.erb +63 -62
- data/app/views/editable_pages/edit.html.erb +1 -1
- data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
- data/app/views/editable_pages/new.html.erb +3 -3
- data/app/views/fallback/show.html.erb +8 -1
- data/app/views/feedback_requests/_form.html.erb +76 -52
- data/app/views/feedback_requests/create.js.erb +1 -10
- data/app/views/index/index/_editable.html.erb +0 -4
- data/app/views/metrics/_form.html.erb +38 -36
- data/app/views/my/confirmations/show.html.erb +5 -3
- data/app/views/my/profiles/closed.html.erb +7 -0
- data/app/views/my/profiles/edit/_form.html.erb +9 -9
- data/app/views/my/profiles/new.html.erb +9 -1
- data/app/views/my/profiles/new/_form.html.erb +22 -1
- data/app/views/my/recoveries/show.html.erb +2 -2
- data/app/views/privilege_groups/_form.html.erb +48 -21
- data/app/views/privileges/_form.html.erb +68 -36
- data/app/views/profiles/_profile.html.erb +3 -3
- data/app/views/shared/_pagination.jbuilder +7 -5
- data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
- data/app/views/shared/forms/_meta_texts.html.erb +3 -3
- data/app/views/shared/forms/_priority.html.erb +12 -0
- data/app/views/shared/forms/_state_container.html.erb +1 -0
- data/app/views/simple_blocks/_empty.html.erb +0 -0
- data/app/views/simple_blocks/_form.html.erb +120 -0
- data/app/views/simple_blocks/_simple_block.html.erb +26 -0
- data/app/views/simple_blocks/edit.html.erb +17 -0
- data/app/views/simple_blocks/new.html.erb +15 -0
- data/app/views/stored_values/_form.html.erb +57 -28
- data/app/views/tokens/_form.html.erb +31 -26
- data/app/views/users/_form.html.erb +1 -1
- data/config/initializers/carrierwave.rb +7 -2
- data/config/locales/common-ru.yml +5 -0
- data/config/locales/components-ru.yml +50 -0
- data/config/locales/editable-pages-en.yml +2 -0
- data/config/locales/editable-pages-ru.yml +50 -7
- data/config/locales/editable-pages-sv.yml +2 -0
- data/config/locales/feedback-ru.yml +1 -0
- data/config/locales/users-en.yml +0 -1
- data/config/locales/users-ru.yml +6 -1
- data/config/locales/users-sv.yml +0 -1
- data/config/routes.rb +32 -6
- data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
- data/db/migrate/20181217000010_create_metrics.rb +40 -0
- data/db/migrate/20181217000015_create_browsers.rb +38 -0
- data/db/migrate/20181217000020_create_languages.rb +30 -0
- data/db/migrate/20181217000030_create_users.rb +118 -0
- data/db/migrate/20181217000035_create_codes.rb +51 -0
- data/db/migrate/20181217000040_create_privileges.rb +142 -0
- data/db/migrate/20181217000100_create_media_folders.rb +53 -0
- data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
- data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
- data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
- data/db/migrate/20181217121212_update_fields181217.rb +29 -0
- data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
- data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
- data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
- data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
- data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
- data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
- data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
- data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
- data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
- data/lib/biovision/base/base_methods.rb +19 -2
- data/lib/biovision/base/version.rb +3 -1
- data/lib/tasks/users.rake +19 -1
- metadata +75 -40
- data/app/views/admin/privileges/_list.html.erb +0 -15
- data/db/migrate/20170228000000_create_languages.rb +0 -23
- data/db/migrate/20170301000001_create_metrics.rb +0 -23
- data/db/migrate/20170301000002_create_metric_values.rb +0 -19
- data/db/migrate/20170301000101_create_browsers.rb +0 -22
- data/db/migrate/20170301000102_create_agents.rb +0 -22
- data/db/migrate/20170302000001_create_users.rb +0 -55
- data/db/migrate/20170302000003_create_tokens.rb +0 -23
- data/db/migrate/20170302000004_create_code_types.rb +0 -20
- data/db/migrate/20170302000005_create_codes.rb +0 -24
- data/db/migrate/20170302000101_create_privileges.rb +0 -41
- data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
- data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
- data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
- data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
- data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
- data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
- data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
- data/db/migrate/20170823000001_create_stored_values.rb +0 -19
- data/db/migrate/20171202000000_create_media_folders.rb +0 -28
- data/db/migrate/20171202000001_create_media_files.rb +0 -27
- data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
- data/db/migrate/20180117160000_create_user_languages.rb +0 -17
- data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
- data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
- data/db/migrate/20180627190000_create_editable_blocks.rb +0 -39
@@ -58,6 +58,18 @@ $button-destroy-text-b: $button-destroy-text-a !default;
|
|
58
58
|
background: $bg-b;
|
59
59
|
color: $text-b;
|
60
60
|
}
|
61
|
+
|
62
|
+
&.inverted {
|
63
|
+
background: $bg-b;
|
64
|
+
color: $text-b;
|
65
|
+
|
66
|
+
&:active,
|
67
|
+
&:focus,
|
68
|
+
&:hover {
|
69
|
+
background: $bg-a;
|
70
|
+
color: $text-a;
|
71
|
+
}
|
72
|
+
}
|
61
73
|
}
|
62
74
|
|
63
75
|
@mixin border-button($border-a, $border-b) {
|
@@ -68,6 +80,16 @@ $button-destroy-text-b: $button-destroy-text-a !default;
|
|
68
80
|
&:hover {
|
69
81
|
border-color: $border-b;
|
70
82
|
}
|
83
|
+
|
84
|
+
&.inverted {
|
85
|
+
border-color: $border-b;
|
86
|
+
|
87
|
+
&:active,
|
88
|
+
&:focus,
|
89
|
+
&:hover {
|
90
|
+
border-color: $border-a;
|
91
|
+
}
|
92
|
+
}
|
71
93
|
}
|
72
94
|
|
73
95
|
.button-action,
|
@@ -11,13 +11,13 @@ $font-size-decreased: 1.3rem !default;
|
|
11
11
|
$font-size-small: 1.1rem !default;
|
12
12
|
$font-size-xs: 1rem !default;
|
13
13
|
|
14
|
-
$spacer-xxs: .4rem !default;
|
15
|
-
$spacer-xs: .8rem !default;
|
16
14
|
$spacer-s: 1.6rem !default;
|
17
|
-
$spacer-
|
18
|
-
$spacer-
|
19
|
-
$spacer-
|
20
|
-
$spacer-
|
15
|
+
$spacer-xxs: #{$spacer-s / 4} !default;
|
16
|
+
$spacer-xs: #{$spacer-s / 2} !default;
|
17
|
+
$spacer-m: #{$spacer-s * 2} !default;
|
18
|
+
$spacer-l: #{$spacer-s * 3} !default;
|
19
|
+
$spacer-xl: #{$spacer-s * 4} !default;
|
20
|
+
$spacer-xxl: #{$spacer-s * 6} !default;
|
21
21
|
|
22
22
|
$content-width: 100rem !default;
|
23
23
|
$content-width-min: 32rem !default;
|
@@ -1,13 +1,25 @@
|
|
1
|
-
$font-family-heading: "Cormorant Garamond", serif !default;
|
2
1
|
$font-family-main: "Roboto", sans-serif !default;
|
2
|
+
$font-family-heading: "Cormorant Garamond", serif !default;
|
3
3
|
|
4
|
-
$font-size-
|
5
|
-
$font-size-
|
6
|
-
$font-size-
|
7
|
-
$font-size-
|
8
|
-
$font-size-
|
9
|
-
|
10
|
-
$
|
4
|
+
$font-size-xxxl: 4.5rem !default;
|
5
|
+
$font-size-xxl: 3.6rem !default;
|
6
|
+
$font-size-xl: 3.2rem !default;
|
7
|
+
$font-size-large: 2.4rem !default;
|
8
|
+
$font-size-increased: 1.8rem !default;
|
9
|
+
$font-size-normal: 1.6rem !default;
|
10
|
+
$font-size-decreased: 1.4rem !default;
|
11
|
+
$font-size-small: 1.2rem !default;
|
12
|
+
$font-size-xs: 1rem !default;
|
13
|
+
|
14
|
+
$spacer-s: 1.6rem !default;
|
15
|
+
$spacer-xxs: #{$spacer-s / 4} !default;
|
16
|
+
$spacer-xs: #{$spacer-s / 2} !default;
|
17
|
+
$spacer-m: #{$spacer-s * 2} !default;
|
18
|
+
$spacer-l: #{$spacer-s * 3} !default;
|
19
|
+
$spacer-xl: #{$spacer-s * 4} !default;
|
20
|
+
$spacer-xxl: #{$spacer-s * 6} !default;
|
21
|
+
|
22
|
+
$content-width: 120rem !default;
|
11
23
|
$content-width-min: 32rem !default;
|
12
24
|
|
13
25
|
$row-background-even: hsl(0, 0%, 95%) !default;
|
@@ -24,6 +36,11 @@ $border-color-secondary: rgb(230, 230, 230) !default;
|
|
24
36
|
$border-primary: .1rem solid $border-color-primary !default;
|
25
37
|
$border-secondary: .1rem solid $border-color-secondary !default;
|
26
38
|
|
39
|
+
$background-body: #f4f4f4 linear-gradient(to top, #f4f4f4, #dfdedc) no-repeat center / cover !default;
|
40
|
+
$background-header: #fff !default;
|
41
|
+
$background-main: #fff !default;
|
42
|
+
$background-footer: #fff !default;
|
43
|
+
|
27
44
|
$link-color: rgb(20, 127, 255) !default;
|
28
45
|
$link-color-visited: rgb(20, 77, 250) !default;
|
29
46
|
$link-color-hover: rgb(255, 77, 20) !default;
|
@@ -1,7 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Administrative part of editable_pages management
|
1
4
|
class Admin::EditablePagesController < AdminController
|
2
5
|
include EntityPriority
|
6
|
+
include ToggleableEntity
|
3
7
|
|
4
|
-
before_action :set_entity, except:
|
8
|
+
before_action :set_entity, except: :index
|
5
9
|
|
6
10
|
# get /admin/editable_pages
|
7
11
|
def index
|
@@ -20,8 +24,6 @@ class Admin::EditablePagesController < AdminController
|
|
20
24
|
|
21
25
|
def set_entity
|
22
26
|
@entity = EditablePage.find_by(id: params[:id])
|
23
|
-
if @entity.nil?
|
24
|
-
handle_http_404("Cannot find editable_page #{params[:id]}")
|
25
|
-
end
|
27
|
+
handle_http_404('Cannot find editable_page') if @entity.nil?
|
26
28
|
end
|
27
29
|
end
|
@@ -1,5 +1,4 @@
|
|
1
1
|
class Admin::PrivilegesController < AdminController
|
2
|
-
include LockableEntity
|
3
2
|
include EntityPriority
|
4
3
|
include ToggleableEntity
|
5
4
|
|
@@ -26,9 +25,9 @@ class Admin::PrivilegesController < AdminController
|
|
26
25
|
end
|
27
26
|
|
28
27
|
def set_entity
|
29
|
-
@entity = Privilege.find_by(id: params[:id]
|
28
|
+
@entity = Privilege.find_by(id: params[:id])
|
30
29
|
if @entity.nil?
|
31
|
-
handle_http_404("Cannot find
|
30
|
+
handle_http_404("Cannot find privilege #{params[:id]}")
|
32
31
|
end
|
33
32
|
end
|
34
33
|
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Administrative controller for managing component settings and parameters
|
4
|
+
class Admin::SettingsController < AdminController
|
5
|
+
before_action :set_handler, except: :index
|
6
|
+
|
7
|
+
# get /admin/settings
|
8
|
+
def index
|
9
|
+
@collection = BiovisionComponent.pluck(:slug)
|
10
|
+
end
|
11
|
+
|
12
|
+
# get /admin/settings/:slug
|
13
|
+
def show
|
14
|
+
end
|
15
|
+
|
16
|
+
# patch /admin/settings/:slug
|
17
|
+
def update
|
18
|
+
new_settings = params.dig(:component, :settings).permit!
|
19
|
+
@handler.settings = new_settings.to_h
|
20
|
+
flash[:notice] = t('admin.settings.update.success')
|
21
|
+
redirect_to(admin_component_path(slug: params[:slug]))
|
22
|
+
end
|
23
|
+
|
24
|
+
# put /admin/settings/:slug/parameter
|
25
|
+
def set_parameter
|
26
|
+
slug = param_from_request(:key, :slug).downcase
|
27
|
+
value = param_from_request(:key, :value)
|
28
|
+
name = param_from_request(:key, :name)
|
29
|
+
description = param_from_request(:key, :description)
|
30
|
+
|
31
|
+
if name.blank? && description.blank?
|
32
|
+
@handler[slug] = value
|
33
|
+
else
|
34
|
+
@handler.set_parameter(slug, value, name, description)
|
35
|
+
end
|
36
|
+
|
37
|
+
head :no_content
|
38
|
+
end
|
39
|
+
|
40
|
+
# delete /admin/settings/:slug/:parameter_slug
|
41
|
+
def delete_parameter
|
42
|
+
@handler.delete_parameter(params[:parameter_slug])
|
43
|
+
|
44
|
+
head :no_content
|
45
|
+
end
|
46
|
+
|
47
|
+
private
|
48
|
+
|
49
|
+
def set_handler
|
50
|
+
@handler = Biovision::Components::BaseComponent.handler(params[:slug])
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Administrative part of simple_blocks management
|
4
|
+
class Admin::SimpleBlocksController < AdminController
|
5
|
+
include ToggleableEntity
|
6
|
+
|
7
|
+
before_action :set_entity, except: :index
|
8
|
+
|
9
|
+
# get /admin/simple_blocks
|
10
|
+
def index
|
11
|
+
@collection = SimpleBlock.list_for_administration
|
12
|
+
end
|
13
|
+
|
14
|
+
# get /admin/simple_blocks/:id
|
15
|
+
def show
|
16
|
+
end
|
17
|
+
|
18
|
+
private
|
19
|
+
|
20
|
+
def restrict_access
|
21
|
+
require_privilege :content_manager
|
22
|
+
end
|
23
|
+
|
24
|
+
def set_entity
|
25
|
+
@entity = SimpleBlock.find_by(id: params[:id])
|
26
|
+
handle_http_404('Cannot find simple_block') if @entity.nil?
|
27
|
+
end
|
28
|
+
end
|
@@ -79,7 +79,7 @@ class Admin::UsersController < AdminController
|
|
79
79
|
end
|
80
80
|
|
81
81
|
def set_privilege
|
82
|
-
@privilege = Privilege.find_by(id: params[:privilege_id]
|
82
|
+
@privilege = Privilege.find_by(id: params[:privilege_id])
|
83
83
|
if @privilege.nil?
|
84
84
|
handle_http_404("Cannot use privilege #{params[:privilege_id]}")
|
85
85
|
end
|
@@ -11,9 +11,9 @@ class AgentsController < AdminController
|
|
11
11
|
def create
|
12
12
|
@entity = Agent.new entity_parameters
|
13
13
|
if @entity.save
|
14
|
-
|
14
|
+
form_processed_ok(admin_agent_path(id: @entity.id))
|
15
15
|
else
|
16
|
-
|
16
|
+
form_processed_with_error(:new)
|
17
17
|
end
|
18
18
|
end
|
19
19
|
|
@@ -28,9 +28,9 @@ class AgentsController < AdminController
|
|
28
28
|
# patch /agents/:id
|
29
29
|
def update
|
30
30
|
if @entity.update entity_parameters
|
31
|
-
|
31
|
+
form_processed_ok(admin_agent_path(id: @entity.id))
|
32
32
|
else
|
33
|
-
|
33
|
+
form_processed_with_error(:edit)
|
34
34
|
end
|
35
35
|
end
|
36
36
|
|
@@ -1,8 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Authentication with form and OAuth
|
1
4
|
class AuthenticationController < ApplicationController
|
2
5
|
include Authentication
|
3
6
|
|
4
|
-
before_action :redirect_authenticated_user, except: [
|
5
|
-
before_action :set_foreign_site, only:
|
7
|
+
before_action :redirect_authenticated_user, except: %i[new destroy]
|
8
|
+
before_action :set_foreign_site, only: :auth_callback
|
6
9
|
|
7
10
|
# get /login
|
8
11
|
def new
|
@@ -10,7 +13,7 @@ class AuthenticationController < ApplicationController
|
|
10
13
|
|
11
14
|
# post /login
|
12
15
|
def create
|
13
|
-
@user =
|
16
|
+
@user = find_user
|
14
17
|
@bouncer = UserBouncer.new(@user, tracking_for_entity)
|
15
18
|
bounce_or_allow
|
16
19
|
end
|
@@ -18,6 +21,8 @@ class AuthenticationController < ApplicationController
|
|
18
21
|
# delete /logout
|
19
22
|
def destroy
|
20
23
|
deactivate_token if current_user
|
24
|
+
|
25
|
+
cleanup_after_destroy
|
21
26
|
redirect_to root_path
|
22
27
|
end
|
23
28
|
|
@@ -34,9 +39,8 @@ class AuthenticationController < ApplicationController
|
|
34
39
|
|
35
40
|
def set_foreign_site
|
36
41
|
@foreign_site = ForeignSite.with_slug(params[:provider]).first
|
37
|
-
|
38
|
-
|
39
|
-
end
|
42
|
+
|
43
|
+
handle_http_503('Cannot set foreign site') if @foreign_site.nil?
|
40
44
|
end
|
41
45
|
|
42
46
|
def bounce_or_allow
|
@@ -66,7 +70,25 @@ class AuthenticationController < ApplicationController
|
|
66
70
|
|
67
71
|
respond_to do |format|
|
68
72
|
format.json
|
73
|
+
format.js { render(js: "document.location.href = '#{@return_path}'") }
|
69
74
|
format.html { redirect_to(@return_path) }
|
70
75
|
end
|
71
76
|
end
|
77
|
+
|
78
|
+
def find_user
|
79
|
+
login = param_from_request(:login).downcase
|
80
|
+
user = User.find_by(slug: login)
|
81
|
+
|
82
|
+
# Try to authenticate by email, if login does not match anything
|
83
|
+
if user.nil? && login.index('@').to_i.positive?
|
84
|
+
user = User.with_email(login).first
|
85
|
+
end
|
86
|
+
|
87
|
+
user
|
88
|
+
end
|
89
|
+
|
90
|
+
# Clean obsolete cookies, session parameters, etc.
|
91
|
+
def cleanup_after_destroy
|
92
|
+
# this method can be redefined in decorators
|
93
|
+
end
|
72
94
|
end
|
@@ -11,9 +11,9 @@ class BrowsersController < AdminController
|
|
11
11
|
def create
|
12
12
|
@entity = Browser.new entity_parameters
|
13
13
|
if @entity.save
|
14
|
-
|
14
|
+
form_processed_ok(admin_browser_path(id: @entity.id))
|
15
15
|
else
|
16
|
-
|
16
|
+
form_processed_with_error(:new)
|
17
17
|
end
|
18
18
|
end
|
19
19
|
|
@@ -24,9 +24,9 @@ class BrowsersController < AdminController
|
|
24
24
|
# patch /browsers/:id
|
25
25
|
def update
|
26
26
|
if @entity.update entity_parameters
|
27
|
-
|
27
|
+
form_processed_ok(admin_browser_path(id: @entity.id))
|
28
28
|
else
|
29
|
-
|
29
|
+
form_processed_with_error(:edit)
|
30
30
|
end
|
31
31
|
end
|
32
32
|
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Adds methods for user authentication
|
1
4
|
module Authentication
|
2
5
|
extend ActiveSupport::Concern
|
3
6
|
|
@@ -18,17 +21,17 @@ module Authentication
|
|
18
21
|
end
|
19
22
|
|
20
23
|
def deactivate_token
|
21
|
-
token = Token.find_by
|
22
|
-
token
|
24
|
+
token = Token.find_by(token: cookies['token'].split(':').last)
|
25
|
+
token&.update(active: false)
|
23
26
|
pop_token
|
24
27
|
end
|
25
28
|
|
26
29
|
def pop_token
|
27
30
|
if cookies['pt']
|
28
31
|
cookies['token'] = {
|
29
|
-
value:
|
30
|
-
expires:
|
31
|
-
domain:
|
32
|
+
value: cookies['pt'],
|
33
|
+
expires: 1.year.from_now,
|
34
|
+
domain: :all,
|
32
35
|
httponly: true
|
33
36
|
}
|
34
37
|
cookies.delete 'pt', domain: :all
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Adds methods for locking and unlocking entity
|
1
4
|
module LockableEntity
|
2
5
|
extend ActiveSupport::Concern
|
3
6
|
|
@@ -16,8 +19,8 @@ module LockableEntity
|
|
16
19
|
protected
|
17
20
|
|
18
21
|
def check_entity_lock
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
+
return unless @entity.locked?
|
23
|
+
|
24
|
+
render json: { errors: { locked: @entity.locked? } }, status: :forbidden
|
22
25
|
end
|
23
26
|
end
|
@@ -1,3 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Adds action for removing entity image in column "image"
|
1
4
|
module RemovableImage
|
2
5
|
extend ActiveSupport::Concern
|
3
6
|
|
@@ -24,10 +27,6 @@ module RemovableImage
|
|
24
27
|
end
|
25
28
|
|
26
29
|
def entity_image_is_locked?
|
27
|
-
|
28
|
-
@entity.locked?
|
29
|
-
else
|
30
|
-
false
|
31
|
-
end
|
30
|
+
@entity.respond_to?(:locked?) ? @entity.locked? : false
|
32
31
|
end
|
33
32
|
end
|