51 lines
1.7 KiB
Python
51 lines
1.7 KiB
Python
from datetime import datetime, timezone
|
|
from app.api.enums.loan_status import LoanStatus
|
|
from app.extensions import db
|
|
from app.models.customer import Customer
|
|
from app.models.loan import Loan
|
|
from sqlalchemy.exc import IntegrityError
|
|
from sqlalchemy.sql import func
|
|
|
|
|
|
class Repayment(db.Model):
|
|
__tablename__ = 'repayments'
|
|
|
|
id = db.Column(
|
|
db.Integer,
|
|
primary_key=True,
|
|
autoincrement=True,
|
|
)
|
|
loan_id = db.Column(db.String(50), nullable=False)
|
|
customer_id = db.Column(db.String(50), nullable=False)
|
|
product_id = db.Column(db.String(20), nullable=True)
|
|
created_at = db.Column(db.DateTime(timezone=True), server_default=func.now())
|
|
updated_at = db.Column(db.DateTime(timezone=True), server_default=func.now(), onupdate=func.now())
|
|
transaction_id = db.Column(db.String(50), nullable=True)
|
|
|
|
@classmethod
|
|
def create_repayment(cls, customer_id, loan, transaction_id):
|
|
|
|
# Check that the loan is active
|
|
if loan.status not in [LoanStatus.ACTIVE, LoanStatus.START_REPAY]:
|
|
raise ValueError(f"Repayment cannot be processed. Loan status: ({loan.status})")
|
|
|
|
|
|
repayment = cls(
|
|
customer_id=customer_id,
|
|
loan_id=loan.id,
|
|
product_id=loan.product_id,
|
|
transaction_id = transaction_id,
|
|
created_at=datetime.now(timezone.utc),
|
|
updated_at=datetime.now(timezone.utc)
|
|
)
|
|
|
|
try:
|
|
db.session.add(repayment)
|
|
except IntegrityError as err:
|
|
raise ValueError(f"Database integrity error: {err}")
|
|
|
|
return repayment
|
|
|
|
def __repr__(self):
|
|
return f'<Repayment {self.id}>'
|