BiTel

Форум BiTel
bgbilling.ru     docs.bitel.ru     wiki.bitel.ru     dbinfo.bitel.ru     bgcrm.ru     billing.bitel.ru     bitel.ru    
Текущее время: 21 июн 2025, 01:10

Часовой пояс: UTC + 5 часов [ Летнее время ]




Начать новую тему Ответить на тему  [ Сообщений: 13 ] 
Автор Сообщение
 Заголовок сообщения: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 11:30 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
есть скрипт который через определенное время закрывает абонентов, выставляя ему дату закрытия, но после этого не закрывается не абонка не ТП. А когда делается руками - то все закрывается, что выполняет биллинг и что мне и где вызвать в скрипте чтоб закрывалось в скрипте все???
Код:
package ru.skyb.scripts.global;

import ru.bitel.bgbilling.kernel.script.server.dev.GlobalScriptBase;
import ru.bitel.bgbilling.server.util.Setup;
import ru.bitel.common.sql.ConnectionSet;
import java.sql.*;
import java.util.*;
import java.util.Date;

import bitel.billing.common.TimeUtils;
import bitel.billing.server.contract.bean.*;

public class archive
   extends GlobalScriptBase
{
   @Override
   public void execute( Setup setup1, ConnectionSet connectionSet2 )
      throws Exception
   {
      Connection con = connectionSet2.getConnection();   
      Calendar calendar = new GregorianCalendar();
      GregorianCalendar nowDate = (GregorianCalendar) calendar.clone();//клонируем дату для дальнейшей работы
      nowDate.get(Calendar.DATE);
      GregorianCalendar sqlDate = (GregorianCalendar) calendar.clone();
      Date dateSql = TimeUtils.convertCalendarToSqlDate(sqlDate);
      Date dateNow = TimeUtils.convertCalendarToDate(nowDate);//переводим дату в тип Date с типа Calendar
      String query = "select id from contract where gr&(1<<3)>0";
      PreparedStatement contractPs = con.prepareStatement( query );
      ResultSet contractRs = contractPs.executeQuery();
      int cid;
      int i = 0;
       while ( contractRs.next() )
          {
            cid = contractRs.getInt( 1 );
            ContractManager contract = new ContractManager(con);
            Contract ct = contract.getContractById(cid);
/*==========================close==============================

getLastBalanceMonth
public java.util.Date getLastBalanceMonth(Contract contract)
возращает самый старший месяц, за который есть данные по Балансу*/
            BalanceUtils balance = new BalanceUtils(con);            
            Date contract_balance = (Date) balance.getLastBalanceMonth(ct);
            if( contract_balance == null)
               {
                  continue;
               } 
//==========================close==============================//
            int mounth = TimeUtils.monthsDelta(contract_balance,dateNow);
            if (mounth > 6 )
               {
                  print ("Контракт с сидом " + cid);
/*         print ("Дата которая попала в жопу " + contract_balance);
         String update_query = "update contract set gr=0 where id = "+ cid;
         PreparedStatement ps = con.prepareStatement( update_query );
         ps.executeUpdate() ; */
                  String close_query = "update contract set date2 = '" + dateSql + "' where id = "+ cid;
                  PreparedStatement rs = con.prepareStatement( close_query );
                  rs.executeUpdate() ;
                  ContractParameterManager cpu = new ContractParameterManager( con );
                  cpu.setGroup( cid, 19 );
                  cpu.unsetGroup( cid, 3 );
                  cpu.unsetGroup( cid, 0 );
                  i++;
               }
   
             }
         print("кол-во " +i );
      }
}

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 11:50 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 29 мар 2010, 23:11
Сообщения: 5854
Карма: 472
closeContract братииииииииш © Павлик

_________________
Цитаты великих людей :umnik:
Напишите в helpdesk © stark
повторяю: => хелпдеск => доработка => профит © dimOn
свершилось... © skn
Мой код изящен, лёгок, оригинален, краток. Как прохладный весенний ветерок, как звонкий ручей! © dimOn
Вежливый разработчик © Artur
Эти баги тоже исправлены, как и те, которые еще не написаны © Artur
ну т.е. существует воркэраунд, ок © dimOn


Последний раз редактировалось Phricker 19 окт 2012, 11:54, всего редактировалось 1 раз.

Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 11:52 
Не в сети
Аватара пользователя

Зарегистрирован: 30 май 2008, 15:51
Сообщения: 6055
Карма: 244
никаких отличий не должно быть. разве что если что-то падает

_________________
I'm clever. I've got a computer.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 11:56 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 29 мар 2010, 23:11
Сообщения: 5854
Карма: 472
dimOn писал(а):
никаких отличий не должно быть. разве что если что-то падает

Да ничего у него не падает (по крайней мере в этом скрипте :lol: В остальном свечку не держал :lol: ). Просто этот скрипт через SQL в базе дату закрытия выставляет. А это не вызывает закрытия сущностей.
Пускай closeContract использует и будет ему счастье. Заодно новым скриптом поделится :D

_________________
Цитаты великих людей :umnik:
Напишите в helpdesk © stark
повторяю: => хелпдеск => доработка => профит © dimOn
свершилось... © skn
Мой код изящен, лёгок, оригинален, краток. Как прохладный весенний ветерок, как звонкий ручей! © dimOn
Вежливый разработчик © Artur
Эти баги тоже исправлены, как и те, которые еще не написаны © Artur
ну т.е. существует воркэраунд, ок © dimOn


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 11:59 
Не в сети
Аватара пользователя

Зарегистрирован: 30 май 2008, 15:51
Сообщения: 6055
Карма: 244
ну а как тогда пишет что закрывается?

_________________
I'm clever. I've got a computer.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:01 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
dimOn писал(а):
ну а как тогда пишет что закрывается?

Код:
String close_query = "update contract set date2 = '" + dateSql + "' where id = "+ cid;

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:03 
Не в сети
Аватара пользователя

Зарегистрирован: 30 май 2008, 15:51
Сообщения: 6055
Карма: 244
ну так это тоже не закроет сущностей то.

Цитата:
А когда делается руками - то все закрывается,
это вот что значит?

_________________
I'm clever. I've got a computer.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:12 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 29 мар 2010, 23:11
Сообщения: 5854
Карма: 472
Я почему то думал что skn ночью не спал и будет с утра тормозить ))) Так у вас там походу групповой поход по пиффку был, и только skn'а прибило и он на форум вылез :D
Этот скрипт через базу выставляет дату закрытия договора, что естественно не вызывает закрытия сущностей. Однако Скуб заметил, что если через клиент биллинга РУКАМИ установить дату закрытия договора - все его сущности закрываются. Поэтому он спрашивает в чем же дело )
Срочно кофе, Димон ))) Большую чашку :umnik:

_________________
Цитаты великих людей :umnik:
Напишите в helpdesk © stark
повторяю: => хелпдеск => доработка => профит © dimOn
свершилось... © skn
Мой код изящен, лёгок, оригинален, краток. Как прохладный весенний ветерок, как звонкий ручей! © dimOn
Вежливый разработчик © Artur
Эти баги тоже исправлены, как и те, которые еще не написаны © Artur
ну т.е. существует воркэраунд, ок © dimOn


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:13 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
Phricker писал(а):
Я почему то думал что skn ночью не спал и будет с утра тормозить ))) Так у вас там походу групповой поход по пиффку был, и только skn'а прибило и он на форум вылез :D
Этот скрипт через базу выставляет дату закрытия договора, что естественно не вызывает закрытия сущностей. Однако Скуб заметил, что если через клиент биллинга РУКАМИ установить дату закрытия договора - все его сущности закрываются. Поэтому он спрашивает в чем же дело )
Срочно кофе, Димон ))) Большую чашку :umnik:

:facepalm: :facepalm: :mrgreen: :mrgreen: :mrgreen: :mrgreen:

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:13 
Не в сети
Аватара пользователя

Зарегистрирован: 30 май 2008, 15:51
Сообщения: 6055
Карма: 244
Объяснять надо ладом :lupa:

_________________
I'm clever. I've got a computer.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:24 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
dimOn писал(а):
Объяснять надо ладом :lupa:

Дык вон, фрикер то сразу понял!!!

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:36 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
блин, а у меня он ещё выпелен, тока в среду появиццо, т.к. обновлятся буду

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: скрипт закрытия абонентов
СообщениеДобавлено: 19 окт 2012, 12:42 
Не в сети
Клиент
Аватара пользователя

Зарегистрирован: 03 авг 2009, 18:42
Сообщения: 7166
Откуда: Благовещенск
Карма: 241
на обновленном тестовом работает

Код:
package ru.skyb.scripts.global;

import ru.bitel.bgbilling.kernel.script.server.dev.GlobalScriptBase;
import ru.bitel.bgbilling.server.util.Setup;
import ru.bitel.common.sql.ConnectionSet;
import java.sql.*;
import java.util.*;
import java.util.Date;

import bitel.billing.common.TimeUtils;
import bitel.billing.server.contract.bean.*;

public class test extends GlobalScriptBase {
   @Override
   public void execute(Setup setup1, ConnectionSet connectionSet2)
         throws Exception {

      Connection con = connectionSet2.getConnection();
      Calendar calendar = new GregorianCalendar();
      GregorianCalendar nowDate = (GregorianCalendar) calendar.clone();// клонируем
                                                         // дату
                                                         // для
                                                         // дальнейшей
                                                         // работы
      nowDate.get(Calendar.DATE);
      GregorianCalendar sqlDate = (GregorianCalendar) calendar.clone();
      Date dateSql = TimeUtils.convertCalendarToSqlDate(sqlDate);
      Date dateNow = TimeUtils.convertCalendarToDate(nowDate);// переводим
                                                // дату в тип
                                                // Date с типа
                                                // Calendar
      String query = "select id from contract where gr&(1<<3)>0";
      PreparedStatement contractPs = con.prepareStatement(query);
      ResultSet contractRs = contractPs.executeQuery();
      int cid;
      int i = 0;
      while (contractRs.next()) {
         cid = contractRs.getInt(1);
         
         ContractManager contract = new ContractManager(con);
         Contract ct = contract.getContractById(cid);
         /*
          * getLastBalanceMonth public
          * java.util.Date getLastBalanceMonth(Contract contract) возращает
          * самый старший месяц, за который есть данные по Балансу
          */
         BalanceUtils balance = new BalanceUtils(con);
         Date contract_balance = (Date) balance.getLastBalanceMonth(ct);
         if (contract_balance == null) {
            continue;
         }
         // ==========================close==============================//
         int mounth = TimeUtils.monthsDelta(contract_balance, dateNow);
         if (mounth > 6) {
            print("Контракт с сидом " + cid);
            /*
             * String update_query = "update contract set gr=0 where id = "+
             * cid; PreparedStatement ps = con.prepareStatement(
             * update_query ); ps.executeUpdate() ; String close_query =
             * "update contract set date2 = '" + dateSql + "' where id = "+
             * cid; PreparedStatement rs = con.prepareStatement( close_query
             * ); rs.executeUpdate() ;
             */
            contract.closeContract(cid);
            ContractParameterManager cpu = new ContractParameterManager(con);
            cpu.setGroup(cid, 19);
            cpu.unsetGroup(cid, 3);
            cpu.unsetGroup(cid, 0);
            i++;
         }

      }
      print("кол-во " + i);
   }

}

_________________
Код:
  Клиент: вер. 6.2.714 / 25.05.2015 17:27:15
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
  Сервер: вер. 6.2.881 / 22.05.2015 17:56:55
    os: Linux; java: Java HotSpot(TM) 64-Bit Server VM, v.1.8.0_45
Помощь по администрированию bgbilling в jabber конференции или Группа в telegram
Стиль программирования - пьяный мастерстер
Разработка мобильных приложений


Вернуться к началу
 Профиль  
 
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 13 ] 

Часовой пояс: UTC + 5 часов [ Летнее время ]


Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 1


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Перейти:  
POWERED_BY
Русская поддержка phpBB
[ Time : 0.045s | 42 Queries | GZIP : On ]