package gov.nist.javax.sip.parser.ims;
/*
* Conditions Of Use
*
* This software was developed by employees of the National Institute of
* Standards and Technology (NIST), an agency of the Federal Government.
* Pursuant to title 15 Untied States Code Section 105, works of NIST
* employees are not subject to copyright protection in the United States
* and are considered to be in the public domain. As a result, a formal
* license is not needed to use the software.
*
* This software is provided by NIST as a service and is expressly
* provided "AS IS." NIST MAKES NO WARRANTY OF ANY KIND, EXPRESS, IMPLIED
* OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTY OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT
* AND DATA ACCURACY. NIST does not warrant or make any representations
* regarding the use of the software or the results thereof, including but
* not limited to the correctness, accuracy, reliability or usefulness of
* the software.
*
* Permission to use this software is contingent upon your acceptance
* of the terms of this agreement
*
* .
*
*/
import java.text.ParseException;
import javax.sip.InvalidArgumentException;
import gov.nist.javax.sip.header.SIPHeader;
import gov.nist.javax.sip.header.ims.PPreferredService;
import gov.nist.javax.sip.header.ims.ParameterNamesIms;
import gov.nist.javax.sip.parser.HeaderParser;
import gov.nist.javax.sip.parser.Lexer;
import gov.nist.javax.sip.parser.TokenTypes;
/**
*
* @author aayush.bhatnagar
* Rancore Technologies Pvt Ltd, Mumbai India.
*
* Parse this:
* P-Preferred-Service: urn:urn-7:3gpp-service.exampletelephony.version1
*
*/
public class PPreferredServiceParser extends HeaderParser implements TokenTypes{
protected PPreferredServiceParser(Lexer lexer) {
super(lexer);
}
public PPreferredServiceParser(String pps)
{
super(pps);
}
/**
* "The URN consists of a hierarchical service identifier or application
* identifier, with a sequence of labels separated by periods.The left-most label is
* the most significant one and is called 'top-level service
* identifier', while names to the right are called 'sub-services' or
* 'sub-applications'.
*
* For any given service identifier, labels can be removed right-to-left and
* the resulting URN is still valid, referring a more generic
* service, with the exception of the top-level service identifier
* and possibly the first sub-service or sub-application identifier.
*
* Labels cannot be removed beyond a defined basic service, for
* example, the label w.x may define a service, but the label w may
* only define an assignment authority for assigning subsequent
* values and not define a service in its own right. In other words,
* if a service identifier 'w.x.y.z' exists, the URNs 'w.x' and
* 'w.x.y' are also valid service identifiers, but w may not be a
* valid service identifier if it merely defines who is responsible"
*
* TODO: PLEASE VALIDATE MY UNDERSTANDING OF THE ABOVE TEXT :)
* @ranga: Please validate my understanding of the above text in the draft :)
* This last para is a little ambiguous.I will only check that atleast
* 1 sub-service or 1 sub-application is present in the URN declaration.
* If not, I throw an exception. I thought of not throwing an exception
* and returning whatever was encoded..but the resultant encoding wont
* make sense. It would be something like-->
* urn:urn-7:3gpp-service OR urn:urn-7:3gpp-application alone with no sub-services
* or sub-applications. This is bound to cause an error at the recepient later.
*
* Sub-service and Application identifiers are not maintained by IANA and
* are organization/application dependent (Section 8.2). So we cannot gurantee what lies
* beyond the first sub-service or sub-application identifier. It should be the responsibility
* of the application to make sense of the entire URN holistically. We can only check for the
* standardized part as per the ABNF.
*/
public SIPHeader parse() throws ParseException {
if(debug)
dbg_enter("PPreferredServiceParser.parse");
try
{
this.lexer.match(TokenTypes.P_PREFERRED_SERVICE);
this.lexer.SPorHT();
this.lexer.match(':');
this.lexer.SPorHT();
PPreferredService pps = new PPreferredService();
String urn = this.lexer.getBuffer();
if(urn.contains(ParameterNamesIms.SERVICE_ID)){
if(urn.contains(ParameterNamesIms.SERVICE_ID_LABEL))
{
String serviceID = urn.split(ParameterNamesIms.SERVICE_ID_LABEL+".")[1];
if(serviceID.trim().equals(""))
try {
throw new InvalidArgumentException("URN should atleast have one sub-service");
} catch (InvalidArgumentException e) {
e.printStackTrace();
}
else
pps.setSubserviceIdentifiers(serviceID);
}
else if(urn.contains(ParameterNamesIms.APPLICATION_ID_LABEL))
{
String appID = urn.split(ParameterNamesIms.APPLICATION_ID_LABEL)[1];
if(appID.trim().equals(""))
try {
throw new InvalidArgumentException("URN should atleast have one sub-application");
} catch (InvalidArgumentException e) {
e.printStackTrace();
}
else
pps.setApplicationIdentifiers(appID);
}
else
{
try {
throw new InvalidArgumentException("URN is not well formed");
} catch (InvalidArgumentException e) {
e.printStackTrace();
}
}
}
super.parse();
return pps;
}
finally{
if(debug)
dbg_enter("PPreferredServiceParser.parse");
}
}
}