| /* |
| * reserved comment block |
| * DO NOT REMOVE OR ALTER! |
| */ |
| /* Copyright (c) 2002 Graz University of Technology. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are met: |
| * |
| * 1. Redistributions of source code must retain the above copyright notice, |
| * this list of conditions and the following disclaimer. |
| * |
| * 2. Redistributions in binary form must reproduce the above copyright notice, |
| * this list of conditions and the following disclaimer in the documentation |
| * and/or other materials provided with the distribution. |
| * |
| * 3. The end-user documentation included with the redistribution, if any, must |
| * include the following acknowledgment: |
| * |
| * "This product includes software developed by IAIK of Graz University of |
| * Technology." |
| * |
| * Alternately, this acknowledgment may appear in the software itself, if |
| * and wherever such third-party acknowledgments normally appear. |
| * |
| * 4. The names "Graz University of Technology" and "IAIK of Graz University of |
| * Technology" must not be used to endorse or promote products derived from |
| * this software without prior written permission. |
| * |
| * 5. Products derived from this software may not be called |
| * "IAIK PKCS Wrapper", nor may "IAIK" appear in their name, without prior |
| * written permission of Graz University of Technology. |
| * |
| * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED |
| * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE LICENSOR BE |
| * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, |
| * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, |
| * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON |
| * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
| * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
| * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| * POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| package sun.security.pkcs11.wrapper; |
| |
| |
| |
| /** |
| * class CK_ECDH2_DERIVE_PARAMS provides the parameters to the |
| * CKM_ECMQV_DERIVE mechanism.<p> |
| * <B>PKCS#11 structure:</B> |
| * <PRE> |
| * typedef struct CK_ECDH2_DERIVE_PARAMS { |
| * CK_EC_KDF_TYPE kdf; |
| * CK_ULONG ulSharedDataLen; |
| * CK_BYTE_PTR pSharedData; |
| * CK_ULONG ulPublicDataLen; |
| * CK_BYTE_PTR pPublicData; |
| * CK_ULONG ulPrivateDataLen; |
| * CK_OBJECT_HANDLE hPrivateData; |
| * CK_ULONG ulPublicDataLen2; |
| * CK_BYTE_PTR pPublicData2; |
| * } CK_ECDH2_DERIVE_PARAMS; |
| * </PRE> |
| * |
| * @author Karl Scheibelhofer <Karl.Scheibelhofer@iaik.at> |
| */ |
| public class CK_ECDH2_DERIVE_PARAMS { |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_EC_KDF_TYPE kdf; |
| * </PRE> |
| */ |
| public long kdf; |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_ULONG ulSharedDataLen; |
| * CK_BYTE_PTR pSharedData; |
| * </PRE> |
| */ |
| public byte[] pSharedData; |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_ULONG ulPublicDataLen; |
| * CK_BYTE_PTR pPublicData; |
| * </PRE> |
| */ |
| public byte[] pPublicData; |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_ULONG ulPrivateDataLen; |
| * </PRE> |
| */ |
| public long ulPrivateDataLen; |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_OBJECT_HANDLE hPrivateData; |
| * </PRE> |
| */ |
| public long hPrivateData; |
| |
| /** |
| * <B>PKCS#11:</B> |
| * <PRE> |
| * CK_ULONG ulPublicDataLen2; |
| * CK_BYTE_PTR pPublicData2; |
| * </PRE> |
| */ |
| public byte[] pPublicData2; |
| |
| /** |
| * Returns the string representation of CK_PKCS5_PBKD2_PARAMS. |
| * |
| * @return the string representation of CK_PKCS5_PBKD2_PARAMS |
| */ |
| public String toString() { |
| StringBuilder sb = new StringBuilder(); |
| |
| sb.append(Constants.INDENT); |
| sb.append("kdf: 0x"); |
| sb.append(Functions.toFullHexString(kdf)); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pSharedDataLen: "); |
| sb.append(pSharedData.length); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pSharedData: "); |
| sb.append(Functions.toHexString(pSharedData)); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pPublicDataLen: "); |
| sb.append(pPublicData.length); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pPublicData: "); |
| sb.append(Functions.toHexString(pPublicData)); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("ulPrivateDataLen: "); |
| sb.append(ulPrivateDataLen); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("hPrivateData: "); |
| sb.append(hPrivateData); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pPublicDataLen2: "); |
| sb.append(pPublicData2.length); |
| sb.append(Constants.NEWLINE); |
| |
| sb.append(Constants.INDENT); |
| sb.append("pPublicData2: "); |
| sb.append(Functions.toHexString(pPublicData2)); |
| //buffer.append(Constants.NEWLINE); |
| |
| return sb.toString(); |
| } |
| |
| } |