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.
Files changed (223) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +5 -21
  3. data/app/assets/images/biovision/base/icons/apply.svg +4 -0
  4. data/app/assets/images/biovision/base/icons/components/contact.svg +26 -0
  5. data/app/assets/images/biovision/base/icons/components/registration.svg +17 -0
  6. data/app/assets/images/biovision/base/icons/destroy.svg +11 -8
  7. data/app/assets/images/biovision/base/icons/settings.svg +41 -0
  8. data/app/assets/images/biovision/base/icons/slider/arrow-left.svg +4 -0
  9. data/app/assets/images/biovision/base/icons/slider/arrow-right.svg +4 -0
  10. data/app/assets/images/biovision/base/placeholders/16x9.svg +10 -3
  11. data/app/assets/images/biovision/base/placeholders/1x1.svg +12 -0
  12. data/app/assets/images/biovision/base/placeholders/3x2.svg +10 -3
  13. data/app/assets/javascripts/biovision/base/biovision.js +780 -461
  14. data/app/assets/javascripts/biovision/base/components/carousel.js +123 -0
  15. data/app/assets/javascripts/biovision/base/polyfills.js +149 -0
  16. data/app/assets/stylesheets/biovision/base/admin.scss +85 -46
  17. data/app/assets/stylesheets/biovision/base/admin/components.scss +141 -0
  18. data/app/assets/stylesheets/biovision/base/biovision.scss +149 -33
  19. data/app/assets/stylesheets/biovision/base/buttons/buttons-common.scss +22 -0
  20. data/app/assets/stylesheets/biovision/base/default.scss +6 -6
  21. data/app/assets/stylesheets/biovision/base/default_admin.scss +25 -8
  22. data/app/assets/stylesheets/biovision/base/themes/simple-layout.scss +0 -3
  23. data/app/controllers/admin/editable_pages_controller.rb +6 -4
  24. data/app/controllers/admin/privileges_controller.rb +2 -3
  25. data/app/controllers/admin/settings_controller.rb +52 -0
  26. data/app/controllers/admin/simple_blocks_controller.rb +28 -0
  27. data/app/controllers/admin/users_controller.rb +1 -1
  28. data/app/controllers/agents_controller.rb +4 -4
  29. data/app/controllers/authentication_controller.rb +28 -6
  30. data/app/controllers/browsers_controller.rb +4 -4
  31. data/app/controllers/concerns/authentication.rb +8 -5
  32. data/app/controllers/concerns/entity_priority.rb +3 -0
  33. data/app/controllers/concerns/lockable_entity.rb +6 -3
  34. data/app/controllers/concerns/removable_image.rb +4 -5
  35. data/app/controllers/concerns/toggleable_entity.rb +4 -5
  36. data/app/controllers/editable_pages_controller.rb +14 -8
  37. data/app/controllers/fallback_controller.rb +7 -2
  38. data/app/controllers/feedback_requests_controller.rb +23 -8
  39. data/app/controllers/metrics_controller.rb +3 -3
  40. data/app/controllers/my/profiles_controller.rb +32 -15
  41. data/app/controllers/privilege_groups_controller.rb +4 -4
  42. data/app/controllers/privileges_controller.rb +7 -26
  43. data/app/controllers/simple_blocks_controller.rb +63 -0
  44. data/app/controllers/stored_values_controller.rb +4 -4
  45. data/app/controllers/tokens_controller.rb +4 -4
  46. data/app/controllers/users_controller.rb +8 -3
  47. data/app/helpers/biovision_users_helper.rb +60 -21
  48. data/app/helpers/editable_pages_helper.rb +22 -0
  49. data/app/helpers/languages_helper.rb +3 -0
  50. data/app/helpers/simple_image_helper.rb +66 -0
  51. data/app/mailers/application_mailer.rb +0 -2
  52. data/app/mailers/code_sender.rb +13 -2
  53. data/app/mailers/feedback_mailer.rb +5 -2
  54. data/app/mailers/user_mailer.rb +6 -1
  55. data/app/models/biovision_component.rb +43 -0
  56. data/app/models/biovision_parameter.rb +34 -0
  57. data/app/models/code.rb +22 -7
  58. data/app/models/code_type.rb +9 -1
  59. data/app/models/concerns/flat_priority.rb +50 -0
  60. data/app/models/concerns/nested_priority.rb +58 -0
  61. data/app/models/concerns/required_unique_slug.rb +5 -2
  62. data/app/models/editable_page.rb +49 -37
  63. data/app/models/foreign_site.rb +5 -3
  64. data/app/models/language.rb +15 -37
  65. data/app/models/metric.rb +2 -4
  66. data/app/models/privilege.rb +23 -45
  67. data/app/models/privilege_group.rb +6 -1
  68. data/app/models/simple_block.rb +66 -0
  69. data/app/models/user.rb +29 -26
  70. data/app/models/user_privilege.rb +1 -1
  71. data/app/services/biovision/components/base_component.rb +115 -0
  72. data/app/services/biovision/components/registration_component.rb +98 -0
  73. data/app/services/code_manager.rb +4 -1
  74. data/app/services/code_manager/confirmation.rb +8 -4
  75. data/app/services/code_manager/invitation.rb +9 -5
  76. data/app/services/code_manager/recovery.rb +9 -6
  77. data/app/services/user_manager.rb +5 -4
  78. data/app/services/user_profile_handler.rb +38 -11
  79. data/app/uploaders/avatar_uploader.rb +5 -1
  80. data/app/uploaders/editable_page_image_uploader.rb +4 -6
  81. data/app/uploaders/media_file_uploader.rb +6 -4
  82. data/app/uploaders/media_snapshot_uploader.rb +6 -2
  83. data/app/uploaders/simple_file_uploader.rb +12 -0
  84. data/app/uploaders/simple_image_uploader.rb +75 -0
  85. data/app/views/about/editable.html.erb +1 -1
  86. data/app/views/admin/agents/_filter.html.erb +1 -1
  87. data/app/views/admin/editable_pages/entity/_in_list.html.erb +16 -0
  88. data/app/views/admin/editable_pages/index.html.erb +8 -1
  89. data/app/views/admin/editable_pages/show.html.erb +21 -17
  90. data/app/views/admin/feedback_requests/entity/_in_list.html.erb +9 -1
  91. data/app/views/admin/index/_biovision_base.html.erb +5 -7
  92. data/app/views/admin/index/_components.html.erb +9 -0
  93. data/app/views/admin/index/dashboard/_editorial.html.erb +2 -2
  94. data/app/views/admin/index/dashboard/_settings.html.erb +2 -2
  95. data/app/views/admin/index/index.html.erb +2 -0
  96. data/app/views/admin/privileges/entity/_groups.html.erb +25 -25
  97. data/app/views/admin/privileges/entity/_in_list.html.erb +30 -9
  98. data/app/views/admin/privileges/index.html.erb +6 -1
  99. data/app/views/admin/privileges/show.html.erb +31 -18
  100. data/app/views/admin/settings/component/_new_parameter.html.erb +62 -0
  101. data/app/views/admin/settings/component/_parameters.html.erb +37 -0
  102. data/app/views/admin/settings/component/_setting.html.erb +18 -0
  103. data/app/views/admin/settings/component/_settings.html.erb +31 -0
  104. data/app/views/admin/settings/index.html.erb +27 -0
  105. data/app/views/admin/settings/show.html.erb +42 -0
  106. data/app/views/admin/simple_blocks/_nav_item.html.erb +6 -0
  107. data/app/views/admin/simple_blocks/entity/_in_list.html.erb +23 -0
  108. data/app/views/admin/simple_blocks/index.html.erb +21 -0
  109. data/app/views/admin/simple_blocks/show.html.erb +51 -0
  110. data/app/views/admin/tokens/_filter.html.erb +1 -1
  111. data/app/views/admin/users/_filter.html.erb +1 -1
  112. data/app/views/admin/users/entity/_privilege.html.erb +12 -21
  113. data/app/views/admin/users/entity/_privilege_tree.html.erb +17 -15
  114. data/app/views/admin/users/privileges.html.erb +9 -1
  115. data/app/views/admin/users/search.jbuilder +3 -3
  116. data/app/views/admin/users/show.html.erb +11 -6
  117. data/app/views/agents/_filter.html.erb +22 -22
  118. data/app/views/agents/_form.html.erb +25 -29
  119. data/app/views/application/forbidden.html.erb +9 -0
  120. data/app/views/application/forbidden.jbuilder +3 -0
  121. data/app/views/authentication/_form.html.erb +13 -13
  122. data/app/views/browsers/_form.html.erb +21 -25
  123. data/app/views/editable_blocks/_entity.html.erb +4 -1
  124. data/app/views/editable_pages/_form.html.erb +63 -62
  125. data/app/views/editable_pages/edit.html.erb +1 -1
  126. data/app/views/editable_pages/entity/_metadata.html.erb +4 -4
  127. data/app/views/editable_pages/new.html.erb +3 -3
  128. data/app/views/fallback/show.html.erb +8 -1
  129. data/app/views/feedback_requests/_form.html.erb +76 -52
  130. data/app/views/feedback_requests/create.js.erb +1 -10
  131. data/app/views/index/index/_editable.html.erb +0 -4
  132. data/app/views/metrics/_form.html.erb +38 -36
  133. data/app/views/my/confirmations/show.html.erb +5 -3
  134. data/app/views/my/profiles/closed.html.erb +7 -0
  135. data/app/views/my/profiles/edit/_form.html.erb +9 -9
  136. data/app/views/my/profiles/new.html.erb +9 -1
  137. data/app/views/my/profiles/new/_form.html.erb +22 -1
  138. data/app/views/my/recoveries/show.html.erb +2 -2
  139. data/app/views/privilege_groups/_form.html.erb +48 -21
  140. data/app/views/privileges/_form.html.erb +68 -36
  141. data/app/views/profiles/_profile.html.erb +3 -3
  142. data/app/views/shared/_pagination.jbuilder +7 -5
  143. data/app/views/shared/admin/_breadcrumbs.html.erb +1 -1
  144. data/app/views/shared/forms/_meta_texts.html.erb +3 -3
  145. data/app/views/shared/forms/_priority.html.erb +12 -0
  146. data/app/views/shared/forms/_state_container.html.erb +1 -0
  147. data/app/views/simple_blocks/_empty.html.erb +0 -0
  148. data/app/views/simple_blocks/_form.html.erb +120 -0
  149. data/app/views/simple_blocks/_simple_block.html.erb +26 -0
  150. data/app/views/simple_blocks/edit.html.erb +17 -0
  151. data/app/views/simple_blocks/new.html.erb +15 -0
  152. data/app/views/stored_values/_form.html.erb +57 -28
  153. data/app/views/tokens/_form.html.erb +31 -26
  154. data/app/views/users/_form.html.erb +1 -1
  155. data/config/initializers/carrierwave.rb +7 -2
  156. data/config/locales/common-ru.yml +5 -0
  157. data/config/locales/components-ru.yml +50 -0
  158. data/config/locales/editable-pages-en.yml +2 -0
  159. data/config/locales/editable-pages-ru.yml +50 -7
  160. data/config/locales/editable-pages-sv.yml +2 -0
  161. data/config/locales/feedback-ru.yml +1 -0
  162. data/config/locales/users-en.yml +0 -1
  163. data/config/locales/users-ru.yml +6 -1
  164. data/config/locales/users-sv.yml +0 -1
  165. data/config/routes.rb +32 -6
  166. data/db/migrate/20181217000000_create_biovision_components.rb +80 -0
  167. data/db/migrate/20181217000010_create_metrics.rb +40 -0
  168. data/db/migrate/20181217000015_create_browsers.rb +38 -0
  169. data/db/migrate/20181217000020_create_languages.rb +30 -0
  170. data/db/migrate/20181217000030_create_users.rb +118 -0
  171. data/db/migrate/20181217000035_create_codes.rb +51 -0
  172. data/db/migrate/20181217000040_create_privileges.rb +142 -0
  173. data/db/migrate/20181217000100_create_media_folders.rb +53 -0
  174. data/db/migrate/20181217000110_create_editable_pages.rb +90 -0
  175. data/db/migrate/20181217000200_create_feedback_requests.rb +27 -0
  176. data/db/migrate/20181217121211_add_uuid_to_users.rb +12 -0
  177. data/db/migrate/20181217121212_update_fields181217.rb +29 -0
  178. data/db/migrate/20190311121212_convert_json_columns.rb +47 -0
  179. data/db/migrate/20190324181818_add_data_to_feedback_requests.rb +14 -0
  180. data/db/migrate/20190326120000_create_simple_blocks.rb +31 -0
  181. data/db/{migrate → obsolete_migrations}/20171223333333_amend_foreign_keys.rb +0 -0
  182. data/db/{migrate → obsolete_migrations}/20180117151515_add_language_to_models.rb +0 -0
  183. data/db/{migrate → obsolete_migrations}/20180321000000_add_profile_data_to_users.rb +4 -4
  184. data/db/{migrate → obsolete_migrations}/20180405000000_add_consent_to_users.rb +0 -0
  185. data/db/{migrate → obsolete_migrations}/20180610222222_add_consent_to_feedback_requests.rb +0 -0
  186. data/db/{migrate → obsolete_migrations}/20180612111111_add_administrative_to_privilege.rb +0 -0
  187. data/db/{migrate → obsolete_migrations}/20180619121212_add_image_alt_text_to_editable_page.rb +0 -0
  188. data/db/{migrate → obsolete_migrations}/20180703111111_add_fields_to_editable_blocks.rb +0 -0
  189. data/db/{migrate → obsolete_migrations}/20180722222222_add_active_to_languages.rb +0 -0
  190. data/db/{migrate → obsolete_migrations}/20180725111111_add_referral_link_to_users.rb +0 -0
  191. data/db/obsolete_migrations/20181012222222_add_deletable_to_privileges.rb +19 -0
  192. data/db/obsolete_migrations/20181012222223_convert_stored_values.rb +13 -0
  193. data/db/obsolete_migrations/20181030080808_update_editable_pages_meta.rb +20 -0
  194. data/lib/biovision/base/base_methods.rb +19 -2
  195. data/lib/biovision/base/version.rb +3 -1
  196. data/lib/tasks/users.rake +19 -1
  197. metadata +75 -40
  198. data/app/views/admin/privileges/_list.html.erb +0 -15
  199. data/db/migrate/20170228000000_create_languages.rb +0 -23
  200. data/db/migrate/20170301000001_create_metrics.rb +0 -23
  201. data/db/migrate/20170301000002_create_metric_values.rb +0 -19
  202. data/db/migrate/20170301000101_create_browsers.rb +0 -22
  203. data/db/migrate/20170301000102_create_agents.rb +0 -22
  204. data/db/migrate/20170302000001_create_users.rb +0 -55
  205. data/db/migrate/20170302000003_create_tokens.rb +0 -23
  206. data/db/migrate/20170302000004_create_code_types.rb +0 -20
  207. data/db/migrate/20170302000005_create_codes.rb +0 -24
  208. data/db/migrate/20170302000101_create_privileges.rb +0 -41
  209. data/db/migrate/20170302000102_create_user_privileges.rb +0 -18
  210. data/db/migrate/20170302000103_create_privilege_groups.rb +0 -23
  211. data/db/migrate/20170302000104_create_privilege_group_privileges.rb +0 -24
  212. data/db/migrate/20170320000000_create_editable_pages.rb +0 -52
  213. data/db/migrate/20170425000001_create_foreign_sites.rb +0 -18
  214. data/db/migrate/20170425000002_create_foreign_users.rb +0 -23
  215. data/db/migrate/20170629120000_create_login_attempts.rb +0 -19
  216. data/db/migrate/20170823000001_create_stored_values.rb +0 -19
  217. data/db/migrate/20171202000000_create_media_folders.rb +0 -28
  218. data/db/migrate/20171202000001_create_media_files.rb +0 -27
  219. data/db/migrate/20171211000000_create_feedback_requests.rb +0 -33
  220. data/db/migrate/20180117160000_create_user_languages.rb +0 -17
  221. data/db/migrate/20180622140000_create_link_blocks.rb +0 -29
  222. data/db/migrate/20180622140001_create_link_block_items.rb +0 -23
  223. 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-m: 3.2rem !default;
18
- $spacer-l: 4.8rem !default;
19
- $spacer-xl: 6.4rem !default;
20
- $spacer-xxl: 9.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
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-large: 2rem !default;
5
- $font-size-increased: 1.6rem !default;
6
- $font-size-normal: 1.4rem !default;
7
- $font-size-decreased: 1.2rem !default;
8
- $font-size-small: 1rem !default;
9
-
10
- $content-width: 100rem !default;
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;
@@ -7,11 +7,8 @@ h1, h2, h3, h4, h5, h6 {
7
7
  body {
8
8
  background: $background-body;
9
9
  color: $text-color-primary;
10
- font-size: $font-size-normal;
11
- margin: 0;
12
10
  min-height: 100vh;
13
11
  min-width: $content-width-min;
14
- padding: 0;
15
12
 
16
13
  > footer,
17
14
  > header {
@@ -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: [:index]
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], deleted: false)
28
+ @entity = Privilege.find_by(id: params[:id])
30
29
  if @entity.nil?
31
- handle_http_404("Cannot find non-deleted privilege #{params[:id]}")
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], deleted: false)
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
- redirect_to admin_agent_path(id: @entity.id)
14
+ form_processed_ok(admin_agent_path(id: @entity.id))
15
15
  else
16
- render :new, status: :bad_request
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
- redirect_to admin_agent_path(id: @entity.id), notice: t('agents.update.success')
31
+ form_processed_ok(admin_agent_path(id: @entity.id))
32
32
  else
33
- render :edit, status: :bad_request
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: [:new, :destroy]
5
- before_action :set_foreign_site, only: [:auth_callback]
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 = User.find_by(slug: param_from_request(:login).downcase)
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
- if @foreign_site.nil?
38
- handle_http_503('Cannot set foreign site')
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
- redirect_to admin_browser_path(id: @entity.id)
14
+ form_processed_ok(admin_browser_path(id: @entity.id))
15
15
  else
16
- render :new, status: :bad_request
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
- redirect_to admin_browser_path(id: @entity.id), notice: t('browsers.update.success')
27
+ form_processed_ok(admin_browser_path(id: @entity.id))
28
28
  else
29
- render :edit, status: :bad_request
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 token: cookies['token'].split(':').last
22
- token.update active: false
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: cookies['pt'],
30
- expires: 1.year.from_now,
31
- domain: :all,
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 method for changing entity priority
1
4
  module EntityPriority
2
5
  extend ActiveSupport::Concern
3
6
 
@@ -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
- if @entity.locked?
20
- render json: { errors: { locked: @entity.locked } }, status: :forbidden
21
- end
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
- if @entity.respond_to?(:locked?)
28
- @entity.locked?
29
- else
30
- false
31
- end
30
+ @entity.respond_to?(:locked?) ? @entity.locked? : false
32
31
  end
33
32
  end