javaextensions/satsa/crypto/javasrc/java/security/Signature.java
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:33:18 +0100
branchRCL_3
changeset 66 2455ef1f5bbc
parent 19 04becd199f91
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: v2.2.11 Kit: 201035

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:
*
*/



package java.security;


import com.nokia.mj.impl.security.SignatureImpl;
import java.security.PrivSignatureImpl;

/**
 * Refer JSR-177 Specification for details
 */
public abstract class Signature
{
    /**
     * Signature implementation
     */
    private SignatureImpl iSignature;

    /**
     * Package private constructor.
     */
    Signature(SignatureImpl aSignature)
    {
        iSignature = aSignature;
    }

    /**
    * Refer JSR-177 Specification for details
    */
    static public Signature getInstance(String aAlgorithm)
    throws NoSuchAlgorithmException
    {
        SignatureImpl signatureImpl = new SignatureImpl(aAlgorithm);
        return new PrivSignatureImpl(signatureImpl);
    }

    /**
    * Refer JSR-177 Specification for details
    */
    public final void initVerify(PublicKey aPublicKey)
    throws InvalidKeyException
    {
        iSignature.initVerifyImpl(aPublicKey);
    }

    /**
    * Refer JSR-177 Specification for details
    */
    public final void update(byte[] aData, int aOffset, int aLength)
    throws SignatureException
    {
        iSignature.updateImpl(aData, aOffset, aLength);
    }

    /**
    * Refer JSR-177 Specification for details
    */
    public final boolean verify(byte[] aSignature) throws SignatureException
    {
        return iSignature.verifyImpl(aSignature);
    }

}