2023-02-27 15:28:45 +08:00
|
|
|
# The Mia! Accounting Flask Project.
|
|
|
|
# Author: imacat@mail.imacat.idv.tw (imacat), 2023/2/19
|
|
|
|
|
|
|
|
# Copyright (c) 2023 imacat.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
"""The path converters for the transaction management.
|
|
|
|
|
|
|
|
"""
|
|
|
|
from datetime import date
|
|
|
|
|
|
|
|
from flask import abort
|
2023-03-17 22:32:01 +08:00
|
|
|
from sqlalchemy.orm import selectinload
|
2023-02-27 15:28:45 +08:00
|
|
|
from werkzeug.routing import BaseConverter
|
|
|
|
|
2023-03-17 22:32:01 +08:00
|
|
|
from accounting.models import Transaction, JournalEntry
|
2023-03-04 19:39:13 +08:00
|
|
|
from accounting.utils.txn_types import TransactionType
|
2023-02-27 15:28:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
class TransactionConverter(BaseConverter):
|
|
|
|
"""The transaction converter to convert the transaction ID from and to the
|
|
|
|
corresponding transaction in the routes."""
|
|
|
|
|
|
|
|
def to_python(self, value: str) -> Transaction:
|
|
|
|
"""Converts a transaction ID to a transaction.
|
|
|
|
|
|
|
|
:param value: The transaction ID.
|
|
|
|
:return: The corresponding transaction.
|
|
|
|
"""
|
2023-03-17 22:32:01 +08:00
|
|
|
transaction: Transaction | None = Transaction.query\
|
|
|
|
.join(JournalEntry)\
|
|
|
|
.filter(Transaction.id == value)\
|
|
|
|
.options(selectinload(Transaction.entries)
|
|
|
|
.selectinload(JournalEntry.offsets)
|
|
|
|
.selectinload(JournalEntry.transaction))\
|
|
|
|
.first()
|
2023-02-27 15:28:45 +08:00
|
|
|
if transaction is None:
|
|
|
|
abort(404)
|
|
|
|
return transaction
|
|
|
|
|
|
|
|
def to_url(self, value: Transaction) -> str:
|
|
|
|
"""Converts a transaction to its ID.
|
|
|
|
|
|
|
|
:param value: The transaction.
|
|
|
|
:return: The ID.
|
|
|
|
"""
|
|
|
|
return str(value.id)
|
|
|
|
|
|
|
|
|
|
|
|
class TransactionTypeConverter(BaseConverter):
|
|
|
|
"""The transaction converter to convert the transaction type ID from and to
|
|
|
|
the corresponding transaction type in the routes."""
|
|
|
|
|
2023-03-04 19:39:13 +08:00
|
|
|
def to_python(self, value: str) -> TransactionType:
|
2023-02-27 15:28:45 +08:00
|
|
|
"""Converts a transaction ID to a transaction.
|
|
|
|
|
|
|
|
:param value: The transaction ID.
|
|
|
|
:return: The corresponding transaction.
|
|
|
|
"""
|
2023-03-04 19:39:13 +08:00
|
|
|
type_dict: dict[str, TransactionType] \
|
|
|
|
= {x.value: x for x in TransactionType}
|
|
|
|
txn_type: TransactionType | None = type_dict.get(value)
|
2023-02-27 15:28:45 +08:00
|
|
|
if txn_type is None:
|
|
|
|
abort(404)
|
|
|
|
return txn_type
|
|
|
|
|
2023-03-04 19:39:13 +08:00
|
|
|
def to_url(self, value: TransactionType) -> str:
|
2023-02-27 15:28:45 +08:00
|
|
|
"""Converts a transaction type to its ID.
|
|
|
|
|
|
|
|
:param value: The transaction type.
|
|
|
|
:return: The ID.
|
|
|
|
"""
|
2023-03-04 19:30:04 +08:00
|
|
|
return str(value.value)
|
2023-02-27 15:28:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
class DateConverter(BaseConverter):
|
|
|
|
"""The date converter to convert the ISO date from and to the
|
|
|
|
corresponding date in the routes."""
|
|
|
|
|
|
|
|
def to_python(self, value: str) -> date:
|
|
|
|
"""Converts an ISO date to a date.
|
|
|
|
|
|
|
|
:param value: The ISO date.
|
|
|
|
:return: The corresponding date.
|
|
|
|
"""
|
|
|
|
try:
|
|
|
|
return date.fromisoformat(value)
|
|
|
|
except ValueError:
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
def to_url(self, value: date) -> str:
|
|
|
|
"""Converts a date to its ISO date.
|
|
|
|
|
|
|
|
:param value: The date.
|
|
|
|
:return: The ISO date.
|
|
|
|
"""
|
|
|
|
return value.isoformat()
|