com.sun.xml.wss.impl.configuration.StaticApplicationContext Maven / Gradle / Ivy
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
/*
* $Id: StaticApplicationContext.java,v 1.2 2010-10-21 15:37:25 snajper Exp $
*/
package com.sun.xml.wss.impl.configuration;
import com.sun.xml.wss.impl.policy.StaticPolicyContext;
/**
* This class represents the static context associated with any Security Policy elements
* defined in a xwss:JAXRPCSecurity
configuration.
* The xwss:JAXRPCSecurity
element supports Security Policies to be specifed
* at three levels
*
* - At a JAXRPC
Service
level
* - At a JAXRPC
Port
level
* - At a JAXRPC
Operation
level
*
* Accordingly the class StaticApplicationContext has methods to identify if the context
* represents a Service, Port or Operation, and stores the corresponding context identifiers
*/
public final class StaticApplicationContext implements StaticPolicyContext {
private boolean isService = false;
private boolean isPort = false;
private boolean isOperation = false;
private String UUID = "";
private String contextRoot = "";
private String serviceIdentifier = "";
private String portIdentifier = "";
private String operationIdentifier = "";
/**
* Default constructor
*/
public StaticApplicationContext() {}
/**
* Copy constructor
*@param context StaticApplicationContext
*/
public StaticApplicationContext(StaticApplicationContext context) {
copy (context);
}
/**
*Set if this context represents a Service
*@param isService set to true if this is a service level context
*/
public void isService (boolean isService) {
this.isService = isService;
}
/**
*@return true if this context represents a Service
*/
public boolean isService () {
return this.isService;
}
/**
*Set if this context represents a Port
*@param isPort set to true if this is a port level context
*/
public void isPort (boolean isPort) {
this.isPort = isPort;
}
/**
*@return true if this context represents a Port
*/
public boolean isPort () {
return this.isPort;
}
/**
*Set if this context represents an Operation
*@param isOperation set to true if this is an Operation level context
*/
public void isOperation (boolean isOperation) {
this.isOperation = isOperation;
}
/**
*@return true if this context represents an Operation
*/
public boolean isOperation () {
return this.isOperation;
}
/**
*Set the service identifier
*@param service the Service Identifier
*/
public void setServiceIdentifier (String service) {
this.serviceIdentifier = service;
}
/**
*@return the service identifier
*/
public String getServiceIdentifier () {
return this.serviceIdentifier;
}
/**
*Set the port identifier
*@param port the Port Identifier
*/
public void setPortIdentifier (String port) {
this.portIdentifier = port;
}
/**
*@return the port identifier
*/
public String getPortIdentifier () {
return this.portIdentifier;
}
/**
*Set the Operation identifier
*@param operation the Operation Identifier
*/
public void setOperationIdentifier (String operation) {
isOperation (true);
this.operationIdentifier = operation;
}
/**
*@return the Operation identifier
*/
public String getOperationIdentifier () {
return this.operationIdentifier;
}
/**
*Set the Unique ID associated with the Service context
*@param uuid the unique id associated with the Service
*/
public void setUUID (String uuid) {
this.UUID = uuid;
}
/**
*@return the Unique ID associated with the Service context
*/
public String getUUID () {
return this.UUID;
}
/**
*@param ctxRoot the Application Context Root/Identifier for the application
*/
public void setApplicationContextRoot (String ctxRoot) {
this.contextRoot = ctxRoot;
}
/**
*@return the Application Context Root/Identifier for the application (if any)
*/
public String getApplicationContextRoot () {
return this.contextRoot;
}
/**
*Copy operator
*@param ctx the StaticApplicationContext to copy from
*/
public void copy (StaticApplicationContext ctx) {
setUUID (ctx.getUUID ());
setApplicationContextRoot (ctx.getApplicationContextRoot ());
isService (ctx.isService ());
isPort (ctx.isPort ());
isOperation (ctx.isOperation ());
setServiceIdentifier (ctx.getServiceIdentifier ());
setPortIdentifier (ctx.getPortIdentifier ());
operationIdentifier = ctx.getOperationIdentifier ();
}
/*
*@return this context
*/
/*public StaticApplicationContext getStaticContext () {
return this;
}*/
/**
* equals operator
* @param obj the Object to be compared with this context for equality
* @return true if the argument object is equal to this context
*/
public boolean equals (Object obj) {
if (obj instanceof StaticApplicationContext) {
return equals((StaticApplicationContext)obj);
}
return false;
}
/**
* equals operator
* @param ctx the StaticApplicationContext to be compared with this context for equality
* @return true if the argument context is equal to this context
*/
public boolean equals (StaticApplicationContext ctx) {
boolean b1 =
(UUID.equalsIgnoreCase (ctx.getUUID())); /* &&
contextRoot.equalsIgnoreCase (ctx.getApplicationContextRoot()));*/
if (!b1) return false;
boolean b2 =
(serviceIdentifier.equalsIgnoreCase (ctx.getServiceIdentifier()) &&
portIdentifier.equalsIgnoreCase (ctx.getPortIdentifier()) &&
operationIdentifier.equalsIgnoreCase (ctx.getOperationIdentifier()));
if (!b2) return false;
return true;
}
// TODO : this hashcode is not unique, change it later, but it works for now
// hashCode needs to be implemented by this class for the equals() operator to
// be called by the HashMap.get() method
// equals() method on HashMap is only called if hashCode succeeds
/**
* @return hashcode for this context
*/
public int hashCode() {
return
UUID.hashCode() + serviceIdentifier.hashCode() +
portIdentifier.hashCode() + operationIdentifier.hashCode();
}
public String toString() {
String ret = "isService=" + isService + "\nisPort=" + isPort + "\nisOperation=" + isOperation +
"\nUUID=" + UUID + "\nserviceIdentifier=" + serviceIdentifier +
"\nportIdentifier=" + portIdentifier + "\noperationIdentifier=" + operationIdentifier;
return ret;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy