kaui 2.1.0 → 3.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (269) hide show
  1. checksums.yaml +5 -5
  2. data/README.md +8 -7
  3. data/Rakefile +4 -2
  4. data/app/assets/config/kaui_manifest.js +45 -0
  5. data/app/assets/javascripts/jquery.spin.js +76 -0
  6. data/app/assets/javascripts/kaui/kaui.js +76 -0
  7. data/app/assets/javascripts/kaui_application.js +25 -0
  8. data/app/assets/javascripts/spin.js +76 -0
  9. data/app/assets/stylesheets/bootstrap_and_overrides.scss +240 -0
  10. data/app/assets/stylesheets/kaui/{account.less → account.scss} +4 -0
  11. data/app/assets/stylesheets/kaui/{audit.less → audit.scss} +5 -1
  12. data/app/assets/stylesheets/kaui/{common.less → common.scss} +17 -15
  13. data/app/assets/stylesheets/kaui/{datatable.less → datatable.scss} +6 -3
  14. data/app/assets/stylesheets/kaui/{header.less → header.scss} +16 -12
  15. data/app/assets/stylesheets/kaui/{home.less → home.scss} +7 -4
  16. data/app/assets/stylesheets/kaui/{invoice.less → invoice.scss} +7 -3
  17. data/app/assets/stylesheets/kaui/kaui.scss +265 -0
  18. data/app/assets/stylesheets/kaui/kaui_bootstrap.scss +3 -0
  19. data/app/assets/stylesheets/kaui/{overdue.less → overdue.scss} +3 -1
  20. data/app/assets/stylesheets/kaui/{payment.less → payment.scss} +3 -0
  21. data/app/assets/stylesheets/kaui/{subscription.less → subscription.scss} +4 -1
  22. data/app/assets/stylesheets/kaui/{tags.less → tags.scss} +9 -5
  23. data/app/assets/stylesheets/kaui/timeline.scss +7 -0
  24. data/app/assets/stylesheets/kaui/tooltip.scss +15 -0
  25. data/app/controllers/kaui/account_children_controller.rb +25 -28
  26. data/app/controllers/kaui/account_custom_fields_controller.rb +16 -15
  27. data/app/controllers/kaui/account_emails_controller.rb +28 -25
  28. data/app/controllers/kaui/account_tags_controller.rb +37 -34
  29. data/app/controllers/kaui/account_timelines_controller.rb +38 -33
  30. data/app/controllers/kaui/accounts_controller.rb +268 -250
  31. data/app/controllers/kaui/admin_allowed_users_controller.rb +105 -99
  32. data/app/controllers/kaui/admin_controller.rb +32 -31
  33. data/app/controllers/kaui/admin_tenants_controller.rb +434 -388
  34. data/app/controllers/kaui/audit_logs_controller.rb +86 -83
  35. data/app/controllers/kaui/bundle_tags_controller.rb +24 -20
  36. data/app/controllers/kaui/bundles_controller.rb +96 -82
  37. data/app/controllers/kaui/chargebacks_controller.rb +36 -33
  38. data/app/controllers/kaui/charges_controller.rb +23 -20
  39. data/app/controllers/kaui/credits_controller.rb +28 -25
  40. data/app/controllers/kaui/custom_fields_controller.rb +172 -38
  41. data/app/controllers/kaui/engine_controller.rb +2 -1
  42. data/app/controllers/kaui/engine_controller_util.rb +128 -117
  43. data/app/controllers/kaui/home_controller.rb +230 -217
  44. data/app/controllers/kaui/invoice_items_controller.rb +43 -39
  45. data/app/controllers/kaui/invoice_tags_controller.rb +24 -20
  46. data/app/controllers/kaui/invoices_controller.rb +132 -117
  47. data/app/controllers/kaui/login_proxy_controller.rb +2 -1
  48. data/app/controllers/kaui/payment_methods_controller.rb +102 -94
  49. data/app/controllers/kaui/payments_controller.rb +95 -92
  50. data/app/controllers/kaui/queues_controller.rb +47 -14
  51. data/app/controllers/kaui/refunds_controller.rb +36 -33
  52. data/app/controllers/kaui/registrations_controller.rb +7 -7
  53. data/app/controllers/kaui/role_definitions_controller.rb +17 -14
  54. data/app/controllers/kaui/sessions_controller.rb +7 -4
  55. data/app/controllers/kaui/subscriptions_controller.rb +197 -187
  56. data/app/controllers/kaui/tag_definitions_controller.rb +28 -27
  57. data/app/controllers/kaui/tags_controller.rb +25 -22
  58. data/app/controllers/kaui/tenants_controller.rb +30 -28
  59. data/app/controllers/kaui/transactions_controller.rb +43 -38
  60. data/app/helpers/kaui/account_helper.rb +16 -14
  61. data/app/helpers/kaui/application_helper.rb +8 -3
  62. data/app/helpers/kaui/date_helper.rb +4 -3
  63. data/app/helpers/kaui/home_helper.rb +2 -0
  64. data/app/helpers/kaui/locale_helper.rb +7 -6
  65. data/app/helpers/kaui/money_helper.rb +2 -1
  66. data/app/helpers/kaui/object_helper.rb +11 -10
  67. data/app/helpers/kaui/payment_helper.rb +7 -6
  68. data/app/helpers/kaui/payment_method_helper.rb +3 -2
  69. data/app/helpers/kaui/permissions_helper.rb +9 -9
  70. data/app/helpers/kaui/plugin_helper.rb +25 -23
  71. data/app/helpers/kaui/subscription_helper.rb +27 -29
  72. data/app/helpers/kaui/us_states_helper.rb +7 -6
  73. data/app/helpers/kaui/uuid_helper.rb +8 -6
  74. data/app/models/kaui/ability.rb +19 -12
  75. data/app/models/kaui/account.rb +45 -28
  76. data/app/models/kaui/account_email.rb +23 -20
  77. data/app/models/kaui/account_timeline.rb +5 -1
  78. data/app/models/kaui/admin.rb +65 -64
  79. data/app/models/kaui/admin_tenant.rb +81 -82
  80. data/app/models/kaui/allowed_user.rb +13 -9
  81. data/app/models/kaui/allowed_user_tenant.rb +4 -2
  82. data/app/models/kaui/application_record.rb +2 -0
  83. data/app/models/kaui/audit_log.rb +6 -3
  84. data/app/models/kaui/base.rb +13 -7
  85. data/app/models/kaui/bundle.rb +41 -24
  86. data/app/models/kaui/catalog.rb +118 -113
  87. data/app/models/kaui/chargeback.rb +5 -1
  88. data/app/models/kaui/credit.rb +4 -1
  89. data/app/models/kaui/custom_field.rb +9 -6
  90. data/app/models/kaui/invoice.rb +25 -22
  91. data/app/models/kaui/invoice_item.rb +9 -6
  92. data/app/models/kaui/invoice_payment.rb +49 -54
  93. data/app/models/kaui/killbill_authenticatable.rb +14 -8
  94. data/app/models/kaui/killbill_registerable.rb +7 -0
  95. data/app/models/kaui/overdue.rb +64 -65
  96. data/app/models/kaui/payment.rb +22 -19
  97. data/app/models/kaui/payment_method.rb +48 -39
  98. data/app/models/kaui/payment_state.rb +41 -38
  99. data/app/models/kaui/rails_methods.rb +9 -9
  100. data/app/models/kaui/refund.rb +7 -1
  101. data/app/models/kaui/role_definition.rb +5 -1
  102. data/app/models/kaui/simple_plan.rb +5 -3
  103. data/app/models/kaui/subscription.rb +10 -7
  104. data/app/models/kaui/tag.rb +25 -22
  105. data/app/models/kaui/tag_definition.rb +50 -45
  106. data/app/models/kaui/tenant.rb +6 -5
  107. data/app/models/kaui/transaction.rb +43 -31
  108. data/app/models/kaui/user.rb +10 -16
  109. data/app/models/kaui/user_role.rb +8 -5
  110. data/app/views/kaui/accounts/_billing_info.html.erb +1 -1
  111. data/app/views/kaui/accounts/_form.html.erb +2 -2
  112. data/app/views/kaui/accounts/index.html.erb +2 -0
  113. data/app/views/kaui/admin_allowed_users/_form.html.erb +3 -3
  114. data/app/views/kaui/admin_tenants/_form_catalog_translation.erb +1 -1
  115. data/app/views/kaui/admin_tenants/_form_invoice_template.erb +1 -1
  116. data/app/views/kaui/admin_tenants/_form_invoice_translation.erb +1 -1
  117. data/app/views/kaui/admin_tenants/_show_catalog_simple.erb +11 -5
  118. data/app/views/kaui/admin_tenants/new_catalog.html.erb +2 -2
  119. data/app/views/kaui/admin_tenants/new_overdue_config.html.erb +2 -2
  120. data/app/views/kaui/admin_tenants/new_plan_currency.html.erb +1 -1
  121. data/app/views/kaui/bundles/index.html.erb +1 -1
  122. data/app/views/kaui/bundles/transfer.html.erb +13 -5
  123. data/app/views/kaui/invoices/_invoice_table.html.erb +1 -1
  124. data/app/views/kaui/layouts/kaui_flash.html.erb +24 -0
  125. data/app/views/kaui/layouts/kaui_header.html.erb +19 -2
  126. data/app/views/kaui/payment_methods/_payment_methods_details_table.html.erb +13 -4
  127. data/app/views/kaui/payments/_payment_table.html.erb +21 -11
  128. data/app/views/kaui/payments/index.html.erb +9 -9
  129. data/app/views/kaui/queues/index.html.erb +1 -1
  130. data/app/views/kaui/subscriptions/_cancel_by_date_modal.html.erb +1 -4
  131. data/app/views/kaui/subscriptions/_edit_form.html.erb +1 -1
  132. data/app/views/kaui/subscriptions/_form.html.erb +1 -1
  133. data/app/views/kaui/subscriptions/_subscriptions_table.html.erb +3 -3
  134. data/app/views/kaui/subscriptions/edit_bcd.erb +1 -1
  135. data/app/views/kaui/tag_definitions/index.html.erb +2 -2
  136. data/app/views/kaui/tags/index.html.erb +1 -0
  137. data/config/initializers/bootstrap_datepicker_rails.rb +3 -0
  138. data/config/initializers/devise.rb +8 -6
  139. data/config/initializers/js_routes.rb +9 -0
  140. data/config/initializers/kilbill_client_init.rb +13 -0
  141. data/config/initializers/killbill_authenticatable.rb +71 -21
  142. data/config/initializers/killbill_registerable.rb +5 -3
  143. data/config/initializers/time_formats.rb +6 -4
  144. data/config/locales/en.yml +78 -1
  145. data/config/routes.rb +34 -32
  146. data/db/migrate/20130812155313_devise_create_kaui_users.rb +10 -8
  147. data/db/migrate/20150109214021_create_kaui_tenants.rb +10 -8
  148. data/db/migrate/20150112232813_create_kaui_allowed_users.rb +10 -8
  149. data/lib/generators/kaui/install/install_generator.rb +23 -20
  150. data/lib/generators/kaui/install/templates/config/initializers/kaui.rb +3 -1
  151. data/lib/kaui/engine.rb +17 -5
  152. data/lib/kaui/installer/installer.rb +27 -26
  153. data/lib/kaui/version.rb +3 -1
  154. data/lib/kaui.rb +28 -30
  155. data/lib/tasks/kaui_tasks.rake +1 -0
  156. metadata +136 -438
  157. data/app/assets/javascripts/application.js +0 -17
  158. data/app/assets/javascripts/kaui/bootstrap-tweaks.js +0 -172
  159. data/app/assets/stylesheets/bootstrap_and_overrides.css.less +0 -44
  160. data/app/assets/stylesheets/kaui/kaui.less +0 -21
  161. data/app/assets/stylesheets/kaui/timeline.less +0 -4
  162. data/config/initializers/asset.rb +0 -1
  163. data/config/initializers/kilbill-client-init.rb +0 -9
  164. data/db/schema.rb +0 -15
  165. data/test/dummy/README.rdoc +0 -261
  166. data/test/dummy/Rakefile +0 -7
  167. data/test/dummy/app/controllers/application_controller.rb +0 -9
  168. data/test/dummy/app/helpers/application_helper.rb +0 -2
  169. data/test/dummy/bin/bundle +0 -3
  170. data/test/dummy/bin/rails +0 -4
  171. data/test/dummy/bin/rake +0 -4
  172. data/test/dummy/bin/setup +0 -38
  173. data/test/dummy/bin/update +0 -29
  174. data/test/dummy/bin/yarn +0 -11
  175. data/test/dummy/config/application.rb +0 -18
  176. data/test/dummy/config/boot.rb +0 -3
  177. data/test/dummy/config/database.yml +0 -27
  178. data/test/dummy/config/environment.rb +0 -5
  179. data/test/dummy/config/environments/development.rb +0 -58
  180. data/test/dummy/config/environments/production.rb +0 -91
  181. data/test/dummy/config/environments/test.rb +0 -49
  182. data/test/dummy/config/initializers/application_controller_renderer.rb +0 -6
  183. data/test/dummy/config/initializers/assets.rb +0 -14
  184. data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
  185. data/test/dummy/config/initializers/cookies_serializer.rb +0 -5
  186. data/test/dummy/config/initializers/filter_parameter_logging.rb +0 -4
  187. data/test/dummy/config/initializers/inflections.rb +0 -16
  188. data/test/dummy/config/initializers/killbill_client.rb +0 -1
  189. data/test/dummy/config/initializers/mime_types.rb +0 -4
  190. data/test/dummy/config/initializers/money.rb +0 -2
  191. data/test/dummy/config/initializers/new_framework_defaults_5_1.rb +0 -14
  192. data/test/dummy/config/initializers/secret_token.rb +0 -7
  193. data/test/dummy/config/initializers/session_store.rb +0 -8
  194. data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
  195. data/test/dummy/config/locales/en.yml +0 -33
  196. data/test/dummy/config/routes.rb +0 -3
  197. data/test/dummy/config/secrets.yml +0 -32
  198. data/test/dummy/config/symmetric-encryption.yml +0 -135
  199. data/test/dummy/config.ru +0 -4
  200. data/test/dummy/db/schema.rb +0 -52
  201. data/test/dummy/public/404.html +0 -26
  202. data/test/dummy/public/422.html +0 -26
  203. data/test/dummy/public/500.html +0 -25
  204. data/test/dummy/public/favicon.ico +0 -0
  205. data/test/dummy/script/rails +0 -6
  206. data/test/fixtures/SpyCarAdvanced.xml +0 -824
  207. data/test/fixtures/catalog-v1.xml +0 -73
  208. data/test/fixtures/catalog_translation_fr-v1.properties +0 -1
  209. data/test/fixtures/invoice_template-v1.html +0 -100
  210. data/test/fixtures/invoice_translation_fr-v1.properties +0 -23
  211. data/test/fixtures/overdue-v1.xml +0 -49
  212. data/test/fixtures/stripe.yml +0 -2
  213. data/test/functional/kaui/account_children_controller_test.rb +0 -32
  214. data/test/functional/kaui/account_custom_fields_controller_test.rb +0 -29
  215. data/test/functional/kaui/account_emails_controller_test.rb +0 -55
  216. data/test/functional/kaui/account_tags_controller_test.rb +0 -48
  217. data/test/functional/kaui/account_timelines_controller_test.rb +0 -20
  218. data/test/functional/kaui/accounts_controller_test.rb +0 -297
  219. data/test/functional/kaui/admin_allowed_users_controller_test.rb +0 -234
  220. data/test/functional/kaui/admin_controller_test.rb +0 -45
  221. data/test/functional/kaui/admin_tenants_controller_test.rb +0 -352
  222. data/test/functional/kaui/audit_logs_controller_test.rb +0 -71
  223. data/test/functional/kaui/bundle_tags_controller_test.rb +0 -23
  224. data/test/functional/kaui/bundles_controller_test.rb +0 -130
  225. data/test/functional/kaui/chargebacks_controller_test.rb +0 -42
  226. data/test/functional/kaui/charges_controller_test.rb +0 -60
  227. data/test/functional/kaui/credits_controller_test.rb +0 -54
  228. data/test/functional/kaui/custom_fields_controller_test.rb +0 -52
  229. data/test/functional/kaui/functional_test_helper.rb +0 -13
  230. data/test/functional/kaui/functional_test_helper_nosetup.rb +0 -120
  231. data/test/functional/kaui/home_controller_test.rb +0 -407
  232. data/test/functional/kaui/invoice_items_controller_test.rb +0 -82
  233. data/test/functional/kaui/invoices_controller_test.rb +0 -88
  234. data/test/functional/kaui/login_proxy_controller_test.rb +0 -12
  235. data/test/functional/kaui/payment_methods_controller_test.rb +0 -52
  236. data/test/functional/kaui/payments_controller_test.rb +0 -59
  237. data/test/functional/kaui/queues_controller_test.rb +0 -17
  238. data/test/functional/kaui/refunds_controller_test.rb +0 -63
  239. data/test/functional/kaui/registrations_controller_test.rb +0 -49
  240. data/test/functional/kaui/role_definitions_controller_test.rb +0 -47
  241. data/test/functional/kaui/subscriptions_controller_test.rb +0 -194
  242. data/test/functional/kaui/tag_definitions_controller_test.rb +0 -29
  243. data/test/functional/kaui/tags_controller_test.rb +0 -21
  244. data/test/functional/kaui/tenants_controller_test.rb +0 -60
  245. data/test/functional/kaui/transactions_controller_test.rb +0 -90
  246. data/test/integration/kaui/date_helper_integration_test.rb +0 -16
  247. data/test/integration/kaui/integration_test_helper.rb +0 -32
  248. data/test/integration/kaui/navigation_test.rb +0 -43
  249. data/test/killbill_test_helper.rb +0 -219
  250. data/test/test_helper.rb +0 -22
  251. data/test/unit/helpers/kaui/admin_allowed_users_helper_test.rb +0 -6
  252. data/test/unit/helpers/kaui/admin_tenants_helper_test.rb +0 -6
  253. data/test/unit/helpers/kaui/payment_method_helper_test.rb +0 -17
  254. data/test/unit/helpers/kaui/tenants_helper_test.rb +0 -6
  255. data/test/unit/helpers/kaui/uuid_helper_test.rb +0 -16
  256. data/test/unit/kaui/account_email_test.rb +0 -19
  257. data/test/unit/kaui/account_test.rb +0 -14
  258. data/test/unit/kaui/admin_tenant_test.rb +0 -132
  259. data/test/unit/kaui/allowed_user_test.rb +0 -34
  260. data/test/unit/kaui/base_test.rb +0 -23
  261. data/test/unit/kaui/date_helper_test.rb +0 -26
  262. data/test/unit/kaui/invoice_item_test.rb +0 -11
  263. data/test/unit/kaui/invoice_payment_test.rb +0 -42
  264. data/test/unit/kaui/invoice_test.rb +0 -20
  265. data/test/unit/kaui/money_helper_test.rb +0 -16
  266. data/test/unit/kaui/payment_test.rb +0 -42
  267. data/test/unit/kaui/tag_definition_test.rb +0 -11
  268. data/test/unit/kaui/tenant_test.rb +0 -19
  269. /data/app/assets/stylesheets/{application.css → kaui_application.css} +0 -0
@@ -1,233 +1,244 @@
1
- class Kaui::SubscriptionsController < Kaui::EngineController
1
+ # frozen_string_literal: true
2
2
 
3
- def new
4
- @base_product_name = params[:base_product_name]
5
- @subscription = Kaui::Subscription.new(:bundle_id => params[:bundle_id],
6
- :account_id => params[:account_id],
7
- :product_category => params[:product_category] || 'BASE')
3
+ module Kaui
4
+ class SubscriptionsController < Kaui::EngineController
5
+ def new
6
+ @base_product_name = params[:base_product_name]
7
+ @subscription = Kaui::Subscription.new(bundle_id: params[:bundle_id],
8
+ account_id: params[:account_id],
9
+ product_category: params[:product_category] || 'BASE')
8
10
 
9
- @bundle, plans_details = lookup_bundle_and_plan_details(@subscription, @base_product_name)
10
- @plans = plans_details.map { |p| p.plan }
11
+ @bundle, plans_details = lookup_bundle_and_plan_details(@subscription, @base_product_name)
12
+ @plans = plans_details.map(&:plan)
11
13
 
12
- if @plans.empty?
13
- if @subscription.product_category == 'BASE'
14
- flash[:error] = 'No plan available in the catalog'
15
- else
16
- flash[:error] = "No add-on available in the catalog for product #{@base_product_name}"
17
- end
18
- redirect_to kaui_engine.account_bundles_path(@subscription.account_id), :error => 'No available plan'
14
+ return unless @plans.empty?
15
+
16
+ flash[:error] = if @subscription.product_category == 'BASE'
17
+ 'No plan available in the catalog'
18
+ else
19
+ "No add-on available in the catalog for product #{@base_product_name}"
20
+ end
21
+ redirect_to kaui_engine.account_bundles_path(@subscription.account_id), error: 'No available plan'
19
22
  end
20
- end
21
23
 
22
- def create
23
- plan_name = params.require(:plan_name)
24
- @base_product_name = params[:base_product_name]
25
- @subscription = Kaui::Subscription.new(params.require(:subscription).delete_if { |key, value| value.blank? })
24
+ def create
25
+ plan_name = params.require(:plan_name)
26
+ @base_product_name = params[:base_product_name]
27
+ @subscription = Kaui::Subscription.new(params.require(:subscription).delete_if { |_key, value| value.blank? })
26
28
 
27
- begin
28
- @bundle, plans_details = lookup_bundle_and_plan_details(@subscription, @base_product_name)
29
+ begin
30
+ @bundle, plans_details = lookup_bundle_and_plan_details(@subscription, @base_product_name)
29
31
 
30
- plan_details = plans_details.find { |p| p.plan == plan_name }
31
- raise "Unable to find plan #{plan_name}" if plan_details.nil?
32
+ plan_details = plans_details.find { |p| p.plan == plan_name }
33
+ raise "Unable to find plan #{plan_name}" if plan_details.nil?
32
34
 
33
- @subscription.plan_name = plan_name
34
- requested_date = params[:type_change] == "DATE" ? params[:requested_date].presence : nil
35
+ @subscription.plan_name = plan_name
36
+ requested_date = params[:type_change] == 'DATE' ? params[:requested_date].presence : nil
35
37
 
36
- # price override?
37
- override_fixed_price = plan_details.phases.first.prices.blank? rescue false
38
- override_recurring_price = !override_fixed_price
39
- phase_type = @bundle.nil? ? plan_details.phases.first.type : @bundle.subscriptions.first.phase_type
40
- overrides = price_overrides(phase_type, override_fixed_price, override_recurring_price)
41
- @subscription.price_overrides = overrides unless overrides.blank?
42
-
43
- # un-set product_category since is not needed if plan name exist
44
- @subscription.product_category = nil
45
- @subscription = @subscription.create(current_user.kb_username, params[:reason], params[:comment], requested_date, false, options_for_klient)
46
- redirect_to kaui_engine.account_bundles_path(@subscription.account_id), :notice => 'Subscription was successfully created'
47
- rescue => e
48
- @plans = plans_details.nil? ? [] : plans_details.map { |p| p.plan }
49
-
50
- if e.is_a?(::KillBillClient::API::BadRequest) && !e.response.nil? && !e.response.body.nil?
51
- error_message = JSON.parse(e.response.body) rescue nil
52
- if !error_message.nil? & !error_message['code'].nil? && error_message['code'] == 2010 # CAT_NO_PRICE_FOR_CURRENCY
53
- # Hack for lack of proper Kill Bill messaging (https://github.com/killbill/killbill-admin-ui/issues/266)
54
- flash.now[:error] = "Unable to create the subscription: a price for this currency hasn't been specified in the catalog"
55
- render :new and return
38
+ # price override?
39
+ override_fixed_price = begin
40
+ plan_details.phases.first.prices.blank?
41
+ rescue StandardError
42
+ false
43
+ end
44
+ override_recurring_price = !override_fixed_price
45
+ phase_type = @bundle.nil? ? plan_details.phases.first.type : @bundle.subscriptions.first.phase_type
46
+ overrides = price_overrides(phase_type, override_fixed_price, override_recurring_price)
47
+ @subscription.price_overrides = overrides unless overrides.blank?
48
+
49
+ # un-set product_category since is not needed if plan name exist
50
+ @subscription.product_category = nil
51
+ @subscription = @subscription.create(current_user.kb_username, params[:reason], params[:comment], requested_date, false, options_for_klient)
52
+ redirect_to kaui_engine.account_bundles_path(@subscription.account_id), notice: 'Subscription was successfully created'
53
+ rescue StandardError => e
54
+ @plans = plans_details.nil? ? [] : plans_details.map(&:plan)
55
+
56
+ if e.is_a?(::KillBillClient::API::BadRequest) && !e.response.nil? && !e.response.body.nil?
57
+ error_message = begin
58
+ JSON.parse(e.response.body)
59
+ rescue StandardError
60
+ nil
61
+ end
62
+ if (!error_message.nil? & !error_message['code'].nil?) && error_message['code'] == 2010 # CAT_NO_PRICE_FOR_CURRENCY
63
+ # Hack for lack of proper Kill Bill messaging (https://github.com/killbill/killbill-admin-ui/issues/266)
64
+ flash.now[:error] = "Unable to create the subscription: a price for this currency hasn't been specified in the catalog"
65
+ render :new and return
66
+ end
56
67
  end
57
- end
58
68
 
59
- flash.now[:error] = "Error while creating the subscription: #{as_string(e)}"
60
- render :new
69
+ flash.now[:error] = "Error while creating the subscription: #{as_string(e)}"
70
+ render :new
71
+ end
61
72
  end
62
- end
63
73
 
64
- def edit
65
- @subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
66
- _, plans_details = lookup_bundle_and_plan_details(@subscription)
67
- # Use a Set to deal with multiple pricelists
68
- @plans = Set.new.merge(plans_details.map { |p| p.plan })
69
- end
70
-
71
- def update
72
- plan_name = params.require(:plan_name)
73
-
74
- requested_date = params[:type_change] == "DATE" ? params[:requested_date].presence : nil
75
- billing_policy = params[:type_change] == "POLICY" ? params[:policy].presence : nil
76
-
77
- wait_for_completion = params[:wait_for_completion] == '1'
78
-
79
- subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
80
-
81
- input = { :planName => plan_name }
74
+ def edit
75
+ @subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
76
+ _, plans_details = lookup_bundle_and_plan_details(@subscription)
77
+ # Use a Set to deal with multiple pricelists
78
+ @plans = Set.new.merge(plans_details.map(&:plan))
79
+ end
82
80
 
83
- # price override?
84
- current_plan = subscription.prices.select { |price| price['phaseType'] == subscription.phase_type }
85
- override_fixed_price = current_plan.last['recurringPrice'].nil?
86
- override_recurring_price = !override_fixed_price
87
- overrides = price_overrides(subscription.phase_type, override_fixed_price, override_recurring_price)
88
- input[:priceOverrides] = overrides unless overrides.blank?
81
+ def update
82
+ plan_name = params.require(:plan_name)
89
83
 
90
- subscription.change_plan(input,
91
- current_user.kb_username,
92
- params[:reason],
93
- params[:comment],
94
- requested_date,
95
- billing_policy,
96
- nil,
97
- wait_for_completion,
98
- options_for_klient)
84
+ requested_date = params[:type_change] == 'DATE' ? params[:requested_date].presence : nil
85
+ billing_policy = params[:type_change] == 'POLICY' ? params[:policy].presence : nil
99
86
 
100
- redirect_to kaui_engine.account_bundles_path(subscription.account_id), :notice => 'Subscription plan successfully changed'
101
- rescue => e
102
- redirect_to edit_subscription_path(params.require(:id)), :flash => { :error => "Error while changing subscription: #{as_string(e)}" }
103
- end
87
+ wait_for_completion = params[:wait_for_completion] == '1'
104
88
 
105
- def destroy
106
- requested_date = params[:requested_date].presence
107
- billing_policy = params[:policy].presence
108
- # START_OF_TERM is *not* a valid entitlement_policy and so would default to IMMEDIATE
109
- entitlement_policy = billing_policy && billing_policy == 'START_OF_TERM' ? 'IMMEDIATE' : billing_policy
89
+ subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
110
90
 
111
- # true by default
112
- use_requested_date_for_billing = (params[:use_requested_date_for_billing] || '1') == '1'
91
+ input = { planName: plan_name }
113
92
 
114
- subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
93
+ # price override?
94
+ current_plan = subscription.prices.select { |price| price['phaseType'] == subscription.phase_type }
95
+ override_fixed_price = current_plan.last['recurringPrice'].nil?
96
+ override_recurring_price = !override_fixed_price
97
+ overrides = price_overrides(subscription.phase_type, override_fixed_price, override_recurring_price)
98
+ input[:priceOverrides] = overrides unless overrides.blank?
99
+
100
+ subscription.change_plan(input,
101
+ current_user.kb_username,
102
+ params[:reason],
103
+ params[:comment],
104
+ requested_date,
105
+ billing_policy,
106
+ nil,
107
+ wait_for_completion,
108
+ options_for_klient)
109
+
110
+ redirect_to kaui_engine.account_bundles_path(subscription.account_id), notice: 'Subscription plan successfully changed'
111
+ rescue StandardError => e
112
+ redirect_to edit_subscription_path(params.require(:id)), flash: { error: "Error while changing subscription: #{as_string(e)}" }
113
+ end
115
114
 
116
- subscription.cancel(current_user.kb_username, params[:reason], params[:comment], requested_date, entitlement_policy, billing_policy, use_requested_date_for_billing, options_for_klient)
115
+ def destroy
116
+ requested_date = params[:requested_date].presence
117
+ billing_policy = params[:policy].presence
118
+ # START_OF_TERM is *not* a valid entitlement_policy and so would default to IMMEDIATE
119
+ entitlement_policy = billing_policy && billing_policy == 'START_OF_TERM' ? 'IMMEDIATE' : billing_policy
120
+
121
+ # true by default except default policy
122
+ use_requested_date_for_billing = if requested_date
123
+ (params[:use_requested_date_for_billing] || '1') == '1'
124
+ else
125
+ nil
126
+ end
127
+ subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
128
+ subscription.cancel(current_user.kb_username, params[:reason], params[:comment], requested_date, entitlement_policy, billing_policy, use_requested_date_for_billing, options_for_klient)
129
+ redirect_to kaui_engine.account_bundles_path(subscription.account_id), notice: 'Subscription was successfully cancelled'
130
+ end
117
131
 
118
- redirect_to kaui_engine.account_bundles_path(subscription.account_id), :notice => 'Subscription was successfully cancelled'
119
- end
132
+ def reinstate
133
+ subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
120
134
 
121
- def reinstate
122
- subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
135
+ subscription.uncancel(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
123
136
 
124
- subscription.uncancel(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
137
+ redirect_to kaui_engine.account_bundles_path(subscription.account_id), notice: 'Subscription was successfully reinstated'
138
+ end
125
139
 
126
- redirect_to kaui_engine.account_bundles_path(subscription.account_id), :notice => 'Subscription was successfully reinstated'
127
- end
140
+ def edit_bcd
141
+ @subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
142
+ end
128
143
 
129
- def edit_bcd
130
- @subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
131
- end
144
+ def update_bcd
145
+ input_subscription = params.require(:subscription)
146
+ subscription = Kaui::Subscription.new
147
+ subscription.subscription_id = params.require(:id)
148
+ subscription.bill_cycle_day_local = input_subscription['bill_cycle_day_local']
132
149
 
133
- def update_bcd
134
- input_subscription = params.require(:subscription)
135
- subscription = Kaui::Subscription.new
136
- subscription.subscription_id = params.require(:id)
137
- subscription.bill_cycle_day_local = input_subscription["bill_cycle_day_local"]
150
+ effective_from_date = params['effective_from_date']
138
151
 
139
- effective_from_date = params["effective_from_date"]
152
+ subscription.update_bcd(current_user.kb_username, params[:reason], params[:comment], effective_from_date, nil, options_for_klient)
153
+ redirect_to kaui_engine.account_bundles_path(input_subscription['account_id']), notice: 'Subscription BCD was successfully changed'
154
+ end
140
155
 
141
- subscription.update_bcd(current_user.kb_username, params[:reason], params[:comment], effective_from_date, nil, options_for_klient)
142
- redirect_to kaui_engine.account_bundles_path(input_subscription["account_id"]), :notice => 'Subscription BCD was successfully changed'
143
- end
156
+ def show
157
+ restful_show
158
+ end
144
159
 
145
- def show
146
- restful_show
147
- end
160
+ def restful_show
161
+ subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
162
+ redirect_to kaui_engine.account_bundles_path(subscription.account_id)
163
+ end
148
164
 
149
- def restful_show
150
- subscription = Kaui::Subscription.find_by_id(params.require(:id), options_for_klient)
151
- redirect_to kaui_engine.account_bundles_path(subscription.account_id)
152
- end
165
+ def validate_bundle_external_key
166
+ json_response do
167
+ external_key = params.require(:external_key)
153
168
 
154
- def validate_bundle_external_key
155
- json_response do
156
- external_key = params.require(:external_key)
169
+ begin
170
+ bundle = Kaui::Bundle.find_by_external_key(external_key, false, options_for_klient)
171
+ rescue KillBillClient::API::NotFound
172
+ bundle = nil
173
+ end
157
174
 
158
- begin
159
- bundle = Kaui::Bundle.find_by_external_key(external_key, false, options_for_klient)
160
- rescue KillBillClient::API::NotFound
161
- bundle = nil
175
+ { is_found: !bundle.nil? }
162
176
  end
163
-
164
- { :is_found => !bundle.nil? }
165
177
  end
166
- end
167
178
 
179
+ def validate_external_key
180
+ json_response do
181
+ external_key = params.require(:external_key)
168
182
 
169
- def validate_external_key
170
- json_response do
171
- external_key = params.require(:external_key)
183
+ begin
184
+ subscription = Kaui::Subscription.find_by_external_key(external_key, options_for_klient)
185
+ rescue KillBillClient::API::NotFound
186
+ subscription = nil
187
+ end
172
188
 
173
- begin
174
- subscription = Kaui::Subscription.find_by_external_key(external_key, options_for_klient)
175
- rescue KillBillClient::API::NotFound
176
- subscription = nil
189
+ { is_found: !subscription.nil? }
177
190
  end
178
-
179
- { :is_found => !subscription.nil? }
180
191
  end
181
- end
182
192
 
183
- def update_tags
184
- subscription_id = params.require(:id)
185
- subscription = Kaui::Subscription.find_by_id(subscription_id, options_for_klient)
193
+ def update_tags
194
+ subscription_id = params.require(:id)
195
+ subscription = Kaui::Subscription.find_by_id(subscription_id, options_for_klient)
186
196
 
187
- tags = []
188
- params.each do |tag|
189
- tag_info = tag.split('_')
190
- next if tag_info.size != 2 or tag_info[0] != 'tag'
191
- tags << tag_info[1]
192
- end
197
+ tags = []
198
+ params.each do |tag|
199
+ tag_info = tag.split('_')
200
+ next if (tag_info.size != 2) || (tag_info[0] != 'tag')
193
201
 
194
- Kaui::Tag.set_for_subscription(subscription_id, tags, current_user.kb_username, params[:reason], params[:comment], options_for_klient)
195
- redirect_to kaui_engine.account_bundles_path(subscription.account_id), :notice => 'Subscription tags successfully set'
196
- end
202
+ tags << tag_info[1]
203
+ end
197
204
 
198
- private
205
+ Kaui::Tag.set_for_subscription(subscription_id, tags, current_user.kb_username, params[:reason], params[:comment], options_for_klient)
206
+ redirect_to kaui_engine.account_bundles_path(subscription.account_id), notice: 'Subscription tags successfully set'
207
+ end
199
208
 
200
- def lookup_bundle_and_plan_details(subscription, base_product_name = nil)
201
- if subscription.product_category == 'ADD_ON'
202
- bundle = Kaui::Bundle.find_by_id(@subscription.bundle_id, options_for_klient)
203
- if base_product_name.blank?
204
- bundle.subscriptions.each do |sub|
205
- if sub.product_category == 'BASE'
206
- base_product_name = sub.product_name
207
- break
209
+ private
210
+
211
+ def lookup_bundle_and_plan_details(subscription, base_product_name = nil)
212
+ if subscription.product_category == 'ADD_ON'
213
+ bundle = Kaui::Bundle.find_by_id(@subscription.bundle_id, options_for_klient)
214
+ if base_product_name.blank?
215
+ bundle.subscriptions.each do |sub|
216
+ if sub.product_category == 'BASE'
217
+ base_product_name = sub.product_name
218
+ break
219
+ end
208
220
  end
209
221
  end
222
+ plans_details = Kaui::Catalog.available_addons(base_product_name, subscription.account_id, options_for_klient)
223
+ else
224
+ bundle = nil
225
+ plans_details = catalog_plans(subscription.product_category == 'BASE' ? nil : subscription.product_category)
210
226
  end
211
- plans_details = Kaui::Catalog.available_addons(base_product_name, options_for_klient)
212
- else
213
- bundle = nil
214
- plans_details = catalog_plans(subscription.product_category == 'BASE' ? nil : subscription.product_category)
227
+ [bundle, plans_details]
215
228
  end
216
- [bundle, plans_details]
217
- end
218
229
 
219
- def catalog_plans(product_category = nil)
220
- if product_category == 'BASE'
221
- return Kaui::Catalog.available_base_plans(options_for_klient)
222
- else
230
+ def catalog_plans(product_category = nil)
231
+ return Kaui::Catalog.available_base_plans(@subscription.account_id, options_for_klient) if product_category == 'BASE'
232
+
223
233
  options = options_for_klient
224
234
 
225
- catalog = Kaui::Catalog.get_tenant_catalog_json(DateTime.now.to_s, options)
235
+ catalog = Kaui::Catalog.get_tenant_catalog_json(DateTime.now.to_s, @subscription.account_id, options)
226
236
  return [] if catalog.blank?
227
237
 
228
238
  plans = []
229
239
  catalog[catalog.size - 1].products.each do |product|
230
240
  next if product.type == 'ADD_ON' || (!product_category.nil? && product.type != product_category)
241
+
231
242
  product.plans.each do |plan|
232
243
  class << plan
233
244
  attr_accessor :plan
@@ -238,23 +249,22 @@ class Kaui::SubscriptionsController < Kaui::EngineController
238
249
  end
239
250
  end
240
251
 
241
- return plans
242
-
252
+ plans
243
253
  end
244
- end
245
254
 
246
- def price_overrides(phase_type, override_fixed_price = true, override_recurring_price = false)
247
- return nil if params[:price_override].blank?
255
+ def price_overrides(phase_type, override_fixed_price, override_recurring_price)
256
+ return nil if params[:price_override].blank? || params[:price_override].to_i.negative?
248
257
 
249
- price_override = params[:price_override]
250
- overrides = []
251
- override = KillBillClient::Model::PhasePriceAttributes.new
252
- override.phase_type = phase_type
253
- override.fixed_price = price_override if override_fixed_price
254
- override.recurring_price = price_override if override_recurring_price
258
+ price_override = params[:price_override]
259
+ overrides = []
260
+ override = KillBillClient::Model::PhasePriceAttributes.new
261
+ override.phase_type = phase_type
262
+ override.fixed_price = price_override if override_fixed_price
263
+ override.recurring_price = price_override if override_recurring_price
255
264
 
256
- overrides << override
265
+ overrides << override
257
266
 
258
- overrides
267
+ overrides
268
+ end
259
269
  end
260
270
  end
@@ -1,40 +1,41 @@
1
- class Kaui::TagDefinitionsController < Kaui::EngineController
1
+ # frozen_string_literal: true
2
2
 
3
- def index
4
- begin
3
+ module Kaui
4
+ class TagDefinitionsController < Kaui::EngineController
5
+ def index
5
6
  @tag_definitions = Kaui::TagDefinition.all('NONE', options_for_klient)
6
- rescue => e
7
+ rescue StandardError => e
7
8
  flash.now[:error] = "Error while retrieving tag definitions: #{as_string(e)}"
8
- @tag_definitions = []
9
+ @tag_definitions = []
9
10
  end
10
- end
11
11
 
12
- def new
13
- @tag_definition = Kaui::TagDefinition.new
14
- end
12
+ def new
13
+ @tag_definition = Kaui::TagDefinition.new
14
+ end
15
15
 
16
- def create
17
- params[:tag_definition][:applicable_object_types] = params[:tag_definition][:applicable_object_types].values unless params[:tag_definition][:applicable_object_types].blank?
18
- @tag_definition = Kaui::TagDefinition.new(params[:tag_definition])
16
+ def create
17
+ params[:tag_definition][:applicable_object_types] = params[:tag_definition][:applicable_object_types].values unless params[:tag_definition][:applicable_object_types].blank?
18
+ @tag_definition = Kaui::TagDefinition.new(params[:tag_definition])
19
19
 
20
- begin
21
- @tag_definition = @tag_definition.create(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
22
- redirect_to kaui_engine.tag_definitions_path, :notice => 'Tag definition successfully created'
23
- rescue => e
24
- flash.now[:error] = "Error while creating tag definition: #{as_string(e)}"
25
- render :action => :new
20
+ begin
21
+ @tag_definition = @tag_definition.create(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
22
+ redirect_to kaui_engine.tag_definitions_path, notice: 'Tag definition successfully created'
23
+ rescue StandardError => e
24
+ flash.now[:error] = "Error while creating tag definition: #{as_string(e)}"
25
+ render action: :new
26
+ end
26
27
  end
27
- end
28
28
 
29
- def destroy
30
- @tag_definition = Kaui::TagDefinition.find_by_id(params[:id], 'NONE', options_for_klient)
29
+ def destroy
30
+ @tag_definition = Kaui::TagDefinition.find_by_id(params[:id], 'NONE', options_for_klient)
31
31
 
32
- begin
33
- @tag_definition.delete(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
34
- redirect_to kaui_engine.tag_definitions_path, :notice => 'Tag definition successfully deleted'
35
- rescue => e
36
- flash.now[:error] = "Error while deleting tag definition: #{as_string(e)}"
37
- render :action => :index
32
+ begin
33
+ @tag_definition.delete(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
34
+ redirect_to kaui_engine.tag_definitions_path, notice: 'Tag definition successfully deleted'
35
+ rescue StandardError => e
36
+ flash.now[:error] = "Error while deleting tag definition: #{as_string(e)}"
37
+ render action: :index
38
+ end
38
39
  end
39
40
  end
40
41
  end
@@ -1,39 +1,42 @@
1
- class Kaui::TagsController < Kaui::EngineController
1
+ # frozen_string_literal: true
2
2
 
3
- def index
4
- @search_query = params[:q]
3
+ module Kaui
4
+ class TagsController < Kaui::EngineController
5
+ def index
6
+ @search_query = params[:q]
5
7
 
6
- @ordering = params[:ordering] || (@search_query.blank? ? 'desc' : 'asc')
7
- @offset = params[:offset] || 0
8
- @limit = params[:limit] || 50
8
+ @ordering = params[:ordering] || (@search_query.blank? ? 'desc' : 'asc')
9
+ @offset = params[:offset] || 0
10
+ @limit = params[:limit] || 50
9
11
 
10
- @max_nb_records = @search_query.blank? ? Kaui::Tag.list_or_search(nil, 0, 0, options_for_klient).pagination_max_nb_records : 0
11
- end
12
-
13
- def pagination
14
- searcher = lambda do |search_key, offset, limit|
15
- Kaui::Tag.list_or_search(search_key, offset, limit, options_for_klient)
12
+ @max_nb_records = @search_query.blank? ? Kaui::Tag.list_or_search(nil, 0, 0, options_for_klient).pagination_max_nb_records : 0
16
13
  end
17
14
 
18
- data_extractor = lambda do |tag, column|
19
- [
15
+ def pagination
16
+ searcher = lambda do |search_key, offset, limit|
17
+ Kaui::Tag.list_or_search(search_key, offset, limit, options_for_klient)
18
+ end
19
+
20
+ data_extractor = lambda do |tag, column|
21
+ [
20
22
  tag.tag_id,
21
23
  tag.object_id,
22
24
  tag.object_type,
23
25
  tag.tag_definition_name
24
- ][column]
25
- end
26
+ ][column]
27
+ end
26
28
 
27
- formatter = lambda do |tag|
28
- url_for_object = view_context.url_for_object(tag.object_id, tag.object_type)
29
- [
29
+ formatter = lambda do |tag|
30
+ url_for_object = view_context.url_for_object(tag.object_id, tag.object_type)
31
+ [
30
32
  tag.tag_id,
31
33
  url_for_object ? view_context.link_to(tag.object_id, url_for_object) : tag.object_id,
32
34
  tag.object_type,
33
35
  tag.tag_definition_name
34
- ]
35
- end
36
+ ]
37
+ end
36
38
 
37
- paginate searcher, data_extractor, formatter
39
+ paginate searcher, data_extractor, formatter
40
+ end
38
41
  end
39
42
  end