From 506b3f58c116e395f6a89e5b6aadf89fe5a7a40e Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Thu, 26 Jan 2023 14:28:28 +0700 Subject: midtrans implementation --- indoteknik_api/controllers/api_v1/sale_order.py | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'indoteknik_api/controllers/api_v1') diff --git a/indoteknik_api/controllers/api_v1/sale_order.py b/indoteknik_api/controllers/api_v1/sale_order.py index 90dee56c..f5569afe 100644 --- a/indoteknik_api/controllers/api_v1/sale_order.py +++ b/indoteknik_api/controllers/api_v1/sale_order.py @@ -7,6 +7,19 @@ class SaleOrder(controller.Controller): prefix = '/api/v1/' PREFIX_PARTNER = prefix + 'partner//' + @http.route(prefix + "sale_order_number", auth='public', method=['GET', 'OPTIONS']) + def get_number_sale_order(self, **kw): + user_token = self.authenticate() + if not user_token: + return self.unauthorized_response() + + sale_order_id = int(kw.get('sale_order_id', '0')) + if sale_order_id <= 0: + return self.unauthorized_response() + + sales = request.env['sale.order'].search_read([('id', '=', sale_order_id)], fields=['id', 'name', 'amount_total']) + return self.response(sales) + @http.route(PREFIX_PARTNER + 'sale_order', auth='public', method=['GET', 'OPTIONS']) def get_partner_sale_order(self, **kw): user_token = self.authenticate() -- cgit v1.2.3 From 60a88ed7262278131a02c2f9ed0490a80d8b2abf Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Thu, 26 Jan 2023 16:19:44 +0700 Subject: add parameter sale number --- indoteknik_api/controllers/api_v1/sale_order.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'indoteknik_api/controllers/api_v1') diff --git a/indoteknik_api/controllers/api_v1/sale_order.py b/indoteknik_api/controllers/api_v1/sale_order.py index f5569afe..f2ec8dfe 100644 --- a/indoteknik_api/controllers/api_v1/sale_order.py +++ b/indoteknik_api/controllers/api_v1/sale_order.py @@ -14,10 +14,12 @@ class SaleOrder(controller.Controller): return self.unauthorized_response() sale_order_id = int(kw.get('sale_order_id', '0')) - if sale_order_id <= 0: - return self.unauthorized_response() + sale_number = str(kw.get('sale_number', '')) + if sale_order_id > 0: + sales = request.env['sale.order'].search_read([('id', '=', sale_order_id)], fields=['id', 'name', 'amount_total', 'state']) + else: + sales = request.env['sale.order'].search_read([('name', '=', sale_number)], fields=['id', 'name', 'amount_total', 'state']) - sales = request.env['sale.order'].search_read([('id', '=', sale_order_id)], fields=['id', 'name', 'amount_total']) return self.response(sales) @http.route(PREFIX_PARTNER + 'sale_order', auth='public', method=['GET', 'OPTIONS']) -- cgit v1.2.3 From e48e4626b94f7e09b3bab95937cf4b7a5ca07e40 Mon Sep 17 00:00:00 2001 From: Rafi Zadanly Date: Thu, 26 Jan 2023 17:00:04 +0700 Subject: api invoice and invoice detail --- indoteknik_api/controllers/api_v1/__init__.py | 1 + indoteknik_api/controllers/api_v1/invoice.py | 89 +++++++++++++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100644 indoteknik_api/controllers/api_v1/invoice.py (limited to 'indoteknik_api/controllers/api_v1') diff --git a/indoteknik_api/controllers/api_v1/__init__.py b/indoteknik_api/controllers/api_v1/__init__.py index e09b8f7b..a4776503 100644 --- a/indoteknik_api/controllers/api_v1/__init__.py +++ b/indoteknik_api/controllers/api_v1/__init__.py @@ -5,6 +5,7 @@ from . import category from . import city from . import district from . import flash_sale +from . import invoice from . import manufacture from . import partner from . import product_variant diff --git a/indoteknik_api/controllers/api_v1/invoice.py b/indoteknik_api/controllers/api_v1/invoice.py new file mode 100644 index 00000000..5a6e8316 --- /dev/null +++ b/indoteknik_api/controllers/api_v1/invoice.py @@ -0,0 +1,89 @@ +from .. import controller +from odoo import http +from odoo.http import request + + +class Invoice(controller.Controller): + PREFIX = '/api/v1/' + PREFIX_PARTNER = PREFIX + 'partner//' + + @http.route(PREFIX_PARTNER + 'invoice', auth='public', method=['GET', 'OPTIONS']) + def get_partner_invoice(self, **kw): + user_token = self.authenticate() + if not user_token: + return self.unauthorized_response() + + params = self.get_request_params(kw, { + 'partner_id': ['number'], + 'name': [], + 'limit': ['default:0', 'number'], + 'offset': ['default:0', 'number'], + }) + limit = params['value']['limit'] + offset = params['value']['offset'] + if not user_token['partner_id'] == params['value']['partner_id']: + return self.unauthorized_response() + if not params['valid']: + return self.response(code=400, description=params) + + partner_child_ids = self.get_partner_child_ids(params['value']['partner_id']) + domain = [ + ('move_type', '=', 'out_invoice'), + ('state', '=', 'posted'), + ('partner_id', 'in', partner_child_ids) + ] + if params['value']['name']: + name = params['value']['name'].replace(' ', '%') + domain.append(('name', 'ilike', '%'+ name +'%')) + invoices = request.env['account.move'].search(domain, offset=offset, limit=limit) + data = { + 'invoice_total': request.env['account.move'].search_count(domain), + 'invoices': [request.env['account.move'].api_v1_single_response(x) for x in invoices] + } + return self.response(data) + + @http.route(PREFIX_PARTNER + 'invoice/', auth='public', method=['GET', 'OPTIONS']) + def get_partner_invoice_by_id(self, **kw): + user_token = self.authenticate() + if not user_token: + return self.unauthorized_response() + + params = self.get_request_params(kw, { + 'partner_id': ['number'], + 'id': ['number'] + }) + if not user_token['partner_id'] == params['value']['partner_id']: + return self.unauthorized_response() + if not params['valid']: + return self.response(code=400, description=params) + + partner_child_ids = self.get_partner_child_ids(params['value']['partner_id']) + domain = [ + ('move_type', '=', 'out_invoice'), + ('state', '=', 'posted'), + ('id', '=', params['value']['id']), + ('partner_id', 'in', partner_child_ids) + ] + data = {} + account_move = request.env['account.move'].search(domain) + if account_move: + res_users = request.env['res.users'] + data = { + 'id': account_move.id, + 'name': account_move.name, + 'purchase_order_name': account_move.ref or '', + 'payment_term': account_move.invoice_payment_term_id.name or '', + 'sales': account_move.invoice_user_id.name, + 'amount_total': account_move.amount_total, + 'amount_residual': account_move.amount_residual, + 'invoice_date': account_move.invoice_date.strftime('%d/%m/%Y') or '', + 'invoice_date_due': account_move.invoice_date_due.strftime('%d/%m/%Y') or '', + 'customer': res_users.api_address_response(account_move.partner_id), + 'products': [], + } + for line in account_move.invoice_line_ids: + product = request.env['product.product'].api_single_response(line.product_id) + product['quantity'] = line.quantity + data['products'].append(product) + + return self.response(data) -- cgit v1.2.3