BGBilling XSLT

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

Перейти к: навигация, поиск

Основная статья с описанием технологии: http://wiki.bitel.ru/index.php/XSLT

В биллинге в качестве xslt-процессора используется Xalan. Он поддерживает XSLT 1.0. Можно использовать его расширения(описаны по ссылке на описание технологий, приведенной выше) .

Также в биллинге доступны некоторые дополнительные возможности XSLT.

Содержание

Счетчик

Используется для корректного сложения дробных чисел с десятичной точкой. При использовании сложения средствами XSLT возможны погрешности округления из-за перевода десятичных дробей к числам с плавающей точкой.

Объявляется так:

<xsl:stylesheet
	version="1.0" 
	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
	xmlns:fo="http://www.w3.org/1999/XSL/Format"
	xmlns:svg="http://www.w3.org/2000/svg" 
	xmlns:xalan="http://xml.apache.org/xalan"
	xmlns:counter="bitel.billing.server.util.exslt.Counter">
	........

Используется так:

<xsl:value-of select="counter:set('total', '0.0')"/>
<xsl:value-of select="counter:add('total', '10.00')"/>
<xsl:value-of select="counter:get('total')"/>

SQL запрос

Используется для выполнения произвольных выборок из базы биллинга. Пример здесь: Квитанция телефонии физ. лицам.

Объявляется расширение так:

<xsl:stylesheet
	version="1.0" 
	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
	xmlns:fo="http://www.w3.org/1999/XSL/Format"
	xmlns:svg="http://www.w3.org/2000/svg" 
	xmlns:xalan="http://xml.apache.org/xalan"
	xmlns:sql="bitel.billing.server.util.exslt.SQLQuery">
	......

Используется так:

<xsl:variable name="query" select="'SELECT id, title FROM contract'"/>
<xsl:variable name="contracts" select="sql:select( $query )"/>
 
<xsl:for-each select="$numbers/row"/>
  	<xsl:value-of select="@id"/>
  	<xsl:value-of select="@title"/>
</xsl:for-each>

Использование произвольных методов Java класов

Например, вызов функции: http://bgbilling.ru/v4.5/javadoc/bitel/billing/common/CommonUtils.html#maskBlank(java.lang.String,%20java.lang.String) Возможен вызов любой функции с простыми параметрами (пустой список, либо строка) из любого класса, входящего в classpath BGBillingServer.

Объявляется так:

<xsl:stylesheet
	version="1.0" 
	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
	xmlns:fo="http://www.w3.org/1999/XSL/Format"
	xmlns:svg="http://www.w3.org/2000/svg" 
	xmlns:xalan="http://xml.apache.org/xalan"
	xmlns:utils="bitel.billing.common.CommonUtils">
	......

Вызывается так:

<xsl:variable name="abon_service" select="utils:replace( '5555,44', ',', '')"/>

Генерация картинки со штрих-кодом

Используется вставки картинок с штрих-кодом в FO страницы. Пример здесь: Квитанция телефонии физ. лицам. На протокол barcode в процессах биллинга повешен генератор картинок с штрих-кодом. Соответсвенно, Java машина при запросе данной картинки вызывает его. В данный момент поддержан формат Code128. Используется примерно так:

<!-- 128-тип кода, затем StartA, T, K, B, CodeC  -->
<xsl:variable name="code_start" select="'128a|TKB&#199;'"/>
<!-- номер телефона (первый) - 7 символов -->
<xsl:variable name="number" select="$numbers/row/@number"/>
<!-- период оплаты - 4 символа -->
<xsl:variable name="period_opl" select="concat( $mm, $yy )"/>
<!-- сумма -->
<xsl:variable name="rub" select="substring-before(/data/bill/@total_sum,'.')"/>
<xsl:variable name="kop" select="substring-after(/data/bill/@total_sum,'.')"/>
<xsl:variable name="rub_length" select="string-length($rub)"/>
 
<fo:external-graphic width="6.5cm" height="1.1cm">
 	<xsl:attribute name="src"><xsl:value-of select="concat('barcode:///', $code_start, $number, $period_opl, $sum_part_c, '&#201;', $sum_part_a, '&lt;SOH&gt;')"/></xsl:attribute>
</fo:external-graphic>

Чтение параметра из конфигурации сервера и модулей (версия 4.6)

Предоставляет возможность читать значения из конфигурации сервера и модулей.

Объявляется так:

<xsl:stylesheet
	version="1.0" 
	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
	xmlns:fo="http://www.w3.org/1999/XSL/Format"
	xmlns:svg="http://www.w3.org/2000/svg" 
	xmlns:xalan="http://xml.apache.org/xalan"
	xmlns:setup="bitel.billing.server.util.exslt.ConfigReader">
	......
	<xalan:component prefix="setup" functions="getValue">
		<xalan:script lang="javaclass" src="xalan://bitel.billing.server.util.exslt.ConfigReader"/>
	</xalan:component>
 	......

Вызывается так:

<xsl:value-of select="setup:getValue(65,'bill.attributes' )" />

Метод:

String getValue(int mid, String name);

Значения параметров:

mid - код модуля, для которого читается конфиг, если 0 то читется из конфига сервера
name - название параметра

Возвращает:

строка - значение параметра из конфига. Если параметра нет, то пустая строка


Выполнение скрипта из библиотек скриптов (версия 4.6)

Выполняет скрипт из библиотеки скриптов.

Объявляется так:

<xsl:stylesheet
	version="1.0" 
	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
	xmlns:fo="http://www.w3.org/1999/XSL/Format"
	xmlns:svg="http://www.w3.org/2000/svg" 
	xmlns:xalan="http://xml.apache.org/xalan"
	xmlns:scriptRunner="bitel.billing.server.util.exslt.ScriptRunner">
	......
	<xalan:component prefix="scriptRunner" functions="getValue">
		<xalan:script lang="javaclass" src="xalan://bitel.billing.server.util.exslt.ScriptRunner"/>
	</xalan:component>
 	......

Вызывается так:

<xsl:value-of select="scriptRunner:run('lib1','fun1','Данные передаем')" />

Метод:

String run(String libTitle, String funTitle, String input);

Значения параметров:

libTitle - имя библиотеки
funTitle - имя функции
input - параметр передается в скрипт. Доступен в скрипте как строка input

Возвращает:

строка - значение переменной output из скрипта

В скрипте также доступны:

con - объект типа java.sql.Connection, соединение с базой биллинга
setup - объект класса bitel.billing.server.radius.RadiusSetup, конфигурация сервера RADIUS
log - обьект класса org.apache.log4j.Logger
Личные инструменты