Go to file
2024-09-13 11:10:31 +03:00
.github TD-955: Add implementation (#1) 2024-09-04 14:23:32 +03:00
src TD-955: Add transaction rollback test. Refactoring (#13) 2024-09-13 11:10:31 +03:00
.gitignore TD-955: Add implementation (#1) 2024-09-04 14:23:32 +03:00
pom.xml TD-955: Add transaction rollback test. Refactoring (#13) 2024-09-13 11:10:31 +03:00
README.md TD-955: Add transaction rollback test. Refactoring (#13) 2024-09-13 11:10:31 +03:00
renovate.json TD-955: Add implementation (#1) 2024-09-04 14:23:32 +03:00

Liminator

Liminator - вспомогательный сервис для подсчета лимитов.


Алгоритм работы

  1. Создание лимита. Необходимо указать наименование лимита и опционально можно указать контекст (провайдер, терминал и т.п.). Если лимит с таким именем уже есть будет выброшена ошибка DuplicateLimitName
  2. Холдирование. Операция заморозки определенного лимита до финализации. Возвращает значения лимитов на момент холдирования. (если что-то пришло чуть позже на долю секунды, то не будет участвовать в подсчете даже если запись в БД уже есть). Могут быть следующие ошибки:
  • LimitNotFound - данная ошибка будет даже если какого-то одного лимита из списка переданных нет в БД
  • DuplicateOperation - данная ошибка будет передана если для связки LimitName+OperationId в БД уже имеется запись в значении HOLD
  • OperationAlreadyInFinalState - данная ошибка будет передана если для связки LimitName+OperationId в БД уже имеется запись в значении COMMIT/ROLLBACK
  1. Финализация операции (COMMIT/ROLLBACK). Применение или отмена внесенного значения. Могут быть следующие ошибки:
  • LimitNotFound - данная ошибка будет даже если какого-то одного лимита из списка переданных нет в БД
  • OperationNotFound - данная ошибка будет передана если для связки LimitName+OperationId в БД отсутствует запись в значении HOLD
  1. Получение значений по лимитам. Может быть получено как для определенной операции, так и последнее актуальное значение. Могут быть следующие ошибки:
  • LimitNotFound - если переданный лимит не найден

Важно:

  • операции производятся транзакционно, т.е. при ошибке во время получения списка лимитов для операции холдирования значение в БД будет подвергнуто роллбэку.