All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gov.nist.javax.sip.parser.Lexer Maven / Gradle / Ivy

/*
 * 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
 *
 * .
 *
 */
package gov.nist.javax.sip.parser;

import gov.nist.core.LexerCore;
import gov.nist.javax.sip.header.extensions.JoinHeader;
import gov.nist.javax.sip.header.extensions.MinSEHeader;
import gov.nist.javax.sip.header.extensions.ReferencesHeader;
import gov.nist.javax.sip.header.extensions.ReferredByHeader;
import gov.nist.javax.sip.header.extensions.ReplacesHeader;
import gov.nist.javax.sip.header.extensions.SessionExpiresHeader;
import gov.nist.javax.sip.header.ims.PAccessNetworkInfoHeader;
import gov.nist.javax.sip.header.ims.PAssertedIdentityHeader;
import gov.nist.javax.sip.header.ims.PAssertedServiceHeader;
import gov.nist.javax.sip.header.ims.PAssociatedURIHeader;
import gov.nist.javax.sip.header.ims.PCalledPartyIDHeader;
import gov.nist.javax.sip.header.ims.PChargingFunctionAddressesHeader;
import gov.nist.javax.sip.header.ims.PChargingVectorHeader;
import gov.nist.javax.sip.header.ims.PMediaAuthorizationHeader;
import gov.nist.javax.sip.header.ims.PPreferredIdentityHeader;
import gov.nist.javax.sip.header.ims.PPreferredServiceHeader;
import gov.nist.javax.sip.header.ims.PProfileKeyHeader;
import gov.nist.javax.sip.header.ims.PServedUserHeader;
import gov.nist.javax.sip.header.ims.PUserDatabaseHeader;
import gov.nist.javax.sip.header.ims.PVisitedNetworkIDHeader;
import gov.nist.javax.sip.header.ims.PathHeader;
import gov.nist.javax.sip.header.ims.PrivacyHeader;
import gov.nist.javax.sip.header.ims.SecurityClientHeader;
import gov.nist.javax.sip.header.ims.SecurityServerHeader;
import gov.nist.javax.sip.header.ims.SecurityVerifyHeader;
import gov.nist.javax.sip.header.ims.ServiceRouteHeader;

import java.util.concurrent.ConcurrentHashMap;

import javax.sip.header.AcceptEncodingHeader;
import javax.sip.header.AcceptHeader;
import javax.sip.header.AcceptLanguageHeader;
import javax.sip.header.AlertInfoHeader;
import javax.sip.header.AllowEventsHeader;
import javax.sip.header.AllowHeader;
import javax.sip.header.AuthenticationInfoHeader;
import javax.sip.header.AuthorizationHeader;
import javax.sip.header.CSeqHeader;
import javax.sip.header.CallIdHeader;
import javax.sip.header.CallInfoHeader;
import javax.sip.header.ContactHeader;
import javax.sip.header.ContentDispositionHeader;
import javax.sip.header.ContentEncodingHeader;
import javax.sip.header.ContentLanguageHeader;
import javax.sip.header.ContentLengthHeader;
import javax.sip.header.ContentTypeHeader;
import javax.sip.header.DateHeader;
import javax.sip.header.ErrorInfoHeader;
import javax.sip.header.EventHeader;
import javax.sip.header.ExpiresHeader;
import javax.sip.header.FromHeader;
import javax.sip.header.InReplyToHeader;
import javax.sip.header.MaxForwardsHeader;
import javax.sip.header.MimeVersionHeader;
import javax.sip.header.MinExpiresHeader;
import javax.sip.header.OrganizationHeader;
import javax.sip.header.PriorityHeader;
import javax.sip.header.ProxyAuthenticateHeader;
import javax.sip.header.ProxyAuthorizationHeader;
import javax.sip.header.ProxyRequireHeader;
import javax.sip.header.RAckHeader;
import javax.sip.header.RSeqHeader;
import javax.sip.header.ReasonHeader;
import javax.sip.header.RecordRouteHeader;
import javax.sip.header.ReferToHeader;
import javax.sip.header.ReplyToHeader;
import javax.sip.header.RequireHeader;
import javax.sip.header.RetryAfterHeader;
import javax.sip.header.RouteHeader;
import javax.sip.header.SIPETagHeader;
import javax.sip.header.SIPIfMatchHeader;
import javax.sip.header.ServerHeader;
import javax.sip.header.SubjectHeader;
import javax.sip.header.SubscriptionStateHeader;
import javax.sip.header.SupportedHeader;
import javax.sip.header.TimeStampHeader;
import javax.sip.header.ToHeader;
import javax.sip.header.UnsupportedHeader;
import javax.sip.header.UserAgentHeader;
import javax.sip.header.ViaHeader;
import javax.sip.header.WWWAuthenticateHeader;
import javax.sip.header.WarningHeader;

/**
 * Lexer class for the parser.
 *
 * @version 1.2
 *
 * @author M. Ranganathan 
* * */ public class Lexer extends LexerCore { /** * get the header name of the line * * @return the header name (stuff before the :) bug fix submitted by * [email protected] */ public static String getHeaderName(String line) { if (line == null) return null; String headerName = null; try { int begin = line.indexOf(":"); headerName = null; if (begin >= 1) headerName = line.substring(0, begin).trim(); } catch (IndexOutOfBoundsException e) { return null; } return headerName; } public Lexer(String lexerName, String buffer) { super(lexerName, buffer); this.selectLexer(lexerName); } /** * get the header value of the line * * @return String */ public static String getHeaderValue(String line) { if (line == null) return null; String headerValue = null; try { int begin = line.indexOf(":"); headerValue = line.substring(begin + 1); } catch (IndexOutOfBoundsException e) { return null; } return headerValue; } public void selectLexer(String lexerName) { // Synchronization Bug fix by Robert Rosen. ConcurrentHashMap lexer = lexerTables.get(lexerName); this.currentLexerName = lexerName; if (lexer == null) { ConcurrentHashMap newLexer = new ConcurrentHashMap(); // Temporarily set newLexer as current, so addKeyword populate it currentLexer = newLexer; // addLexer(lexerName); if (lexerName.equals("method_keywordLexer")) { addKeyword(TokenNames.REGISTER, TokenTypes.REGISTER); addKeyword(TokenNames.ACK, TokenTypes.ACK); addKeyword(TokenNames.OPTIONS, TokenTypes.OPTIONS); addKeyword(TokenNames.BYE, TokenTypes.BYE); addKeyword(TokenNames.INVITE, TokenTypes.INVITE); addKeyword(TokenNames.SIP, TokenTypes.SIP); addKeyword(TokenNames.SIPS, TokenTypes.SIPS); addKeyword(TokenNames.SUBSCRIBE, TokenTypes.SUBSCRIBE); addKeyword(TokenNames.NOTIFY, TokenTypes.NOTIFY); addKeyword(TokenNames.MESSAGE, TokenTypes.MESSAGE); // JvB: added to support RFC3903 addKeyword(TokenNames.PUBLISH, TokenTypes.PUBLISH); } else if (lexerName.equals("command_keywordLexer")) { addKeyword(ErrorInfoHeader.NAME, TokenTypes.ERROR_INFO); addKeyword(AllowEventsHeader.NAME, TokenTypes.ALLOW_EVENTS); addKeyword(AuthenticationInfoHeader.NAME, TokenTypes.AUTHENTICATION_INFO); addKeyword(EventHeader.NAME, TokenTypes.EVENT); addKeyword(MinExpiresHeader.NAME, TokenTypes.MIN_EXPIRES); addKeyword(RSeqHeader.NAME, TokenTypes.RSEQ); addKeyword(RAckHeader.NAME, TokenTypes.RACK); addKeyword(ReasonHeader.NAME, TokenTypes.REASON); addKeyword(ReplyToHeader.NAME, TokenTypes.REPLY_TO); addKeyword(SubscriptionStateHeader.NAME, TokenTypes.SUBSCRIPTION_STATE); addKeyword(TimeStampHeader.NAME, TokenTypes.TIMESTAMP); addKeyword(InReplyToHeader.NAME, TokenTypes.IN_REPLY_TO); addKeyword(MimeVersionHeader.NAME, TokenTypes.MIME_VERSION); addKeyword(AlertInfoHeader.NAME, TokenTypes.ALERT_INFO); addKeyword(FromHeader.NAME, TokenTypes.FROM); addKeyword(ToHeader.NAME, TokenTypes.TO); addKeyword(ReferToHeader.NAME, TokenTypes.REFER_TO); addKeyword(ViaHeader.NAME, TokenTypes.VIA); addKeyword(UserAgentHeader.NAME, TokenTypes.USER_AGENT); addKeyword(ServerHeader.NAME, TokenTypes.SERVER); addKeyword(AcceptEncodingHeader.NAME, TokenTypes.ACCEPT_ENCODING); addKeyword(AcceptHeader.NAME, TokenTypes.ACCEPT); addKeyword(AllowHeader.NAME, TokenTypes.ALLOW); addKeyword(RouteHeader.NAME, TokenTypes.ROUTE); addKeyword(AuthorizationHeader.NAME, TokenTypes.AUTHORIZATION); addKeyword(ProxyAuthorizationHeader.NAME, TokenTypes.PROXY_AUTHORIZATION); addKeyword(RetryAfterHeader.NAME, TokenTypes.RETRY_AFTER); addKeyword(ProxyRequireHeader.NAME, TokenTypes.PROXY_REQUIRE); addKeyword(ContentLanguageHeader.NAME, TokenTypes.CONTENT_LANGUAGE); addKeyword(UnsupportedHeader.NAME, TokenTypes.UNSUPPORTED); addKeyword(SupportedHeader.NAME, TokenTypes.SUPPORTED); addKeyword(WarningHeader.NAME, TokenTypes.WARNING); addKeyword(MaxForwardsHeader.NAME, TokenTypes.MAX_FORWARDS); addKeyword(DateHeader.NAME, TokenTypes.DATE); addKeyword(PriorityHeader.NAME, TokenTypes.PRIORITY); addKeyword(ProxyAuthenticateHeader.NAME, TokenTypes.PROXY_AUTHENTICATE); addKeyword(ContentEncodingHeader.NAME, TokenTypes.CONTENT_ENCODING); addKeyword(ContentLengthHeader.NAME, TokenTypes.CONTENT_LENGTH); addKeyword(SubjectHeader.NAME, TokenTypes.SUBJECT); addKeyword(ContentTypeHeader.NAME, TokenTypes.CONTENT_TYPE); addKeyword(ContactHeader.NAME, TokenTypes.CONTACT); addKeyword(CallIdHeader.NAME, TokenTypes.CALL_ID); addKeyword(RequireHeader.NAME, TokenTypes.REQUIRE); addKeyword(ExpiresHeader.NAME, TokenTypes.EXPIRES); addKeyword(RecordRouteHeader.NAME, TokenTypes.RECORD_ROUTE); addKeyword(OrganizationHeader.NAME, TokenTypes.ORGANIZATION); addKeyword(CSeqHeader.NAME, TokenTypes.CSEQ); addKeyword(AcceptLanguageHeader.NAME, TokenTypes.ACCEPT_LANGUAGE); addKeyword(WWWAuthenticateHeader.NAME, TokenTypes.WWW_AUTHENTICATE); addKeyword(CallInfoHeader.NAME, TokenTypes.CALL_INFO); addKeyword(ContentDispositionHeader.NAME, TokenTypes.CONTENT_DISPOSITION); // And now the dreaded short forms.... addKeyword(TokenNames.K, TokenTypes.SUPPORTED); addKeyword(TokenNames.C, TokenTypes.CONTENT_TYPE); addKeyword(TokenNames.E, TokenTypes.CONTENT_ENCODING); addKeyword(TokenNames.F, TokenTypes.FROM); addKeyword(TokenNames.I, TokenTypes.CALL_ID); addKeyword(TokenNames.M, TokenTypes.CONTACT); addKeyword(TokenNames.L, TokenTypes.CONTENT_LENGTH); addKeyword(TokenNames.S, TokenTypes.SUBJECT); addKeyword(TokenNames.T, TokenTypes.TO); addKeyword(TokenNames.U, TokenTypes.ALLOW_EVENTS); // JvB: added addKeyword(TokenNames.V, TokenTypes.VIA); addKeyword(TokenNames.R, TokenTypes.REFER_TO); addKeyword(TokenNames.O, TokenTypes.EVENT); // Bug // fix // by // Mario // Mantak addKeyword(TokenNames.X, TokenTypes.SESSIONEXPIRES_TO); // Bug fix by Jozef Saniga // JvB: added to support RFC3903 addKeyword(SIPETagHeader.NAME, TokenTypes.SIP_ETAG); addKeyword(SIPIfMatchHeader.NAME, TokenTypes.SIP_IF_MATCH); // pmusgrave: Add RFC4028 and ReferredBy addKeyword(SessionExpiresHeader.NAME, TokenTypes.SESSIONEXPIRES_TO); addKeyword(MinSEHeader.NAME, TokenTypes.MINSE_TO); addKeyword(ReferredByHeader.NAME, TokenTypes.REFERREDBY_TO); // pmusgrave RFC3891 addKeyword(ReplacesHeader.NAME, TokenTypes.REPLACES_TO); //jean deruelle RFC3911 addKeyword(JoinHeader.NAME, TokenTypes.JOIN_TO); // IMS Headers addKeyword(PathHeader.NAME, TokenTypes.PATH); addKeyword(ServiceRouteHeader.NAME, TokenTypes.SERVICE_ROUTE); addKeyword(PAssertedIdentityHeader.NAME, TokenTypes.P_ASSERTED_IDENTITY); addKeyword(PPreferredIdentityHeader.NAME, TokenTypes.P_PREFERRED_IDENTITY); addKeyword(PrivacyHeader.NAME, TokenTypes.PRIVACY); // issued by Miguel Freitas addKeyword(PCalledPartyIDHeader.NAME, TokenTypes.P_CALLED_PARTY_ID); addKeyword(PAssociatedURIHeader.NAME, TokenTypes.P_ASSOCIATED_URI); addKeyword(PVisitedNetworkIDHeader.NAME, TokenTypes.P_VISITED_NETWORK_ID); addKeyword(PChargingFunctionAddressesHeader.NAME, TokenTypes.P_CHARGING_FUNCTION_ADDRESSES); addKeyword(PChargingVectorHeader.NAME, TokenTypes.P_VECTOR_CHARGING); addKeyword(PAccessNetworkInfoHeader.NAME, TokenTypes.P_ACCESS_NETWORK_INFO); addKeyword(PMediaAuthorizationHeader.NAME, TokenTypes.P_MEDIA_AUTHORIZATION); addKeyword(SecurityServerHeader.NAME, TokenTypes.SECURITY_SERVER); addKeyword(SecurityVerifyHeader.NAME, TokenTypes.SECURITY_VERIFY); addKeyword(SecurityClientHeader.NAME, TokenTypes.SECURITY_CLIENT); // added by aayush@rancore addKeyword(PUserDatabaseHeader.NAME, TokenTypes.P_USER_DATABASE); // added by aayush@rancore addKeyword(PProfileKeyHeader.NAME, TokenTypes.P_PROFILE_KEY); // added by aayush@rancore addKeyword(PServedUserHeader.NAME, TokenTypes.P_SERVED_USER); // added by aayush@rancore addKeyword(PPreferredServiceHeader.NAME, TokenTypes.P_PREFERRED_SERVICE); // added by aayush@rancore addKeyword(PAssertedServiceHeader.NAME, TokenTypes.P_ASSERTED_SERVICE); // added References header addKeyword(ReferencesHeader.NAME,TokenTypes.REFERENCES); // end // } else if (lexerName.equals("status_lineLexer")) { addKeyword(TokenNames.SIP, TokenTypes.SIP); } else if (lexerName.equals("request_lineLexer")) { addKeyword(TokenNames.SIP, TokenTypes.SIP); } else if (lexerName.equals("sip_urlLexer")) { addKeyword(TokenNames.TEL, TokenTypes.TEL); addKeyword(TokenNames.SIP, TokenTypes.SIP); addKeyword(TokenNames.SIPS, TokenTypes.SIPS); } // Now newLexer is completely initialized, let's check if somebody // have put lexer in table lexer = lexerTables.putIfAbsent(lexerName, newLexer); if (lexer == null) { // put succeeded, use new value lexer = newLexer; } currentLexer = lexer; } else { currentLexer = lexer; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy