MessageSecurityContext_soapbox.java
- /*
- * GovWay - A customizable API Gateway
- * https://govway.org
- *
- * Copyright (c) 2005-2025 Link.it srl (https://link.it).
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 3, as published by
- * the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
- package org.openspcoop2.security.message.soapbox;
- import org.adroitlogic.soapbox.CryptoSupport;
- import org.slf4j.Logger;
- import org.apache.xml.security.exceptions.AlgorithmAlreadyRegisteredException;
- import org.apache.xml.security.transforms.Transform;
- import org.openspcoop2.security.SecurityException;
- import org.openspcoop2.security.message.IMessageSecurityContext;
- import org.openspcoop2.security.message.MessageSecurityContext;
- import org.openspcoop2.security.message.constants.WSSAttachmentsConstants;
- import org.openspcoop2.security.message.soapbox.signature.XMLSecAttachmentContentTransform;
- /**
- * WSSContext_soapbox
- *
- * @author Andrea Poli (apoli@link.it)
- * @author Giovanni Bussu (bussu@link.it)
- * @author $Author$
- * @version $Rev$, $Date$
- */
- public class MessageSecurityContext_soapbox implements IMessageSecurityContext{
- private static boolean initialized = false;
- private static synchronized void init_engine(MessageSecurityContext wssContext)throws SecurityException {
- if(MessageSecurityContext_soapbox.initialized==false){
-
- try{
- MessageSecurityContext_soapbox.initWsuIdAllocator(wssContext.getPrefixWsuId(),wssContext.getLog());
- }catch(Throwable e){
- wssContext.getLog().error("Inizializzazione wsu id allocator non riuscita: "+e.getMessage(),e);
- throw new SecurityException(e.getMessage(),e);
- }
-
- try{
- CryptoSupport.initializeInstance(100, 100, 100);
- }catch(Throwable e){
- wssContext.getLog().error("Inizializzazione CryptoSupport non riuscita: "+e.getMessage(),e);
- throw new SecurityException(e.getMessage(),e);
- }
-
- // try{
- // org.apache.xml.security.Init.init();
- // }catch(Throwable e){
- // wssContext.getLog().error("Inizializzazione org.apache.xml.security non riuscita: "+e.getMessage(),e);
- // throw new SecurityException(e.getMessage(),e);
- // }
-
- // Li registro entrambi in modo da poter switchare tra le implementazioni
- try{
- try{
- wssContext.getLog().info("Transformer registrato: ["+XMLSecAttachmentContentTransform.class.getName()+"]");
- Transform.register(WSSAttachmentsConstants.ATTACHMENT_CONTENT_SIGNATURE_TRANSFORM_URI, XMLSecAttachmentContentTransform.class.getName());
- }catch(AlgorithmAlreadyRegisteredException e){
- // Succede in caso di hot redeploy
- wssContext.getLog().debug("Registrazione org.apache.xml.security.transforms.Transform non riuscita, classe gia registrata: "+e.getMessage());
- }
- catch(Throwable e){
- wssContext.getLog().error("Registrazione org.apache.xml.security.transforms.Transform non riuscita: "+e.getMessage(),e);
- throw new SecurityException(e.getMessage(),e);
- }
- }
- catch(SecurityException e){
- throw e;
- }
- catch(Throwable e){
- wssContext.getLog().error("Inizializzazione Trasform Security non riuscita: "+e.getMessage(),e);
- throw new SecurityException(e.getMessage(),e);
- }
-
-
- MessageSecurityContext_soapbox.initialized = true;
- }
- }
-
- @Override
- public void init(MessageSecurityContext wssContext) throws SecurityException {
- if(MessageSecurityContext_soapbox.initialized==false){
- MessageSecurityContext_soapbox.init_engine(wssContext);
- }
-
- }
- /** WSS Id Allocator */
- private static org.apache.wss4j.dom.WsuIdAllocator wsuIdAllocator = null;
- private static String prefixWsuId = null;
- public static org.apache.wss4j.dom.WsuIdAllocator getWsuIdAllocator() {
- return MessageSecurityContext_soapbox.wsuIdAllocator;
- }
- private static synchronized void initWsuIdAllocator(String prefixWsuIdParam,Logger log) throws Exception{
- if(MessageSecurityContext_soapbox.wsuIdAllocator==null){
- MessageSecurityContext_soapbox.prefixWsuId=prefixWsuIdParam;
- if(prefixWsuIdParam==null || "".equals(prefixWsuIdParam)){
- MessageSecurityContext_soapbox.wsuIdAllocator = new org.openspcoop2.security.message.WsuIdAllocator("openspcoop2_soapbox_");// Default di wss4j
- }
- else{
- MessageSecurityContext_soapbox.wsuIdAllocator = new org.openspcoop2.security.message.WsuIdAllocator(prefixWsuIdParam);
- }
- log.info("WsuIdAllocator="+MessageSecurityContext_soapbox.wsuIdAllocator.getClass().getName());
- }
- else{
- if(MessageSecurityContext_soapbox.prefixWsuId==null){
- throw new Exception("WsuIdAllocator istanziato con la classe ["+MessageSecurityContext_soapbox.wsuIdAllocator.getClass().getName()+"] e variabile prefixWsuId non istanziata??");
- }
- else if(!MessageSecurityContext_soapbox.prefixWsuId.equals(prefixWsuIdParam)){
- throw new Exception("WsuIdAllocator gia' istanziato con la classe ["+MessageSecurityContext_soapbox.wsuIdAllocator.getClass().getName()
- +"] e variabile prefixWsuId uguale al valore ["+MessageSecurityContext_soapbox.prefixWsuId+"]. Nuovo valore ["+prefixWsuIdParam+"] non impostabile.");
- }
- }
- }
- }