summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafi Zadanly <zadanlyr@gmail.com>2023-04-08 13:35:11 +0700
committerRafi Zadanly <zadanlyr@gmail.com>2023-04-08 13:35:11 +0700
commit307682aaa5dcbdeab60e6b3a49e3dce50e72218b (patch)
tree173e7363012cec62c2609e332c5941cabea788ca
parent7b6cdcaae39893e7ed682b4d5864f4365c92f37a (diff)
fixing api product
-rw-r--r--indoteknik_api/controllers/__init__.py3
-rw-r--r--indoteknik_api/controllers/api_v1/product.py1
-rw-r--r--indoteknik_api/controllers/api_v2/__init__.py1
-rw-r--r--indoteknik_api/controllers/api_v2/product.py21
-rw-r--r--indoteknik_api/controllers/api_v2/product_variant.py22
-rw-r--r--indoteknik_api/models/product_product.py25
-rw-r--r--indoteknik_api/models/product_template.py47
7 files changed, 118 insertions, 2 deletions
diff --git a/indoteknik_api/controllers/__init__.py b/indoteknik_api/controllers/__init__.py
index 30664b92..01dde20f 100644
--- a/indoteknik_api/controllers/__init__.py
+++ b/indoteknik_api/controllers/__init__.py
@@ -1,2 +1,3 @@
from . import controller
-from . import api_v1 \ No newline at end of file
+from . import api_v1
+from . import api_v2 \ No newline at end of file
diff --git a/indoteknik_api/controllers/api_v1/product.py b/indoteknik_api/controllers/api_v1/product.py
index 736fd68e..54b039c7 100644
--- a/indoteknik_api/controllers/api_v1/product.py
+++ b/indoteknik_api/controllers/api_v1/product.py
@@ -4,7 +4,6 @@ from odoo.http import request
from datetime import datetime, timedelta
import ast
import logging
-import math
_logger = logging.getLogger(__name__)
diff --git a/indoteknik_api/controllers/api_v2/__init__.py b/indoteknik_api/controllers/api_v2/__init__.py
new file mode 100644
index 00000000..23275437
--- /dev/null
+++ b/indoteknik_api/controllers/api_v2/__init__.py
@@ -0,0 +1 @@
+from . import product \ No newline at end of file
diff --git a/indoteknik_api/controllers/api_v2/product.py b/indoteknik_api/controllers/api_v2/product.py
new file mode 100644
index 00000000..772906f6
--- /dev/null
+++ b/indoteknik_api/controllers/api_v2/product.py
@@ -0,0 +1,21 @@
+from .. import controller
+from odoo import http
+from odoo.http import request
+
+class V2Product(controller.Controller):
+ prefix = '/api/v2/'
+
+ @http.route(prefix + 'product/<id>', auth='public', methods=['GET'])
+ @controller.Controller.must_authorized()
+ def v2_get_product_by_id(self, **kw):
+ id = kw.get('id')
+ if not id:
+ return self.response(code=400, description='id is required')
+
+ data = []
+ id = [int(x) for x in id.split(',')]
+ product_templates = request.env['product.template'].search([('id', 'in', id)])
+ if product_templates:
+ data = [request.env['product.template'].v2_api_single_response(x, with_detail='DEFAULT') for x in product_templates]
+
+ return self.response(data) \ No newline at end of file
diff --git a/indoteknik_api/controllers/api_v2/product_variant.py b/indoteknik_api/controllers/api_v2/product_variant.py
new file mode 100644
index 00000000..b74e4936
--- /dev/null
+++ b/indoteknik_api/controllers/api_v2/product_variant.py
@@ -0,0 +1,22 @@
+from .. import controller
+from odoo import http
+from odoo.http import request
+
+class V2ProductVariant(controller.Controller):
+ prefix = '/api/v2/'
+
+ @http.route(prefix + 'product_variant/<id>', auth='public', methods=['GET', 'OPTIONS'])
+ @controller.Controller.must_authorized()
+ def v2_get_product_variant_by_id(self, **kw):
+ id = kw.get('id')
+ if not id:
+ return self.response(code=400, description='id is required')
+
+ data = []
+ id = [int(x) for x in id.split(',')]
+ product_products = request.env['product.product'].search([('id', 'in', id)])
+ if product_products:
+ data = [request.env['product.product'].v2_api_single_response(x) for x in product_products]
+
+ return self.response(data)
+
diff --git a/indoteknik_api/models/product_product.py b/indoteknik_api/models/product_product.py
index f83ede27..c867eaa0 100644
--- a/indoteknik_api/models/product_product.py
+++ b/indoteknik_api/models/product_product.py
@@ -25,6 +25,31 @@ class ProductProduct(models.Model):
'manufacture' : self.api_manufacture(product_product)
}
return data
+
+ def v2_api_single_response(self, product_product):
+ product_pricelist_default_discount_id = self.env['ir.config_parameter'].get_param('product.pricelist.default_discount_id')
+ product_pricelist_default_discount_id = int(product_pricelist_default_discount_id)
+ product_template = product_product.product_tmpl_id
+ data = {
+ 'id': product_product.id,
+ 'parent': {
+ 'id': product_template.id,
+ 'name': product_template.name,
+ 'image': self.env['ir.attachment'].api_image('product.template', 'image_256', product_template.id),
+ },
+ 'code': product_product.default_code or '',
+ 'name': product_product.display_name,
+ 'price': {
+ 'price': product_product._get_website_price_exclude_tax(),
+ 'discount_percentage': product_product._get_website_disc(0),
+ 'price_discount': product_product._get_website_price_after_disc_and_tax()
+ },
+ 'stock': product_product.qty_stock_vendor,
+ 'weight': product_product.weight,
+ 'attributes': [x.name for x in product_product.product_template_attribute_value_ids],
+ 'manufacture' : self.api_manufacture(product_product)
+ }
+ return data
def api_manufacture(self, product_template):
if product_template.x_manufacture:
diff --git a/indoteknik_api/models/product_template.py b/indoteknik_api/models/product_template.py
index 72dda17f..4d16727f 100644
--- a/indoteknik_api/models/product_template.py
+++ b/indoteknik_api/models/product_template.py
@@ -51,6 +51,53 @@ class ProductTemplate(models.Model):
data.update(data_with_detail)
return data
+ def v2_api_single_response(self, product_template, with_detail=''):
+ product_pricelist_default_discount_id = self.env['ir.config_parameter'].get_param('product.pricelist.default_discount_id')
+ product_pricelist_default_discount_id = int(product_pricelist_default_discount_id)
+ data = {
+ 'id': product_template.id,
+ 'image': self.env['ir.attachment'].api_image('product.template', 'image_128', product_template.id),
+ 'code': product_template.default_code or '',
+ 'name': product_template.name,
+ 'lowest_price': self.env['product.pricelist'].get_lowest_product_variant_price(product_template, product_pricelist_default_discount_id),
+ 'variant_total': len(product_template.product_variant_ids),
+ 'stock_total': product_template.qty_stock_vendor,
+ 'weight': product_template.weight,
+ 'manufacture': self.api_manufacture(product_template),
+ 'categories': self.api_categories(product_template),
+ }
+
+ if with_detail != '':
+ data_with_detail = {
+ 'image': self.env['ir.attachment'].api_image('product.template', 'image_512', product_template.id),
+ 'display_name': product_template.display_name,
+ 'variants': [self.env['product.product'].v2_api_single_response(variant) for variant in product_template.product_variant_ids],
+ 'description': product_template.website_description or '',
+ }
+ data.update(data_with_detail)
+
+ if with_detail == 'SOLR':
+ is_image_found = self.env['ir.attachment'].is_found('product.template', 'image_128', product_template.id)
+ rate = 0
+ if data['lowest_price']['price'] > 0:
+ rate += 1
+ if product_template.have_promotion_program:
+ rate += 1
+ if is_image_found:
+ rate += 1
+ if product_template.website_description:
+ rate += 1
+ if product_template.qty_stock_vendor > 0:
+ rate += 1
+ data_with_detail = {
+ 'solr_flag': product_template.solr_flag,
+ 'product_rating': rate,
+ 'search_rank': product_template.search_rank,
+ 'search_rank_weekly': product_template.search_rank_weekly
+ }
+ data.update(data_with_detail)
+ return data
+
def api_manufacture(self, product_template):
if product_template.x_manufacture:
manufacture = product_template.x_manufacture