disco_app 0.15.2 → 0.18.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (310) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +1 -5
  3. data/app/clients/disco_app/api_client.rb +25 -19
  4. data/app/clients/disco_app/graphql_client.rb +85 -0
  5. data/app/controllers/disco_app/admin/app_settings_controller.rb +2 -0
  6. data/app/controllers/disco_app/admin/application_controller.rb +1 -0
  7. data/app/controllers/disco_app/admin/concerns/app_settings_controller.rb +2 -1
  8. data/app/controllers/disco_app/admin/concerns/authenticated_controller.rb +5 -3
  9. data/app/controllers/disco_app/admin/concerns/plans_controller.rb +3 -2
  10. data/app/controllers/disco_app/admin/concerns/shops_controller.rb +1 -0
  11. data/app/controllers/disco_app/admin/concerns/sources_controller.rb +2 -1
  12. data/app/controllers/disco_app/admin/concerns/subscriptions_controller.rb +3 -2
  13. data/app/controllers/disco_app/admin/plans_controller.rb +2 -0
  14. data/app/controllers/disco_app/admin/resources/shops_controller.rb +2 -0
  15. data/app/controllers/disco_app/admin/shops_controller.rb +2 -0
  16. data/app/controllers/disco_app/admin/sources_controller.rb +2 -0
  17. data/app/controllers/disco_app/admin/subscriptions_controller.rb +2 -0
  18. data/app/controllers/disco_app/charges_controller.rb +6 -7
  19. data/app/controllers/disco_app/concerns/app_proxy_controller.rb +6 -6
  20. data/app/controllers/disco_app/concerns/authenticated_controller.rb +26 -27
  21. data/app/controllers/disco_app/concerns/carrier_request_controller.rb +22 -11
  22. data/app/controllers/disco_app/concerns/user_authenticated_controller.rb +1 -0
  23. data/app/controllers/disco_app/concerns/webhooks_controller.rb +13 -12
  24. data/app/controllers/disco_app/flow/actions_controller.rb +9 -0
  25. data/app/controllers/disco_app/flow/concerns/actions_controller.rb +23 -0
  26. data/app/controllers/disco_app/flow/concerns/trigger_usage_controller.rb +29 -0
  27. data/app/controllers/disco_app/flow/concerns/verifies_flow_payload.rb +39 -0
  28. data/app/controllers/disco_app/flow/trigger_usage_controller.rb +9 -0
  29. data/app/controllers/disco_app/frame_controller.rb +0 -1
  30. data/app/controllers/disco_app/install_controller.rb +3 -6
  31. data/app/controllers/disco_app/subscriptions_controller.rb +12 -4
  32. data/app/controllers/disco_app/user_sessions_controller.rb +1 -0
  33. data/app/controllers/disco_app/webhooks_controller.rb +2 -0
  34. data/app/controllers/sessions_controller.rb +5 -6
  35. data/app/helpers/disco_app/application_helper.rb +7 -7
  36. data/app/jobs/disco_app/app_installed_job.rb +2 -0
  37. data/app/jobs/disco_app/app_uninstalled_job.rb +2 -0
  38. data/app/jobs/disco_app/concerns/app_installed_job.rb +2 -3
  39. data/app/jobs/disco_app/concerns/app_uninstalled_job.rb +2 -1
  40. data/app/jobs/disco_app/concerns/customers_data_request_job.rb +13 -0
  41. data/app/jobs/disco_app/concerns/customers_redact_job.rb +13 -0
  42. data/app/jobs/disco_app/concerns/render_asset_group_job.rb +1 -0
  43. data/app/jobs/disco_app/concerns/shop_redact_job.rb +13 -0
  44. data/app/jobs/disco_app/concerns/shop_update_job.rb +9 -2
  45. data/app/jobs/disco_app/concerns/subscription_changed_job.rb +2 -1
  46. data/app/jobs/disco_app/concerns/synchronise_carrier_service_job.rb +8 -7
  47. data/app/jobs/disco_app/concerns/synchronise_resources_job.rb +1 -0
  48. data/app/jobs/disco_app/concerns/synchronise_users_job.rb +6 -3
  49. data/app/jobs/disco_app/concerns/synchronise_webhooks_job.rb +24 -11
  50. data/app/jobs/disco_app/customers_data_request_job.rb +5 -0
  51. data/app/jobs/disco_app/customers_redact_job.rb +5 -0
  52. data/app/jobs/disco_app/flow/process_action_job.rb +11 -0
  53. data/app/jobs/disco_app/flow/process_trigger_job.rb +11 -0
  54. data/app/jobs/disco_app/render_asset_group_job.rb +2 -0
  55. data/app/jobs/disco_app/shop_job.rb +10 -10
  56. data/app/jobs/disco_app/shop_redact_job.rb +5 -0
  57. data/app/jobs/disco_app/shop_update_job.rb +2 -0
  58. data/app/jobs/disco_app/subscription_changed_job.rb +2 -0
  59. data/app/jobs/disco_app/synchronise_carrier_service_job.rb +2 -0
  60. data/app/jobs/disco_app/synchronise_resources_job.rb +2 -0
  61. data/app/jobs/disco_app/synchronise_users_job.rb +2 -0
  62. data/app/jobs/disco_app/synchronise_webhooks_job.rb +2 -0
  63. data/app/models/application_record.rb +2 -0
  64. data/app/models/disco_app/app_settings.rb +2 -0
  65. data/app/models/disco_app/application_charge.rb +1 -1
  66. data/app/models/disco_app/concerns/app_settings.rb +2 -0
  67. data/app/models/disco_app/concerns/can_be_liquified.rb +29 -14
  68. data/app/models/disco_app/concerns/has_metafields.rb +1 -2
  69. data/app/models/disco_app/concerns/plan.rb +3 -4
  70. data/app/models/disco_app/concerns/plan_code.rb +1 -2
  71. data/app/models/disco_app/concerns/renders_assets.rb +15 -21
  72. data/app/models/disco_app/concerns/shop.rb +20 -14
  73. data/app/models/disco_app/concerns/source.rb +2 -3
  74. data/app/models/disco_app/concerns/subscription.rb +3 -3
  75. data/app/models/disco_app/concerns/synchronises.rb +10 -15
  76. data/app/models/disco_app/concerns/taggable.rb +1 -0
  77. data/app/models/disco_app/concerns/user.rb +3 -2
  78. data/app/models/disco_app/flow/action.rb +9 -0
  79. data/app/models/disco_app/flow/concerns/action.rb +27 -0
  80. data/app/models/disco_app/flow/concerns/trigger.rb +28 -0
  81. data/app/models/disco_app/flow/concerns/trigger_usage.rb +17 -0
  82. data/app/models/disco_app/flow/trigger.rb +9 -0
  83. data/app/models/disco_app/flow/trigger_usage.rb +9 -0
  84. data/app/models/disco_app/plan.rb +2 -0
  85. data/app/models/disco_app/plan_code.rb +2 -0
  86. data/app/models/disco_app/session_storage.rb +5 -2
  87. data/app/models/disco_app/shop.rb +2 -0
  88. data/app/models/disco_app/source.rb +2 -0
  89. data/app/models/disco_app/subscription.rb +2 -0
  90. data/app/models/disco_app/user.rb +2 -0
  91. data/app/resources/disco_app/admin/resources/concerns/shop_resource.rb +12 -15
  92. data/app/resources/disco_app/admin/resources/shop_resource.rb +1 -0
  93. data/app/services/disco_app/carrier_request_service.rb +3 -3
  94. data/app/services/disco_app/charges_service.rb +26 -34
  95. data/app/services/disco_app/flow/create_action.rb +35 -0
  96. data/app/services/disco_app/flow/create_trigger.rb +34 -0
  97. data/app/services/disco_app/flow/process_action.rb +50 -0
  98. data/app/services/disco_app/flow/process_trigger.rb +72 -0
  99. data/app/services/disco_app/flow/update_trigger_usage.rb +42 -0
  100. data/app/services/disco_app/partner_app_service.rb +1 -1
  101. data/app/services/disco_app/proxy_service.rb +2 -2
  102. data/app/services/disco_app/request_validation_service.rb +2 -2
  103. data/app/services/disco_app/subscription_service.rb +60 -32
  104. data/app/services/disco_app/webhook_service.rb +9 -11
  105. data/app/views/layouts/admin.html.erb +1 -2
  106. data/app/views/layouts/application.html.erb +1 -2
  107. data/app/views/layouts/embedded_app.html.erb +2 -4
  108. data/app/views/layouts/embedded_app_modal.html.erb +2 -3
  109. data/app/views/shopify_app/sessions/new.html.erb +2 -4
  110. data/config/routes.rb +11 -3
  111. data/db/migrate/20150525000000_create_shops_if_not_existent.rb +80 -80
  112. data/db/migrate/20170315062548_create_disco_app_sources.rb +2 -0
  113. data/db/migrate/20170315062629_add_sources_to_shop_subscriptions.rb +3 -1
  114. data/db/migrate/20170327214540_create_disco_app_users.rb +2 -1
  115. data/db/migrate/20170606160751_fix_disco_app_users_index.rb +2 -0
  116. data/db/migrate/20181229100327_create_flow_actions_and_triggers.rb +32 -0
  117. data/db/migrate/20200405000000_create_flow_trigger_usages.rb +16 -0
  118. data/lib/disco_app/configuration.rb +12 -5
  119. data/lib/disco_app/constants.rb +4 -2
  120. data/lib/disco_app/engine.rb +1 -1
  121. data/lib/disco_app/session.rb +1 -0
  122. data/lib/disco_app/support/file_fixtures.rb +2 -1
  123. data/lib/disco_app/version.rb +3 -1
  124. data/lib/generators/disco_app/install/USAGE +5 -0
  125. data/lib/generators/disco_app/install/install_generator.rb +297 -0
  126. data/lib/generators/disco_app/{templates → install/templates}/assets/javascripts/application.js +0 -0
  127. data/lib/generators/disco_app/{templates → install/templates}/assets/javascripts/components.js +0 -0
  128. data/lib/generators/disco_app/{templates → install/templates}/assets/stylesheets/application.scss +0 -0
  129. data/lib/generators/disco_app/install/templates/config/appsignal.yml +12 -0
  130. data/lib/generators/disco_app/install/templates/config/cable.yml.tt +11 -0
  131. data/lib/generators/disco_app/{templates → install/templates}/config/database.yml.tt +6 -3
  132. data/lib/generators/disco_app/install/templates/config/environments/staging.rb +108 -0
  133. data/lib/generators/disco_app/{templates → install/templates}/config/puma.rb +0 -0
  134. data/lib/generators/disco_app/{templates → install/templates}/controllers/home_controller.rb +1 -0
  135. data/lib/generators/disco_app/{templates → install/templates}/initializers/disco_app.rb +5 -0
  136. data/lib/generators/disco_app/install/templates/initializers/session_store.rb +2 -0
  137. data/lib/generators/disco_app/install/templates/initializers/shopify_app.rb +11 -0
  138. data/lib/generators/disco_app/{templates → install/templates}/initializers/shopify_session_repository.rb +0 -0
  139. data/lib/generators/disco_app/install/templates/initializers/timber.rb +4 -0
  140. data/lib/generators/disco_app/{templates → install/templates}/root/.editorconfig +0 -0
  141. data/lib/generators/disco_app/{templates → install/templates}/root/.env +7 -0
  142. data/lib/generators/disco_app/{templates → install/templates}/root/.env.local +4 -0
  143. data/lib/generators/disco_app/{templates → install/templates}/root/.github/PULL_REQUEST_TEMPLATE.md +0 -0
  144. data/lib/generators/disco_app/{templates → install/templates}/root/.gitignore +6 -0
  145. data/lib/generators/disco_app/install/templates/root/.rspec +1 -0
  146. data/lib/generators/disco_app/{templates → install/templates}/root/.rubocop.yml +315 -217
  147. data/lib/generators/disco_app/install/templates/root/.tool-versions +2 -0
  148. data/lib/generators/disco_app/{templates → install/templates}/root/CHECKS +0 -0
  149. data/lib/generators/disco_app/{templates → install/templates}/root/Procfile +0 -0
  150. data/lib/generators/disco_app/{templates → install/templates}/root/README.md +0 -0
  151. data/lib/generators/disco_app/install/templates/root/package.json.tt +17 -0
  152. data/lib/generators/disco_app/install/templates/spec/rails_helper.rb +40 -0
  153. data/lib/generators/disco_app/install/templates/spec/spec_helper.rb +24 -0
  154. data/lib/generators/disco_app/install/templates/spec/support/active_job.rb +13 -0
  155. data/lib/generators/disco_app/install/templates/spec/support/coveralls.rb +3 -0
  156. data/lib/generators/disco_app/install/templates/spec/support/database_cleaner.rb +17 -0
  157. data/lib/generators/disco_app/install/templates/spec/support/factory_bot.rb +3 -0
  158. data/lib/generators/disco_app/install/templates/spec/support/helpers/json_helper.rb +13 -0
  159. data/lib/generators/disco_app/install/templates/spec/support/shared_examples/a_synchronise_job.rb +12 -0
  160. data/lib/generators/disco_app/install/templates/spec/support/shoulda.rb +6 -0
  161. data/lib/generators/disco_app/install/templates/spec/support/vcr.rb +14 -0
  162. data/lib/generators/disco_app/install/templates/spec/support/webmock.rb +8 -0
  163. data/lib/generators/disco_app/{templates → install/templates}/views/home/index.html.erb +0 -0
  164. data/lib/generators/disco_app/react/USAGE +5 -0
  165. data/lib/generators/disco_app/react/react_generator.rb +108 -0
  166. data/lib/generators/disco_app/react/templates/app/controllers/embedded/api/base_controller.rb +18 -0
  167. data/lib/generators/disco_app/react/templates/app/controllers/embedded/api/home_controller.rb +10 -0
  168. data/lib/generators/disco_app/react/templates/app/controllers/embedded/api/shops_controller.rb +11 -0
  169. data/lib/generators/disco_app/react/templates/app/controllers/embedded/api/users_controller.rb +11 -0
  170. data/lib/generators/disco_app/react/templates/app/controllers/embedded/home_controller.rb +13 -0
  171. data/lib/generators/disco_app/react/templates/app/models/api_response.rb +107 -0
  172. data/lib/generators/disco_app/react/templates/app/serializers/disco_app/shop_serializer.rb +13 -0
  173. data/lib/generators/disco_app/react/templates/app/serializers/disco_app/user_serializer.rb +13 -0
  174. data/lib/generators/disco_app/react/templates/app/serializers/empty_serializer.rb +5 -0
  175. data/lib/generators/disco_app/react/templates/app/serializers/error_serializer.rb +76 -0
  176. data/lib/generators/disco_app/react/templates/app/views/embedded/home/index.html.erb +12 -0
  177. data/lib/generators/disco_app/react/templates/app/views/layouts/embedded.html.erb +10 -0
  178. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/App.jsx +77 -0
  179. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/HomePage.jsx +34 -0
  180. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/Shared/EmbeddedPage.jsx +70 -0
  181. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/Shared/ErrorBanner.jsx +58 -0
  182. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/Shared/PaginationWrapper.jsx +10 -0
  183. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/Shared/ScrollToTop.jsx +23 -0
  184. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/components/withApi.jsx +125 -0
  185. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/index.jsx +39 -0
  186. data/lib/generators/disco_app/react/templates/app/webpack/javascripts/embedded/utils.js +19 -0
  187. data/lib/generators/disco_app/react/templates/app/webpack/packs/embedded.js +2 -0
  188. data/lib/generators/disco_app/react/templates/app/webpack/stylesheets/embedded/shared/banners.scss +7 -0
  189. data/lib/generators/disco_app/react/templates/app/webpack/stylesheets/embedded/shared/busy.scss +3 -0
  190. data/lib/generators/disco_app/react/templates/app/webpack/stylesheets/embedded/shared/index.scss +3 -0
  191. data/lib/generators/disco_app/react/templates/app/webpack/stylesheets/embedded/shared/pagination.scss +5 -0
  192. data/lib/generators/disco_app/react/templates/app/webpack/stylesheets/embedded.scss +2 -0
  193. data/lib/generators/disco_app/react/templates/config/initializers/mime_types.rb +13 -0
  194. data/lib/generators/disco_app/react/templates/config/initializers/omniauth.rb +27 -0
  195. data/lib/generators/disco_app/react/templates/config/initializers/version.rb.tt +7 -0
  196. data/lib/generators/disco_app/react/templates/config/webpack/staging.js +5 -0
  197. data/lib/generators/disco_app/react/templates/config/webpack/test.js +5 -0
  198. data/lib/generators/disco_app/react/templates/config/webpacker.yml +96 -0
  199. data/lib/generators/disco_app/react/templates/root/.eslintignore +5 -0
  200. data/lib/generators/disco_app/react/templates/root/.eslintrc +69 -0
  201. data/lib/generators/disco_app/react/templates/root/.prettierrc +3 -0
  202. data/lib/generators/disco_app/react/templates/root/VERSION +1 -0
  203. data/lib/generators/disco_app/react/templates/root/babel.config.js +72 -0
  204. data/lib/generators/disco_app/react/templates/root/package.json.tt +84 -0
  205. data/lib/generators/disco_app/react/templates/root/postcss.config.js +14 -0
  206. data/lib/tasks/api.rake +0 -2
  207. data/lib/tasks/carrier_service.rake +0 -2
  208. data/lib/tasks/database.rake +1 -1
  209. data/lib/tasks/sessions.rake +0 -2
  210. data/lib/tasks/shops.rake +0 -2
  211. data/lib/tasks/users.rake +0 -2
  212. data/lib/tasks/webhooks.rake +0 -2
  213. data/test/clients/disco_app/api_client_test.rb +3 -3
  214. data/test/controllers/disco_app/admin/shops_controller_test.rb +1 -0
  215. data/test/controllers/disco_app/charges_controller_test.rb +8 -9
  216. data/test/controllers/disco_app/flow/trigger_usage_controller_test.rb +41 -0
  217. data/test/controllers/disco_app/install_controller_test.rb +2 -1
  218. data/test/controllers/disco_app/subscriptions_controller_test.rb +2 -1
  219. data/test/controllers/disco_app/webhooks_controller_test.rb +1 -0
  220. data/test/controllers/home_controller_test.rb +1 -1
  221. data/test/disco_app_test.rb +3 -1
  222. data/test/dummy/Rakefile +1 -1
  223. data/test/dummy/app/assets/config/manifest.js +2 -0
  224. data/test/dummy/app/controllers/application_controller.rb +2 -0
  225. data/test/dummy/app/controllers/carrier_request_controller.rb +1 -0
  226. data/test/dummy/app/controllers/disco_app/admin/shops_controller.rb +1 -0
  227. data/test/dummy/app/controllers/home_controller.rb +1 -0
  228. data/test/dummy/app/controllers/proxy_controller.rb +1 -0
  229. data/test/dummy/app/javascript/packs/application.js +18 -0
  230. data/test/dummy/app/jobs/disco_app/app_installed_job.rb +2 -3
  231. data/test/dummy/app/jobs/disco_app/app_uninstalled_job.rb +1 -0
  232. data/test/dummy/app/models/application_record.rb +2 -0
  233. data/test/dummy/app/models/cart.rb +4 -3
  234. data/test/dummy/app/models/disco_app/shop.rb +4 -5
  235. data/test/dummy/app/models/js_configuration.rb +1 -0
  236. data/test/dummy/app/models/product.rb +3 -2
  237. data/test/dummy/app/models/widget_configuration.rb +1 -0
  238. data/test/dummy/babel.config.js +72 -0
  239. data/test/dummy/bin/bundle +1 -1
  240. data/test/dummy/bin/rails +1 -1
  241. data/test/dummy/bin/setup +8 -8
  242. data/test/dummy/bin/webpack +19 -0
  243. data/test/dummy/bin/webpack-dev-server +19 -0
  244. data/test/dummy/config/application.rb +4 -3
  245. data/test/dummy/config/boot.rb +2 -2
  246. data/test/dummy/config/database.yml +3 -0
  247. data/test/dummy/config/environment.rb +1 -1
  248. data/test/dummy/config/environments/staging.rb +85 -0
  249. data/test/dummy/config/initializers/disco_app.rb +8 -1
  250. data/test/dummy/config/initializers/omniauth.rb +3 -4
  251. data/test/dummy/config/initializers/session_store.rb +1 -1
  252. data/test/dummy/config/initializers/shopify_app.rb +1 -0
  253. data/test/dummy/config/routes.rb +0 -2
  254. data/test/dummy/config/secrets.yml +3 -0
  255. data/test/dummy/config/webpack/development.js +5 -0
  256. data/test/dummy/config/webpack/environment.js +3 -0
  257. data/test/dummy/config/webpack/production.js +5 -0
  258. data/test/dummy/config/webpack/test.js +5 -0
  259. data/test/dummy/config/webpacker.yml +95 -0
  260. data/test/dummy/db/migrate/20160307182229_create_products.rb +3 -1
  261. data/test/dummy/db/migrate/20160530160739_create_asset_models.rb +3 -1
  262. data/test/dummy/db/migrate/20161105054746_create_carts.rb +2 -1
  263. data/test/dummy/db/schema.rb +45 -6
  264. data/test/dummy/package.json +8 -0
  265. data/test/dummy/postcss.config.js +12 -0
  266. data/test/dummy/yarn.lock +7244 -0
  267. data/test/fixtures/api/subscriptions/valid_request.json +1 -1
  268. data/test/fixtures/api/widget_store/empty_webhooks.json +3 -0
  269. data/test/fixtures/api/widget_store/existing_webhooks.json +43 -0
  270. data/test/fixtures/disco_app/shops.yml +3 -0
  271. data/test/fixtures/webhooks/flow/trigger_usage.json +7 -0
  272. data/test/integration/synchronises_test.rb +2 -1
  273. data/test/jobs/disco_app/app_installed_job_test.rb +28 -9
  274. data/test/jobs/disco_app/app_uninstalled_job_test.rb +5 -2
  275. data/test/jobs/disco_app/send_subscription_job_test.rb +3 -2
  276. data/test/jobs/disco_app/synchronise_carrier_service_job_test.rb +1 -0
  277. data/test/jobs/disco_app/synchronise_users_job_test.rb +1 -0
  278. data/test/jobs/disco_app/synchronise_webhooks_job_test.rb +70 -13
  279. data/test/models/disco_app/can_be_liquified_test.rb +3 -1
  280. data/test/models/disco_app/has_metafields_test.rb +37 -18
  281. data/test/models/disco_app/renders_assets_test.rb +2 -1
  282. data/test/models/disco_app/session_test.rb +2 -2
  283. data/test/models/disco_app/shop_test.rb +1 -1
  284. data/test/services/disco_app/charges_service_test.rb +7 -8
  285. data/test/services/disco_app/flow/create_action_test.rb +51 -0
  286. data/test/services/disco_app/flow/create_trigger_test.rb +56 -0
  287. data/test/services/disco_app/flow/process_action_test.rb +68 -0
  288. data/test/services/disco_app/flow/process_trigger_test.rb +94 -0
  289. data/test/services/disco_app/flow/update_trigger_usage_test.rb +87 -0
  290. data/test/services/disco_app/subscription_service_test.rb +3 -2
  291. data/test/support/test_file_fixtures.rb +2 -2
  292. data/test/support/test_shopify_api.rb +1 -1
  293. data/test/test_helper.rb +10 -7
  294. data/test/vcr/flow_trigger_invalid_title.yml +35 -0
  295. data/test/vcr/flow_trigger_valid.yml +38 -0
  296. data/test/vcr/webhook_failure.yml +13 -13
  297. metadata +282 -148
  298. data/app/clients/disco_app/disco_api_error.rb +0 -2
  299. data/app/clients/disco_app/rollbar_client.rb +0 -53
  300. data/app/clients/disco_app/rollbar_client_error.rb +0 -2
  301. data/lib/generators/disco_app/USAGE +0 -5
  302. data/lib/generators/disco_app/disco_app_generator.rb +0 -236
  303. data/lib/generators/disco_app/templates/config/newrelic.yml +0 -26
  304. data/lib/generators/disco_app/templates/initializers/rollbar.rb +0 -23
  305. data/lib/generators/disco_app/templates/initializers/session_store.rb +0 -2
  306. data/lib/generators/disco_app/templates/initializers/shopify_app.rb +0 -6
  307. data/lib/generators/disco_app/templates/root/.codeclimate.yml +0 -7
  308. data/lib/generators/disco_app/templates/root/.ruby-version +0 -1
  309. data/lib/tasks/rollbar.rake +0 -24
  310. data/test/fixtures/api/widget_store/webhooks.json +0 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ffe2c53f6a63376cf9484d15fbfb9030d7e4b5c07e0c38cccbc3f2ef095ac00f
4
- data.tar.gz: 91019e6d795d0bd4b930badc400d8add493da10965312747db9b67ed58a8addc
3
+ metadata.gz: 0e64f5353b2ff61d1c3dfb3687437e41a5b0bcd95341997a50a94a1f514b9b87
4
+ data.tar.gz: 995cdd1d825a71b2a27e0fb9bee55bd95a24b5b89967e1719875c413a1882dca
5
5
  SHA512:
6
- metadata.gz: dba9193914aa136db5dd59dd9c25b49e70396967f0aa2f0cbe05682408864c93d6e57f6afb771ad5c19b3e00074efb4b1d9f6e76f3805aed7473a390993a2183
7
- data.tar.gz: 3b171fa44ccab7a8af5470c50106ff1023370a29c95da68e9f2909287d551d5858ac840063daf9c091ed2184157eb25184278b4ac05916ffe887b1fe6df1b09d
6
+ metadata.gz: b5195516feed35026a348bf3842c64e9fd7235a25eaf6544dad2b69ba7be8fdf885bf731bba300cdfe6dcea1f76a2d37da1c75d315b45d6fb62d68791a3d7bc4
7
+ data.tar.gz: e43fcbd82c8b9804e3cb574436bf406fcede8b12c3dc9ae7e65323ab8c4bdb5b8b605162f3efc036fd37ad7a1d22fad817e2a52b585a43f3ca718cd89cec38e1
data/Rakefile CHANGED
@@ -14,14 +14,11 @@ RDoc::Task.new(:rdoc) do |rdoc|
14
14
  rdoc.rdoc_files.include('lib/**/*.rb')
15
15
  end
16
16
 
17
- APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__)
17
+ APP_RAKEFILE = File.expand_path('test/dummy/Rakefile', __dir__)
18
18
  load 'rails/tasks/engine.rake'
19
19
 
20
-
21
20
  load 'rails/tasks/statistics.rake'
22
21
 
23
-
24
-
25
22
  Bundler::GemHelper.install_tasks
26
23
 
27
24
  require 'rake/testtask'
@@ -33,5 +30,4 @@ Rake::TestTask.new(:test) do |t|
33
30
  t.verbose = false
34
31
  end
35
32
 
36
-
37
33
  task default: :test
@@ -1,27 +1,33 @@
1
1
  require 'rest-client'
2
2
 
3
- class DiscoApp::ApiClient
3
+ module DiscoApp
4
4
 
5
- SUBSCRIPTION_ENDPOINT = 'app_subscriptions.json'
5
+ class DiscoApiError < StandardError; end
6
6
 
7
- def initialize(shop, url)
8
- @shop = shop
9
- @url = url
10
- end
7
+ class ApiClient
8
+
9
+ SUBSCRIPTION_ENDPOINT = 'app_subscriptions.json'.freeze
11
10
 
12
- def create_app_subscription
13
- return unless @url.present?
14
- url = @url + SUBSCRIPTION_ENDPOINT
15
- begin
16
- response = RestClient::Request.execute(
17
- method: :post,
18
- headers: { content_type: :json },
19
- url: url,
20
- payload: { shop: @shop, subscription: @shop.current_subscription }.to_json
21
- )
22
- rescue RestClient::BadRequest, RestClient::ResourceNotFound => e
23
- raise DiscoApiError.new(e.message)
11
+ def initialize(shop, url)
12
+ @shop = shop
13
+ @url = url
24
14
  end
25
- end
26
15
 
16
+ def create_app_subscription
17
+ return if @url.blank?
18
+
19
+ url = @url + SUBSCRIPTION_ENDPOINT
20
+ begin
21
+ RestClient::Request.execute(
22
+ method: :post,
23
+ headers: { content_type: :json },
24
+ url: url,
25
+ payload: { shop: @shop, subscription: @shop.current_subscription }.to_json
26
+ )
27
+ rescue RestClient::BadRequest, RestClient::ResourceNotFound => e
28
+ raise DiscoApiError, e.message
29
+ end
30
+ end
31
+
32
+ end
27
33
  end
@@ -0,0 +1,85 @@
1
+ require 'rest-client'
2
+
3
+ ##
4
+ # This file defines a very simple GraphQL API client to support a single type
5
+ # of GraphQL API call for a Shopify store - sending a Shopify Flow trigger.
6
+ #
7
+ # We use this simple approach rather than using an existing GraphQL client
8
+ # library such as https://github.com/github/graphql-client (either standalone
9
+ # or as bundled with the Shopify API gem) for a couple of reasons:
10
+ #
11
+ # - These libraries tend to presume that a single client instance is
12
+ # instantiated once and then reused across the application, which isn't the
13
+ # case when we're making API calls once per trigger for each background
14
+ # job.
15
+ # - These libraries make an API call to fetch the Shopify GraphQL schema on
16
+ # initialisation. The schema is very large, so the API call takes a number
17
+ # of seconds to complete and when parsed consumes a large amount of memory.
18
+ # - These libraries do not natively work well with the idea of a dynamic API
19
+ # endpoint (ie, changing the request URL frequently), which is required
20
+ # when making many requests to different Shopify stores.
21
+ #
22
+ module DiscoApp
23
+ class GraphqlClient
24
+
25
+ def initialize(shop)
26
+ @shop = shop
27
+ end
28
+
29
+ ##
30
+ # Fire a Shopify Flow Trigger.
31
+ # Returns a tuple {Boolean, Array} representing {success, errors}.
32
+ def create_flow_trigger(title, resource_name, resource_url, properties)
33
+ body = {
34
+ trigger_title: title,
35
+ resources: [
36
+ {
37
+ name: resource_name,
38
+ url: resource_url
39
+ }
40
+ ],
41
+ properties: properties
42
+ }
43
+
44
+ # The double .to_json.to_json below looks odd but is required to properly escape the JSON hash
45
+ # when inserting it into the GraphQL mutation call.
46
+ response = execute(%(
47
+ mutation {
48
+ flowTriggerReceive(body: #{body.to_json.to_json}) {
49
+ userErrors {
50
+ field,
51
+ message
52
+ }
53
+ }
54
+ }
55
+ ))
56
+
57
+ errors = response.dig(:data, :flowTriggerReceive, :userErrors)
58
+ [errors.empty?, errors]
59
+ end
60
+
61
+ private
62
+
63
+ def execute(query)
64
+ response = RestClient::Request.execute(
65
+ method: :post,
66
+ headers: headers,
67
+ url: url,
68
+ payload: { query: query }.to_json
69
+ )
70
+ JSON.parse(response.body).with_indifferent_access
71
+ end
72
+
73
+ def headers
74
+ {
75
+ 'Content-Type' => 'application/json',
76
+ 'X-Shopify-Access-Token' => @shop.shopify_token
77
+ }
78
+ end
79
+
80
+ def url
81
+ "https://#{@shop.shopify_domain}/admin/api/graphql.json"
82
+ end
83
+
84
+ end
85
+ end
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::AppSettingsController < DiscoApp::Admin::ApplicationController
2
+
2
3
  include DiscoApp::Admin::Concerns::AppSettingsController
4
+
3
5
  end
@@ -1,4 +1,5 @@
1
1
  class DiscoApp::Admin::ApplicationController < ActionController::Base
2
+
2
3
  include DiscoApp::Admin::Concerns::AuthenticatedController
3
4
 
4
5
  private
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Admin::Concerns::AppSettingsController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  def edit
@@ -7,7 +8,7 @@ module DiscoApp::Admin::Concerns::AppSettingsController
7
8
 
8
9
  def update
9
10
  @app_settings = DiscoApp::AppSettings.instance
10
- if @app_settings.update_attributes(app_settings_params)
11
+ if @app_settings.update(app_settings_params)
11
12
  flash[:success] = 'Settings updated.'
12
13
  redirect_to edit_admin_app_settings_path
13
14
  else
@@ -1,19 +1,21 @@
1
1
  module DiscoApp::Admin::Concerns::AuthenticatedController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
5
-
6
6
  protect_from_forgery with: :exception
7
7
  before_action :authenticate_administrator
8
8
  layout 'admin'
9
-
10
9
  end
11
10
 
12
11
  private
13
12
 
14
13
  def authenticate_administrator
15
14
  authenticate_or_request_with_http_basic do |username, password|
16
- (not username.blank?) && (not password.blank?) && username == ENV['ADMIN_APP_USERNAME'] && password == ENV['ADMIN_APP_PASSWORD']
15
+ username.present? &&
16
+ password.present? &&
17
+ username == ENV['ADMIN_APP_USERNAME'] &&
18
+ password == ENV['ADMIN_APP_PASSWORD']
17
19
  end
18
20
  end
19
21
 
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Admin::Concerns::PlansController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -26,7 +27,7 @@ module DiscoApp::Admin::Concerns::PlansController
26
27
  end
27
28
 
28
29
  def update
29
- if @plan.update_attributes(plan_params)
30
+ if @plan.update(plan_params)
30
31
  redirect_to edit_admin_plan_path(@plan)
31
32
  else
32
33
  render 'edit'
@@ -47,7 +48,7 @@ module DiscoApp::Admin::Concerns::PlansController
47
48
  def plan_params
48
49
  params.require(:plan).permit(
49
50
  :name, :status, :plan_type, :trial_period_days, :amount,
50
- :plan_codes_attributes => [:id, :_destroy, :code, :trial_period_days, :amount]
51
+ plan_codes_attributes: %i[id _destroy code trial_period_days amount]
51
52
  )
52
53
  end
53
54
 
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Admin::Concerns::ShopsController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  def index
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Admin::Concerns::SourcesController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -26,7 +27,7 @@ module DiscoApp::Admin::Concerns::SourcesController
26
27
  end
27
28
 
28
29
  def update
29
- if @source.update_attributes(source_params)
30
+ if @source.update(source_params)
30
31
  redirect_to edit_admin_plan_path(@source)
31
32
  else
32
33
  render 'edit'
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Admin::Concerns::SubscriptionsController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -9,7 +10,7 @@ module DiscoApp::Admin::Concerns::SubscriptionsController
9
10
  end
10
11
 
11
12
  def update
12
- if @subscription.update_attributes(subscription_params)
13
+ if @subscription.update(subscription_params)
13
14
  redirect_to edit_admin_shop_subscription_path(@subscription.shop, @subscription)
14
15
  else
15
16
  render 'edit'
@@ -19,7 +20,7 @@ module DiscoApp::Admin::Concerns::SubscriptionsController
19
20
  private
20
21
 
21
22
  def find_subscription
22
- @subscription = DiscoApp::Subscription.find_by_id(params[:id])
23
+ @subscription = DiscoApp::Subscription.find_by(id: params[:id])
23
24
  end
24
25
 
25
26
  def subscription_params
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::PlansController < DiscoApp::Admin::ApplicationController
2
+
2
3
  include DiscoApp::Admin::Concerns::PlansController
4
+
3
5
  end
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::Resources::ShopsController < JSONAPI::ResourceController
2
+
2
3
  include DiscoApp::Admin::Concerns::AuthenticatedController
4
+
3
5
  end
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::ShopsController < DiscoApp::Admin::ApplicationController
2
+
2
3
  include DiscoApp::Admin::Concerns::ShopsController
4
+
3
5
  end
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::SourcesController < DiscoApp::Admin::ApplicationController
2
+
2
3
  include DiscoApp::Admin::Concerns::SourcesController
4
+
3
5
  end
@@ -1,3 +1,5 @@
1
1
  class DiscoApp::Admin::SubscriptionsController < DiscoApp::Admin::ApplicationController
2
+
2
3
  include DiscoApp::Admin::Concerns::SubscriptionsController
4
+
3
5
  end
@@ -1,4 +1,5 @@
1
1
  class DiscoApp::ChargesController < ApplicationController
2
+
2
3
  include DiscoApp::Concerns::AuthenticatedController
3
4
 
4
5
  skip_before_action :check_active_charge
@@ -13,7 +14,7 @@ class DiscoApp::ChargesController < ApplicationController
13
14
  # subscription. If successful, redirect to the (external) charge confirmation
14
15
  # URL. If it fails, redirect back to the new charge page.
15
16
  def create
16
- if(charge = DiscoApp::ChargesService.create(@shop, @subscription)).nil?
17
+ if (charge = DiscoApp::ChargesService.create(@shop, @subscription)).nil?
17
18
  redirect_to action: :new
18
19
  else
19
20
  redirect_to charge.confirmation_url
@@ -25,8 +26,8 @@ class DiscoApp::ChargesController < ApplicationController
25
26
  # charge wasn't accepted, the flow will start again.
26
27
  def activate
27
28
  # First attempt to find a matching charge.
28
- if(charge = @subscription.charges.find_by(id: params[:id], shopify_id: params[:charge_id])).nil?
29
- redirect_to action: :new and return
29
+ if (charge = @subscription.charges.find_by(id: params[:id], shopify_id: params[:charge_id])).nil?
30
+ redirect_to(action: :new) && return
30
31
  end
31
32
  if DiscoApp::ChargesService.activate(@shop, charge)
32
33
  redirect_to main_app.root_url
@@ -38,10 +39,8 @@ class DiscoApp::ChargesController < ApplicationController
38
39
  private
39
40
 
40
41
  def find_subscription
41
- @subscription = @shop.subscriptions.find_by_id!(params[:subscription_id])
42
- unless @subscription.requires_active_charge? and not @subscription.active_charge?
43
- redirect_to main_app.root_url
44
- end
42
+ @subscription = @shop.subscriptions.find_by!(id: params[:subscription_id])
43
+ redirect_to main_app.root_url unless @subscription.requires_active_charge? && !@subscription.active_charge?
45
44
  end
46
45
 
47
46
  end
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Concerns::AppProxyController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -6,7 +7,7 @@ module DiscoApp::Concerns::AppProxyController
6
7
  before_action :shopify_shop
7
8
  after_action :add_liquid_header
8
9
 
9
- rescue_from ActiveRecord::RecordNotFound do |exception|
10
+ rescue_from ActiveRecord::RecordNotFound do |_exception|
10
11
  render_error 404
11
12
  end
12
13
  end
@@ -14,18 +15,17 @@ module DiscoApp::Concerns::AppProxyController
14
15
  private
15
16
 
16
17
  def verify_proxy_signature
17
- unless proxy_signature_is_valid?
18
- head :unauthorized
19
- end
18
+ head :unauthorized unless proxy_signature_is_valid?
20
19
  end
21
20
 
22
21
  def proxy_signature_is_valid?
23
- return true if (Rails.env.development? || Rails.env.test?) and DiscoApp.configuration.skip_proxy_verification?
22
+ return true if (Rails.env.development? || Rails.env.test?) && DiscoApp.configuration.skip_proxy_verification?
23
+
24
24
  DiscoApp::ProxyService.proxy_signature_is_valid?(request.query_string, ShopifyApp.configuration.secret)
25
25
  end
26
26
 
27
27
  def shopify_shop
28
- @shop = DiscoApp::Shop.find_by_shopify_domain!(params[:shop])
28
+ @shop = DiscoApp::Shop.find_by!(shopify_domain: params[:shop])
29
29
  end
30
30
 
31
31
  def add_liquid_header
@@ -1,11 +1,12 @@
1
1
  module DiscoApp::Concerns::AuthenticatedController
2
+
2
3
  extend ActiveSupport::Concern
3
4
  include ShopifyApp::LoginProtection
4
5
 
5
6
  included do
6
7
  before_action :auto_login
7
8
  before_action :check_shop_whitelist
8
- before_action :login_again_if_different_shop
9
+ before_action :login_again_if_different_user_or_shop
9
10
  before_action :shopify_shop
10
11
  before_action :check_installed
11
12
  before_action :check_current_subscription
@@ -17,52 +18,50 @@ module DiscoApp::Concerns::AuthenticatedController
17
18
  private
18
19
 
19
20
  def auto_login
20
- if shop_session.nil? and request_hmac_valid?
21
- if(shop = DiscoApp::Shop.find_by_shopify_domain(sanitized_shop_name)).present?
22
- session[:shopify] = shop.id
23
- session[:shopify_domain] = sanitized_shop_name
24
- end
25
- end
21
+ return unless shop_session.nil? && request_hmac_valid?
22
+
23
+ shop = DiscoApp::Shop.find_by(shopify_domain: sanitized_shop_name)
24
+ return if shop.blank?
25
+
26
+ session[:shopify] = shop.id
27
+ session[:shopify_domain] = sanitized_shop_name
26
28
  end
27
29
 
28
30
  def shopify_shop
29
31
  if shop_session
30
- @shop = DiscoApp::Shop.find_by!(shopify_domain: @shop_session.url)
32
+ @shop = DiscoApp::Shop.find_by!(shopify_domain: @shop_session.domain)
31
33
  else
32
34
  redirect_to_login
33
35
  end
34
36
  end
35
37
 
36
38
  def check_installed
37
- if @shop.awaiting_install? or @shop.installing?
39
+ if @shop.awaiting_install? || @shop.installing?
38
40
  redirect_if_not_current_path disco_app.installing_path
39
41
  return
40
42
  end
41
- if @shop.awaiting_uninstall? or @shop.uninstalling?
43
+ if @shop.awaiting_uninstall? || @shop.uninstalling?
42
44
  redirect_if_not_current_path disco_app.uninstalling_path
43
45
  return
44
46
  end
45
- unless @shop.installed?
46
- redirect_if_not_current_path disco_app.install_path
47
- end
47
+ redirect_if_not_current_path disco_app.install_path unless @shop.installed?
48
48
  end
49
49
 
50
50
  def check_current_subscription
51
- unless @shop.current_subscription?
52
- redirect_if_not_current_path disco_app.new_subscription_path
53
- end
51
+ redirect_if_not_current_path disco_app.new_subscription_path unless @shop.current_subscription?
54
52
  end
55
53
 
56
54
  def check_active_charge
57
- if @shop.current_subscription? and @shop.current_subscription.requires_active_charge? and not @shop.development? and not @shop.current_subscription.active_charge?
58
- redirect_if_not_current_path disco_app.new_subscription_charge_path(@shop.current_subscription)
59
- end
55
+ return unless @shop.current_subscription?
56
+ return unless @shop.current_subscription.requires_active_charge?
57
+ return if @shop.development?
58
+ return if @shop.current_subscription.active_charge?
59
+
60
+ redirect_if_not_current_path disco_app.new_subscription_charge_path(@shop.current_subscription)
60
61
  end
61
62
 
62
63
  def redirect_if_not_current_path(target)
63
- if request.path != target
64
- redirect_to target
65
- end
64
+ redirect_to target if request.path != target
66
65
  end
67
66
 
68
67
  def request_hmac_valid?
@@ -70,11 +69,11 @@ module DiscoApp::Concerns::AuthenticatedController
70
69
  end
71
70
 
72
71
  def check_shop_whitelist
73
- if shop_session
74
- if ENV['WHITELISTED_DOMAINS'].present? && !ENV['WHITELISTED_DOMAINS'].include?(shop_session.url)
75
- redirect_to_login
76
- end
77
- end
72
+ return unless shop_session
73
+ return if ENV['WHITELISTED_DOMAINS'].blank?
74
+ return if ENV['WHITELISTED_DOMAINS'].include?(shop_session.url)
75
+
76
+ redirect_to_login
78
77
  end
79
78
 
80
79
  end
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Concerns::CarrierRequestController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -10,26 +11,36 @@ module DiscoApp::Concerns::CarrierRequestController
10
11
  private
11
12
 
12
13
  def verify_carrier_request
13
- unless carrier_request_signature_is_valid?
14
- head :unauthorized
15
- end
14
+ head :unauthorized unless carrier_request_signature_is_valid?
16
15
  end
17
16
 
18
17
  def carrier_request_signature_is_valid?
19
- return true if Rails.env.development? and DiscoApp.configuration.skip_carrier_request_verification?
20
- DiscoApp::CarrierRequestService.is_valid_hmac?(request.body.read.to_s, ShopifyApp.configuration.secret, request.headers['HTTP_X_SHOPIFY_HMAC_SHA256'])
18
+ return true if Rails.env.development? && DiscoApp.configuration.skip_carrier_request_verification?
19
+
20
+ DiscoApp::CarrierRequestService.valid_hmac?(
21
+ request.body.read.to_s,
22
+ ShopifyApp.configuration.secret,
23
+ request.headers['HTTP_X_SHOPIFY_HMAC_SHA256']
24
+ )
21
25
  end
22
26
 
23
27
  def find_shop
24
- unless (@shop = DiscoApp::Shop.find_by_shopify_domain(request.headers['HTTP_X_SHOPIFY_SHOP_DOMAIN']))
25
- head :unauthorized
26
- end
28
+ @shop = DiscoApp::Shop.find_by(shopify_domain: request.headers['HTTP_X_SHOPIFY_SHOP_DOMAIN'])
29
+
30
+ head :unauthorized unless @shop
27
31
  end
28
32
 
29
33
  def validate_rate_params
30
- unless params[:rate].present? and params[:rate][:origin].present? and params[:rate][:destination].present? and params[:rate][:items].present?
31
- head :bad_request
32
- end
34
+ head :bad_request unless request_is_valid?
35
+ end
36
+
37
+ def request_is_valid?
38
+ return false if params[:rate].blank?
39
+ return false if params[:rate][:origin].blank?
40
+ return false if params[:rate][:destination].blank?
41
+ return false if params[:rate][:items].blank?
42
+
43
+ true
33
44
  end
34
45
 
35
46
  end
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Concerns::UserAuthenticatedController
2
+
2
3
  extend ActiveSupport::Concern
3
4
  include ShopifyApp::LoginProtection
4
5
 
@@ -1,4 +1,5 @@
1
1
  module DiscoApp::Concerns::WebhooksController
2
+
2
3
  extend ActiveSupport::Concern
3
4
 
4
5
  included do
@@ -12,20 +13,16 @@ module DiscoApp::Concerns::WebhooksController
12
13
  shopify_domain = request.headers['HTTP_X_SHOPIFY_SHOP_DOMAIN']
13
14
 
14
15
  # Ensure a domain was provided in the headers.
15
- unless shopify_domain
16
- head :bad_request
17
- end
16
+ return head :bad_request unless shopify_domain
18
17
 
19
18
  # Try to find a matching background job task for the given topic using class name.
20
19
  job_class = DiscoApp::WebhookService.find_job_class(topic)
21
20
 
22
21
  # Return bad request if we couldn't match a job class.
23
- unless job_class.present?
24
- head :bad_request
25
- end
22
+ return head :bad_request if job_class.blank?
26
23
 
27
24
  # Decode the body data and enqueue the appropriate job.
28
- data = ActiveSupport::JSON::decode(request.body.read).with_indifferent_access
25
+ data = JSON.parse(request.body.read).with_indifferent_access
29
26
  job_class.perform_later(shopify_domain, data)
30
27
 
31
28
  render body: nil
@@ -34,15 +31,19 @@ module DiscoApp::Concerns::WebhooksController
34
31
  private
35
32
 
36
33
  def verify_webhook
37
- unless webhook_is_valid?
38
- head :unauthorized
39
- end
34
+ return head :unauthorized unless webhook_is_valid?
35
+
40
36
  request.body.rewind
41
37
  end
42
38
 
43
39
  def webhook_is_valid?
44
- return true if Rails.env.development? and DiscoApp.configuration.skip_webhook_verification?
45
- DiscoApp::WebhookService.is_valid_hmac?(request.body.read.to_s, ShopifyApp.configuration.secret, request.headers['HTTP_X_SHOPIFY_HMAC_SHA256'])
40
+ return true if Rails.env.development? && DiscoApp.configuration.skip_webhook_verification?
41
+
42
+ DiscoApp::WebhookService.valid_hmac?(
43
+ request.body.read.to_s,
44
+ ShopifyApp.configuration.secret,
45
+ request.headers['HTTP_X_SHOPIFY_HMAC_SHA256']
46
+ )
46
47
  end
47
48
 
48
49
  end
@@ -0,0 +1,9 @@
1
+ module DiscoApp
2
+ module Flow
3
+ class ActionsController < ActionController::Base
4
+
5
+ include DiscoApp::Flow::Concerns::ActionsController
6
+
7
+ end
8
+ end
9
+ end
@@ -0,0 +1,23 @@
1
+ module DiscoApp
2
+ module Flow
3
+ module Concerns
4
+ module ActionsController
5
+
6
+ extend ActiveSupport::Concern
7
+ include DiscoApp::Flow::Concerns::VerifiesFlowPayload
8
+
9
+ def create_flow_action
10
+ DiscoApp::Flow::CreateAction.call(
11
+ shop: @shop,
12
+ action_id: params[:id],
13
+ action_run_id: params[:action_run_id],
14
+ properties: params[:properties]
15
+ )
16
+
17
+ head :ok
18
+ end
19
+
20
+ end
21
+ end
22
+ end
23
+ end