Implementing Session-Based Charging
The RoApplication
can be used to create new sessions for session-based credit authorization. The RoSession
class implements the appropriate state machine depending on the credit control type, either ECUR (Event-Based Charging with Unit Reservation) or SCUR (Session-based Charging with Unit Reservation). The RoSession
class is also serializable, so it can be stored as a SIP session attribute. This allows the session to be restored when necessary to terminate the session or update credit authorization.
The example in Example 4-3 creates a new RoSession
for event-based charging, and sends a CCR request to start the first interrogation. The RoSession
instance is saved so that it can be terminated later, after the service has finished.
Note that the RoSession
class automatically handles creating session IDs; the application is not required to set the session ID.
Example 4-3 Creating and Using a RoSession
RoSession session = roApp.createSession(); CCR ccr = session.createCCR(RequestType.INITIAL); CCA cca = ccr.sendAndWait(); sipAppSession.setAttribute("RoSession", session); ...
Handling Re-Auth-Request Messages
The OCS may initiate credit re-authorization by issuing a Re-Auth-Request (RAR)
to the CTF. The application can register a session listener for handling this type of request.
Upon receiving a RAR, the Diameter subsystem invoke the session listener on the applications
corresponding RoSession
object. The application must then respond to the OCS
with an appropriate RAA message and initiate credit re-authorization to the CTF by sending a
CCR with the CC-Request-Type AVP set to the value UPDATE_REQUEST, as described in section 5.5
of RFC 4006 (http://www.ietf.org/rfc/rfc4006.txt
).
A session listener must implement the SessionListener
interface
and be serializable, or it must be an instance of SipServlet
. A Servlet can
register a listener as follows:
RoSession session = roApp.createSession(); session.addListener(new SessionListener() { public void rcvMessage(Message msg) { System.out.println("Got message: id = " msg.getSession().getId()); } }
Example 4-4 shows sample rcvMessage()
code for processing a
Re-Auth-Request.
Example 4-4 Managing a Re-Auth-Request
RoSession session = roApp.createSession(); session.addListener(new SessionListener() { public void rcvMessage(Message msg) { Request req = (Request)msg; if (req.getCommand() != Command.RE_AUTH_REQUEST) return; RoSession session = (RoSession) req.getSession(); Answer ans = req.createAnswer(); ans.setResultCode(ResultCode.LIMITED_SUCCESS); // Per RFC 4006 5.5 ans.send(); CCR ccr = session.createCCR(Ro.UPDATE_REQUEST); // Set CCR AVPs according to requested credit re-authorization... ccr.send(); CCA cca = (CCA) ccr.waitForAnswer(); }
In Example 4-4, upon receiving the Re-Auth-Request the application sends an RAA with the result code DIAMETER_LIMITED_SUCCESS to indicate to the OCS that an additional CCR request is required in order to complete the procedure. The CCR is then sent to initiate credit re-authorization.
Note:
Because the Diameter
subsystem locks the call state before delivering the request to the corresponding
RoSession
, the call state remains locked while the handler processes the
request.