glib-web 0.5.92 → 0.5.93

Sign up to get free protection for your applications and to get access to all the features.
Files changed (191) hide show
  1. checksums.yaml +4 -4
  2. data/app/channels/glib/channel/is_typing_channel.rb +34 -34
  3. data/app/channels/glib/channel/online_channel.rb +36 -36
  4. data/app/controllers/concerns/glib/analytics/funnel.rb +61 -61
  5. data/app/controllers/concerns/glib/auth/policy.rb +149 -149
  6. data/app/controllers/concerns/glib/json/dynamic_text.rb +126 -126
  7. data/app/controllers/concerns/glib/json/libs.rb +149 -149
  8. data/app/controllers/concerns/glib/json/new_dynamic_text.rb +122 -122
  9. data/app/controllers/concerns/glib/json/transformation.rb +11 -11
  10. data/app/controllers/concerns/glib/json/traversal.rb +92 -92
  11. data/app/controllers/concerns/glib/json/ui.rb +88 -88
  12. data/app/controllers/concerns/glib/json/validation.rb +13 -13
  13. data/app/controllers/glib/home_controller.rb +54 -54
  14. data/app/helpers/glib/app_feature_support_helper.rb +16 -16
  15. data/app/helpers/glib/dynamic_images_helper.rb +55 -55
  16. data/app/helpers/glib/dynamic_texts_helper.rb +42 -42
  17. data/app/helpers/glib/enum_helper.rb +18 -18
  18. data/app/helpers/glib/forms_helper.rb +15 -15
  19. data/app/helpers/glib/json_ui/abstract_builder.rb +309 -309
  20. data/app/helpers/glib/json_ui/action_builder/dialogs.rb +58 -58
  21. data/app/helpers/glib/json_ui/action_builder/http.rb +39 -39
  22. data/app/helpers/glib/json_ui/action_builder/iap.rb +15 -15
  23. data/app/helpers/glib/json_ui/action_builder/panels.rb +14 -14
  24. data/app/helpers/glib/json_ui/action_builder/sheets.rb +15 -15
  25. data/app/helpers/glib/json_ui/action_builder/snackbars.rb +41 -41
  26. data/app/helpers/glib/json_ui/action_builder/windows.rb +38 -38
  27. data/app/helpers/glib/json_ui/action_builder.rb +140 -140
  28. data/app/helpers/glib/json_ui/analytics_helper.rb +17 -17
  29. data/app/helpers/glib/json_ui/dynamic_field_builders.rb +25 -25
  30. data/app/helpers/glib/json_ui/generic_builders.rb +28 -28
  31. data/app/helpers/glib/json_ui/list_builders.rb +110 -110
  32. data/app/helpers/glib/json_ui/menu_builder.rb +96 -96
  33. data/app/helpers/glib/json_ui/page_helper.rb +221 -221
  34. data/app/helpers/glib/json_ui/response_helper.rb +25 -25
  35. data/app/helpers/glib/json_ui/styling_helper.rb +55 -55
  36. data/app/helpers/glib/json_ui/table_builders.rb +74 -74
  37. data/app/helpers/glib/json_ui/view_builder/banners.rb +26 -26
  38. data/app/helpers/glib/json_ui/view_builder/charts.rb +49 -49
  39. data/app/helpers/glib/json_ui/view_builder/fields.rb +293 -291
  40. data/app/helpers/glib/json_ui/view_builder/iap.rb +11 -11
  41. data/app/helpers/glib/json_ui/view_builder/panels.rb +262 -262
  42. data/app/helpers/glib/json_ui/view_builder.rb +251 -251
  43. data/app/helpers/glib/urls_helper.rb +12 -12
  44. data/app/models/concerns/glib/soft_deletable.rb +73 -73
  45. data/app/models/glib/active_storage/attachment.rb +9 -9
  46. data/app/models/glib/active_storage/blob.rb +9 -9
  47. data/app/models/glib/application_record.rb +18 -18
  48. data/app/models/glib/dynamic_text_record.rb +9 -9
  49. data/app/models/glib/text.rb +95 -95
  50. data/app/policies/glib/application_policy.rb +191 -191
  51. data/app/validators/email_typo_validator.rb +38 -38
  52. data/app/validators/email_validator.rb +7 -7
  53. data/app/validators/url_validator.rb +20 -20
  54. data/app/views/json_ui/garage/_nav_menu.json.jbuilder +72 -72
  55. data/app/views/json_ui/garage/actions/_dialogs.json.jbuilder +104 -104
  56. data/app/views/json_ui/garage/actions/_http.json.jbuilder +24 -24
  57. data/app/views/json_ui/garage/actions/_panels.json.jbuilder +18 -18
  58. data/app/views/json_ui/garage/actions/_reload.json.jbuilder +17 -17
  59. data/app/views/json_ui/garage/actions/_sheets.json.jbuilder +18 -18
  60. data/app/views/json_ui/garage/actions/_snackbars.json.jbuilder +33 -33
  61. data/app/views/json_ui/garage/actions/_timeouts.json.jbuilder +24 -24
  62. data/app/views/json_ui/garage/actions/_windows.json.jbuilder +24 -24
  63. data/app/views/json_ui/garage/actions/dialogs_oauth_post.json.jbuilder +6 -6
  64. data/app/views/json_ui/garage/actions/index.json.jbuilder +24 -24
  65. data/app/views/json_ui/garage/forms/_alert_post_data.json.jbuilder +10 -10
  66. data/app/views/json_ui/garage/forms/basic.json.jbuilder +21 -21
  67. data/app/views/json_ui/garage/forms/basic_post.json.jbuilder +8 -8
  68. data/app/views/json_ui/garage/forms/checkboxes.json.jbuilder +61 -61
  69. data/app/views/json_ui/garage/forms/conditional_value.json.jbuilder +36 -36
  70. data/app/views/json_ui/garage/forms/dynamic_group.json.jbuilder +39 -39
  71. data/app/views/json_ui/garage/forms/dynamic_select.json.jbuilder +24 -24
  72. data/app/views/json_ui/garage/forms/dynamic_select_data.json.jbuilder +38 -38
  73. data/app/views/json_ui/garage/forms/file_upload.json.jbuilder +37 -37
  74. data/app/views/json_ui/garage/forms/floating_submit.json.jbuilder +19 -19
  75. data/app/views/json_ui/garage/forms/generic_post.json.jbuilder +3 -3
  76. data/app/views/json_ui/garage/forms/get_request.json.jbuilder +27 -27
  77. data/app/views/json_ui/garage/forms/index.json.jbuilder +116 -116
  78. data/app/views/json_ui/garage/forms/new_rich_text.json.jbuilder +40 -40
  79. data/app/views/json_ui/garage/forms/online_participant1.json.jbuilder +25 -25
  80. data/app/views/json_ui/garage/forms/online_participant2.json.jbuilder +25 -25
  81. data/app/views/json_ui/garage/forms/payments.json.jbuilder +34 -34
  82. data/app/views/json_ui/garage/forms/pickers.json.jbuilder +89 -81
  83. data/app/views/json_ui/garage/forms/ratings.json.jbuilder +49 -49
  84. data/app/views/json_ui/garage/forms/rich_text.json.jbuilder +40 -40
  85. data/app/views/json_ui/garage/forms/selects.json.jbuilder +91 -91
  86. data/app/views/json_ui/garage/forms/show_hide.json.jbuilder +150 -150
  87. data/app/views/json_ui/garage/forms/styled_boxes.json.jbuilder +35 -35
  88. data/app/views/json_ui/garage/forms/submission_flow.json.jbuilder +17 -17
  89. data/app/views/json_ui/garage/forms/submission_flow_post.json.jbuilder +26 -26
  90. data/app/views/json_ui/garage/forms/submission_indicator.json.jbuilder +63 -63
  91. data/app/views/json_ui/garage/forms/submission_indicator_post.json.jbuilder +25 -25
  92. data/app/views/json_ui/garage/forms/text_validation.json.jbuilder +65 -65
  93. data/app/views/json_ui/garage/forms/timers.json.jbuilder +120 -120
  94. data/app/views/json_ui/garage/home/blank.json.jbuilder +10 -10
  95. data/app/views/json_ui/garage/home/index.json.jbuilder +36 -36
  96. data/app/views/json_ui/garage/home/slow.json.jbuilder +11 -11
  97. data/app/views/json_ui/garage/lists/_autoload_section.json.jbuilder +30 -30
  98. data/app/views/json_ui/garage/lists/autoload_all.json.jbuilder +32 -32
  99. data/app/views/json_ui/garage/lists/autoload_as_needed.json.jbuilder +35 -35
  100. data/app/views/json_ui/garage/lists/autoload_as_needed_responsive_columns.json.jbuilder +27 -27
  101. data/app/views/json_ui/garage/lists/chat_ui.json.jbuilder +94 -94
  102. data/app/views/json_ui/garage/lists/edit_actions.json.jbuilder +62 -62
  103. data/app/views/json_ui/garage/lists/fab.json.jbuilder +12 -12
  104. data/app/views/json_ui/garage/lists/index.json.jbuilder +41 -41
  105. data/app/views/json_ui/garage/lists/reordering.json.jbuilder +34 -34
  106. data/app/views/json_ui/garage/lists/templating.json.jbuilder +35 -35
  107. data/app/views/json_ui/garage/notifications/action_cable.json.jbuilder +114 -114
  108. data/app/views/json_ui/garage/notifications/android_post.json.jbuilder +48 -48
  109. data/app/views/json_ui/garage/notifications/index.json.jbuilder +36 -36
  110. data/app/views/json_ui/garage/notifications/web_socket.json.jbuilder +60 -60
  111. data/app/views/json_ui/garage/pages/flat_centered.json.jbuilder +29 -29
  112. data/app/views/json_ui/garage/pages/full_width.json.jbuilder +29 -29
  113. data/app/views/json_ui/garage/pages/full_width_height.json.jbuilder +16 -16
  114. data/app/views/json_ui/garage/pages/index.json.jbuilder +62 -62
  115. data/app/views/json_ui/garage/pages/layout.json.jbuilder +18 -18
  116. data/app/views/json_ui/garage/pages/lifecycle_hooks.json.jbuilder +13 -13
  117. data/app/views/json_ui/garage/pages/loading_indicator.json.jbuilder +10 -10
  118. data/app/views/json_ui/garage/pages/nav_buttons.json.jbuilder +21 -21
  119. data/app/views/json_ui/garage/pages/nested_scroll.json.jbuilder +40 -40
  120. data/app/views/json_ui/garage/pages/tab_bar.json.jbuilder +92 -92
  121. data/app/views/json_ui/garage/panels/_styled.json.jbuilder +78 -78
  122. data/app/views/json_ui/garage/panels/card.json.jbuilder +4 -4
  123. data/app/views/json_ui/garage/panels/carousel.json.jbuilder +38 -38
  124. data/app/views/json_ui/garage/panels/custom.json.jbuilder +17 -17
  125. data/app/views/json_ui/garage/panels/flow.json.jbuilder +59 -59
  126. data/app/views/json_ui/garage/panels/horizontal.json.jbuilder +101 -101
  127. data/app/views/json_ui/garage/panels/index.json.jbuilder +138 -138
  128. data/app/views/json_ui/garage/panels/outlined.json.jbuilder +4 -4
  129. data/app/views/json_ui/garage/panels/responsive.json.jbuilder +98 -98
  130. data/app/views/json_ui/garage/panels/split.json.jbuilder +182 -182
  131. data/app/views/json_ui/garage/panels/ul.json.jbuilder +33 -33
  132. data/app/views/json_ui/garage/panels/vertical.json.jbuilder +55 -55
  133. data/app/views/json_ui/garage/panels/web.json.jbuilder +15 -15
  134. data/app/views/json_ui/garage/services/dynamic_text.json.jbuilder +13 -13
  135. data/app/views/json_ui/garage/services/image.json.jbuilder +47 -47
  136. data/app/views/json_ui/garage/services/index.json.jbuilder +17 -17
  137. data/app/views/json_ui/garage/tables/_autoload_section.json.jbuilder +16 -16
  138. data/app/views/json_ui/garage/tables/autoload_all.json.jbuilder +43 -43
  139. data/app/views/json_ui/garage/tables/autoload_as_needed.json.jbuilder +50 -50
  140. data/app/views/json_ui/garage/tables/export_import.json.jbuilder +29 -29
  141. data/app/views/json_ui/garage/tables/horizontal_scroll.json.jbuilder +26 -26
  142. data/app/views/json_ui/garage/tables/index.json.jbuilder +25 -25
  143. data/app/views/json_ui/garage/tables/layout.json.jbuilder +40 -40
  144. data/app/views/json_ui/garage/views/_chart_data.json.jbuilder +17 -17
  145. data/app/views/json_ui/garage/views/banners.json.jbuilder +67 -67
  146. data/app/views/json_ui/garage/views/calendar_data.json.jbuilder +30 -30
  147. data/app/views/json_ui/garage/views/charts.json.jbuilder +125 -125
  148. data/app/views/json_ui/garage/views/controls.json.jbuilder +39 -39
  149. data/app/views/json_ui/garage/views/iap.json.jbuilder +21 -21
  150. data/app/views/json_ui/garage/views/icon_names.json.jbuilder +1450 -1450
  151. data/app/views/json_ui/garage/views/icons.json.jbuilder +15 -15
  152. data/app/views/json_ui/garage/views/images.json.jbuilder +89 -89
  153. data/app/views/json_ui/garage/views/index.json.jbuilder +83 -83
  154. data/app/views/json_ui/garage/views/links.json.jbuilder +70 -70
  155. data/app/views/json_ui/garage/views/map_cluster_data.json.jbuilder +41 -41
  156. data/app/views/json_ui/garage/views/map_data.json.jbuilder +51 -51
  157. data/app/views/json_ui/garage/views/maps.json.jbuilder +31 -31
  158. data/app/views/json_ui/garage/views/markdowns.json.jbuilder +41 -41
  159. data/app/views/json_ui/garage/views/misc.json.jbuilder +34 -34
  160. data/app/views/json_ui/garage/views/progress.json.jbuilder +31 -31
  161. data/app/views/json_ui/garage/views/texts.json.jbuilder +35 -35
  162. data/app/views/layouts/json_ui/renderer.html.erb +35 -35
  163. data/config/routes.rb +7 -7
  164. data/lib/generators/glib/install_generator.rb +24 -24
  165. data/lib/generators/templates/20191017062519_create_texts.rb +12 -12
  166. data/lib/generators/templates/20191024063257_add_scope_to_texts.rb +7 -7
  167. data/lib/generators/templates/20191112095018_add_lang_to_texts.rb +7 -7
  168. data/lib/generators/templates/20191126071051_create_active_storage_tables.active_storage.rb +27 -27
  169. data/lib/generators/templates/database.yml +107 -107
  170. data/lib/generators/templates/dynamic_text.rb +2 -2
  171. data/lib/glib/crypt/utils.rb +26 -26
  172. data/lib/glib/dynamic_text/config.rb +21 -21
  173. data/lib/glib/engine.rb +7 -7
  174. data/lib/glib/json_crawler/action_crawler.rb +23 -23
  175. data/lib/glib/json_crawler/action_crawlers/action_http.rb +11 -11
  176. data/lib/glib/json_crawler/action_crawlers/forms_submit.rb +48 -48
  177. data/lib/glib/json_crawler/action_crawlers/menu.rb +12 -12
  178. data/lib/glib/json_crawler/action_crawlers/nav_initiate.rb +19 -19
  179. data/lib/glib/json_crawler/action_crawlers/run_multiple.rb +13 -13
  180. data/lib/glib/json_crawler/action_crawlers/windows_open.rb +33 -33
  181. data/lib/glib/json_crawler/coverage.rb +20 -20
  182. data/lib/glib/json_crawler/http.rb +120 -120
  183. data/lib/glib/json_crawler/router.rb +90 -90
  184. data/lib/glib/json_crawler.rb +11 -11
  185. data/lib/glib/mailer_tester.rb +36 -36
  186. data/lib/glib/test_helpers.rb +52 -52
  187. data/lib/glib/value.rb +7 -7
  188. data/lib/glib/version.rb +5 -5
  189. data/lib/glib-web.rb +9 -9
  190. data/lib/tasks/db.rake +95 -95
  191. metadata +2 -3
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3da198c00ca4b0904b2d5b9fcf2c73424b7cfcd4ce343c602b9ca1fe6a78edf5
4
- data.tar.gz: '028e7025084479ce421f09b61a23a9df834e4af57c75b8cc50fff8c84615f516'
3
+ metadata.gz: e237f4f116aaaa24e860e0a14884ca5613ce0b012d65db797a54c6b2c036a46b
4
+ data.tar.gz: e7205204632d4bf98c51f29e641ce0517b3d49881a27cb4724c72b395fceab8a
5
5
  SHA512:
6
- metadata.gz: 686a1d38ad28d5b1d965093e7d2b1eb680f902fc7c843f23833eb09ffa0b9409d2335faffa42a7a47139f0ad8d8d19289c97d438240203a2ff059ec48f768772
7
- data.tar.gz: bc4cdd5e454c22b550a929ccef93579d48da23788a18557062b2eb14bfd336f44f9c5e54a60f1830871cccd007426c429e527eff862cc697588ec33dfd6e4a2a
6
+ metadata.gz: 2f54dce3792f8dde903370975ddae9bfc7c8926e8164077fdbaf27be6c1c8a529e2925578c96cd9705a4fa1d48cac9ca6c99df005dbbc43be387d487238e1fe0
7
+ data.tar.gz: 9b4d8a1ac3efd39876a5360149e90d40eb391d638b7056c19063a2af97e3b6aa20c6f61b194c22af34128e2693a1ccc73ffd5ffd1cfa6a1a7a98bccefe85b76f
@@ -1,34 +1,34 @@
1
- module Glib
2
- module Channel
3
- class IsTypingChannel < ApplicationCable::Channel
4
- class << self
5
- attr_accessor :channel_name
6
- end
7
-
8
- def channel_name
9
- self.class.channel_name
10
- end
11
-
12
- def subscribed
13
- stream_from "#{self.class.channel_name}_#{params['conversation_id']}"
14
- end
15
-
16
- def typing(data)
17
- if data['status']
18
- text = "#{User.find(data['user_id']).full_name} is typing"
19
- else
20
- text = ''
21
- end
22
-
23
- ActionCable.server.broadcast \
24
- "#{self.class.channel_name}_#{params['conversation_id']}",
25
- action: {
26
- action: 'component/set',
27
- text: text,
28
- status: data['status'],
29
- user_id: data['user_id']
30
- }
31
- end
32
- end
33
- end
34
- end
1
+ module Glib
2
+ module Channel
3
+ class IsTypingChannel < ApplicationCable::Channel
4
+ class << self
5
+ attr_accessor :channel_name
6
+ end
7
+
8
+ def channel_name
9
+ self.class.channel_name
10
+ end
11
+
12
+ def subscribed
13
+ stream_from "#{self.class.channel_name}_#{params['conversation_id']}"
14
+ end
15
+
16
+ def typing(data)
17
+ if data['status']
18
+ text = "#{User.find(data['user_id']).full_name} is typing"
19
+ else
20
+ text = ''
21
+ end
22
+
23
+ ActionCable.server.broadcast \
24
+ "#{self.class.channel_name}_#{params['conversation_id']}",
25
+ action: {
26
+ action: 'component/set',
27
+ text: text,
28
+ status: data['status'],
29
+ user_id: data['user_id']
30
+ }
31
+ end
32
+ end
33
+ end
34
+ end
@@ -1,36 +1,36 @@
1
- module Glib
2
- module Channel
3
- class OnlineChannel < ApplicationCable::Channel
4
- class << self
5
- attr_accessor :channel_name
6
- end
7
-
8
- def channel_name
9
- self.class.channel_name
10
- end
11
-
12
- def subscribed
13
- stream_from "#{self.class.channel_name}_#{params['conversation_id']}"
14
- end
15
-
16
- def online_status(data)
17
- if data['status'] == true
18
- text = "#{User.find(data['user_id']).full_name} is online"
19
- else
20
- text = "#{User.find(data['user_id']).full_name} is offline"
21
- end
22
-
23
- ActionCable.server.broadcast \
24
- "#{self.class.channel_name}_#{params['conversation_id']}",
25
- action: {
26
- action: 'component/set',
27
- text: text,
28
- status: data['status'],
29
- value: data['reset_value'],
30
- event: 'online_status'
31
- },
32
- filterKey: data['user_id']
33
- end
34
- end
35
- end
36
- end
1
+ module Glib
2
+ module Channel
3
+ class OnlineChannel < ApplicationCable::Channel
4
+ class << self
5
+ attr_accessor :channel_name
6
+ end
7
+
8
+ def channel_name
9
+ self.class.channel_name
10
+ end
11
+
12
+ def subscribed
13
+ stream_from "#{self.class.channel_name}_#{params['conversation_id']}"
14
+ end
15
+
16
+ def online_status(data)
17
+ if data['status'] == true
18
+ text = "#{User.find(data['user_id']).full_name} is online"
19
+ else
20
+ text = "#{User.find(data['user_id']).full_name} is offline"
21
+ end
22
+
23
+ ActionCable.server.broadcast \
24
+ "#{self.class.channel_name}_#{params['conversation_id']}",
25
+ action: {
26
+ action: 'component/set',
27
+ text: text,
28
+ status: data['status'],
29
+ value: data['reset_value'],
30
+ event: 'online_status'
31
+ },
32
+ filterKey: data['user_id']
33
+ end
34
+ end
35
+ end
36
+ end
@@ -1,61 +1,61 @@
1
- module Glib::Analytics
2
- module Funnel
3
- extend ActiveSupport::Concern
4
-
5
- included do
6
- # include Overrides
7
- extend ClassMethods
8
-
9
- helper_method :glib_analytics_feature_segment
10
- helper_method :glib_analytics_feature_referer
11
- helper_method :glib_analytics_included?
12
- end
13
-
14
- # module Overrides
15
-
16
- # # Expose protected method
17
- # public # Override
18
- # def policy_scope(*args)
19
- # super
20
- # end
21
- # end
22
-
23
- def glib_analytics_included?
24
- true
25
- end
26
-
27
- def glib_analytics_feature_segment
28
- # To be overridden
29
- nil
30
- end
31
-
32
- def glib_analytics_feature_referer
33
- group = request.headers['GApp-Analytics-Referer-Group']
34
- action = request.headers['GApp-Analytics-Referer-Action']
35
- segment = request.headers['GApp-Analytics-Referer-Segment']
36
- placement = request.headers['GApp-Analytics-Referer-Placement']
37
-
38
- if group && action
39
- return { group: group, action: action, segment: segment, placement: placement }
40
- end
41
-
42
- nil
43
- end
44
-
45
-
46
-
47
- module ClassMethods
48
- # def glib_auth_inited?
49
- # @@__glib_auth_init ||= false
50
- # end
51
-
52
- # def glib_analytics_init
53
- # @@__glib_analytics_init = true
54
- # end
55
-
56
- # def glib_analytics_inited?
57
- # @@__glib_analytics_init ||= false
58
- # end
59
- end
60
- end
61
- end
1
+ module Glib::Analytics
2
+ module Funnel
3
+ extend ActiveSupport::Concern
4
+
5
+ included do
6
+ # include Overrides
7
+ extend ClassMethods
8
+
9
+ helper_method :glib_analytics_feature_segment
10
+ helper_method :glib_analytics_feature_referer
11
+ helper_method :glib_analytics_included?
12
+ end
13
+
14
+ # module Overrides
15
+
16
+ # # Expose protected method
17
+ # public # Override
18
+ # def policy_scope(*args)
19
+ # super
20
+ # end
21
+ # end
22
+
23
+ def glib_analytics_included?
24
+ true
25
+ end
26
+
27
+ def glib_analytics_feature_segment
28
+ # To be overridden
29
+ nil
30
+ end
31
+
32
+ def glib_analytics_feature_referer
33
+ group = request.headers['GApp-Analytics-Referer-Group']
34
+ action = request.headers['GApp-Analytics-Referer-Action']
35
+ segment = request.headers['GApp-Analytics-Referer-Segment']
36
+ placement = request.headers['GApp-Analytics-Referer-Placement']
37
+
38
+ if group && action
39
+ return { group: group, action: action, segment: segment, placement: placement }
40
+ end
41
+
42
+ nil
43
+ end
44
+
45
+
46
+
47
+ module ClassMethods
48
+ # def glib_auth_inited?
49
+ # @@__glib_auth_init ||= false
50
+ # end
51
+
52
+ # def glib_analytics_init
53
+ # @@__glib_analytics_init = true
54
+ # end
55
+
56
+ # def glib_analytics_inited?
57
+ # @@__glib_analytics_init ||= false
58
+ # end
59
+ end
60
+ end
61
+ end
@@ -1,149 +1,149 @@
1
- require 'pundit'
2
-
3
- module Glib::Auth
4
- module Policy
5
- extend ActiveSupport::Concern
6
-
7
- included do
8
- include Pundit
9
- include Overrides
10
- extend ClassMethods
11
-
12
- # TODO: Ultimately we want to uncomment this line, but:
13
- # - Need to be able to set aside some time to run rspec tests to ensure nothing gets broken
14
- # - Need to find a solution where we can reuse a single public policy
15
- # after_action :verify_authorized
16
-
17
- helper_method :policy, :can?, :cannot?
18
- end
19
-
20
- module Overrides
21
-
22
- public # Override
23
- def policy(record, policy_name = nil, attributes = {})
24
- policy_name ||= record
25
-
26
- @__pundit_policies ||= {}
27
- return @__pundit_policies[policy_name] if @__pundit_policies[policy_name]
28
-
29
- if policy_name.is_a?(Symbol) && policy_name.to_s.ends_with?('_admin')
30
- policy_class = CommonAdminPolicy
31
- else
32
- policy_class = Pundit::PolicyFinder.new(policy_name).policy
33
- end
34
-
35
- raise "Policy not found for #{policy_name.is_a?(Symbol) || policy_name.is_a?(Class) ? policy_name : policy_name.class}" unless policy_class
36
-
37
- @__pundit_policies[policy_name] = policy_class.new(current_user, record, policy_name, self, request, params, attributes: attributes)
38
- end
39
-
40
- # Expose protected method
41
- public # Override
42
- def policy_scope(*args)
43
- super
44
- end
45
-
46
- end
47
-
48
- private
49
- def raise_access_denied(record, policy)
50
- raise UnauthorizedError.new(record: record, policy: policy, query: "#{action_name}?")
51
- end
52
-
53
- public
54
- def can?(action, record, attributes = {})
55
- policy(record, nil, attributes).send("#{action}?")
56
- end
57
-
58
- public
59
- def cannot?(action, record)
60
- !policy(record).send("#{action}?")
61
- end
62
-
63
- # Inspired from https://github.com/ryanb/cancan/wiki/Non-RESTful-Controllers
64
- public
65
- def glib_authorize_resource(*args)
66
- options = args.extract_options!
67
- resource_name = args.first
68
-
69
- resource_name ||= controller_name.split('/').last.singularize
70
-
71
- if (resource_key = options[:class]).nil?
72
- policy_name = resource_name.camelize.constantize
73
- else
74
- policy_name = case resource_key
75
- when false
76
- resource_name.to_sym
77
- when Symbol, Class
78
- resource_key
79
- else
80
- raise "Invalid resource class: #{resource_key}"
81
- end
82
- end
83
-
84
- resource_instance = instance_variable_get("@#{resource_name}") || policy_name
85
-
86
- query = "#{action_name}?"
87
- policy_instance = policy(resource_instance, policy_name, options.except(:class))
88
- raise_access_denied(resource_instance, policy_instance) unless policy_instance.public_send(query)
89
- end
90
-
91
-
92
-
93
- class UnauthorizedError < Pundit::NotAuthorizedError
94
- end
95
-
96
-
97
-
98
- module ClassMethods
99
- def glib_auth_init
100
- @@__glib_auth_init = true
101
-
102
- before_action :glib_load_resource
103
- before_action :glib_authorize_resource
104
- end
105
-
106
- def glib_auth_inited?
107
- @@__glib_auth_init ||= false
108
- end
109
-
110
- # TODO: Consider deprecating
111
- public
112
- def authorize_resource(*args)
113
- options = args.extract_options!
114
- resource_name = args.first
115
-
116
- self.before_action(options.slice(:only, :except, :if, :unless)) do |controller|
117
- resource_name ||= resource_name_from_controller
118
-
119
- begin
120
- if !(resource_key = options[:class]).nil?
121
- resource = case resource_key
122
- when false
123
- resource_name.to_sym
124
- when Symbol, Class
125
- resource_key
126
- else
127
- raise "Invalid resource class: #{resource_key}"
128
- end
129
-
130
- authorize resource
131
- elsif (resource_instance = controller.instance_variable_get("@#{resource_name}"))
132
- authorize resource_instance
133
- else
134
- authorize resource_name.camelize.constantize
135
- end
136
- rescue Pundit::NotAuthorizedError => e
137
- raise_access_denied(e.record, e.policy)
138
- end
139
-
140
- verify_authorized
141
- end
142
- end
143
- end
144
-
145
- def resource_name_from_controller
146
- params[:controller].split('/').last.singularize
147
- end
148
- end
149
- end
1
+ require 'pundit'
2
+
3
+ module Glib::Auth
4
+ module Policy
5
+ extend ActiveSupport::Concern
6
+
7
+ included do
8
+ include Pundit
9
+ include Overrides
10
+ extend ClassMethods
11
+
12
+ # TODO: Ultimately we want to uncomment this line, but:
13
+ # - Need to be able to set aside some time to run rspec tests to ensure nothing gets broken
14
+ # - Need to find a solution where we can reuse a single public policy
15
+ # after_action :verify_authorized
16
+
17
+ helper_method :policy, :can?, :cannot?
18
+ end
19
+
20
+ module Overrides
21
+
22
+ public # Override
23
+ def policy(record, policy_name = nil, attributes = {})
24
+ policy_name ||= record
25
+
26
+ @__pundit_policies ||= {}
27
+ return @__pundit_policies[policy_name] if @__pundit_policies[policy_name]
28
+
29
+ if policy_name.is_a?(Symbol) && policy_name.to_s.ends_with?('_admin')
30
+ policy_class = CommonAdminPolicy
31
+ else
32
+ policy_class = Pundit::PolicyFinder.new(policy_name).policy
33
+ end
34
+
35
+ raise "Policy not found for #{policy_name.is_a?(Symbol) || policy_name.is_a?(Class) ? policy_name : policy_name.class}" unless policy_class
36
+
37
+ @__pundit_policies[policy_name] = policy_class.new(current_user, record, policy_name, self, request, params, attributes: attributes)
38
+ end
39
+
40
+ # Expose protected method
41
+ public # Override
42
+ def policy_scope(*args)
43
+ super
44
+ end
45
+
46
+ end
47
+
48
+ private
49
+ def raise_access_denied(record, policy)
50
+ raise UnauthorizedError.new(record: record, policy: policy, query: "#{action_name}?")
51
+ end
52
+
53
+ public
54
+ def can?(action, record, attributes = {})
55
+ policy(record, nil, attributes).send("#{action}?")
56
+ end
57
+
58
+ public
59
+ def cannot?(action, record)
60
+ !policy(record).send("#{action}?")
61
+ end
62
+
63
+ # Inspired from https://github.com/ryanb/cancan/wiki/Non-RESTful-Controllers
64
+ public
65
+ def glib_authorize_resource(*args)
66
+ options = args.extract_options!
67
+ resource_name = args.first
68
+
69
+ resource_name ||= controller_name.split('/').last.singularize
70
+
71
+ if (resource_key = options[:class]).nil?
72
+ policy_name = resource_name.camelize.constantize
73
+ else
74
+ policy_name = case resource_key
75
+ when false
76
+ resource_name.to_sym
77
+ when Symbol, Class
78
+ resource_key
79
+ else
80
+ raise "Invalid resource class: #{resource_key}"
81
+ end
82
+ end
83
+
84
+ resource_instance = instance_variable_get("@#{resource_name}") || policy_name
85
+
86
+ query = "#{action_name}?"
87
+ policy_instance = policy(resource_instance, policy_name, options.except(:class))
88
+ raise_access_denied(resource_instance, policy_instance) unless policy_instance.public_send(query)
89
+ end
90
+
91
+
92
+
93
+ class UnauthorizedError < Pundit::NotAuthorizedError
94
+ end
95
+
96
+
97
+
98
+ module ClassMethods
99
+ def glib_auth_init
100
+ @@__glib_auth_init = true
101
+
102
+ before_action :glib_load_resource
103
+ before_action :glib_authorize_resource
104
+ end
105
+
106
+ def glib_auth_inited?
107
+ @@__glib_auth_init ||= false
108
+ end
109
+
110
+ # TODO: Consider deprecating
111
+ public
112
+ def authorize_resource(*args)
113
+ options = args.extract_options!
114
+ resource_name = args.first
115
+
116
+ self.before_action(options.slice(:only, :except, :if, :unless)) do |controller|
117
+ resource_name ||= resource_name_from_controller
118
+
119
+ begin
120
+ if !(resource_key = options[:class]).nil?
121
+ resource = case resource_key
122
+ when false
123
+ resource_name.to_sym
124
+ when Symbol, Class
125
+ resource_key
126
+ else
127
+ raise "Invalid resource class: #{resource_key}"
128
+ end
129
+
130
+ authorize resource
131
+ elsif (resource_instance = controller.instance_variable_get("@#{resource_name}"))
132
+ authorize resource_instance
133
+ else
134
+ authorize resource_name.camelize.constantize
135
+ end
136
+ rescue Pundit::NotAuthorizedError => e
137
+ raise_access_denied(e.record, e.policy)
138
+ end
139
+
140
+ verify_authorized
141
+ end
142
+ end
143
+ end
144
+
145
+ def resource_name_from_controller
146
+ params[:controller].split('/').last.singularize
147
+ end
148
+ end
149
+ end