spree_core 4.0.0 → 4.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (764) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/spree/base_controller.rb +2 -2
  3. data/app/finders/concerns/spree/product_filterable.rb +9 -0
  4. data/app/finders/spree/addresses/find.rb +6 -0
  5. data/app/finders/spree/base_finder.rb +14 -0
  6. data/app/finders/spree/cms_pages/find.rb +41 -0
  7. data/app/finders/spree/countries/find.rb +11 -3
  8. data/app/finders/spree/credit_cards/find.rb +2 -2
  9. data/app/finders/spree/menus/find.rb +11 -0
  10. data/app/finders/spree/option_values/find_available.rb +28 -0
  11. data/app/finders/spree/orders/find_complete.rb +14 -2
  12. data/app/finders/spree/orders/find_current.rb +2 -14
  13. data/app/finders/spree/product_properties/find_available.rb +20 -0
  14. data/app/finders/spree/products/find.rb +155 -27
  15. data/app/finders/spree/stores/find_current.rb +24 -0
  16. data/app/finders/spree/taxons/find.rb +31 -8
  17. data/app/finders/spree/variants/option_types_finder.rb +21 -0
  18. data/app/finders/spree/variants/visible_finder.rb +22 -0
  19. data/app/helpers/spree/base_helper.rb +187 -31
  20. data/app/helpers/spree/currency_helper.rb +34 -0
  21. data/app/helpers/spree/locale_helper.rb +39 -0
  22. data/app/helpers/spree/products_helper.rb +112 -21
  23. data/app/jobs/spree/base_job.rb +4 -0
  24. data/app/jobs/spree/stock_locations/stock_items/create_job.rb +13 -0
  25. data/app/jobs/spree/variants/remove_from_incomplete_orders_job.rb +9 -0
  26. data/app/jobs/spree/variants/remove_line_item_job.rb +9 -0
  27. data/app/models/concerns/spree/calculated_adjustments.rb +1 -1
  28. data/app/models/concerns/spree/default_price.rb +3 -6
  29. data/app/models/concerns/spree/display_link.rb +30 -0
  30. data/app/models/concerns/spree/display_money.rb +8 -2
  31. data/app/models/concerns/spree/filter_param.rb +21 -0
  32. data/app/models/concerns/spree/image_methods.rb +36 -0
  33. data/app/models/concerns/spree/memoized_data.rb +24 -0
  34. data/app/models/concerns/spree/metadata.rb +23 -0
  35. data/app/models/concerns/spree/multi_store_resource.rb +24 -0
  36. data/app/models/concerns/spree/named_type.rb +1 -1
  37. data/app/models/concerns/spree/number_identifier.rb +18 -0
  38. data/app/models/concerns/spree/product_scopes.rb +135 -36
  39. data/app/models/concerns/spree/single_store_resource.rb +19 -0
  40. data/app/models/concerns/spree/translatable_resource.rb +25 -0
  41. data/app/models/concerns/spree/translatable_resource_scopes.rb +24 -0
  42. data/app/models/concerns/spree/translatable_resource_slug.rb +17 -0
  43. data/app/models/concerns/spree/unique_name.rb +10 -0
  44. data/app/models/concerns/spree/user_address.rb +19 -0
  45. data/app/models/concerns/spree/user_methods.rb +40 -12
  46. data/app/models/concerns/spree/user_payment_source.rb +1 -1
  47. data/app/models/concerns/spree/user_reporting.rb +35 -10
  48. data/app/models/concerns/spree/user_roles.rb +43 -0
  49. data/app/models/spree/ability.rb +58 -37
  50. data/app/models/spree/address.rb +56 -9
  51. data/app/models/spree/adjustment.rb +2 -0
  52. data/app/models/spree/asset/support/active_storage.rb +3 -2
  53. data/app/models/spree/asset.rb +4 -0
  54. data/app/models/spree/base.rb +38 -0
  55. data/app/models/spree/calculator/flat_rate.rb +1 -1
  56. data/app/models/spree/calculator/flexi_rate.rb +1 -1
  57. data/app/models/spree/calculator/price_sack.rb +1 -1
  58. data/app/models/spree/calculator/shipping/digital_delivery.rb +22 -0
  59. data/app/models/spree/calculator/shipping/flat_rate.rb +1 -1
  60. data/app/models/spree/calculator/shipping/flexi_rate.rb +1 -1
  61. data/app/models/spree/calculator/shipping/per_item.rb +1 -1
  62. data/app/models/spree/calculator/shipping/price_sack.rb +1 -1
  63. data/app/models/spree/calculator.rb +2 -2
  64. data/app/models/spree/classification.rb +3 -0
  65. data/app/models/spree/cms/pages/feature_page.rb +7 -0
  66. data/app/models/spree/cms/pages/homepage.rb +20 -0
  67. data/app/models/spree/cms/pages/standard_page.rb +4 -0
  68. data/app/models/spree/cms/sections/featured_article.rb +22 -0
  69. data/app/models/spree/cms/sections/hero_image.rb +38 -0
  70. data/app/models/spree/cms/sections/image_gallery.rb +103 -0
  71. data/app/models/spree/cms/sections/product_carousel.rb +14 -0
  72. data/app/models/spree/cms/sections/rich_text_content.rb +13 -0
  73. data/app/models/spree/cms/sections/side_by_side_images.rb +74 -0
  74. data/app/models/spree/cms_page.rb +70 -0
  75. data/app/models/spree/cms_section.rb +69 -0
  76. data/app/models/spree/cms_section_image.rb +15 -0
  77. data/app/models/spree/cms_section_image_one.rb +4 -0
  78. data/app/models/spree/cms_section_image_three.rb +4 -0
  79. data/app/models/spree/cms_section_image_two.rb +4 -0
  80. data/app/models/spree/country.rb +18 -8
  81. data/app/models/spree/credit_card.rb +33 -13
  82. data/app/models/spree/customer_return.rb +14 -3
  83. data/app/models/spree/data_feed/google.rb +15 -0
  84. data/app/models/spree/data_feed.rb +40 -0
  85. data/app/models/spree/digital.rb +19 -0
  86. data/app/models/spree/digital_link.rb +57 -0
  87. data/app/models/spree/fulfilment_changer.rb +58 -16
  88. data/app/models/spree/gateway/bogus.rb +11 -5
  89. data/app/models/spree/icon.rb +13 -0
  90. data/app/models/spree/image/configuration/active_storage.rb +17 -20
  91. data/app/models/spree/image.rb +33 -3
  92. data/app/models/spree/inventory_unit.rb +8 -10
  93. data/app/models/spree/legacy_user.rb +2 -2
  94. data/app/models/spree/line_item.rb +34 -14
  95. data/app/models/spree/linkable/homepage.rb +3 -0
  96. data/app/models/spree/linkable/uri.rb +3 -0
  97. data/app/models/spree/log_entry.rb +9 -1
  98. data/app/models/spree/menu.rb +66 -0
  99. data/app/models/spree/menu_item.rb +72 -0
  100. data/app/models/spree/option_type.rb +22 -4
  101. data/app/models/spree/option_value.rb +22 -0
  102. data/app/models/spree/option_value_variant.rb +1 -1
  103. data/app/models/spree/order/address_book.rb +11 -25
  104. data/app/models/spree/order/checkout.rb +7 -1
  105. data/app/models/spree/order/currency_updater.rb +1 -1
  106. data/app/models/spree/order/digital.rb +33 -0
  107. data/app/models/spree/order/emails.rb +32 -0
  108. data/app/models/spree/order/payments.rb +11 -3
  109. data/app/models/spree/order/store_credit.rb +3 -1
  110. data/app/models/spree/order.rb +126 -61
  111. data/app/models/spree/order_inventory.rb +1 -1
  112. data/app/models/spree/order_merger.rb +1 -1
  113. data/app/models/spree/order_promotion.rb +1 -1
  114. data/app/models/spree/payment/processing.rb +4 -3
  115. data/app/models/spree/payment.rb +57 -9
  116. data/app/models/spree/payment_capture_event.rb +4 -0
  117. data/app/models/spree/payment_method/store_credit.rb +1 -1
  118. data/app/models/spree/payment_method.rb +29 -0
  119. data/app/models/spree/payment_source.rb +10 -0
  120. data/app/models/spree/preference.rb +6 -1
  121. data/app/models/spree/price.rb +30 -8
  122. data/app/models/spree/product.rb +197 -53
  123. data/app/models/spree/product_property.rb +31 -6
  124. data/app/models/spree/promotion/actions/create_item_adjustments.rb +1 -1
  125. data/app/models/spree/promotion/rules/country.rb +1 -1
  126. data/app/models/spree/promotion/rules/first_order.rb +4 -3
  127. data/app/models/spree/promotion/rules/option_value.rb +3 -3
  128. data/app/models/spree/promotion/rules/product.rb +3 -2
  129. data/app/models/spree/promotion/rules/taxon.rb +10 -7
  130. data/app/models/spree/promotion/rules/user.rb +2 -1
  131. data/app/models/spree/promotion.rb +18 -24
  132. data/app/models/spree/promotion_action.rb +1 -1
  133. data/app/models/spree/promotion_handler/cart.rb +7 -2
  134. data/app/models/spree/promotion_handler/coupon.rb +6 -6
  135. data/app/models/spree/promotion_handler/free_shipping.rb +5 -6
  136. data/app/models/spree/promotion_handler/page.rb +3 -2
  137. data/app/models/spree/promotion_handler/promotion_duplicator.rb +10 -3
  138. data/app/models/spree/promotion_rule.rb +3 -1
  139. data/app/models/spree/promotion_rule_user.rb +1 -1
  140. data/app/models/spree/property.rb +38 -1
  141. data/app/models/spree/prototype.rb +5 -0
  142. data/app/models/spree/refund.rb +12 -2
  143. data/app/models/spree/reimbursement.rb +9 -2
  144. data/app/models/spree/reimbursement_type/reimbursement_helpers.rb +2 -1
  145. data/app/models/spree/return_authorization.rb +7 -2
  146. data/app/models/spree/return_item/eligibility_validator/base_validator.rb +1 -1
  147. data/app/models/spree/return_item/eligibility_validator/default.rb +0 -2
  148. data/app/models/spree/return_item.rb +5 -1
  149. data/app/models/spree/role.rb +3 -3
  150. data/app/models/spree/role_user.rb +1 -1
  151. data/app/models/spree/shipment.rb +16 -37
  152. data/app/models/spree/shipment_handler.rb +4 -2
  153. data/app/models/spree/shipping_category.rb +4 -1
  154. data/app/models/spree/shipping_method.rb +9 -5
  155. data/app/models/spree/shipping_rate.rb +2 -11
  156. data/app/models/spree/state.rb +1 -1
  157. data/app/models/spree/state_change.rb +1 -1
  158. data/app/models/spree/stock/availability_validator.rb +9 -4
  159. data/app/models/spree/stock/content_item.rb +1 -1
  160. data/app/models/spree/stock/quantifier.rb +7 -7
  161. data/app/models/spree/stock/splitter/digital.rb +35 -0
  162. data/app/models/spree/stock_item.rb +8 -7
  163. data/app/models/spree/stock_location.rb +32 -13
  164. data/app/models/spree/stock_movement.rb +7 -0
  165. data/app/models/spree/stock_transfer.rb +6 -6
  166. data/app/models/spree/store.rb +229 -10
  167. data/app/models/spree/store_credit.rb +18 -7
  168. data/app/models/spree/store_credit_category.rb +2 -0
  169. data/app/models/spree/store_credit_event.rb +4 -9
  170. data/app/models/spree/store_credit_type.rb +2 -0
  171. data/app/models/spree/store_favicon_image.rb +17 -0
  172. data/app/models/spree/store_logo.rb +9 -0
  173. data/app/models/spree/store_mailer_logo.rb +13 -0
  174. data/app/models/spree/store_payment_method.rb +11 -0
  175. data/app/models/spree/store_product.rb +11 -0
  176. data/app/models/spree/store_promotion.rb +11 -0
  177. data/app/models/spree/tax_category.rb +9 -1
  178. data/app/models/spree/tax_rate.rb +9 -2
  179. data/app/models/spree/taxon.rb +67 -13
  180. data/app/models/spree/taxon_image/configuration/active_storage.rb +8 -12
  181. data/app/models/spree/taxon_image.rb +4 -2
  182. data/app/models/spree/taxonomy.rb +18 -2
  183. data/app/models/spree/variant.rb +114 -51
  184. data/app/models/spree/wished_item.rb +33 -0
  185. data/app/models/spree/wishlist.rb +38 -0
  186. data/app/models/spree/zone.rb +33 -12
  187. data/app/paginators/spree/shared/paginate.rb +8 -1
  188. data/app/presenters/spree/filters/options_presenter.rb +47 -0
  189. data/app/presenters/spree/filters/price_presenter.rb +22 -0
  190. data/app/presenters/spree/filters/price_range_presenter.rb +29 -0
  191. data/app/presenters/spree/filters/properties_presenter.rb +23 -0
  192. data/app/presenters/spree/filters/property_presenter.rb +42 -0
  193. data/app/presenters/spree/filters/quantified_price_range_presenter.rb +44 -0
  194. data/app/presenters/spree/product_summary_presenter.rb +26 -0
  195. data/app/presenters/spree/variant_presenter.rb +80 -0
  196. data/app/presenters/spree/variants/option_types_presenter.rb +87 -0
  197. data/app/presenters/spree/variants/options_presenter.rb +49 -0
  198. data/app/services/spree/account/addresses/create.rb +8 -0
  199. data/app/services/spree/account/addresses/update.rb +8 -0
  200. data/app/services/spree/account/create.rb +17 -0
  201. data/app/services/spree/account/update.rb +15 -0
  202. data/app/services/spree/addresses/create.rb +24 -0
  203. data/app/services/spree/addresses/helper.rb +41 -0
  204. data/app/services/spree/addresses/update.rb +32 -0
  205. data/app/services/spree/cart/add_item.rb +4 -2
  206. data/app/services/spree/cart/associate.rb +16 -0
  207. data/app/services/spree/cart/change_currency.rb +27 -0
  208. data/app/services/spree/cart/create.rb +9 -5
  209. data/app/services/spree/cart/destroy.rb +40 -0
  210. data/app/services/spree/cart/empty.rb +36 -0
  211. data/app/services/spree/cart/estimate_shipping_rates.rb +3 -3
  212. data/app/services/spree/cart/remove_line_item.rb +1 -0
  213. data/app/services/spree/cart/update.rb +2 -2
  214. data/app/services/spree/checkout/add_store_credit.rb +5 -2
  215. data/app/services/spree/checkout/get_shipping_rates.rb +7 -10
  216. data/app/services/spree/checkout/select_shipping_method.rb +49 -0
  217. data/app/services/spree/checkout/update.rb +11 -7
  218. data/app/services/spree/classifications/reposition.rb +18 -0
  219. data/app/services/spree/compare_line_items.rb +4 -2
  220. data/app/services/spree/credit_cards/destroy.rb +41 -0
  221. data/app/services/spree/data_feeds/google/optional_attributes.rb +23 -0
  222. data/app/services/spree/data_feeds/google/optional_sub_attributes.rb +21 -0
  223. data/app/services/spree/data_feeds/google/products_list.rb +14 -0
  224. data/app/services/spree/data_feeds/google/required_attributes.rb +67 -0
  225. data/app/services/spree/data_feeds/google/rss.rb +107 -0
  226. data/app/services/spree/line_items/create.rb +20 -0
  227. data/app/services/spree/line_items/destroy.rb +18 -0
  228. data/app/services/spree/line_items/helper.rb +11 -0
  229. data/app/services/spree/line_items/update.rb +17 -0
  230. data/app/services/spree/orders/approve.rb +18 -0
  231. data/app/services/spree/orders/cancel.rb +18 -0
  232. data/app/services/spree/payments/create.rb +66 -0
  233. data/app/services/spree/seeds/all.rb +26 -0
  234. data/app/services/spree/seeds/countries.rb +50 -0
  235. data/app/services/spree/seeds/default_reimbursement_types.rb +12 -0
  236. data/app/services/spree/seeds/roles.rb +11 -0
  237. data/app/services/spree/seeds/shipping_categories.rb +12 -0
  238. data/app/services/spree/seeds/states.rb +72 -0
  239. data/app/services/spree/seeds/stock_locations.rb +18 -0
  240. data/app/services/spree/seeds/store_credit_categories.rb +14 -0
  241. data/app/services/spree/seeds/stores.rb +31 -0
  242. data/app/services/spree/seeds/zones.rb +39 -0
  243. data/app/services/spree/shipments/add_item.rb +32 -0
  244. data/app/services/spree/shipments/change_state.rb +14 -0
  245. data/app/services/spree/shipments/create.rb +48 -0
  246. data/app/services/spree/shipments/helper.rb +23 -0
  247. data/app/services/spree/shipments/remove_item.rb +55 -0
  248. data/app/services/spree/shipments/update.rb +40 -0
  249. data/app/services/spree/stock_locations/stock_items/create.rb +31 -0
  250. data/app/services/spree/variants/remove_line_items.rb +15 -0
  251. data/app/services/spree/wallet/create_payment_source.rb +26 -0
  252. data/app/sorters/spree/base_sorter.rb +47 -0
  253. data/app/sorters/spree/orders/sort.rb +1 -37
  254. data/app/sorters/spree/products/sort.rb +47 -31
  255. data/app/validators/db_maximum_length_validator.rb +5 -0
  256. data/app/validators/email_validator.rb +4 -2
  257. data/app/validators/spree/url_validator.rb +23 -0
  258. data/brakeman.ignore +328 -0
  259. data/config/initializers/active_storage.rb +1 -5
  260. data/config/initializers/friendly_id.rb +2 -0
  261. data/config/initializers/inflections.rb +3 -0
  262. data/config/initializers/mobility.rb +18 -0
  263. data/config/initializers/rails61_fixes.rb +3 -0
  264. data/config/locales/en.yml +320 -71
  265. data/config/routes.rb +41 -2
  266. data/db/migrate/20210914000000_spree_four_three.rb +1205 -0
  267. data/db/migrate/20210915064321_add_metadata_to_spree_orders.rb +13 -0
  268. data/db/migrate/20210915064322_add_metadata_to_spree_products.rb +13 -0
  269. data/db/migrate/20210915064323_add_metadata_to_spree_variants.rb +13 -0
  270. data/db/migrate/20210915064324_add_metadata_to_spree_line_items.rb +13 -0
  271. data/db/migrate/20210915064325_add_metadata_to_spree_shipments.rb +13 -0
  272. data/db/migrate/20210915064326_add_metadata_to_spree_payments.rb +13 -0
  273. data/db/migrate/20210915064327_add_metadata_to_spree_taxons_and_taxonomies.rb +18 -0
  274. data/db/migrate/20210915064328_add_metadata_to_spree_stock_transfers.rb +13 -0
  275. data/db/migrate/20210915064329_add_metadata_to_spree_multiple_tables.rb +30 -0
  276. data/db/migrate/20210920090344_add_deleted_at_to_spree_stores.rb +8 -0
  277. data/db/migrate/20210921070812_rename_column_access_hash_to_token.rb +8 -0
  278. data/db/migrate/20210921070813_create_spree_wishlists.rb +18 -0
  279. data/db/migrate/20210921070814_create_spree_wished_products.rb +16 -0
  280. data/db/migrate/20210921070815_rename_spree_wished_products_to_spree_wished_items.rb +5 -0
  281. data/db/migrate/20210921090344_add_unique_stock_item_stock_location_variant_deleted_at_index.rb +5 -0
  282. data/db/migrate/20210929090344_create_stock_item_stock_location_id_variant_id_coalesce_deleted_at_unique_index.rb +32 -0
  283. data/db/migrate/20210929091444_create_spree_digital_links.rb +13 -0
  284. data/db/migrate/20210929093238_create_spree_digitals.rb +9 -0
  285. data/db/migrate/20210930143043_rename_secret_to_token_on_spree_digital_links.rb +5 -0
  286. data/db/migrate/20210930155649_add_settings_to_spree_stores.rb +11 -0
  287. data/db/migrate/20211201202851_update_linkable_resource_types.rb +10 -0
  288. data/db/migrate/20211203082008_add_settings_to_payment_methods.rb +11 -0
  289. data/db/migrate/20211229162122_disable_propagate_all_variants_by_default.rb +5 -0
  290. data/db/migrate/20220103082046_add_status_and_make_active_at_to_spree_products.rb +7 -0
  291. data/db/migrate/20220106230929_add_internal_note_to_spree_orders.rb +5 -0
  292. data/db/migrate/20220113052823_create_payment_sources.rb +22 -0
  293. data/db/migrate/20220117100333_add_make_active_at_to_spree_products.rb +17 -0
  294. data/db/migrate/20220120092821_add_metadata_to_spree_tax_rates.rb +13 -0
  295. data/db/migrate/20220201103922_add_first_name_and_last_name_to_spree_users.rb +9 -0
  296. data/db/migrate/20220222083546_add_barcode_to_spree_variants.rb +6 -0
  297. data/db/migrate/20220329113557_fix_cms_pages_unique_indexes.rb +8 -0
  298. data/db/migrate/20220613133029_add_metadata_to_spree_stock_items.rb +13 -0
  299. data/db/migrate/20220706112554_create_product_name_and_description_translations_for_mobility_table_backend.rb +27 -0
  300. data/db/migrate/20220715083542_create_spree_product_translations_for_mobility.rb +7 -0
  301. data/db/migrate/20220715120222_change_product_name_null_to_true.rb +5 -0
  302. data/db/migrate/20220718100743_create_spree_taxon_name_and_description_translations_for_mobility_table_backend.rb +27 -0
  303. data/db/migrate/20220718100948_change_taxon_name_null_to_true.rb +5 -0
  304. data/db/migrate/20220802070609_add_locale_to_friendly_id_slugs.rb +11 -0
  305. data/db/migrate/20220802073225_create_spree_product_slug_translations_for_mobility_table_backend.rb +5 -0
  306. data/db/migrate/20220804073928_transfer_data_to_translatable_tables.rb +66 -0
  307. data/db/migrate/20221215151408_add_selected_locale_to_spree_users.rb +8 -0
  308. data/db/migrate/20221219123957_add_deleted_at_to_product_translations.rb +6 -0
  309. data/db/migrate/20221220133432_add_uniqueness_constraint_to_product_translations.rb +5 -0
  310. data/db/migrate/20221229132350_create_spree_data_feed_settings.rb +14 -0
  311. data/db/migrate/20230103144439_create_option_type_translations.rb +26 -0
  312. data/db/migrate/20230103151034_create_option_value_translations.rb +26 -0
  313. data/db/migrate/20230109084253_create_product_property_translations.rb +25 -0
  314. data/db/migrate/20230109094907_transfer_options_data_to_translatable_tables.rb +58 -0
  315. data/db/migrate/20230109105943_create_property_translations.rb +26 -0
  316. data/db/migrate/20230109110840_transfer_property_data_to_translatable_tables.rb +59 -0
  317. data/db/migrate/20230110142344_backfill_friendly_id_slug_locale.rb +15 -0
  318. data/db/migrate/20230111121534_add_additional_taxon_translation_fields.rb +8 -0
  319. data/db/migrate/20230111122511_transfer_product_and_taxon_data_to_translatable_tables.rb +82 -0
  320. data/db/migrate/20230117115531_create_taxonomy_translations.rb +24 -0
  321. data/db/migrate/20230117120430_allow_null_taxonomy_name.rb +5 -0
  322. data/db/migrate/20230117121303_transfer_taxonomy_data_to_translatable_tables.rb +11 -0
  323. data/db/migrate/20230210142732_create_store_translations.rb +50 -0
  324. data/db/migrate/20230210142849_transfer_store_data_to_translatable_tables.rb +11 -0
  325. data/db/migrate/20230210230434_add_deleted_at_to_store_translations.rb +6 -0
  326. data/db/migrate/20230415155958_rename_data_feed_settings_table.rb +5 -0
  327. data/db/migrate/20230415160828_rename_data_feed_table_columns.rb +7 -0
  328. data/db/migrate/20230415161226_add_indexes_to_data_feeds_table.rb +5 -0
  329. data/db/migrate/20230512094803_rename_data_feeds_column_provider_to_type.rb +5 -0
  330. data/db/migrate/20230514162157_add_index_on_locale_and_permalink_to_spree_taxons.rb +5 -0
  331. data/db/seeds.rb +1 -5
  332. data/lib/friendly_id/paranoia.rb +4 -0
  333. data/lib/generators/spree/dummy/dummy_generator.rb +25 -9
  334. data/lib/generators/spree/dummy/templates/package.json +12 -0
  335. data/lib/generators/spree/dummy/templates/rails/database.yml +20 -18
  336. data/lib/generators/spree/dummy/templates/rails/test.rb +4 -0
  337. data/lib/generators/spree/dummy_model/templates/model.rb.tt +1 -1
  338. data/lib/generators/spree/install/install_generator.rb +25 -26
  339. data/lib/generators/spree/install/templates/config/initializers/spree.rb +1 -0
  340. data/lib/spree/core/components.rb +8 -0
  341. data/lib/spree/core/configuration.rb +91 -0
  342. data/lib/spree/core/controller_helpers/auth.rb +14 -4
  343. data/lib/spree/core/controller_helpers/common.rb +22 -9
  344. data/lib/spree/core/controller_helpers/currency.rb +56 -0
  345. data/lib/spree/core/controller_helpers/locale.rb +84 -0
  346. data/lib/spree/core/controller_helpers/order.rb +28 -15
  347. data/lib/spree/core/controller_helpers/search.rb +3 -2
  348. data/lib/spree/core/controller_helpers/store.rb +32 -8
  349. data/lib/spree/core/dependencies.rb +106 -0
  350. data/lib/spree/core/dependencies_helper.rb +30 -0
  351. data/lib/spree/core/engine.rb +60 -40
  352. data/lib/spree/core/importer/order.rb +9 -9
  353. data/lib/spree/core/importer/product.rb +4 -2
  354. data/lib/spree/core/number_generator.rb +5 -6
  355. data/{app/models/spree → lib/spree/core}/preferences/configuration.rb +5 -2
  356. data/{app/models/spree → lib/spree/core}/preferences/preferable.rb +16 -1
  357. data/{app/models/spree → lib/spree/core}/preferences/preferable_class_methods.rb +12 -1
  358. data/{app/models/spree → lib/spree/core}/preferences/store.rb +2 -2
  359. data/lib/spree/core/product_duplicator.rb +2 -1
  360. data/lib/spree/core/product_filters.rb +10 -7
  361. data/lib/spree/core/search/base.rb +74 -38
  362. data/lib/spree/core/version.rb +3 -1
  363. data/lib/spree/core.rb +55 -17
  364. data/lib/spree/database_type_utilities.rb +12 -0
  365. data/lib/spree/i18n.rb +17 -19
  366. data/lib/spree/money.rb +11 -3
  367. data/lib/spree/permitted_attributes.rb +60 -18
  368. data/lib/spree/service_module.rb +8 -4
  369. data/lib/spree/testing_support/authorization_helpers.rb +15 -7
  370. data/lib/spree/testing_support/capybara_config.rb +14 -17
  371. data/lib/spree/testing_support/capybara_ext.rb +1 -51
  372. data/lib/spree/testing_support/common_rake.rb +39 -7
  373. data/lib/spree/testing_support/controller_requests.rb +10 -10
  374. data/lib/spree/testing_support/extension_rake.rb +2 -2
  375. data/lib/spree/testing_support/factories/address_factory.rb +1 -1
  376. data/lib/spree/testing_support/factories/asset_factory.rb +15 -0
  377. data/lib/spree/testing_support/factories/classification_factory.rb +8 -0
  378. data/lib/spree/testing_support/factories/cms_page_factory.rb +20 -0
  379. data/lib/spree/testing_support/factories/cms_section_factory.rb +31 -0
  380. data/lib/spree/testing_support/factories/customer_return_factory.rb +24 -17
  381. data/lib/spree/testing_support/factories/digital_factory.rb +10 -0
  382. data/lib/spree/testing_support/factories/digital_link_factory.rb +6 -0
  383. data/lib/spree/testing_support/factories/favicon_image_factory.rb +9 -0
  384. data/lib/spree/testing_support/factories/google_data_feed_factory.rb +8 -0
  385. data/lib/spree/testing_support/factories/icon_factory.rb +9 -0
  386. data/lib/spree/testing_support/factories/image_factory.rb +3 -1
  387. data/lib/spree/testing_support/factories/line_item_factory.rb +6 -2
  388. data/lib/spree/testing_support/factories/log_entry_factory.rb +6 -0
  389. data/lib/spree/testing_support/factories/menu_factory.rb +16 -0
  390. data/lib/spree/testing_support/factories/menu_item_factory.rb +10 -0
  391. data/lib/spree/testing_support/factories/options_factory.rb +15 -0
  392. data/lib/spree/testing_support/factories/order_factory.rb +17 -4
  393. data/lib/spree/testing_support/factories/payment_capture_event_factory.rb +6 -0
  394. data/lib/spree/testing_support/factories/payment_factory.rb +3 -3
  395. data/lib/spree/testing_support/factories/payment_method_factory.rb +21 -4
  396. data/lib/spree/testing_support/factories/product_factory.rb +29 -2
  397. data/lib/spree/testing_support/factories/product_property_factory.rb +2 -1
  398. data/lib/spree/testing_support/factories/product_translation_factory.rb +6 -0
  399. data/lib/spree/testing_support/factories/promotion_action_factory.rb +5 -0
  400. data/lib/spree/testing_support/factories/promotion_factory.rb +44 -23
  401. data/lib/spree/testing_support/factories/property_factory.rb +22 -0
  402. data/lib/spree/testing_support/factories/refund_factory.rb +1 -1
  403. data/lib/spree/testing_support/factories/reimbursement_credit_factory.rb +7 -0
  404. data/lib/spree/testing_support/factories/return_authorization_factory.rb +1 -1
  405. data/lib/spree/testing_support/factories/role_factory.rb +1 -1
  406. data/lib/spree/testing_support/factories/shipment_factory.rb +7 -9
  407. data/lib/spree/testing_support/factories/shipping_category_factory.rb +1 -1
  408. data/lib/spree/testing_support/factories/shipping_rate_factory.rb +7 -0
  409. data/lib/spree/testing_support/factories/state_change_factory.rb +8 -0
  410. data/lib/spree/testing_support/factories/stock_item_factory.rb +7 -0
  411. data/lib/spree/testing_support/factories/stock_location_factory.rb +6 -4
  412. data/lib/spree/testing_support/factories/stock_transfer_factory.rb +9 -0
  413. data/lib/spree/testing_support/factories/store_credit_factory.rb +1 -0
  414. data/lib/spree/testing_support/factories/store_credit_type_factory.rb +5 -0
  415. data/lib/spree/testing_support/factories/store_factory.rb +24 -5
  416. data/lib/spree/testing_support/factories/tax_rate_factory.rb +1 -0
  417. data/lib/spree/testing_support/factories/taxon_factory.rb +3 -1
  418. data/lib/spree/testing_support/factories/taxon_image_factory.rb +9 -0
  419. data/lib/spree/testing_support/factories/taxonomy_factory.rb +1 -0
  420. data/lib/spree/testing_support/factories/user_factory.rb +13 -2
  421. data/lib/spree/testing_support/factories/variant_factory.rb +10 -2
  422. data/lib/spree/testing_support/factories/wished_variant_factory.rb +6 -0
  423. data/lib/spree/testing_support/factories/wishlist_factory.rb +18 -0
  424. data/lib/spree/testing_support/factories/zone_factory.rb +16 -13
  425. data/lib/spree/testing_support/flatpickr_capybara.rb +124 -0
  426. data/lib/spree/testing_support/i18n.rb +1 -1
  427. data/lib/spree/testing_support/jobs.rb +9 -0
  428. data/lib/spree/testing_support/locale_helpers.rb +78 -0
  429. data/lib/spree/testing_support/metadata.rb +54 -0
  430. data/lib/spree/testing_support/next_instance_of.rb +38 -0
  431. data/lib/spree/testing_support/order_walkthrough.rb +16 -7
  432. data/lib/spree/testing_support/rspec_retry_config.rb +15 -0
  433. data/lib/spree/translation_migrations.rb +40 -0
  434. data/lib/spree_core.rb +2 -1
  435. data/lib/tasks/core.rake +17 -5
  436. data/spec/fixtures/favicon.ico +0 -0
  437. data/spec/fixtures/files/icon_256x256.gif +0 -0
  438. data/spec/fixtures/files/icon_256x256.png +0 -0
  439. data/spec/fixtures/files/icon_512x512.png +0 -0
  440. data/spec/fixtures/files/img_256x128.png +0 -0
  441. data/spree_core.gemspec +37 -26
  442. metadata +443 -426
  443. data/app/assets/images/logo/spree_50.png +0 -0
  444. data/app/assets/images/noimage/large.png +0 -0
  445. data/app/assets/images/noimage/mini.png +0 -0
  446. data/app/assets/images/noimage/product.png +0 -0
  447. data/app/assets/images/noimage/small.png +0 -0
  448. data/app/assets/javascripts/spree.js +0 -60
  449. data/app/mailers/spree/base_mailer.rb +0 -32
  450. data/app/mailers/spree/order_mailer.rb +0 -17
  451. data/app/mailers/spree/reimbursement_mailer.rb +0 -10
  452. data/app/mailers/spree/shipment_mailer.rb +0 -10
  453. data/app/mailers/spree/test_mailer.rb +0 -8
  454. data/app/models/friendly_id/slug_decorator.rb +0 -9
  455. data/app/models/spree/app_configuration.rb +0 -76
  456. data/app/models/spree/app_dependencies.rb +0 -74
  457. data/app/models/spree/validations/db_maximum_length_validator.rb +0 -22
  458. data/app/views/layouts/spree/base_mailer.html.erb +0 -41
  459. data/app/views/spree/order_mailer/_adjustment.html.erb +0 -8
  460. data/app/views/spree/order_mailer/_subtotal.html.erb +0 -8
  461. data/app/views/spree/order_mailer/_total.html.erb +0 -8
  462. data/app/views/spree/order_mailer/cancel_email.html.erb +0 -30
  463. data/app/views/spree/order_mailer/cancel_email.text.erb +0 -16
  464. data/app/views/spree/order_mailer/confirm_email.html.erb +0 -70
  465. data/app/views/spree/order_mailer/confirm_email.text.erb +0 -38
  466. data/app/views/spree/reimbursement_mailer/reimbursement_email.html.erb +0 -61
  467. data/app/views/spree/reimbursement_mailer/reimbursement_email.text.erb +0 -22
  468. data/app/views/spree/shared/_base_mailer_footer.html.erb +0 -20
  469. data/app/views/spree/shared/_base_mailer_header.html.erb +0 -33
  470. data/app/views/spree/shared/_base_mailer_stylesheets.html.erb +0 -777
  471. data/app/views/spree/shared/_error_messages.html.erb +0 -11
  472. data/app/views/spree/shared/_mailer_line_item.html.erb +0 -16
  473. data/app/views/spree/shared/_paths.html.erb +0 -8
  474. data/app/views/spree/shipment_mailer/shipped_email.html.erb +0 -41
  475. data/app/views/spree/shipment_mailer/shipped_email.text.erb +0 -16
  476. data/app/views/spree/test_mailer/test_email.html.erb +0 -40
  477. data/app/views/spree/test_mailer/test_email.text.erb +0 -4
  478. data/config/initializers/assets.rb +0 -1
  479. data/config/initializers/premailer_assets.rb +0 -1
  480. data/config/initializers/premailer_rails.rb +0 -3
  481. data/db/default/spree/countries.rb +0 -18
  482. data/db/default/spree/default_reimbursement_type.rb +0 -1
  483. data/db/default/spree/roles.rb +0 -2
  484. data/db/default/spree/states.rb +0 -12
  485. data/db/default/spree/stores.rb +0 -10
  486. data/db/default/spree/zones.rb +0 -26
  487. data/db/migrate/20120831092320_spree_one_two.rb +0 -481
  488. data/db/migrate/20120831092359_spree_promo_one_two.rb +0 -45
  489. data/db/migrate/20120905145253_add_tax_rate_label.rb +0 -5
  490. data/db/migrate/20120905151823_add_toggle_tax_rate_display.rb +0 -5
  491. data/db/migrate/20120929093553_remove_unused_preference_columns.rb +0 -8
  492. data/db/migrate/20121009142519_add_lock_version_to_variant.rb +0 -5
  493. data/db/migrate/20121010142909_add_states_required_to_countries.rb +0 -5
  494. data/db/migrate/20121012071449_add_on_demand_to_product_and_variant.rb +0 -6
  495. data/db/migrate/20121017010007_remove_not_null_constraint_from_products_on_hand.rb +0 -11
  496. data/db/migrate/20121031162139_split_prices_from_variants.rb +0 -31
  497. data/db/migrate/20121107003422_remove_not_null_from_spree_prices_amount.rb +0 -9
  498. data/db/migrate/20121107184631_add_currency_to_line_items.rb +0 -5
  499. data/db/migrate/20121107194006_add_currency_to_orders.rb +0 -5
  500. data/db/migrate/20121109173623_add_cost_currency_to_variants.rb +0 -5
  501. data/db/migrate/20121111231553_remove_display_on_from_payment_methods.rb +0 -5
  502. data/db/migrate/20121124203911_add_position_to_taxonomies.rb +0 -5
  503. data/db/migrate/20121126040517_add_last_ip_to_spree_orders.rb +0 -5
  504. data/db/migrate/20121213162028_add_state_to_spree_adjustments.rb +0 -6
  505. data/db/migrate/20130114053446_add_display_on_to_spree_payment_methods.rb +0 -9
  506. data/db/migrate/20130120201805_add_position_to_product_properties.spree.rb +0 -6
  507. data/db/migrate/20130203232234_add_identifier_to_spree_payments.rb +0 -5
  508. data/db/migrate/20130207155350_add_order_id_index_to_payments.rb +0 -9
  509. data/db/migrate/20130208032954_add_primary_to_spree_products_taxons.rb +0 -5
  510. data/db/migrate/20130211190146_create_spree_stock_items.rb +0 -14
  511. data/db/migrate/20130211191120_create_spree_stock_locations.rb +0 -11
  512. data/db/migrate/20130213191427_create_default_stock.rb +0 -33
  513. data/db/migrate/20130222032153_add_order_id_index_to_shipments.rb +0 -5
  514. data/db/migrate/20130226032817_change_meta_description_on_spree_products_to_text.rb +0 -5
  515. data/db/migrate/20130226191231_add_stock_location_id_to_spree_shipments.rb +0 -5
  516. data/db/migrate/20130227143905_add_pending_to_inventory_unit.rb +0 -6
  517. data/db/migrate/20130228164411_remove_on_demand_from_product_and_variant.rb +0 -6
  518. data/db/migrate/20130228210442_create_shipping_method_zone.rb +0 -21
  519. data/db/migrate/20130301162745_remove_shipping_category_id_from_shipping_method.rb +0 -5
  520. data/db/migrate/20130301162924_create_shipping_method_categories.rb +0 -13
  521. data/db/migrate/20130301205200_add_tracking_url_to_spree_shipping_methods.rb +0 -5
  522. data/db/migrate/20130304162240_create_spree_shipping_rates.rb +0 -24
  523. data/db/migrate/20130304192936_remove_category_match_attributes_from_shipping_method.rb +0 -7
  524. data/db/migrate/20130305143310_create_stock_movements.rb +0 -12
  525. data/db/migrate/20130306181701_add_address_fields_to_stock_location.rb +0 -22
  526. data/db/migrate/20130306191917_add_active_field_to_stock_locations.rb +0 -5
  527. data/db/migrate/20130306195650_add_backorderable_to_stock_item.rb +0 -5
  528. data/db/migrate/20130307161754_add_default_quantity_to_stock_movement.rb +0 -5
  529. data/db/migrate/20130318151756_add_source_and_destination_to_stock_movements.rb +0 -8
  530. data/db/migrate/20130319062004_change_orders_total_precision.rb +0 -8
  531. data/db/migrate/20130319063911_change_spree_payments_amount_precision.rb +0 -7
  532. data/db/migrate/20130319064308_change_spree_return_authorization_amount_precision.rb +0 -7
  533. data/db/migrate/20130319082943_change_adjustments_amount_precision.rb +0 -7
  534. data/db/migrate/20130319183250_add_originator_to_stock_movement.rb +0 -7
  535. data/db/migrate/20130319190507_drop_source_and_destination_from_stock_movement.rb +0 -15
  536. data/db/migrate/20130325163316_migrate_inventory_unit_sold_to_on_hand.rb +0 -9
  537. data/db/migrate/20130326175857_add_stock_location_to_rma.rb +0 -5
  538. data/db/migrate/20130328130308_update_shipment_state_for_canceled_orders.rb +0 -15
  539. data/db/migrate/20130328195253_add_seo_metas_to_taxons.rb +0 -9
  540. data/db/migrate/20130329134939_remove_stock_item_and_variant_lock.rb +0 -14
  541. data/db/migrate/20130413230529_add_name_to_spree_credit_cards.rb +0 -5
  542. data/db/migrate/20130414000512_update_name_fields_on_spree_credit_cards.rb +0 -13
  543. data/db/migrate/20130417120034_add_index_to_source_columns_on_adjustments.rb +0 -5
  544. data/db/migrate/20130417120035_update_adjustment_states.rb +0 -16
  545. data/db/migrate/20130417123427_add_shipping_rates_to_shipments.rb +0 -15
  546. data/db/migrate/20130418125341_create_spree_stock_transfers.rb +0 -14
  547. data/db/migrate/20130423110707_drop_products_count_on_hand.rb +0 -5
  548. data/db/migrate/20130423223847_set_default_shipping_rate_cost.rb +0 -5
  549. data/db/migrate/20130509115210_add_number_to_stock_transfer.rb +0 -23
  550. data/db/migrate/20130514151929_add_sku_index_to_spree_variants.rb +0 -5
  551. data/db/migrate/20130515180736_add_backorderable_default_to_spree_stock_location.rb +0 -5
  552. data/db/migrate/20130516151222_add_propage_all_variants_to_spree_stock_location.rb +0 -5
  553. data/db/migrate/20130611054351_rename_shipping_methods_zones_to_spree_shipping_methods_zones.rb +0 -5
  554. data/db/migrate/20130611185927_add_user_id_index_to_spree_orders.rb +0 -5
  555. data/db/migrate/20130618041418_add_updated_at_to_spree_countries.rb +0 -9
  556. data/db/migrate/20130619012236_add_updated_at_to_spree_states.rb +0 -9
  557. data/db/migrate/20130626232741_add_cvv_result_code_and_cvv_result_message_to_spree_payments.rb +0 -6
  558. data/db/migrate/20130628021056_add_unique_index_to_permalink_on_spree_products.rb +0 -5
  559. data/db/migrate/20130628022817_add_unique_index_to_orders_shipments_and_stock_transfers.rb +0 -7
  560. data/db/migrate/20130708052307_add_deleted_at_to_spree_tax_rates.rb +0 -5
  561. data/db/migrate/20130711200933_remove_lock_version_from_inventory_units.rb +0 -6
  562. data/db/migrate/20130718042445_add_cost_price_to_line_item.rb +0 -5
  563. data/db/migrate/20130718233855_set_backorderable_to_default_to_false.rb +0 -6
  564. data/db/migrate/20130725031716_add_created_by_id_to_spree_orders.rb +0 -5
  565. data/db/migrate/20130729214043_index_completed_at_on_spree_orders.rb +0 -5
  566. data/db/migrate/20130802014537_add_tax_category_id_to_spree_line_items.rb +0 -5
  567. data/db/migrate/20130802022321_migrate_tax_categories_to_line_items.rb +0 -10
  568. data/db/migrate/20130806022521_drop_spree_mail_methods.rb +0 -12
  569. data/db/migrate/20130806145853_set_default_stock_location_on_shipments.rb +0 -8
  570. data/db/migrate/20130807024301_upgrade_adjustments.rb +0 -46
  571. data/db/migrate/20130807024302_rename_adjustment_fields.rb +0 -20
  572. data/db/migrate/20130809164245_add_admin_name_column_to_spree_shipping_methods.rb +0 -5
  573. data/db/migrate/20130809164330_add_admin_name_column_to_spree_stock_locations.rb +0 -5
  574. data/db/migrate/20130813004002_add_shipment_total_to_spree_orders.rb +0 -5
  575. data/db/migrate/20130813140619_expand_order_number_size.rb +0 -9
  576. data/db/migrate/20130813232134_rename_activators_to_promotions.rb +0 -5
  577. data/db/migrate/20130815000406_add_adjustment_total_to_line_items.rb +0 -5
  578. data/db/migrate/20130815024413_add_adjustment_total_to_shipments.rb +0 -5
  579. data/db/migrate/20130826062534_add_depth_to_spree_taxons.rb +0 -16
  580. data/db/migrate/20130828234942_add_tax_total_to_line_items_shipments_and_orders.rb +0 -8
  581. data/db/migrate/20130830001033_add_shipping_category_to_shipping_methods_and_products.rb +0 -15
  582. data/db/migrate/20130830001159_migrate_old_shipping_calculators.rb +0 -19
  583. data/db/migrate/20130903183026_add_code_to_spree_promotion_rules.rb +0 -5
  584. data/db/migrate/20130909115621_change_states_required_for_countries.rb +0 -9
  585. data/db/migrate/20130915032339_add_deleted_at_to_spree_stock_items.rb +0 -5
  586. data/db/migrate/20130917024658_remove_promotions_event_name_field.rb +0 -5
  587. data/db/migrate/20130924040529_add_promo_total_to_line_items_and_shipments_and_orders.rb +0 -7
  588. data/db/migrate/20131001013410_remove_unused_credit_card_fields.rb +0 -16
  589. data/db/migrate/20131026154747_add_track_inventory_to_variant.rb +0 -5
  590. data/db/migrate/20131107132123_add_tax_category_to_variants.rb +0 -6
  591. data/db/migrate/20131113035136_add_channel_to_spree_orders.rb +0 -5
  592. data/db/migrate/20131118043959_add_included_to_adjustments.rb +0 -5
  593. data/db/migrate/20131118050234_rename_tax_total_fields.rb +0 -11
  594. data/db/migrate/20131118183431_add_line_item_id_to_spree_inventory_units.rb +0 -21
  595. data/db/migrate/20131120234456_add_updated_at_to_variants.rb +0 -5
  596. data/db/migrate/20131127001002_add_position_to_classifications.rb +0 -5
  597. data/db/migrate/20131211112807_create_spree_orders_promotions.rb +0 -8
  598. data/db/migrate/20131211192741_unique_shipping_method_categories.rb +0 -24
  599. data/db/migrate/20131218054603_add_item_count_to_spree_orders.rb +0 -5
  600. data/db/migrate/20140106065820_remove_value_type_from_spree_preferences.rb +0 -8
  601. data/db/migrate/20140106224208_rename_permalink_to_slug_for_products.rb +0 -5
  602. data/db/migrate/20140120160805_add_index_to_variant_id_and_currency_on_prices.rb +0 -5
  603. data/db/migrate/20140124023232_rename_activator_id_in_rules_and_actions_to_promotion_id.rb +0 -6
  604. data/db/migrate/20140129024326_add_deleted_at_to_spree_prices.rb +0 -5
  605. data/db/migrate/20140203161722_add_approver_id_and_approved_at_to_orders.rb +0 -6
  606. data/db/migrate/20140204115338_add_confirmation_delivered_to_spree_orders.rb +0 -5
  607. data/db/migrate/20140204192230_add_auto_capture_to_payment_methods.rb +0 -5
  608. data/db/migrate/20140205120320_create_spree_payment_capture_events.rb +0 -12
  609. data/db/migrate/20140205144710_add_uncaptured_amount_to_payments.rb +0 -5
  610. data/db/migrate/20140205181631_default_variant_weight_to_zero.rb +0 -11
  611. data/db/migrate/20140207085910_add_tax_category_id_to_shipping_methods.rb +0 -5
  612. data/db/migrate/20140207093021_add_tax_rate_id_to_shipping_rates.rb +0 -5
  613. data/db/migrate/20140211040159_add_pre_tax_amount_to_line_items_and_shipments.rb +0 -6
  614. data/db/migrate/20140213184916_add_more_indexes.rb +0 -13
  615. data/db/migrate/20140219060952_add_considered_risky_to_orders.rb +0 -5
  616. data/db/migrate/20140227112348_add_preference_store_to_everything.rb +0 -8
  617. data/db/migrate/20140307235515_add_user_id_to_spree_credit_cards.rb +0 -13
  618. data/db/migrate/20140309023735_migrate_old_preferences.rb +0 -27
  619. data/db/migrate/20140309024355_create_spree_stores.rb +0 -25
  620. data/db/migrate/20140309033438_create_store_from_preferences.rb +0 -37
  621. data/db/migrate/20140315053743_add_timestamps_to_spree_assets.rb +0 -6
  622. data/db/migrate/20140318191500_create_spree_taxons_promotion_rules.rb +0 -8
  623. data/db/migrate/20140331100557_add_additional_store_fields.rb +0 -8
  624. data/db/migrate/20140410141842_add_many_missing_indexes.rb +0 -18
  625. data/db/migrate/20140410150358_correct_some_polymorphic_index_and_add_more_missing.rb +0 -66
  626. data/db/migrate/20140415041315_add_user_id_created_by_id_index_to_order.rb +0 -5
  627. data/db/migrate/20140508151342_change_spree_price_amount_precision.rb +0 -8
  628. data/db/migrate/20140518174634_add_token_to_spree_orders.rb +0 -5
  629. data/db/migrate/20140530024945_move_order_token_from_tokenized_permission.rb +0 -29
  630. data/db/migrate/20140601011216_set_shipment_total_for_users_upgrading.rb +0 -10
  631. data/db/migrate/20140604135309_drop_credit_card_first_name_and_last_name.rb +0 -6
  632. data/db/migrate/20140609201656_add_deleted_at_to_spree_promotion_actions.rb +0 -6
  633. data/db/migrate/20140616202624_remove_uncaptured_amount_from_spree_payments.rb +0 -5
  634. data/db/migrate/20140625214618_create_spree_refunds.rb +0 -12
  635. data/db/migrate/20140702140656_create_spree_return_authorization_inventory_unit.rb +0 -12
  636. data/db/migrate/20140707125621_rename_return_authorization_inventory_unit_to_return_items.rb +0 -5
  637. data/db/migrate/20140709160534_backfill_line_item_pre_tax_amount.rb +0 -10
  638. data/db/migrate/20140710041921_recreate_spree_return_authorizations.rb +0 -55
  639. data/db/migrate/20140710181204_add_amount_fields_to_return_items.rb +0 -7
  640. data/db/migrate/20140710190048_drop_return_authorization_amount.rb +0 -5
  641. data/db/migrate/20140713140455_create_spree_return_authorization_reasons.rb +0 -28
  642. data/db/migrate/20140713140527_create_spree_refund_reasons.rb +0 -14
  643. data/db/migrate/20140713142214_rename_return_authorization_reason.rb +0 -5
  644. data/db/migrate/20140715182625_create_spree_promotion_categories.rb +0 -11
  645. data/db/migrate/20140716204111_drop_received_at_on_return_items.rb +0 -9
  646. data/db/migrate/20140716212330_add_reception_and_acceptance_status_to_return_items.rb +0 -6
  647. data/db/migrate/20140717155155_create_default_refund_reason.rb +0 -9
  648. data/db/migrate/20140717185932_add_default_to_spree_stock_locations.rb +0 -7
  649. data/db/migrate/20140718133010_create_spree_customer_returns.rb +0 -9
  650. data/db/migrate/20140718133349_add_customer_return_id_to_return_item.rb +0 -6
  651. data/db/migrate/20140718195325_create_friendly_id_slugs.rb +0 -15
  652. data/db/migrate/20140723004419_rename_spree_refund_return_authorization_id.rb +0 -5
  653. data/db/migrate/20140723152808_increase_return_item_pre_tax_amount_precision.rb +0 -13
  654. data/db/migrate/20140723214541_copy_product_slugs_to_slug_history.rb +0 -15
  655. data/db/migrate/20140725131539_create_spree_reimbursements.rb +0 -21
  656. data/db/migrate/20140728225422_add_promotionable_to_spree_products.rb +0 -5
  657. data/db/migrate/20140729133613_add_exchange_inventory_unit_foreign_keys.rb +0 -7
  658. data/db/migrate/20140730155938_add_acceptance_status_errors_to_return_item.rb +0 -5
  659. data/db/migrate/20140731150017_create_spree_reimbursement_types.rb +0 -20
  660. data/db/migrate/20140804185157_add_default_to_shipment_cost.rb +0 -10
  661. data/db/migrate/20140805171035_add_default_to_spree_credit_cards.rb +0 -5
  662. data/db/migrate/20140805171219_make_existing_credit_cards_default.rb +0 -10
  663. data/db/migrate/20140806144901_add_type_to_reimbursement_type.rb +0 -9
  664. data/db/migrate/20140808184039_create_spree_reimbursement_credits.rb +0 -10
  665. data/db/migrate/20140827170513_add_meta_title_to_spree_products.rb +0 -7
  666. data/db/migrate/20140911173301_add_kind_to_zone.rb +0 -11
  667. data/db/migrate/20140924164824_add_code_to_spree_tax_categories.rb +0 -5
  668. data/db/migrate/20140927193717_default_pre_tax_amount_should_be_zero.rb +0 -6
  669. data/db/migrate/20141002191113_add_code_to_spree_shipping_methods.rb +0 -5
  670. data/db/migrate/20141007230328_add_cancel_audit_fields_to_spree_orders.rb +0 -6
  671. data/db/migrate/20141009204607_add_store_id_to_orders.rb +0 -8
  672. data/db/migrate/20141012083513_create_spree_taxons_prototypes.rb +0 -8
  673. data/db/migrate/20141021194502_add_state_lock_version_to_order.rb +0 -5
  674. data/db/migrate/20141023005240_add_counter_cache_from_spree_variants_to_spree_stock_items.rb +0 -8
  675. data/db/migrate/20141101231208_fix_adjustment_order_presence.rb +0 -13
  676. data/db/migrate/20141105213646_update_classifications_positions.rb +0 -9
  677. data/db/migrate/20141120135441_add_guest_token_index_to_spree_orders.rb +0 -5
  678. data/db/migrate/20141215232040_remove_token_permissions_table.rb +0 -6
  679. data/db/migrate/20141215235502_remove_extra_products_slug_index.rb +0 -5
  680. data/db/migrate/20141217215630_update_product_slug_index.rb +0 -6
  681. data/db/migrate/20141218025915_rename_identifier_to_number_for_payment.rb +0 -5
  682. data/db/migrate/20150118210639_create_spree_store_credits.rb +0 -24
  683. data/db/migrate/20150118211500_create_spree_store_credit_categories.rb +0 -8
  684. data/db/migrate/20150118212051_create_spree_store_credit_events.rb +0 -17
  685. data/db/migrate/20150118212101_create_spree_store_credit_types.rb +0 -10
  686. data/db/migrate/20150121022521_remove_environment_from_payment_method.rb +0 -6
  687. data/db/migrate/20150122145607_add_resellable_to_return_items.rb +0 -5
  688. data/db/migrate/20150122202432_add_code_to_spree_promotion_categories.rb +0 -5
  689. data/db/migrate/20150128032538_remove_environment_from_tracker.rb +0 -8
  690. data/db/migrate/20150128060325_remove_spree_configurations.rb +0 -16
  691. data/db/migrate/20150216173445_add_index_to_spree_stock_items_variant_id.rb +0 -13
  692. data/db/migrate/20150309161154_ensure_payments_have_numbers.rb +0 -13
  693. data/db/migrate/20150314013438_add_missing_indexes_on_spree_tables.rb +0 -67
  694. data/db/migrate/20150317174308_remove_duplicated_indexes_from_multi_columns.rb +0 -18
  695. data/db/migrate/20150324104002_remove_user_index_from_spree_state_changes.rb +0 -14
  696. data/db/migrate/20150515211137_fix_adjustment_order_id.rb +0 -70
  697. data/db/migrate/20150522071831_add_position_to_spree_payment_methods.rb +0 -5
  698. data/db/migrate/20150522181728_add_deleted_at_to_friendly_id_slugs.rb +0 -6
  699. data/db/migrate/20150609093816_increase_scale_on_pre_tax_amounts.rb +0 -16
  700. data/db/migrate/20150626181949_add_taxable_adjustment_total_to_line_item.rb +0 -19
  701. data/db/migrate/20150627090949_migrate_payment_methods_display.rb +0 -12
  702. data/db/migrate/20150707204155_enable_acts_as_paranoid_on_calculators.rb +0 -6
  703. data/db/migrate/20150714154102_spree_payment_method_store_credits.rb +0 -12
  704. data/db/migrate/20150726141425_rename_has_and_belongs_to_associations_to_model_names.rb +0 -18
  705. data/db/migrate/20150727191614_spree_store_credit_types.rb +0 -11
  706. data/db/migrate/20150819154308_add_discontinued_to_products_and_variants.rb +0 -68
  707. data/db/migrate/20151220072838_remove_shipping_method_id_from_spree_orders.rb +0 -13
  708. data/db/migrate/20160207191757_add_id_column_to_earlier_habtm_tables.rb +0 -16
  709. data/db/migrate/20160219165458_add_indexes.rb +0 -14
  710. data/db/migrate/20160509064646_remove_counter_cache_from_spree_variants_to_spree_stock_items.rb +0 -10
  711. data/db/migrate/20160608090604_add_zipcode_required_to_spree_countries.rb +0 -7
  712. data/db/migrate/20161014145148_add_created_at_to_variant.rb +0 -8
  713. data/db/migrate/20161014152814_add_null_false_to_spree_variants_timestamps.rb +0 -6
  714. data/db/migrate/20161125065505_add_quantity_to_inventory_units.rb +0 -5
  715. data/db/migrate/20170119122701_add_original_return_item_id_to_spree_inventory_units.rb +0 -29
  716. data/db/migrate/20170315152755_add_unique_index_on_number_to_spree_orders.rb +0 -16
  717. data/db/migrate/20170316154338_add_unique_index_on_number_to_spree_stock_transfer.rb +0 -16
  718. data/db/migrate/20170316205511_add_unique_index_on_number_to_spree_shipment.rb +0 -16
  719. data/db/migrate/20170320134043_add_unique_index_on_number_to_spree_payments.rb +0 -17
  720. data/db/migrate/20170320142750_add_unique_index_on_number_to_spree_return_authorizations.rb +0 -16
  721. data/db/migrate/20170320145040_add_unique_index_on_number_to_spree_customer_returns.rb +0 -16
  722. data/db/migrate/20170320145518_add_unique_index_on_number_to_spree_reimbursements.rb +0 -16
  723. data/db/migrate/20170323151450_add_missing_unique_indexes_for_unique_attributes.rb +0 -37
  724. data/db/migrate/20170329110859_add_index_on_stock_location_to_spree_customer_returns.rb +0 -5
  725. data/db/migrate/20170329113917_add_index_on_prototype_to_spree_option_type_prototype.rb +0 -19
  726. data/db/migrate/20170330082155_add_indexes_to_spree_option_value_variant.rb +0 -19
  727. data/db/migrate/20170330132215_add_index_on_promotion_id_to_order_promotions.rb +0 -5
  728. data/db/migrate/20170331101758_add_indexes_for_property_prototype.rb +0 -20
  729. data/db/migrate/20170331103334_add_index_for_prototype_id_to_prototype_taxons.rb +0 -5
  730. data/db/migrate/20170331110454_add_indexes_to_refunds.rb +0 -6
  731. data/db/migrate/20170331111757_add_indexes_to_reimbursement_credits.rb +0 -6
  732. data/db/migrate/20170331115246_add_indexes_to_return_authorizations.rb +0 -6
  733. data/db/migrate/20170331120125_add_indexes_to_return_items.rb +0 -11
  734. data/db/migrate/20170331121725_add_index_to_role_users.rb +0 -18
  735. data/db/migrate/20170331123625_add_index_to_shipping_method_categories.rb +0 -5
  736. data/db/migrate/20170331123832_add_index_to_shipping_method_zones.rb +0 -20
  737. data/db/migrate/20170331124251_add_index_to_spree_shipping_rates.rb +0 -6
  738. data/db/migrate/20170331124513_add_index_to_spree_stock_items.rb +0 -5
  739. data/db/migrate/20170331124924_add_index_to_spree_stock_movement.rb +0 -5
  740. data/db/migrate/20170413211707_change_indexes_on_friendly_id_slugs.rb +0 -10
  741. data/db/migrate/20170722102643_add_analytics_kind_to_spree_trackers.rb +0 -5
  742. data/db/migrate/20170727103056_rename_tracker_kind_field.rb +0 -5
  743. data/db/migrate/20171004223836_remove_icon_from_taxons.rb +0 -8
  744. data/db/migrate/20180222133746_add_unique_index_on_spree_promotions_code.rb +0 -6
  745. data/db/migrate/20180613080857_rename_guest_token_to_token_in_orders.rb +0 -5
  746. data/db/migrate/20180915160001_add_timestamps_to_spree_prices.rb +0 -12
  747. data/db/migrate/20181024100754_add_deleted_at_to_spree_credit_cards.rb +0 -6
  748. data/db/migrate/20190305121659_add_iso_and_iso3_validation_on_presence_and_uniqueness.rb +0 -18
  749. data/db/migrate/20190523092729_add_user_id_and_deleted_at_to_spree_addresses.rb +0 -12
  750. data/lib/friendly_id/slug_rails5_patch.rb +0 -11
  751. data/lib/generators/spree/install/templates/vendor/assets/javascripts/spree/backend/all.js +0 -17
  752. data/lib/generators/spree/install/templates/vendor/assets/javascripts/spree/frontend/all.js +0 -18
  753. data/lib/generators/spree/install/templates/vendor/assets/stylesheets/spree/backend/all.css +0 -16
  754. data/lib/generators/spree/install/templates/vendor/assets/stylesheets/spree/frontend/all.css +0 -16
  755. data/lib/spree/dependencies_helper.rb +0 -11
  756. data/lib/spree/i18n/base.rb +0 -17
  757. data/lib/spree/i18n/initializer.rb +0 -1
  758. data/lib/tasks/email.rake +0 -10
  759. data/vendor/assets/javascripts/fetch.umd.js +0 -531
  760. data/vendor/assets/javascripts/jquery.payment.js +0 -652
  761. data/vendor/assets/javascripts/jsuri.js +0 -458
  762. data/vendor/assets/javascripts/polyfill.min.js +0 -1
  763. /data/app/models/spree/return_item/eligibility_validator/{r_m_a_required.rb → rma_required.rb} +0 -0
  764. /data/{app/models/spree → lib/spree/core}/preferences/scoped_store.rb +0 -0
@@ -0,0 +1,47 @@
1
+ module Spree
2
+ class BaseSorter
3
+ def initialize(scope, params = {}, allowed_sort_attributes = [])
4
+ @scope = scope
5
+ @allowed_sort_attributes = allowed_sort_attributes
6
+ @sort = sort_fields(params[:sort])
7
+ end
8
+
9
+ def call
10
+ by_param_attributes(scope)
11
+ end
12
+
13
+ protected
14
+
15
+ attr_reader :scope, :collection, :sort, :allowed_sort_attributes
16
+
17
+ def by_param_attributes(scope)
18
+ return scope if sort.empty?
19
+
20
+ sort.each do |value, order|
21
+ next if value.blank? || allowed_sort_attributes.exclude?(value.to_sym)
22
+
23
+ scope = scope.order("#{value}": order)
24
+ end
25
+
26
+ scope
27
+ end
28
+
29
+ def sort_fields(sort)
30
+ return [] if sort.nil?
31
+
32
+ sort.split(',').map { |field| [sort_field(field), order_direction(field)] }
33
+ end
34
+
35
+ def desc_order(field)
36
+ String(field)[0] == '-'
37
+ end
38
+
39
+ def sort_field(field)
40
+ desc_order(field) ? field[1..-1] : field
41
+ end
42
+
43
+ def order_direction(field)
44
+ desc_order(field) ? :desc : :asc
45
+ end
46
+ end
47
+ end
@@ -1,42 +1,6 @@
1
1
  module Spree
2
2
  module Orders
3
- class Sort
4
- attr_reader :scope, :sort
5
-
6
- def initialize(scope, params)
7
- @scope = scope
8
- @sort = params[:sort]
9
- end
10
-
11
- def call
12
- orders = completed_at(scope)
13
-
14
- orders
15
- end
16
-
17
- private
18
-
19
- def desc_order
20
- @desc_order ||= String(sort)[0] == '-'
21
- end
22
-
23
- def sort_field
24
- @sort_field ||= desc_order ? sort[1..-1] : sort
25
- end
26
-
27
- def order_direction
28
- desc_order ? :asc : :desc
29
- end
30
-
31
- def completed_at?
32
- sort_field.eql?('completed_at')
33
- end
34
-
35
- def completed_at(orders)
36
- return orders unless completed_at?
37
-
38
- orders.order(completed_at: order_direction)
39
- end
3
+ class Sort < ::Spree::BaseSorter
40
4
  end
41
5
  end
42
6
  end
@@ -1,57 +1,73 @@
1
1
  module Spree
2
2
  module Products
3
- class Sort
4
- def initialize(scope, params, current_currency)
5
- @scope = scope
6
- @sort = params[:sort]
3
+ class Sort < ::Spree::BaseSorter
4
+ def initialize(scope, current_currency, params = {}, allowed_sort_attributes = [])
5
+ super(scope, params, allowed_sort_attributes)
7
6
  @currency = params[:currency] || current_currency
8
7
  end
9
8
 
10
9
  def call
11
- products = updated_at(scope)
12
- products = price(products)
10
+ products = by_param_attributes(scope)
11
+ products = by_price(products)
12
+ products = by_sku(products)
13
13
 
14
- products
14
+ products = select_translatable_fields(products)
15
+
16
+ products.distinct
15
17
  end
16
18
 
17
19
  private
18
20
 
19
- attr_reader :sort, :scope, :currency
21
+ attr_reader :sort, :scope, :currency, :allowed_sort_attributes
20
22
 
21
- def desc_order
22
- @desc_order ||= String(sort)[0] == '-'
23
- end
23
+ def by_price(scope)
24
+ return scope unless (value = sort_by?('price'))
24
25
 
25
- def sort_field
26
- @sort_field ||= desc_order ? sort[1..-1] : sort
26
+ scope.joins(master: :prices).
27
+ select("#{Spree::Product.table_name}.*, #{Spree::Price.table_name}.amount").
28
+ distinct.
29
+ where(spree_prices: { currency: currency }).
30
+ order("#{Spree::Price.table_name}.amount #{value[1]}")
27
31
  end
28
32
 
29
- def updated_at?
30
- sort_field == 'updated_at'
31
- end
33
+ def by_sku(scope)
34
+ return scope unless (value = sort_by?('sku'))
32
35
 
33
- def price?
34
- sort_field == 'price'
36
+ select_product_attributes = if scope.to_sql.include?("#{Spree::Product.table_name}.*")
37
+ ''
38
+ else
39
+ "#{Spree::Product.table_name}.*, "
40
+ end
41
+
42
+ scope.joins(:master).
43
+ select("#{select_product_attributes}#{Spree::Variant.table_name}.sku").
44
+ where(Spree::Variant.table_name.to_s => { is_master: true }).
45
+ order("#{Spree::Variant.table_name}.sku #{value[1]}")
35
46
  end
36
47
 
37
- def order_direction
38
- desc_order ? :desc : :asc
48
+ def sort_by?(field)
49
+ sort.detect { |s| s[0] == field }
39
50
  end
40
51
 
41
- def updated_at(products)
42
- return products unless updated_at?
52
+ # Add translatable fields to SELECT statement to avoid InvalidColumnReference error (workaround for Mobility issue #596)
53
+ def select_translatable_fields(scope)
54
+ translatable_fields = translatable_sortable_fields
55
+ return scope if translatable_fields.empty?
43
56
 
44
- products.order(updated_at: order_direction)
57
+ # if sorting by 'sku' or 'price', spree_products.* is already included in SELECT statement
58
+ if sort_by?('sku') || sort_by?('price')
59
+ scope.i18n.select(*translatable_fields)
60
+ else
61
+ scope.i18n.select("#{Product.table_name}.*").select(*translatable_fields)
62
+ end
45
63
  end
46
64
 
47
- def price(products)
48
- return products unless price?
49
-
50
- products.joins(master: :prices).
51
- select("#{Spree::Product.table_name}.*, #{Spree::Price.table_name}.amount").
52
- distinct.
53
- where(spree_prices: { currency: currency }).
54
- order("#{Spree::Price.table_name}.amount #{order_direction}")
65
+ def translatable_sortable_fields
66
+ fields = []
67
+ Product.translatable_fields.each do |field|
68
+ fields << field if sort_by?(field.to_s)
69
+ end
70
+ fields
55
71
  end
56
72
  end
57
73
  end
@@ -2,6 +2,11 @@
2
2
  # Validates a field based on the maximum length of the underlying DB field, if there is one.
3
3
  class DbMaximumLengthValidator < ActiveModel::EachValidator
4
4
  def validate_each(record, attribute, value)
5
+ ActiveSupport::Deprecation.warn(<<-DEPRECATION, caller)
6
+ `DbMaximumLengthValidator` is deprecated and will be removed in Spree 5.0.
7
+ Please remove any `db_maximum_length: true` validations from your codebase
8
+ DEPRECATION
9
+
5
10
  limit = if defined?(Globalize)
6
11
  record.class.translation_class.columns_hash[attribute.to_s].limit
7
12
  else
@@ -1,7 +1,9 @@
1
1
  class EmailValidator < ActiveModel::EachValidator
2
+ EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(\.[a-z\d\-]+)*\.[a-z]+\z/i
3
+
2
4
  def validate_each(record, attribute, value)
3
- unless value =~ /\A[^@\s]+@[^@\s]+\z/
4
- record.errors.add(attribute, :invalid, { value: value }.merge!(options))
5
+ unless value =~ EMAIL_REGEX
6
+ record.errors.add(attribute, :invalid, **{ value: value }.merge!(options))
5
7
  end
6
8
  end
7
9
  end
@@ -0,0 +1,23 @@
1
+ module Spree
2
+ class UrlValidator < ActiveModel::EachValidator
3
+ def validate_each(record, attribute, value)
4
+ unless url_valid?(value)
5
+ record.errors.add(attribute, (options[:message] || ERROR_MESSAGE))
6
+ end
7
+ end
8
+
9
+ private
10
+
11
+ ERROR_MESSAGE = 'must be a valid URL'
12
+ private_constant :ERROR_MESSAGE
13
+
14
+ def url_valid?(url)
15
+ uri = begin
16
+ URI.parse(url)
17
+ rescue URI::InvalidURIError
18
+ return false
19
+ end
20
+ uri.host.present? && uri.is_a?(URI::HTTP)
21
+ end
22
+ end
23
+ end
data/brakeman.ignore ADDED
@@ -0,0 +1,328 @@
1
+ {
2
+ "ignored_warnings": [
3
+ {
4
+ "warning_type": "SQL Injection",
5
+ "warning_code": 0,
6
+ "fingerprint": "011b2643940ba1112f7a737e403abe3616ad91764703c801cc35a48d36b721da",
7
+ "check_name": "SQL",
8
+ "message": "Possible SQL injection",
9
+ "file": "app/models/concerns/spree/product_scopes.rb",
10
+ "line": 64,
11
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
12
+ "code": "where(\"#{price_table_name}.amount <= ?\", price)",
13
+ "render_path": null,
14
+ "location": {
15
+ "type": "method",
16
+ "class": "Spree",
17
+ "method": null
18
+ },
19
+ "user_input": "price_table_name",
20
+ "confidence": "Medium",
21
+ "cwe_id": [
22
+ 89
23
+ ],
24
+ "note": "interpolating table name"
25
+ },
26
+ {
27
+ "warning_type": "Redirect",
28
+ "warning_code": 18,
29
+ "fingerprint": "05d3870f66d650510c859a8949d5686b05eb028825083b096d0f65fedf80b118",
30
+ "check_name": "Redirect",
31
+ "message": "Possible unprotected redirect",
32
+ "file": "lib/spree/core/controller_helpers/auth.rb",
33
+ "line": 25,
34
+ "link": "https://brakemanscanner.org/docs/warning_types/redirect/",
35
+ "code": "redirect_to((session[\"spree_user_return_to\"] or (request.env[\"HTTP_REFERER\"] or default)))",
36
+ "render_path": null,
37
+ "location": {
38
+ "type": "method",
39
+ "class": "Spree::Core::ControllerHelpers::Auth",
40
+ "method": "redirect_back_or_default"
41
+ },
42
+ "user_input": "request.env[\"HTTP_REFERER\"]",
43
+ "confidence": "High",
44
+ "cwe_id": [
45
+ 601
46
+ ],
47
+ "note": ""
48
+ },
49
+ {
50
+ "warning_type": "SQL Injection",
51
+ "warning_code": 0,
52
+ "fingerprint": "1c12fcb833b0ddffa07880acb7e604922c0d1d52de598316186241baf16551cd",
53
+ "check_name": "SQL",
54
+ "message": "Possible SQL injection",
55
+ "file": "app/finders/spree/taxons/find.rb",
56
+ "line": 75,
57
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
58
+ "code": "taxons.joins(\"INNER JOIN #{Spree::Taxon.table_name} AS parent_taxon ON parent_taxon.id = #{Spree::Taxon.table_name}.parent_id\").join_translation_table(Taxon, \"parent_taxon\").where([\"#{Taxon.translation_table_alias}.permalink = ?\", parent_permalink])",
59
+ "render_path": null,
60
+ "location": {
61
+ "type": "method",
62
+ "class": "Spree::Taxons::Find",
63
+ "method": "by_parent_permalink"
64
+ },
65
+ "user_input": "Taxon.translation_table_alias",
66
+ "confidence": "Weak",
67
+ "cwe_id": [
68
+ 89
69
+ ],
70
+ "note": ""
71
+ },
72
+ {
73
+ "warning_type": "SQL Injection",
74
+ "warning_code": 0,
75
+ "fingerprint": "1f02952550c2f54d044c9577a45e7ba7c7990c8b8a59d1dac83a96790237f507",
76
+ "check_name": "SQL",
77
+ "message": "Possible SQL injection",
78
+ "file": "app/models/concerns/spree/product_scopes.rb",
79
+ "line": 139,
80
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
81
+ "code": "joins(:properties).join_translation_table(Property).join_translation_table(ProductProperty).where(\"#{ProductProperty.translation_table_alias}.value = ?\", value)",
82
+ "render_path": null,
83
+ "location": {
84
+ "type": "method",
85
+ "class": "Spree::ProductScopes",
86
+ "method": null
87
+ },
88
+ "user_input": "ProductProperty.translation_table_alias",
89
+ "confidence": "Weak",
90
+ "cwe_id": [
91
+ 89
92
+ ],
93
+ "note": ""
94
+ },
95
+ {
96
+ "warning_type": "SQL Injection",
97
+ "warning_code": 0,
98
+ "fingerprint": "7928c0813a0bf084ead091b4554ef6abea9ae9c7167936f5c62da9e328b9f736",
99
+ "check_name": "SQL",
100
+ "message": "Possible SQL injection",
101
+ "file": "app/models/concerns/spree/product_scopes.rb",
102
+ "line": 139,
103
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
104
+ "code": "joins(:properties).join_translation_table(Property).join_translation_table(ProductProperty).where(\"#{ProductProperty.translation_table_alias}.value = ?\", value)",
105
+ "render_path": null,
106
+ "location": {
107
+ "type": "method",
108
+ "class": "Spree",
109
+ "method": null
110
+ },
111
+ "user_input": "ProductProperty.translation_table_alias",
112
+ "confidence": "Weak",
113
+ "cwe_id": [
114
+ 89
115
+ ],
116
+ "note": ""
117
+ },
118
+ {
119
+ "warning_type": "SQL Injection",
120
+ "warning_code": 0,
121
+ "fingerprint": "857c335935a00f584137f31dbcb1a4532af5c8bb5cf53a86058b4af98c6597dc",
122
+ "check_name": "SQL",
123
+ "message": "Possible SQL injection",
124
+ "file": "lib/spree/translation_migrations.rb",
125
+ "line": 21,
126
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
127
+ "code": "ActiveRecord::Base.connection.execute(\"\\n UPDATE #{resource_class.table_name}\\n SET #{resource_class.translatable_fields.map do\n \"#{f}=null\"\n end.join(\", \")};\\n \")",
128
+ "render_path": null,
129
+ "location": {
130
+ "type": "method",
131
+ "class": "Spree::TranslationMigrations",
132
+ "method": "transfer_translation_data"
133
+ },
134
+ "user_input": "resource_class.translatable_fields.map do\n \"#{f}=null\"\n end.join(\", \")",
135
+ "confidence": "Medium",
136
+ "cwe_id": [
137
+ 89
138
+ ],
139
+ "note": ""
140
+ },
141
+ {
142
+ "warning_type": "SQL Injection",
143
+ "warning_code": 0,
144
+ "fingerprint": "965d3919f811ab63b7b8d62da528559a7f38dc122c57efea7136e7ec5ef1f062",
145
+ "check_name": "SQL",
146
+ "message": "Possible SQL injection",
147
+ "file": "app/models/concerns/spree/product_scopes.rb",
148
+ "line": 68,
149
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
150
+ "code": "where(\"#{price_table_name}.amount >= ?\", price)",
151
+ "render_path": null,
152
+ "location": {
153
+ "type": "method",
154
+ "class": "Spree::ProductScopes",
155
+ "method": null
156
+ },
157
+ "user_input": "price_table_name",
158
+ "confidence": "Medium",
159
+ "cwe_id": [
160
+ 89
161
+ ],
162
+ "note": "interpolating table name"
163
+ },
164
+ {
165
+ "warning_type": "SQL Injection",
166
+ "warning_code": 0,
167
+ "fingerprint": "98607ecfb86c2d3c2567390f813861edbc42d6ffa9f482afb7c0b3464eaf6e73",
168
+ "check_name": "SQL",
169
+ "message": "Possible SQL injection",
170
+ "file": "app/models/concerns/spree/translatable_resource_scopes.rb",
171
+ "line": 18,
172
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
173
+ "code": "joins(\"LEFT OUTER JOIN #{translatable_class::Translation.table_name} #{translatable_class.translation_table_alias}\\n ON #{translatable_class.translation_table_alias}.#{\"#{translatable_class.table_name.singularize}_id\"} = #{(translatable_class.table_name or join_on_table_alias)}.id\\n AND #{translatable_class.translation_table_alias}.locale = '#{Mobility.locale}'\")",
174
+ "render_path": null,
175
+ "location": {
176
+ "type": "method",
177
+ "class": "Spree::TranslatableResourceScopes",
178
+ "method": "join_translation_table"
179
+ },
180
+ "user_input": "translatable_class.translation_table_alias",
181
+ "confidence": "Medium",
182
+ "cwe_id": [
183
+ 89
184
+ ],
185
+ "note": ""
186
+ },
187
+ {
188
+ "warning_type": "SQL Injection",
189
+ "warning_code": 0,
190
+ "fingerprint": "abd8e90e7a7dfbcdcd6d44fd3fb550598aee6d7a9ef2bb132ad1a18a3c50be30",
191
+ "check_name": "SQL",
192
+ "message": "Possible SQL injection",
193
+ "file": "app/models/concerns/spree/product_scopes.rb",
194
+ "line": 64,
195
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
196
+ "code": "where(\"#{price_table_name}.amount <= ?\", price)",
197
+ "render_path": null,
198
+ "location": {
199
+ "type": "method",
200
+ "class": "Spree::ProductScopes",
201
+ "method": null
202
+ },
203
+ "user_input": "price_table_name",
204
+ "confidence": "Medium",
205
+ "cwe_id": [
206
+ 89
207
+ ],
208
+ "note": "interpolating table name"
209
+ },
210
+ {
211
+ "warning_type": "SQL Injection",
212
+ "warning_code": 0,
213
+ "fingerprint": "c1c97347a2d74ea41d46519e3bfbd94c511a1bd9c285f3f2a1fa0cb7e624d232",
214
+ "check_name": "SQL",
215
+ "message": "Possible SQL injection",
216
+ "file": "lib/spree/translation_migrations.rb",
217
+ "line": 32,
218
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
219
+ "code": "ActiveRecord::Base.connection.execute(\"\\n UPDATE #{resource_class.table_name}\\n SET (#{resource_class.translatable_fields.join(\", \")}) = #{(\"ROW\" or \"\")}(#{resource_class.translatable_fields.map do\n \"#{resource_class::Translation.table_name}.#{f}\"\n end.join(\", \")})\\n FROM #{resource_class::Translation.table_name}\\n WHERE #{resource_class::Translation.table_name}.#{\"#{resource_class.table_name.singularize}_id\"} = #{resource_class.table_name}.id\\n \")",
220
+ "render_path": null,
221
+ "location": {
222
+ "type": "method",
223
+ "class": "Spree::TranslationMigrations",
224
+ "method": "revert_translation_data_transfer"
225
+ },
226
+ "user_input": "resource_class.translatable_fields.join(\", \")",
227
+ "confidence": "Medium",
228
+ "cwe_id": [
229
+ 89
230
+ ],
231
+ "note": ""
232
+ },
233
+ {
234
+ "warning_type": "SQL Injection",
235
+ "warning_code": 0,
236
+ "fingerprint": "c2bc48d98076b7c4fc3314c6a85f7bd1132efe5fcc346da4d28df7c25f93633f",
237
+ "check_name": "SQL",
238
+ "message": "Possible SQL injection",
239
+ "file": "app/models/spree/variant.rb",
240
+ "line": 126,
241
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
242
+ "code": "joins(:product).join_translation_table(Product).where(\"LOWER(#{Product.translation_table_alias}.name) LIKE LOWER(:query)\\n OR LOWER(sku) LIKE LOWER(:query)\", :query => (\"%#{query}%\"))",
243
+ "render_path": null,
244
+ "location": {
245
+ "type": "method",
246
+ "class": "Spree::Variant",
247
+ "method": "Spree::Variant.product_name_or_sku_cont"
248
+ },
249
+ "user_input": "Product.translation_table_alias",
250
+ "confidence": "Weak",
251
+ "cwe_id": [
252
+ 89
253
+ ],
254
+ "note": ""
255
+ },
256
+ {
257
+ "warning_type": "SQL Injection",
258
+ "warning_code": 0,
259
+ "fingerprint": "ed253ae6b1b4ea3fe3d87d3652380fecab80133319b1ed041d98d163fd16b815",
260
+ "check_name": "SQL",
261
+ "message": "Possible SQL injection",
262
+ "file": "app/finders/spree/taxons/find.rb",
263
+ "line": 71,
264
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
265
+ "code": "taxons.joins(:parent).join_translation_table(Taxon, \"parents_spree_taxons\").where([\"#{Taxon.translation_table_alias}.permalink = ?\", parent_permalink])",
266
+ "render_path": null,
267
+ "location": {
268
+ "type": "method",
269
+ "class": "Spree::Taxons::Find",
270
+ "method": "by_parent_permalink"
271
+ },
272
+ "user_input": "Taxon.translation_table_alias",
273
+ "confidence": "Weak",
274
+ "cwe_id": [
275
+ 89
276
+ ],
277
+ "note": ""
278
+ },
279
+ {
280
+ "warning_type": "SQL Injection",
281
+ "warning_code": 0,
282
+ "fingerprint": "efcc57e1a5648d7db59d1beaf5e399d2278539a8667b19c520b305a6ca7e15e8",
283
+ "check_name": "SQL",
284
+ "message": "Possible SQL injection",
285
+ "file": "app/models/concerns/spree/product_scopes.rb",
286
+ "line": 68,
287
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
288
+ "code": "where(\"#{price_table_name}.amount >= ?\", price)",
289
+ "render_path": null,
290
+ "location": {
291
+ "type": "method",
292
+ "class": "Spree",
293
+ "method": null
294
+ },
295
+ "user_input": "price_table_name",
296
+ "confidence": "Medium",
297
+ "cwe_id": [
298
+ 89
299
+ ],
300
+ "note": "interpolating table name"
301
+ },
302
+ {
303
+ "warning_type": "SQL Injection",
304
+ "warning_code": 0,
305
+ "fingerprint": "f14dd62fac0dd1e9d5532dd5efc770e2eb873a8db80faf366b6295378634754a",
306
+ "check_name": "SQL",
307
+ "message": "Possible SQL injection",
308
+ "file": "lib/spree/translation_migrations.rb",
309
+ "line": 16,
310
+ "link": "https://brakemanscanner.org/docs/warning_types/sql_injection/",
311
+ "code": "ActiveRecord::Base.connection.execute(\"\\n INSERT INTO #{resource_class::Translation.table_name} (#{resource_class.translatable_fields.join(\", \")}, #{\"#{resource_class.table_name.singularize}_id\"}, locale, created_at, updated_at)\\n SELECT #{resource_class.translatable_fields.join(\", \")}, id, '#{default_locale}' as locale, created_at, updated_at FROM #{resource_class.table_name};\\n \")",
312
+ "render_path": null,
313
+ "location": {
314
+ "type": "method",
315
+ "class": "Spree::TranslationMigrations",
316
+ "method": "transfer_translation_data"
317
+ },
318
+ "user_input": "resource_class.translatable_fields.join(\", \")",
319
+ "confidence": "Medium",
320
+ "cwe_id": [
321
+ 89
322
+ ],
323
+ "note": ""
324
+ }
325
+ ],
326
+ "updated": "2023-03-22 20:11:32 +0100",
327
+ "brakeman_version": "5.4.1"
328
+ }
@@ -1,5 +1 @@
1
- class ActiveStorage::PurgeJob < ActiveStorage::BaseJob
2
- def perform(blob)
3
- blob.purge unless blob.attachments.present?
4
- end
5
- end
1
+ Rails.application.config.active_storage.content_types_to_serve_as_binary.delete('image/svg+xml')
@@ -1,3 +1,5 @@
1
+ require 'friendly_id/mobility'
2
+
1
3
  # To learn more, check out the guide:
2
4
  # http://norman.github.io/friendly_id/file.Guide.html
3
5
  FriendlyId.defaults do |config|
@@ -0,0 +1,3 @@
1
+ ActiveSupport::Inflector.inflections(:en) do |inflect|
2
+ inflect.acronym 'RMA'
3
+ end
@@ -0,0 +1,18 @@
1
+ Mobility.configure do |config|
2
+ config.plugins do
3
+ ransack
4
+ backend :table
5
+ active_record
6
+ reader
7
+ writer
8
+ backend_reader
9
+ query
10
+ cache
11
+ fallbacks
12
+ locale_accessors
13
+ presence
14
+ dirty
15
+ end
16
+
17
+ config.defaults[:fallbacks] = true
18
+ end
@@ -0,0 +1,3 @@
1
+ if Rails::VERSION::STRING >= '6.1'
2
+ ActiveRecord::Base.has_many_inversing = false
3
+ end