summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/api_v1
diff options
context:
space:
mode:
authorRafi Zadanly <zadanlyr@gmail.com>2024-02-16 09:39:38 +0700
committerRafi Zadanly <zadanlyr@gmail.com>2024-02-16 09:39:38 +0700
commit5cf60908a43f8c74281111438415581f997efa96 (patch)
tree5d92b6487386be5dd155f636c034bc4b3a316fa9 /indoteknik_api/controllers/api_v1
parentff33c441cd031b47bcc381f1163633cf6e8586d0 (diff)
Add get all voucher api
Diffstat (limited to 'indoteknik_api/controllers/api_v1')
-rw-r--r--indoteknik_api/controllers/api_v1/voucher.py28
1 files changed, 18 insertions, 10 deletions
diff --git a/indoteknik_api/controllers/api_v1/voucher.py b/indoteknik_api/controllers/api_v1/voucher.py
index 3c056ecd..1888fe29 100644
--- a/indoteknik_api/controllers/api_v1/voucher.py
+++ b/indoteknik_api/controllers/api_v1/voucher.py
@@ -1,31 +1,39 @@
-from .. import controller
+from bs4 import BeautifulSoup
from odoo import http
from odoo.http import request
-from bs4 import BeautifulSoup
+
+from .. import controller
class Voucher(controller.Controller):
- prefix = '/api/v1/'
+ PREFIX_API = '/api/v1/'
+
+ @http.route(PREFIX_API + 'voucher', auth='public', methods=['GET', 'OPTIONS'])
+ @controller.Controller.must_authorized()
+ def get_vouchers(self, **kw):
+ vouchers = request.env['voucher'].get_active_voucher([('visibility', 'in', ['public'])])
+ vouchers = vouchers.res_format()
+ return self.response(vouchers)
- @http.route(prefix + 'user/<user_id>/voucher', auth='public', methods=['GET', 'OPTIONS'])
+ @http.route(PREFIX_API + 'user/<user_id>/voucher', auth='public', methods=['GET', 'OPTIONS'])
@controller.Controller.must_authorized(private=True, private_key='user_id')
- def get_vouchers(self, **kw):
+ def get_vouchers_by_user_id(self, **kw):
cart = request.env['website.user.cart']
code = kw.get('code')
user_id = int(kw.get('user_id', 0))
source = kw.get('source')
visibility = ['public']
- parameter = []
+ domain = []
if code:
visibility.append('private')
- parameter += [('code', '=', code)]
+ domain += [('code', '=', code)]
user_pricelist = request.env.context.get('user_pricelist')
if user_pricelist:
- parameter += [('excl_pricelist_ids', 'not in', [user_pricelist.id])]
+ domain += [('excl_pricelist_ids', 'not in', [user_pricelist.id])]
- parameter += [('visibility', 'in', visibility)]
- vouchers = request.env['voucher'].get_active_voucher(parameter)
+ domain += [('visibility', 'in', visibility)]
+ vouchers = request.env['voucher'].get_active_voucher(domain)
checkout = cart.get_user_checkout(user_id, source=source)
products = checkout['products']