diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2023-04-28 09:03:04 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2023-04-28 09:03:04 +0700 |
| commit | 57d55f545da0fc501a9828bb3ca2988f126b241a (patch) | |
| tree | 75b98126546eea20b90ca777b2887b4813946871 /indoteknik_api/controllers/api_v1 | |
| parent | 3592c254ca5baf4a0a769f500f9e28a9cbc272a7 (diff) | |
| parent | 6fa5de951abc02884eb37cdc6786c0f3d141ccc5 (diff) | |
Merge branch 'staging' into release
Diffstat (limited to 'indoteknik_api/controllers/api_v1')
| -rw-r--r-- | indoteknik_api/controllers/api_v1/__init__.py | 1 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/flash_sale.py | 2 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/lead.py | 26 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/sale_order.py | 42 | ||||
| -rw-r--r-- | indoteknik_api/controllers/api_v1/user.py | 73 |
5 files changed, 120 insertions, 24 deletions
diff --git a/indoteknik_api/controllers/api_v1/__init__.py b/indoteknik_api/controllers/api_v1/__init__.py index 682cb369..5d5f723b 100644 --- a/indoteknik_api/controllers/api_v1/__init__.py +++ b/indoteknik_api/controllers/api_v1/__init__.py @@ -7,6 +7,7 @@ from . import district from . import download from . import flash_sale from . import invoice +from . import lead from . import manufacture from . import page_content from . import partner diff --git a/indoteknik_api/controllers/api_v1/flash_sale.py b/indoteknik_api/controllers/api_v1/flash_sale.py index cad2cb61..a0aaa44e 100644 --- a/indoteknik_api/controllers/api_v1/flash_sale.py +++ b/indoteknik_api/controllers/api_v1/flash_sale.py @@ -10,7 +10,7 @@ _logger = logging.getLogger(__name__) class FlashSale(controller.Controller): prefix = '/api/v1/' - @http.route(prefix + 'flashsale/header', auth='public', methods=['GET']) + @http.route(prefix + 'flashsale/header', auth='public', methods=['GET', 'OPTIONS']) @controller.Controller.must_authorized() def _get_flash_sale_header(self, **kw): try: diff --git a/indoteknik_api/controllers/api_v1/lead.py b/indoteknik_api/controllers/api_v1/lead.py new file mode 100644 index 00000000..df4f46bd --- /dev/null +++ b/indoteknik_api/controllers/api_v1/lead.py @@ -0,0 +1,26 @@ +from .. import controller +from odoo import http +from odoo.http import request + +class Lead(controller.Controller): + @http.route('/api/v1/lead', auth='public', methods=['POST', 'OPTIONS'], csrf=False) + @controller.Controller.must_authorized() + def create_lead(self, **kw): + params = self.get_request_params(kw, { + "name": ["required"], + "contact_name": [], + "email_from": [], + "phone": [], + "file_npwp": [], + "file_nib": [], + "file_tdp": [], + "file_siup": [], + "description": [] + }) + + if not params['valid']: + return self.response(code=400, description=params) + + lead = request.env['crm.lead'].create(params['value']) + + return self.response(True)
\ No newline at end of file diff --git a/indoteknik_api/controllers/api_v1/sale_order.py b/indoteknik_api/controllers/api_v1/sale_order.py index 76fbfddb..425dd296 100644 --- a/indoteknik_api/controllers/api_v1/sale_order.py +++ b/indoteknik_api/controllers/api_v1/sale_order.py @@ -53,6 +53,7 @@ class SaleOrder(controller.Controller): 'name': [], 'limit': ['default:0', 'number'], 'offset': ['default:0', 'number'], + 'context': [] }) limit = params['value']['limit'] offset = params['value']['offset'] @@ -61,6 +62,13 @@ class SaleOrder(controller.Controller): partner_child_ids = self.get_partner_child_ids(params['value']['partner_id']) domain = [('partner_id', 'in', partner_child_ids)] + + context = params['value']['context'] + if context == 'quotation': + domain += [('approval_status', '=', False)] + if not context: + domain += [('approval_status', '!=', False)] + if params['value']['name']: name = params['value']['name'].replace(' ', '%') domain += [ @@ -213,8 +221,11 @@ class SaleOrder(controller.Controller): @http.route(PREFIX_PARTNER + 'sale_order/checkout', auth='public', method=['POST', 'OPTIONS'], csrf=False) @controller.Controller.must_authorized(private=True, private_key='partner_id') def create_partner_sale_order(self, **kw): - product_pricelist_default_discount_id = request.env['ir.config_parameter'].get_param('product.pricelist.default_discount_id') - product_pricelist_default_discount_id = int(product_pricelist_default_discount_id) + config = request.env['ir.config_parameter'] + product_pricelist_default_discount_id = int(config.get_param('product.pricelist.default_discount_id')) + product_pricelist_tier1 = int(config.get_param('product.pricelist.tier1')) + product_pricelist_tier2 = int(config.get_param('product.pricelist.tier2')) + product_pricelist_tier3 = int(config.get_param('product.pricelist.tier3')) params = self.get_request_params(kw, { 'partner_id': ['number'], @@ -232,7 +243,7 @@ class SaleOrder(controller.Controller): parameters = { 'warehouse_id': 8, 'carrier_id': 1, - 'sales_tax_id': 23, + 'sales_tax_id': 21, 'pricelist_id': product_pricelist_default_discount_id, 'payment_term_id': 26, 'team_id': 2, @@ -252,15 +263,36 @@ class SaleOrder(controller.Controller): sale_order = request.env['sale.order'].create([parameters]) order_line = json.loads(params['value']['order_line']) parameters = [] + + partner = request.env['res.partner'].browse(params['value']['partner_id']) + partner_pricelist = partner.property_product_pricelist for line in order_line: product = request.env['product.product'].search([('id', '=', line['product_id'])], limit=1) + discount = product._get_website_disc(0) + + price_tier = False + pricelist = { + 'tier1': product._get_pricelist_tier1, + 'tier2': product._get_pricelist_tier2, + 'tier3': product._get_pricelist_tier3, + } + partner_pricelist_id = partner_pricelist.id if partner_pricelist else False + if partner_pricelist_id == product_pricelist_tier1: price_tier = 'tier1' + if partner_pricelist_id == product_pricelist_tier2: price_tier = 'tier2' + if partner_pricelist_id == product_pricelist_tier3: price_tier = 'tier3' + + if price_tier: + price = pricelist[price_tier]() + discount_key = 'discount_%s' % price_tier + if price[discount_key] > 0: discount = price[discount_key] + parameters.append({ 'company_id': 1, 'order_id': sale_order.id, 'product_id': line['product_id'], 'product_uom_qty': line['quantity'], - 'price_subtotal': product._get_website_price_exclude_tax(), - 'discount': product._get_website_disc(0) + 'price_unit': product._get_website_price_exclude_tax(), + 'discount': discount }) request.env['sale.order.line'].create(parameters) return self.response({ diff --git a/indoteknik_api/controllers/api_v1/user.py b/indoteknik_api/controllers/api_v1/user.py index 1f1f2413..5edb208e 100644 --- a/indoteknik_api/controllers/api_v1/user.py +++ b/indoteknik_api/controllers/api_v1/user.py @@ -118,6 +118,60 @@ class User(controller.Controller): 'user': request.env['res.users'].api_single_response(user) }) + @http.route(prefix + 'user/activation', auth='public', methods=['POST'], csrf=False) + @controller.Controller.must_authorized() + def activation_user(self, **kw): + token = kw.get('token') + if not token: + return self.response(code=400, description='token is required') + + user = request.env['res.users'].search([('activation_token', '=', token), ('active', '=', False)], limit=1) + if not user: + return self.response({'activation': False, 'reason': 'INVALID_TOKEN'}) + + user.active = True + user.activation_token = '' + return self.response({ + 'activation': True, + 'user': self.response_with_token(user) + }) + + @http.route(prefix + 'user/forgot-password', auth='public', methods=['POST'], csrf=False) + @controller.Controller.must_authorized() + def forgot_password_user(self, **kw): + email = kw.get('email') + user = self.get_user_by_email(email) + if not user: + return self.response({'success': False, 'reason': 'NOT_FOUND'}) + + token_source = string.ascii_letters + string.digits + user.reset_password_token = ''.join(random.choice(token_source) for i in range(21)) + return self.response({ + 'success': True, + 'token': user.reset_password_token, + 'user': request.env['res.users'].api_single_response(user) + }) + + @http.route(prefix + 'user/reset-password', auth='public', methods=['POST', 'OPTIONS'], csrf=False) + @controller.Controller.must_authorized() + def reset_password_user(self, **kw): + token = kw.get('token') + if not token: + return self.response(code=400, description='token is required') + + user = request.env['res.users'].search([('reset_password_token', '=', token), ('active', 'in', [False, True])], limit=1) + + if not user: + return self.response({'success': False, 'reason': 'INVALID_TOKEN'}) + + password = kw.get('password', '') + user.password = password + user.reset_password_token = '' + return self.response({ + 'success': True, + 'user': request.env['res.users'].api_single_response(user) + }) + @http.route(prefix + 'user/<id>', auth='public', methods=['PUT', 'OPTIONS'], csrf=False) @controller.Controller.must_authorized() def update_user(self, **kw): @@ -151,21 +205,4 @@ class User(controller.Controller): address = [request.env['res.users'].api_address_response(x) for x in partners] return self.response(address) - - @http.route(prefix + 'user/activation', auth='public', methods=['POST'], csrf=False) - @controller.Controller.must_authorized() - def activation_user(self, **kw): - token = kw.get('token') - if not token: - return self.response(code=400, description='token is required') - - user = request.env['res.users'].search([('activation_token', '=', token), ('active', '=', False)], limit=1) - if not user: - return self.response({'activation': False, 'reason': 'INVALID_TOKEN'}) - - user.active = True - user.activation_token = '' - return self.response({ - 'activation': True, - 'user': self.response_with_token(user) - })
\ No newline at end of file +
\ No newline at end of file |
