Реализация стандартного шлюза Manad на BeanShell

Материал из BiTel WiKi

(Различия между версиями)
Перейти к: навигация, поиск
(убрал обраюотчиики событий из скрипта, чтобы было понятно где он падает)
Строка 27: Строка 27:
   
   
   
   
-
try
 
-
{
 
socket = new Socket( host, port );
socket = new Socket( host, port );
out = new PrintWriter( socket.getOutputStream(), true );
out = new PrintWriter( socket.getOutputStream(), true );
Строка 37: Строка 35:
kods = in.readLine();
kods = in.readLine();
   
   
-
        if ( log.isDebugEnabled() )
+
                if ( log.isDebugEnabled() )
-
        {
+
                {
-
            log.debug( gid + " Test => " + kods + "\n" );
+
                    log.debug( gid + " Test => " + kods + "\n" );
-
        }
+
                }
   
   
// список открытых договоров с шлюза
// список открытых договоров с шлюза
Строка 95: Строка 93:
in.close();
in.close();
out.close();
out.close();
-
socket.close();
+
socket.close();
-
}
+
-
catch ( e )
+
-
{
+
-
                e.printStackTrace();
+
-
log.error( "error while gate sync :" + e.getMessage(), e );
+
-
throw new RuntimeException ( e );
+
-
}
+
}
}
   
   

Версия 12:06, 7 апреля 2009

конфигурация типа шлюза :

user_rule.editor.class=bitel.billing.module.services.ipn.editor.ManadContractRuleEditor
gate_manager.class=bitel.billing.server.ipn.ManadGateWorker
use.script=1

Код :

import java.io.*;
import java.net.*;
import java.util.*;
import bitel.billing.common.module.ipn.*;
import bitel.billing.server.ipn.bean.*;
 
void doSync()
{
	host = gate.getHost();
	port = gate.getPort();
	gid = gate.getId();
 
	if ( log.isDebugEnabled() )
	{
	    log.debug( gid + " gate: " + host + ":" + port );
	}
 
 
		socket = new Socket( host, port );
		out = new PrintWriter( socket.getOutputStream(), true );
		isr = new InputStreamReader( socket.getInputStream() );
		in = new BufferedReader( isr );
 
		out.println( "test" );
		kods = in.readLine();
 
                if ( log.isDebugEnabled() )
                {
                    log.debug( gid + " Test => " + kods + "\n" );
                }
 
		// список открытых договоров с шлюза
		gateRules = new HashSet( 5, 5 );
		st = new StringTokenizer( kods );
		while ( st.hasMoreTokens() )
		{
			gateRules.add( new Integer( st.nextToken() ) );
		}
 
		for( i = 0; i < statusList.size(); i++ )
		{
			status = statusList.get(i);
			cid = status.contractId;
 
			// флаг того то правило есть на шлюзе
			flag = false;
 
			// правило для этого договора есть на шлюзе
			if ( gateRules.contains( cid ) )
			{
				//	если правило есть а юзер заблокирован - удаляем правило
				if ( status.status > 0 )
                {
					rule = getRule( status );
					command = "remove\t" + cid.intValue() + "\t" + rule;
					out.println( command );
                    if ( log.isDebugEnabled() )
                    {
                        log.debug( gid + " " + command );
                    }
                }						
 
				flag = true;
				gateRules.remove( cid );
			}
 
			// правила нет, а юзер открыт 
			if ( !flag && 
				status.status == IPNContractStatus.STATUS_OPEN )
			{
				rule = getRule( status );
 
				command = "add\t" + cid.intValue() + "\t" + rule;
				out.println( command );
 
			    if ( log.isDebugEnabled() )
                {
                    log.debug( gid + " " + command );
                }
			}
		}
 
		in.close();
		out.close();
		socket.close();	
}
 
getRule( status )
{
	rule = null;
 
	// пользовательское правило, без типа
	if( status.ruleType == null )
	{
		rule = status.rule.getRuleText();
	}
	// типизированное правило
	else
	{	
		rule = generateRule( status.rule.getRuleText(), status.gateType, status.ruleType );			
	}
 
	rule = rule.replaceAll( "\r", "" );
	rule = rule.replaceAll( "\n", "|" );
 
	return rule;
}	
 
generateRule( addresses, gateType, ruleType )
{
    ruleText = ManadUtils.getRule( gateType, ruleType );
    return ManadUtils.generateRule( ruleText, addresses, null, ruleType );    	
}
Личные инструменты