Class: Spree::Api::V1::ProductsController

Inherits:
BaseController
  • Object
show all
Defined in:
app/controllers/spree/api/v1/products_controller.rb

Instance Attribute Summary

Attributes inherited from BaseController

#current_api_user

Instance Method Summary collapse

Methods inherited from BaseController

#content_type, #permitted_line_item_attributes

Methods included from ControllerSetup

included

Instance Method Details

#createObject



61
62
63
64
65
66
67
68
69
70
71
72
73
74
# File 'app/controllers/spree/api/v1/products_controller.rb', line 61

def create
  authorize! :create, Product
  params[:product][:available_on] ||= Time.current
  set_up_shipping_category

  options = { variants_attrs: variants_params, options_attrs: option_types_params }
  @product = Core::Importer::Product.new(nil, product_params, options).create

  if @product.persisted?
    respond_with(@product, status: 201, default_template: :show)
  else
    invalid_resource!(@product)
  end
end

#destroyObject



90
91
92
93
94
95
# File 'app/controllers/spree/api/v1/products_controller.rb', line 90

def destroy
  @product = find_product(params[:id])
  authorize! :destroy, @product
  @product.destroy
  respond_with(@product, status: 204)
end

#indexObject



5
6
7
8
9
10
11
12
13
14
15
16
# File 'app/controllers/spree/api/v1/products_controller.rb', line 5

def index
  if params[:ids]
    @products = product_scope.where(id: params[:ids].split(',').flatten)
  else
    @products = product_scope.ransack(params[:q]).result
  end

  @products = @products.distinct.page(params[:page]).per(params[:per_page])
  expires_in 15.minutes, public: true
  headers['Surrogate-Control'] = "max-age=#{15.minutes}"
  respond_with(@products)
end

#newObject

Takes besides the products attributes either an array of variants or an array of option types.

By submitting an array of variants the option types will be created using the name key in options hash. e.g

product: {
  ...
  variants: {
    price: 19.99,
    sku: "hey_you",
    options: [
      { name: "size", value: "small" },
      { name: "color", value: "black" }
    ]
  }
}

Or just pass in the option types hash:

product: {
  ...
  option_types: ['size', 'color']
}

By passing the shipping category name you can fetch or create that shipping category on the fly. e.g.

product: {
  ...
  shipping_category: "Free Shipping Items"
}


59
# File 'app/controllers/spree/api/v1/products_controller.rb', line 59

def new; end

#showObject



18
19
20
21
22
23
24
# File 'app/controllers/spree/api/v1/products_controller.rb', line 18

def show
  @product = find_product(params[:id])
  expires_in 15.minutes, public: true
  headers['Surrogate-Control'] = "max-age=#{15.minutes}"
  headers['Surrogate-Key'] = 'product_id=1'
  respond_with(@product)
end

#updateObject



76
77
78
79
80
81
82
83
84
85
86
87
88
# File 'app/controllers/spree/api/v1/products_controller.rb', line 76

def update
  @product = find_product(params[:id])
  authorize! :update, @product

  options = { variants_attrs: variants_params, options_attrs: option_types_params }
  @product = Core::Importer::Product.new(@product, product_params, options).update

  if @product.errors.empty?
    respond_with(@product.reload, status: 200, default_template: :show)
  else
    invalid_resource!(@product)
  end
end