You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
2.3 KiB
61 lines
2.3 KiB
# -*- coding: utf-8 -*-
|
|
###############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: Afra K (odoo@cybrosys.com)
|
|
#
|
|
# You can modify it under the terms of the GNU AFFERO
|
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
|
|
#
|
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
# (AGPL v3) along with this program.
|
|
# If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
###############################################################################
|
|
from odoo import http
|
|
from odoo.http import request
|
|
|
|
|
|
class CreditDetails(http.Controller):
|
|
""" Controllers to get the credit details and the credit amount of each
|
|
partner."""
|
|
|
|
@http.route('/credit/details', type='http', auth='public', website=True,
|
|
csrf=False)
|
|
def credit_details(self, **post):
|
|
""" Get the credit amount for each user and return the credit payment
|
|
page."""
|
|
credit_amount = request.env.user.credit_amount
|
|
return request.render(
|
|
'customer_credit_payment_website.credit_payment_page',
|
|
{'credit_amount': credit_amount})
|
|
|
|
@http.route('/add/credit/balance', type='http', auth='public', website=True,
|
|
csrf=False)
|
|
def add_credit_balance(self, **post):
|
|
""" Add the credit amount from the website."""
|
|
return request.render(
|
|
'customer_credit_payment_website.add_credit_payment_page')
|
|
|
|
|
|
class PaymentCreditPayController(http.Controller):
|
|
_simulation_url = '/payment/credit_pay/simulate_payment'
|
|
|
|
@http.route('/payment/credit_pay/simulate_payment', type='json',
|
|
auth='public')
|
|
def credit_pay_simulate_payment(self, **data):
|
|
""" Simulate the response of a payment request.
|
|
|
|
:param dict data: The simulated notification data.
|
|
:return: None
|
|
"""
|
|
return request.env[
|
|
'payment.transaction'].sudo()._handle_notification_data(
|
|
'credit_pay', data.get('args'))
|
|
|