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

org.apache.directory.api.ldap.extras.extended.certGeneration.CertGenerationRequestImpl Maven / Gradle / Ivy

There is a newer version: 2.1.6
Show newest version
/*
 *  Licensed to the Apache Software Foundation (ASF) under one
 *  or more contributor license agreements.  See the NOTICE file
 *  distributed with this work for additional information
 *  regarding copyright ownership.  The ASF licenses this file
 *  to you 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.apache.directory.api.ldap.extras.extended.certGeneration;


import org.apache.directory.api.ldap.model.message.AbstractExtendedRequest;


/**
 * 
 * An extended operation requesting the server to generate a public/private key pair and a certificate
 * and store them in a specified target entry in the DIT.
 *
 * @author Apache Directory Project
 */
public class CertGenerationRequestImpl extends AbstractExtendedRequest implements CertGenerationRequest
{
    /** the Dn of the server entry which will be updated*/
    private String targetDN;

    /** the issuer Dn that will be set in the certificate*/
    private String issuerDN;

    /** the Dn of the subject that is present in the certificate*/
    private String subjectDN;

    /** name of the algorithm used for generating the keys*/
    private String keyAlgorithm;


    /**
     * Creates a new instance of CertGenerationRequest.
     *
     * @param messageId the message id
     * @param targerDN the Dn of target entry whose key and certificate values will be changed
     * @param issuerDN Dn to be used as the issuer's Dn in the certificate
     * @param subjectDN Dn to be used as certificate's subject
     * @param keyAlgorithm crypto algorithm name to be used for generating the keys
     */
    public CertGenerationRequestImpl( int messageId, String targerDN, String issuerDN, String subjectDN,
        String keyAlgorithm )
    {
        super( messageId );
        setRequestName( EXTENSION_OID );
        this.targetDN = targerDN;
        this.issuerDN = issuerDN;
        this.subjectDN = subjectDN;
        this.keyAlgorithm = keyAlgorithm;
    }


    /**
     * Creates a new instance of CertGenerationRequest.
     */
    public CertGenerationRequestImpl()
    {
        setRequestName( EXTENSION_OID );
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public String getTargetDN()
    {
        return targetDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public void setTargetDN( String targetDN )
    {
        this.targetDN = targetDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public String getIssuerDN()
    {
        return issuerDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public void setIssuerDN( String issuerDN )
    {
        this.issuerDN = issuerDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public String getSubjectDN()
    {
        return subjectDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public void setSubjectDN( String subjectDN )
    {
        this.subjectDN = subjectDN;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public String getKeyAlgorithm()
    {
        return keyAlgorithm;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public void setKeyAlgorithm( String keyAlgorithm )
    {
        this.keyAlgorithm = keyAlgorithm;
    }


    /**
     * {@inheritDoc}
     */
    @Override
    public CertGenerationResponse getResultResponse()
    {
        if ( getResponse() == null )
        {
            setResponse( new CertGenerationResponseImpl() );
        }

        return ( CertGenerationResponse ) getResponse();
    }


    /***
     * {@inheritDoc}
     */
    @Override
    public String toString()
    {
        StringBuilder sb = new StringBuilder();
        sb.append( "Certficate Generation Object { " ).append( " Target Dn: " ).append( targetDN ).append( ',' );
        sb.append( " Issuer Dn: " ).append( issuerDN ).append( ',' );
        sb.append( " Subject Dn: " ).append( subjectDN ).append( ',' );
        sb.append( " Key Algorithm: " ).append( keyAlgorithm ).append( " }" );

        return sb.toString();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy