summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/api_v1
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2023-04-28 09:03:04 +0700
committerstephanchrst <stephanchrst@gmail.com>2023-04-28 09:03:04 +0700
commit57d55f545da0fc501a9828bb3ca2988f126b241a (patch)
tree75b98126546eea20b90ca777b2887b4813946871 /indoteknik_api/controllers/api_v1
parent3592c254ca5baf4a0a769f500f9e28a9cbc272a7 (diff)
parent6fa5de951abc02884eb37cdc6786c0f3d141ccc5 (diff)
Merge branch 'staging' into release
Diffstat (limited to 'indoteknik_api/controllers/api_v1')
-rw-r--r--indoteknik_api/controllers/api_v1/__init__.py1
-rw-r--r--indoteknik_api/controllers/api_v1/flash_sale.py2
-rw-r--r--indoteknik_api/controllers/api_v1/lead.py26
-rw-r--r--indoteknik_api/controllers/api_v1/sale_order.py42
-rw-r--r--indoteknik_api/controllers/api_v1/user.py73
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