summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/api_v1/flash_sale.py
diff options
context:
space:
mode:
authorIT Fixcomart <it@fixcomart.co.id>2022-10-12 16:52:46 +0700
committerIT Fixcomart <it@fixcomart.co.id>2022-10-12 16:52:46 +0700
commitc4b6e2d594b8cbd7d424673d04741a1a4cb2ff81 (patch)
treeda13382d8d442a991a23e058f2021e0a96c73c87 /indoteknik_api/controllers/api_v1/flash_sale.py
parentdae117ce9bb219557c9a4fc995e93bc4a88ea03f (diff)
Update Feature:
- filter product_name, manufactures, categories in flash sale - add categories in product response - create get manufacture and category by page
Diffstat (limited to 'indoteknik_api/controllers/api_v1/flash_sale.py')
-rw-r--r--indoteknik_api/controllers/api_v1/flash_sale.py24
1 files changed, 21 insertions, 3 deletions
diff --git a/indoteknik_api/controllers/api_v1/flash_sale.py b/indoteknik_api/controllers/api_v1/flash_sale.py
index 5addd7fe..7f0166ee 100644
--- a/indoteknik_api/controllers/api_v1/flash_sale.py
+++ b/indoteknik_api/controllers/api_v1/flash_sale.py
@@ -1,6 +1,5 @@
from datetime import datetime
import logging
-from urllib import response
from .. import controller
from odoo import http
from odoo.http import request
@@ -14,12 +13,31 @@ class FlashSale(controller.Controller):
@http.route(prefix + 'flash_sale', auth='public', methods=['GET'])
def get_flash_sale(self, **kw):
try:
- self.authenticate()
+ if not self.authenticate():
+ return self.response(code=401, description='Unauthorized')
base_url = request.env['ir.config_parameter'].get_param('web.base.url')
active_flash_sale = request.env['product.pricelist'].get_active_flash_sale()
data = {}
if active_flash_sale:
- product_variant_ids = [x.product_id.id for x in active_flash_sale.item_ids]
+ flash_sale_product_variant_ids = [x.product_id.id for x in active_flash_sale.item_ids]
+ query = [('id', 'in', flash_sale_product_variant_ids)]
+
+ product_name = kw.get('product_name')
+ if product_name:
+ product_name = '%' + product_name.replace(' ', '%') + '%'
+ query += ['|', ('name', 'ilike', product_name), ('default_code', 'ilike', product_name)]
+
+ manufactures = kw.get('manufactures')
+ if manufactures:
+ query += [('x_manufacture', 'in', [int(x) for x in manufactures.split(',')])]
+
+ categories = kw.get('categories')
+ if categories:
+ query += [('public_categ_ids', 'child_of', [int(x) for x in categories.split(',')])]
+
+ product_variants = request.env['product.product'].search(query)
+ product_variant_ids = [x.id for x in product_variants]
+
query = [('product_variant_ids', 'in', product_variant_ids)]
product_templates = self.search_filter('product.template', kw, query)
data = {