Class AssistPaymentManager

java.lang.Object
ru.bitel.bgbilling.modules.assist.server.bean.AssistPaymentManager

public class AssistPaymentManager extends Object
Менеджер платежей ассист, записи о платежах/транзакциях в БД биллинга.
  • Field Details

    • DEFAULT_PAYMENT_COMMENT

      public static String DEFAULT_PAYMENT_COMMENT
  • Constructor Details

    • AssistPaymentManager

      public AssistPaymentManager(Connection con, int mid)
  • 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.1999
      status - статусов маска (комбинация из 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

      public AssistPayment getPayment(int cid, long id) throws ru.bitel.bgbilling.common.BGException
      Чтение одного платежа через его id и через cid (опционально). Также заполняется название договора.
      Parameters:
      cid - контрактИд, если надо специфицировать, или -1, если игнорировать этот параметр. Для пущей надёжности сделано, так что пренебрегать - чревато! Название договора заполняется независимо от этого параметра.
      id - идПлатежа (он же "номер заказа" в терминах всей платёжной цепочки)
      Returns:
      объект Payment (или null если нужного не найдено)
      Throws:
      SQLException
      ru.bitel.bgbilling.common.BGException
    • updatePayment

      public void updatePayment(AssistPayment payment) throws ru.bitel.bgbilling.common.BGException
      Обновляет платеж
      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