Class AssistPaymentManager
java.lang.Object
ru.bitel.bgbilling.modules.assist.server.bean.AssistPaymentManager
Менеджер платежей ассист, записи о платежах/транзакциях в БД биллинга.
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionint
addPayment
(int cid, BigDecimal summ, int recurringParentId) Добавляем первоначальную строку платежа, когда юзер только пытается провести платёж - заносим сюда цид, дату и сумму.void
carryOutPayment
(AssistPayment payment, Preferences moduleSetup) Проведение платежа.int
getFirstYear
(int cid) Возвращает год, с которого были платежи для этого договораgetLastRecurringForCid
(int cid, int recurringParentId) Последний рекуррентный платёж.getPayment
(int cid, long id) Чтение одного платежа через его id и через cid (опционально).static AssistPayment
getPaymentFromRS
(ResultSet rs, boolean contractTitle) getPaymentList
(int cid, Date from, Date until, int status) Платежи за период для договора с указанным статусом.getPaymentList
(Period period, int status, String f_groups, String f_orderid, String f_contract, String f_cardname, String f_cardtext, String f_billnumber) Поиск платежей по нескольким условниямvoid
updatePayment
(AssistPayment payment) Обновляет платеж
-
Field Details
-
DEFAULT_PAYMENT_COMMENT
-
-
Constructor Details
-
AssistPaymentManager
-
-
Method Details
-
addPayment
public int addPayment(int cid, BigDecimal summ, int recurringParentId) throws ru.bitel.bgbilling.common.BGException Добавляем первоначальную строку платежа, когда юзер только пытается провести платёж - заносим сюда цид, дату и сумму. Для того, чтобы ИД этой записи отдать в качестве уникального номера заказа процессинговому центру. Пока статус - "непроведённый".- Parameters:
cid
- цидsumm
- суммаrecurringParentId
- если > 0 - добавляет рекуррентный (а не обычный платёж), должно быть номер orderId родительског платежа (это у нас сущность id нашей этой же таблицы assist_payment, хранится в настрйоках assist_payment_recurring)- Returns:
- ид новой записи (ид_платежа/номер_заказа)
- Throws:
SQLException
ru.bitel.bgbilling.common.BGException
-
getPaymentList
public List<AssistPayment> getPaymentList(Period period, int status, String f_groups, String f_orderid, String f_contract, String f_cardname, String f_cardtext, String f_billnumber) throws SQLException Поиск платежей по нескольким условниям- Parameters:
period
- дата начала (может не быть) и конца (может не быть) периода. учитывается с точностью до дня (!) и включительно. то есть чтобы вывести например за один день концы промежутка должны быть равны: 01.01.1999-01.01.1999status
- статусов маска (комбинация из OK/FAIL/NEW статусов), должна быть указанаf_groups
- список групп договоров (если ничего нет, то будет маска договоров стало быть ноль и при поиске будет игнорироваться, то есть если не указано ничего, то предполагаются что все)f_orderid
- поиск по части номера ID (типа номер заказа) (может не быть)f_contract
- поиск по части номера договора (может не быть)f_cardname
- поиск по части имени держателя карты ИЛИ по части имени плательщика этой карты (может не быть)f_cardtext
- поиск по части номера карты ИЛИ части типа карты ИЛИ по части субтипа карты (может не быть)f_billnumber
- поиск по части номера платежа системы assist (может не быть)- Returns:
- список платежей удовлетворяющих этим требованиям
- Throws:
SQLException
-
getPaymentList
public List<AssistPayment> getPaymentList(int cid, Date from, Date until, int status) throws ru.bitel.bgbilling.common.BGException Платежи за период для договора с указанным статусом. Также для веба используется - все платежи за указанный месяц, используется для вывода в вебе списка платежей. Там тогда возвращаются все статусы - NEW, OK, FAIL.- Parameters:
cid
- цидfrom
- дата начала (включительно)until
- дата конца (включительно)status
- маска статусов которые надо выбрать- Returns:
- список пайментов
- Throws:
SQLException
ru.bitel.bgbilling.common.BGException
-
getPayment
Чтение одного платежа через его id и через cid (опционально). Также заполняется название договора.- Parameters:
cid
- контрактИд, если надо специфицировать, или -1, если игнорировать этот параметр. Для пущей надёжности сделано, так что пренебрегать - чревато! Название договора заполняется независимо от этого параметра.id
- идПлатежа (он же "номер заказа" в терминах всей платёжной цепочки)- Returns:
- объект Payment (или null если нужного не найдено)
- Throws:
SQLException
ru.bitel.bgbilling.common.BGException
-
updatePayment
Обновляет платеж- Parameters:
payment
-- Throws:
SQLException
ru.bitel.bgbilling.common.BGException
-
carryOutPayment
public void carryOutPayment(AssistPayment payment, Preferences moduleSetup) throws ru.bitel.bgbilling.common.BGException Проведение платежа. Проверяется, чтобы статус у переданного был OK. Используется в админке при редактировании платежа, при запросе статуса ручном и в экзекутере.- Throws:
ru.bitel.bgbilling.common.BGException
-
getPaymentFromRS
public static AssistPayment getPaymentFromRS(ResultSet rs, boolean contractTitle) throws SQLException - Throws:
SQLException
-
getFirstYear
public int getFirstYear(int cid) throws ru.bitel.bgbilling.common.BGException Возвращает год, с которого были платежи для этого договора- Parameters:
cid
- контракт_ид- Returns:
- четырёхзначное число - год
- Throws:
SQLException
ru.bitel.bgbilling.common.BGException
-
getLastRecurringForCid
public AssistPayment getLastRecurringForCid(int cid, int recurringParentId) throws ru.bitel.bgbilling.common.BGException Последний рекуррентный платёж. Для указанного договора. Для заданного родителя этого платежа (чтобы различать пдатежи от разных подключенных автоплатежей). Учитываются только проведённые или пока висящие (со статусом FAIL не считаются, что наверно логично) Берётся только последний, если есть, если нету, то будет null.- Parameters:
cid
-recurringParentId
-- Returns:
- Throws:
ru.bitel.bgbilling.common.BGException
-