spree_api 4.2.6 → 4.3.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +14 -1
- data/app/controllers/concerns/spree/api/v2/product_list_includes.rb +23 -0
- data/app/controllers/spree/api/v1/classifications_controller.rb +4 -3
- data/app/controllers/spree/api/v1/orders_controller.rb +5 -1
- data/app/controllers/spree/api/v1/products_controller.rb +2 -2
- data/app/controllers/spree/api/v1/taxonomies_controller.rb +1 -1
- data/app/controllers/spree/api/v2/base_controller.rb +29 -6
- data/app/controllers/spree/api/v2/platform/addresses_controller.rb +19 -0
- data/app/controllers/spree/api/v2/platform/classifications_controller.rb +43 -0
- data/app/controllers/spree/api/v2/platform/cms_pages_controller.rb +15 -0
- data/app/controllers/spree/api/v2/platform/cms_sections_controller.rb +34 -0
- data/app/controllers/spree/api/v2/platform/countries_controller.rb +19 -0
- data/app/controllers/spree/api/v2/platform/menu_items_controller.rb +35 -0
- data/app/controllers/spree/api/v2/platform/menus_controller.rb +19 -0
- data/app/controllers/spree/api/v2/platform/option_types_controller.rb +15 -0
- data/app/controllers/spree/api/v2/platform/option_values_controller.rb +19 -0
- data/app/controllers/spree/api/v2/platform/products_controller.rb +21 -0
- data/app/controllers/spree/api/v2/platform/resource_controller.rb +112 -0
- data/app/controllers/spree/api/v2/platform/taxons_controller.rb +30 -0
- data/app/controllers/spree/api/v2/platform/users_controller.rb +28 -0
- data/app/controllers/spree/api/v2/resource_controller.rb +18 -6
- data/app/controllers/spree/api/v2/storefront/account/addresses_controller.rb +2 -14
- data/app/controllers/spree/api/v2/storefront/account/credit_cards_controller.rb +13 -11
- data/app/controllers/spree/api/v2/storefront/account/orders_controller.rb +2 -2
- data/app/controllers/spree/api/v2/storefront/account_controller.rb +32 -1
- data/app/controllers/spree/api/v2/storefront/cart_controller.rb +28 -6
- data/app/controllers/spree/api/v2/storefront/checkout_controller.rb +2 -1
- data/app/controllers/spree/api/v2/storefront/cms_pages_controller.rb +41 -0
- data/app/controllers/spree/api/v2/storefront/countries_controller.rb +9 -14
- data/app/controllers/spree/api/v2/storefront/menus_controller.rb +35 -0
- data/app/controllers/spree/api/v2/storefront/order_status_controller.rb +1 -1
- data/app/controllers/spree/api/v2/storefront/products_controller.rb +6 -12
- data/app/controllers/spree/api/v2/storefront/stores_controller.rb +1 -1
- data/app/controllers/spree/api/v2/storefront/taxons_controller.rb +7 -8
- data/app/helpers/spree/api/v2/display_money_helper.rb +2 -2
- data/app/models/spree/api_configuration.rb +1 -0
- data/app/models/spree/api_dependencies.rb +19 -5
- data/app/serializers/concerns/spree/api/v2/resource_serializer_concern.rb +16 -0
- data/app/serializers/spree/api/v2/base_serializer.rb +32 -0
- data/app/serializers/spree/api/v2/platform/address_serializer.rb +15 -0
- data/app/serializers/spree/api/v2/platform/base_serializer.rb +10 -0
- data/app/serializers/spree/api/v2/platform/classification_serializer.rb +14 -0
- data/app/serializers/spree/api/v2/platform/cms_page_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/cms_section_serializer.rb +11 -0
- data/app/serializers/spree/api/v2/platform/country_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/image_serializer.rb +15 -0
- data/app/serializers/spree/api/v2/platform/menu_item_serializer.rb +22 -0
- data/app/serializers/spree/api/v2/platform/menu_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/option_type_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/option_value_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/product_property_serializer.rb +11 -0
- data/app/serializers/spree/api/v2/platform/product_serializer.rb +78 -0
- data/app/serializers/spree/api/v2/platform/state_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/stock_item_serializer.rb +20 -0
- data/app/serializers/spree/api/v2/platform/stock_location_serializer.rb +16 -0
- data/app/serializers/spree/api/v2/platform/store_serializer.rb +14 -0
- data/app/serializers/spree/api/v2/platform/tax_category_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/taxon_image_serializer.rb +13 -0
- data/app/serializers/spree/api/v2/platform/taxon_serializer.rb +38 -0
- data/app/serializers/spree/api/v2/platform/taxonomy_serializer.rb +14 -0
- data/app/serializers/spree/api/v2/platform/user_serializer.rb +21 -0
- data/app/serializers/spree/api/v2/platform/variant_serializer.rb +57 -0
- data/app/serializers/spree/v2/storefront/base_serializer.rb +3 -2
- data/app/serializers/spree/v2/storefront/cms_page_serializer.rb +14 -0
- data/app/serializers/spree/v2/storefront/cms_section_serializer.rb +28 -0
- data/app/serializers/spree/v2/storefront/country_serializer.rb +4 -4
- data/app/serializers/spree/v2/storefront/estimated_shipping_rate_serializer.rb +2 -0
- data/app/serializers/spree/v2/storefront/menu_item_serializer.rb +37 -0
- data/app/serializers/spree/v2/storefront/menu_serializer.rb +13 -0
- data/app/serializers/spree/v2/storefront/product_property_serializer.rb +1 -1
- data/app/serializers/spree/v2/storefront/product_serializer.rb +4 -1
- data/app/serializers/spree/v2/storefront/store_serializer.rb +10 -0
- data/app/serializers/spree/v2/storefront/taxon_serializer.rb +6 -5
- data/config/initializers/doorkeeper.rb +8 -1
- data/config/initializers/rabl.rb +9 -0
- data/config/routes.rb +115 -3
- data/db/migrate/20210727102516_change_integer_id_columns_type.rb +9 -0
- data/docs/oauth/index.yml +2 -2
- data/docs/v2/platform/index.yaml +1501 -0
- data/docs/v2/storefront/index.yaml +48 -2
- data/lib/spree/api/engine.rb +6 -17
- data/lib/spree/api/testing_support/v2/base.rb +1 -1
- data/lib/spree/api/testing_support/v2/platform_contexts.rb +214 -0
- data/lib/spree/api/testing_support/v2/serializers_params.rb +14 -0
- data/lib/spree/api.rb +1 -0
- data/spree_api.gemspec +3 -0
- metadata +101 -11
- data/app/assets/javascripts/spree/api/main.js +0 -36
- data/app/assets/javascripts/spree/api/storefront/cart.js +0 -49
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 381bcae626a5cfcc30444d47853c1bc26063befbc5c18db328276d8c1998c309
|
4
|
+
data.tar.gz: 01fc310be446eff60debb73a6da32a1b4e548dcd2ec7e7fca562ef7fada5a248
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 03c6087202462b6ff19e3cc1b081a175e3db9273ce486b321c27aa44e4ae82a57c9b73b24894f788c1335584e0cfcf7b94733844f3875d8f4ff67be59ba04acb
|
7
|
+
data.tar.gz: 24ae9980e17d37c7963cdbd7fb1e9ab6a02ef099e7763b83bf8276d9ea8e296ee49e4a3b4c42587a3b02010151f450478c0c376f6c835f8db4e6536fbc33d0fa
|
data/Rakefile
CHANGED
@@ -3,7 +3,6 @@ require 'rake'
|
|
3
3
|
require 'rake/testtask'
|
4
4
|
require 'rspec/core/rake_task'
|
5
5
|
require 'spree/testing_support/common_rake'
|
6
|
-
require 'rails/all'
|
7
6
|
|
8
7
|
RSpec::Core::RakeTask.new
|
9
8
|
|
@@ -14,3 +13,17 @@ task :test_app do
|
|
14
13
|
ENV['LIB_NAME'] = 'spree/api'
|
15
14
|
Rake::Task['common:test_app'].invoke
|
16
15
|
end
|
16
|
+
|
17
|
+
namespace :rswag do
|
18
|
+
namespace :specs do
|
19
|
+
desc 'Generate Swagger JSON files from integration specs'
|
20
|
+
RSpec::Core::RakeTask.new('swaggerize') do |t|
|
21
|
+
t.pattern = ENV.fetch(
|
22
|
+
'PATTERN',
|
23
|
+
'spec/integration/**/*_spec.rb'
|
24
|
+
)
|
25
|
+
|
26
|
+
t.rspec_opts = ['--format Rswag::Specs::SwaggerFormatter', '--order defined']
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module ProductListIncludes
|
5
|
+
def product_list_includes
|
6
|
+
variant_includes = {
|
7
|
+
prices: [],
|
8
|
+
option_values: :option_type,
|
9
|
+
images: []
|
10
|
+
}
|
11
|
+
|
12
|
+
{
|
13
|
+
product_properties: [],
|
14
|
+
option_types: [],
|
15
|
+
variant_images: [],
|
16
|
+
master: variant_includes,
|
17
|
+
variants: variant_includes
|
18
|
+
}
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -9,9 +9,10 @@ module Spree
|
|
9
9
|
product_id: params[:product_id],
|
10
10
|
taxon_id: params[:taxon_id]
|
11
11
|
)
|
12
|
-
|
13
|
-
|
14
|
-
|
12
|
+
Spree::Dependencies.classification_reposition_service.constantize.call(
|
13
|
+
classification: classification,
|
14
|
+
position: params[:position]
|
15
|
+
)
|
15
16
|
head :ok
|
16
17
|
end
|
17
18
|
end
|
@@ -56,7 +56,7 @@ module Spree
|
|
56
56
|
|
57
57
|
def empty
|
58
58
|
authorize! :update, @order, order_token
|
59
|
-
@order
|
59
|
+
cart_empty_service.call(order: @order)
|
60
60
|
render plain: nil, status: 204
|
61
61
|
end
|
62
62
|
|
@@ -150,6 +150,10 @@ module Spree
|
|
150
150
|
def order_id
|
151
151
|
super || params[:id]
|
152
152
|
end
|
153
|
+
|
154
|
+
def cart_empty_service
|
155
|
+
Spree::Dependencies.cart_empty_service.constantize
|
156
|
+
end
|
153
157
|
end
|
154
158
|
end
|
155
159
|
end
|
@@ -64,7 +64,7 @@ module Spree
|
|
64
64
|
params[:product][:available_on] ||= Time.current
|
65
65
|
set_up_shipping_category
|
66
66
|
|
67
|
-
options = { variants_attrs: variants_params, options_attrs: option_types_params }
|
67
|
+
options = { store: current_store, variants_attrs: variants_params, options_attrs: option_types_params }
|
68
68
|
@product = Core::Importer::Product.new(nil, product_params, options).create
|
69
69
|
|
70
70
|
if @product.persisted?
|
@@ -77,7 +77,7 @@ module Spree
|
|
77
77
|
def update
|
78
78
|
authorize! :update, @product
|
79
79
|
|
80
|
-
options = { variants_attrs: variants_params, options_attrs: option_types_params }
|
80
|
+
options = { store: current_store, variants_attrs: variants_params, options_attrs: option_types_params }
|
81
81
|
@product = Core::Importer::Product.new(@product, product_params, options).update
|
82
82
|
|
83
83
|
if @product.errors.empty?
|
@@ -19,7 +19,7 @@ module Spree
|
|
19
19
|
|
20
20
|
def create
|
21
21
|
authorize! :create, Taxonomy
|
22
|
-
@taxonomy =
|
22
|
+
@taxonomy = current_store.taxonomies.new(taxonomy_params)
|
23
23
|
if @taxonomy.save
|
24
24
|
respond_with(@taxonomy, status: 201, default_template: :show)
|
25
25
|
else
|
@@ -7,8 +7,10 @@ module Spree
|
|
7
7
|
include Spree::Core::ControllerHelpers::Store
|
8
8
|
include Spree::Core::ControllerHelpers::Locale
|
9
9
|
include Spree::Core::ControllerHelpers::Currency
|
10
|
+
|
10
11
|
rescue_from ActiveRecord::RecordNotFound, with: :record_not_found
|
11
12
|
rescue_from CanCan::AccessDenied, with: :access_denied
|
13
|
+
rescue_from Doorkeeper::Errors::DoorkeeperError, with: :access_denied_401
|
12
14
|
rescue_from Spree::Core::GatewayError, with: :gateway_error
|
13
15
|
rescue_from ActionController::ParameterMissing, with: :error_during_processing
|
14
16
|
if defined?(JSONAPI::Serializer::UnsupportedIncludeError)
|
@@ -39,7 +41,7 @@ module Spree
|
|
39
41
|
end
|
40
42
|
|
41
43
|
def paginated_collection
|
42
|
-
collection_paginator.new(sorted_collection, params).call
|
44
|
+
@paginated_collection ||= collection_paginator.new(sorted_collection, params).call
|
43
45
|
end
|
44
46
|
|
45
47
|
def collection_paginator
|
@@ -51,10 +53,22 @@ module Spree
|
|
51
53
|
end
|
52
54
|
|
53
55
|
def render_error_payload(error, status = 422)
|
54
|
-
if error.is_a?(
|
55
|
-
|
56
|
-
|
57
|
-
|
56
|
+
json = if error.is_a?(ActiveModel::Errors)
|
57
|
+
{ error: error.full_messages.to_sentence, errors: error.messages }
|
58
|
+
elsif error.is_a?(Struct)
|
59
|
+
{ error: error.to_s, errors: error.to_h }
|
60
|
+
else
|
61
|
+
{ error: error }
|
62
|
+
end
|
63
|
+
|
64
|
+
render json: json, status: status, content_type: content_type
|
65
|
+
end
|
66
|
+
|
67
|
+
def render_result(result)
|
68
|
+
if result.success?
|
69
|
+
render_serialized_payload { serialize_resource(result.value) }
|
70
|
+
else
|
71
|
+
render_error_payload(result.error)
|
58
72
|
end
|
59
73
|
end
|
60
74
|
|
@@ -114,7 +128,12 @@ module Spree
|
|
114
128
|
end
|
115
129
|
|
116
130
|
def serializer_params
|
117
|
-
{
|
131
|
+
{
|
132
|
+
currency: current_currency,
|
133
|
+
locale: current_locale,
|
134
|
+
store: current_store,
|
135
|
+
user: spree_current_user
|
136
|
+
}
|
118
137
|
end
|
119
138
|
|
120
139
|
def record_not_found
|
@@ -125,6 +144,10 @@ module Spree
|
|
125
144
|
render_error_payload(exception.message, 403)
|
126
145
|
end
|
127
146
|
|
147
|
+
def access_denied_401(exception)
|
148
|
+
render_error_payload(exception.message, 401)
|
149
|
+
end
|
150
|
+
|
128
151
|
def gateway_error(exception)
|
129
152
|
render_error_payload(exception.message)
|
130
153
|
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class AddressesController < ResourceController
|
6
|
+
private
|
7
|
+
|
8
|
+
def model_class
|
9
|
+
Spree::Address
|
10
|
+
end
|
11
|
+
|
12
|
+
def scope_includes
|
13
|
+
[:country, :state, :user]
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class ClassificationsController < ResourceController
|
6
|
+
before_action -> { doorkeeper_authorize! :write, :admin }, only: WRITE_ACTIONS << :reposition
|
7
|
+
|
8
|
+
def reposition
|
9
|
+
spree_authorize! :update, resource if spree_current_user.present?
|
10
|
+
|
11
|
+
result = classification_reposition_service.call(
|
12
|
+
classification: resource,
|
13
|
+
position: permitted_resource_params[:position]
|
14
|
+
)
|
15
|
+
|
16
|
+
if result.success?
|
17
|
+
render_serialized_payload { serialize_resource(result.value) }
|
18
|
+
else
|
19
|
+
render_error_payload(result.error)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
private
|
24
|
+
|
25
|
+
def model_class
|
26
|
+
Spree::Classification
|
27
|
+
end
|
28
|
+
|
29
|
+
def scope_includes
|
30
|
+
[
|
31
|
+
taxon: [],
|
32
|
+
product: [:variants_including_master, :variant_images, :master, variants: [:prices]]
|
33
|
+
]
|
34
|
+
end
|
35
|
+
|
36
|
+
def classification_reposition_service
|
37
|
+
Spree::Dependencies.classification_reposition_service.constantize
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class CmsSectionsController < ResourceController
|
6
|
+
before_action -> { doorkeeper_authorize! :write, :admin }, only: WRITE_ACTIONS << :reposition
|
7
|
+
|
8
|
+
def reposition
|
9
|
+
spree_authorize! :update, @moved_section if spree_current_user.present?
|
10
|
+
|
11
|
+
@moved_section = scope.find(params[:section_id])
|
12
|
+
new_index = params[:new_position_idx].to_i + 1
|
13
|
+
|
14
|
+
if @moved_section && new_index
|
15
|
+
@moved_section.set_list_position(new_index)
|
16
|
+
else
|
17
|
+
head :bad_request
|
18
|
+
end
|
19
|
+
|
20
|
+
if @moved_section.save
|
21
|
+
head :no_content
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def model_class
|
28
|
+
Spree::CmsSection
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class CountriesController < ResourceController
|
6
|
+
private
|
7
|
+
|
8
|
+
def model_class
|
9
|
+
Spree::Country
|
10
|
+
end
|
11
|
+
|
12
|
+
def scope_includes
|
13
|
+
[:states, :zones]
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class MenuItemsController < ResourceController
|
6
|
+
before_action -> { doorkeeper_authorize! :write, :admin }, only: WRITE_ACTIONS << :reposition
|
7
|
+
|
8
|
+
def reposition
|
9
|
+
spree_authorize! :update, @moved_item if spree_current_user.present?
|
10
|
+
|
11
|
+
@moved_item = scope.find(params[:moved_item_id])
|
12
|
+
@new_parent = scope.find(params[:new_parent_id])
|
13
|
+
new_index = params[:new_position_idx].to_i
|
14
|
+
|
15
|
+
if @moved_item && @new_parent && new_index
|
16
|
+
@moved_item.move_to_child_with_index(@new_parent, new_index)
|
17
|
+
else
|
18
|
+
head :bad_request
|
19
|
+
end
|
20
|
+
|
21
|
+
if @moved_item.save
|
22
|
+
head :no_content
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
private
|
27
|
+
|
28
|
+
def model_class
|
29
|
+
Spree::MenuItem
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class OptionValuesController < ResourceController
|
6
|
+
private
|
7
|
+
|
8
|
+
def model_class
|
9
|
+
Spree::OptionValue
|
10
|
+
end
|
11
|
+
|
12
|
+
def scope_includes
|
13
|
+
[:option_type]
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class ProductsController < ResourceController
|
6
|
+
include ::Spree::Api::V2::ProductListIncludes
|
7
|
+
|
8
|
+
private
|
9
|
+
|
10
|
+
def model_class
|
11
|
+
Spree::Product
|
12
|
+
end
|
13
|
+
|
14
|
+
def scope_includes
|
15
|
+
product_list_includes
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,112 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class ResourceController < ::Spree::Api::V2::ResourceController
|
6
|
+
READ_ACTIONS = %i[show index]
|
7
|
+
WRITE_ACTIONS = %i[create update destroy]
|
8
|
+
|
9
|
+
# doorkeeper scopes usage: https://github.com/doorkeeper-gem/doorkeeper/wiki/Using-Scopes
|
10
|
+
before_action -> { doorkeeper_authorize! :read, :admin }, only: READ_ACTIONS
|
11
|
+
before_action -> { doorkeeper_authorize! :write, :admin }, only: WRITE_ACTIONS
|
12
|
+
|
13
|
+
# optional authorization if using a user token instead of app token
|
14
|
+
before_action :authorize_spree_user, only: WRITE_ACTIONS
|
15
|
+
|
16
|
+
# index and show acrtions are defined in Spree::Api::V2::ResourceController
|
17
|
+
|
18
|
+
def create
|
19
|
+
resource = model_class.new(permitted_resource_params)
|
20
|
+
|
21
|
+
if resource.save
|
22
|
+
render_serialized_payload(201) { serialize_resource(resource) }
|
23
|
+
else
|
24
|
+
render_error_payload(resource.errors)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def update
|
29
|
+
if resource.update(permitted_resource_params)
|
30
|
+
render_serialized_payload { serialize_resource(resource) }
|
31
|
+
else
|
32
|
+
render_error_payload(resource.errors)
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def destroy
|
37
|
+
if resource.destroy
|
38
|
+
head 204
|
39
|
+
else
|
40
|
+
render_error_payload(resource.errors)
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
protected
|
45
|
+
|
46
|
+
def resource_serializer
|
47
|
+
"Spree::Api::V2::Platform::#{model_class.to_s.demodulize}Serializer".constantize
|
48
|
+
end
|
49
|
+
|
50
|
+
def collection_serializer
|
51
|
+
resource_serializer
|
52
|
+
end
|
53
|
+
|
54
|
+
# overwiting to utilize ransack gem for filtering
|
55
|
+
# https://github.com/activerecord-hackery/ransack#search-matchers
|
56
|
+
def collection
|
57
|
+
@collection ||= scope.ransack(params[:filter]).result
|
58
|
+
end
|
59
|
+
|
60
|
+
# overwriting to skip cancancan check if API is consumed by an application
|
61
|
+
def scope
|
62
|
+
return super if spree_current_user.present?
|
63
|
+
|
64
|
+
super(skip_cancancan: true)
|
65
|
+
end
|
66
|
+
|
67
|
+
# We're overwriting this method because the original one calls `dookreeper_authorize`
|
68
|
+
# which breaks our application authorizations defined on top of this controller
|
69
|
+
def spree_current_user
|
70
|
+
return nil unless doorkeeper_token
|
71
|
+
return nil if doorkeeper_token.resource_owner_id.nil?
|
72
|
+
return @spree_current_user if @spree_current_user
|
73
|
+
|
74
|
+
@spree_current_user ||= Spree.user_class.find_by(id: doorkeeper_token.resource_owner_id)
|
75
|
+
end
|
76
|
+
|
77
|
+
def access_denied(exception)
|
78
|
+
access_denied_401(exception)
|
79
|
+
end
|
80
|
+
|
81
|
+
# if using a user oAuth token we need to check CanCanCan abilities
|
82
|
+
# defined in https://github.com/spree/spree/blob/master/core/app/models/spree/ability.rb
|
83
|
+
def authorize_spree_user
|
84
|
+
return if spree_current_user.nil?
|
85
|
+
|
86
|
+
if action_name == 'create'
|
87
|
+
spree_authorize! :create, model_class
|
88
|
+
else
|
89
|
+
spree_authorize! action_name, resource
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
def model_param_name
|
94
|
+
model_class.to_s.demodulize.underscore
|
95
|
+
end
|
96
|
+
|
97
|
+
def spree_permitted_attributes
|
98
|
+
Spree::PermittedAttributes.try("#{model_param_name}_attributes") || {}
|
99
|
+
end
|
100
|
+
|
101
|
+
def permitted_resource_params
|
102
|
+
params.require(model_param_name).permit(spree_permitted_attributes)
|
103
|
+
end
|
104
|
+
|
105
|
+
def allowed_sort_attributes
|
106
|
+
(super << spree_permitted_attributes).uniq.compact
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class TaxonsController < ResourceController
|
6
|
+
private
|
7
|
+
|
8
|
+
def model_class
|
9
|
+
Spree::Taxon
|
10
|
+
end
|
11
|
+
|
12
|
+
def scope_includes
|
13
|
+
node_includes = %i[icon parent taxonomy]
|
14
|
+
|
15
|
+
{
|
16
|
+
parent: node_includes,
|
17
|
+
children: node_includes,
|
18
|
+
taxonomy: [root: node_includes],
|
19
|
+
icon: [attachment_attachment: :blob]
|
20
|
+
}
|
21
|
+
end
|
22
|
+
|
23
|
+
def serializer_params
|
24
|
+
super.merge(include_products: action_name == 'show')
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module Spree
|
2
|
+
module Api
|
3
|
+
module V2
|
4
|
+
module Platform
|
5
|
+
class UsersController < ResourceController
|
6
|
+
private
|
7
|
+
|
8
|
+
def model_class
|
9
|
+
Spree.user_class
|
10
|
+
end
|
11
|
+
|
12
|
+
def resource_serializer
|
13
|
+
Spree::Api::V2::Platform::UserSerializer
|
14
|
+
end
|
15
|
+
|
16
|
+
def scope_includes
|
17
|
+
[:ship_address, :bill_address]
|
18
|
+
end
|
19
|
+
|
20
|
+
# we need to define this here as developers can configure their own `user_class`
|
21
|
+
def model_param_name
|
22
|
+
'user'
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -15,7 +15,7 @@ module Spree
|
|
15
15
|
protected
|
16
16
|
|
17
17
|
def sorted_collection
|
18
|
-
collection_sorter.new(collection, params, allowed_sort_attributes).call
|
18
|
+
@sorted_collection ||= collection_sorter.new(collection, params, allowed_sort_attributes).call
|
19
19
|
end
|
20
20
|
|
21
21
|
def allowed_sort_attributes
|
@@ -23,11 +23,14 @@ module Spree
|
|
23
23
|
end
|
24
24
|
|
25
25
|
def default_sort_atributes
|
26
|
-
[:id, :updated_at, :created_at]
|
26
|
+
[:id, :name, :number, :position, :updated_at, :created_at]
|
27
27
|
end
|
28
28
|
|
29
|
-
def scope
|
30
|
-
model_class.
|
29
|
+
def scope(skip_cancancan: false)
|
30
|
+
base_scope = model_class.for_store(current_store)
|
31
|
+
base_scope = base_scope.accessible_by(current_ability, :show) unless skip_cancancan
|
32
|
+
base_scope = base_scope.includes(scope_includes) if scope_includes.any? && action_name == 'index'
|
33
|
+
base_scope
|
31
34
|
end
|
32
35
|
|
33
36
|
def scope_includes
|
@@ -36,7 +39,7 @@ module Spree
|
|
36
39
|
|
37
40
|
def resource
|
38
41
|
@resource ||= if defined?(resource_finder)
|
39
|
-
resource_finder.new(scope: scope, params:
|
42
|
+
resource_finder.new(scope: scope, params: finder_params).execute
|
40
43
|
else
|
41
44
|
scope.find(params[:id])
|
42
45
|
end
|
@@ -44,12 +47,21 @@ module Spree
|
|
44
47
|
|
45
48
|
def collection
|
46
49
|
@collection ||= if defined?(collection_finder)
|
47
|
-
collection_finder.new(scope: scope, params:
|
50
|
+
collection_finder.new(scope: scope, params: finder_params).execute
|
48
51
|
else
|
49
52
|
scope
|
50
53
|
end
|
51
54
|
end
|
52
55
|
|
56
|
+
def finder_params
|
57
|
+
params.merge(
|
58
|
+
store: current_store,
|
59
|
+
locale: current_locale,
|
60
|
+
currency: current_currency,
|
61
|
+
user: spree_current_user
|
62
|
+
)
|
63
|
+
end
|
64
|
+
|
53
65
|
def collection_sorter
|
54
66
|
Spree::Api::Dependencies.storefront_collection_sorter.constantize
|
55
67
|
end
|