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

org.italiangrid.voms.request.impl.LegacyRequestSender Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) Istituto Nazionale di Fisica Nucleare, 2006-2014.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.italiangrid.voms.request.impl;

import java.io.OutputStream;
import java.io.StringWriter;

import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.italiangrid.voms.VOMSError;
import org.italiangrid.voms.request.VOMSACRequest;
import org.italiangrid.voms.request.VOMSProtocolListener;
import org.italiangrid.voms.request.VOMSServerInfo;
import org.w3c.dom.Document;

/**
 * This class manages the client-side communication protocol with the VOMS
 * server.
 * 
 * @author Andrea Ceccanti
 * 
 */
public class LegacyRequestSender {

  private VOMSRequestFactory requestFactory = VOMSRequestFactory.instance();
  private TransformerFactory transformerFactory;

  private VOMSProtocolListener listener;

  private LegacyRequestSender(VOMSProtocolListener listener) {

    transformerFactory = TransformerFactory.newInstance();
    this.listener = listener;
  }

  public static LegacyRequestSender instance(VOMSProtocolListener listener) {

    return new LegacyRequestSender(listener);
  }

  protected String xmlDocAsString(Document doc) {

    Transformer transformer;

    try {

      transformer = transformerFactory.newTransformer();

    } catch (TransformerConfigurationException e) {

      throw new VOMSError(e.getMessage(), e);

    }

    StringWriter writer = new StringWriter();

    DOMSource source = new DOMSource(doc);

    StreamResult res = new StreamResult(writer);

    try {

      transformer.transform(source, res);

    } catch (TransformerException e) {

      throw new VOMSError(e.getMessage(), e);

    }

    writer.flush();

    return writer.toString();
  }

  /**
   * 
   * This method is used to send a request to a VOMS server.
   * 
   * 
   * @param acRequest
   *          the AC request parameters. See {@link VOMSACRequest}.
   * @param endpoint
   *          the {@link VOMSServerInfo} endpoint to use for this 
   *          request
   * @param stream
   *          an output stream.
   */
  public void sendRequest(VOMSACRequest acRequest, VOMSServerInfo endpoint,
    OutputStream stream) {

    Document request = requestFactory.buildRequest(acRequest, endpoint);

    Transformer transformer;

    try {

      transformer = transformerFactory.newTransformer();

    } catch (TransformerConfigurationException e) {

      throw new VOMSError(e.getMessage(), e);
    }

    listener.notifyLegacyRequest(xmlDocAsString(request));

    DOMSource source = new DOMSource(request);

    StreamResult res = new StreamResult(stream);

    try {

      transformer.transform(source, res);
      stream.flush();

    } catch (Exception e) {

      throw new VOMSError(e.getMessage(), e);

    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy