亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? dsakeytype.c

?? IBE是一種非對(duì)稱密碼技術(shù)
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/* Copyright 2003-2006, Voltage Security, all rights reserved.
 */
#include "vibecrypto.h"
#include "environment.h"
#include "base.h"
#include "libctx.h"
#include "keyobj.h"
#include "dsa.h"
#include "mpint.h"
#include "errorctx.h"

/* Gets the key data out of a key object.
 *
 * @param object The object from which the data is to be extracted.
 * @param getInfo The address where the function will deposit the
 * pointer to the info.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV VoltKeyGetDsaPublic VOLT_PROTO_LIST ((
   VtKeyObject object,
   Pointer *getInfo
));

/* Gets the key data out of a key object.
 *
 * @param object The object from which the data is to be extracted.
 * @param getInfo The address where the function will deposit the
 * pointer to the info.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV VoltKeyGetDsaPrivate VOLT_PROTO_LIST ((
   VtKeyObject object,
   Pointer *getInfo
));

/* This routine does the work. It allocates and fills in the contexts.
 *
 * @param obj The key object to set.
 * @param keyInfo The data, params and pub value.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV SetObjectDSAPublic VOLT_PROTO_LIST ((
   VoltKeyObject *obj,
   VtDSAPubKeyInfo *keyInfo
));

/* This routine does the work. It allocates and fills in the contexts.
 *
 * @param obj The key object to set.
 * @param keyInfo The data, params and pub and pri values.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV SetObjectDSAPrivate VOLT_PROTO_LIST ((
   VoltKeyObject *obj,
   VtDSAPriKeyInfo *keyInfo
));

/* This routine computes the DSA public key given the DSA private key.
 * Because we don't store the public key with the DSA private key, this
 * can be helpful if we want to rebuild the public key from the private
 * key. It also sets the key object with the public value.  
 *
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV SetObjectDSAPubFromPrivate VOLT_PROTO_LIST ((
   VoltLibCtx *libCtx,
   VoltMpIntCtx *mpCtx,
   VoltDsaPrivateKey *priKey
));

/* Fill in the buffer with the public key info as a
 * VtDSAPubKeyInfo struct.
 * <p>This routine does no argument checking, it is the responsibility
 * of the caller not to make mistakes. If buffer is NULL, *bufferSize
 * must be 0.
 *
 * @param obj The key object.
 * @param pubKey The VoltDsaPublicKey struct with the MpInt version of
 * the key data.
 * @param The buffer to fill.
 * @param bufferSize As input, the current size of the buffer, as
 * output, the size the buffer needs to be or the number of bytes paced
 * into the buffer.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV BuildPubKeyInfo VOLT_PROTO_LIST ((
   VoltKeyObject *obj,
   VoltDsaPublicKey *pubKey,
   unsigned char *buffer,
   unsigned int *bufferSize
));

/* Fill in the buffer with the private key info as a
 * VtDSAPriKeyInfo struct.
 * <p>This routine does no argument checking, it is the responsibility
 * of the caller not to make mistakes. If buffer is NULL, *bufferSize
 * must be 0.
 *
 * @param obj The key object.
 * @param pubKey The VoltDsaPrivateKey struct with the MpInt version of
 * the key data.
 * @param The buffer to fill.
 * @param bufferSize As input, the current size of the buffer, as
 * output, the size the buffer needs to be or the number of bytes paced
 * into the buffer.
 * @return an int, 0 if the function completed successfully or a
 * non-zero error code.
 */
static int VOLT_CALLING_CONV BuildPriKeyInfo VOLT_PROTO_LIST ((
   VoltKeyObject *obj,
   VoltDsaPrivateKey *priKey,
   unsigned char *buffer,
   unsigned int *bufferSize
));

int VtKeyParamDSAPublic (
   VtKeyObject object,
   Pointer info,
   unsigned int flag
   )
{
  int status;
  VoltKeyObject *obj = (VoltKeyObject *)object;
  VtDSAPubKeyInfo *keyInfo = (VtDSAPubKeyInfo *)info;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    if (flag == VOLT_KEY_GET_TYPE_FLAG)
    {
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltKeyGetDsaPublic (object, (Pointer *)info);
      break;
    }

    /* Check the flag, it should be VOLT_KEY_SET_TYPE_FLAG.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_TYPE;
    if (flag != VOLT_KEY_SET_TYPE_FLAG)
      break;

    /* The associated info should be a pointer to VtDSAPubKeyInfo.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (info == (Pointer)0)
      break;

    /* If using this KeyParam, the key must already have an mpCtx
     * loaded.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_KEY_OBJ;
    if (obj->mpCtx == (VoltMpIntCtx *)0)
      break;

    /* Make sure the key data is there.
     * This check demands a 1024-bit primeP and a 160-bit subprimeQ.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if ( (keyInfo->primeP.data == (unsigned char *)0) ||
         (keyInfo->primeP.len < 64 ) || 
         (keyInfo->primeP.len > 256) ||
         (keyInfo->subprimeQ.data == (unsigned char *)0) ||
         (keyInfo->subprimeQ.len != 20) ||
         (keyInfo->baseG.data == (unsigned char *)0) ||
         (keyInfo->pubValY.data == (unsigned char *)0) )
      break;

    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = SetObjectDSAPublic (obj, keyInfo);
    if (status != 0)
      break;

    /* Set the FIPS bit in the object type, this object is a FIPS
     * object.
     */
    obj->voltObject.objectType |= VOLT_OBJECT_TYPE_FIPS;

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->keyType = 0;

  VOLT_LOG_ERROR (
    obj->voltObject.libraryCtx, status, errorType, fnctLine,
    "VtKeyParamDSAPublic", (char *)0)

  return (status);
}

int VtKeyParamDSAPrivate (
   VtKeyObject object,
   Pointer info,
   unsigned int flag
   )
{
  int status;
  VoltKeyObject *obj = (VoltKeyObject *)object;
  VtDSAPriKeyInfo *keyInfo = (VtDSAPriKeyInfo *)info;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    if (flag == VOLT_KEY_GET_TYPE_FLAG)
    {
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VoltKeyGetDsaPrivate (object, (Pointer *)info);
      break;
    }

    /* Check the flag, it should be VOLT_KEY_SET_TYPE_FLAG.
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_TYPE;
    if (flag != VOLT_KEY_SET_TYPE_FLAG)
      break;

    /* The associated info should be a pointer to VtDSAPriKeyInfo.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if (info == (Pointer)0)
      break;

    /* If using this KeyParam, the key must already have an mpCtx
     * loaded.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_KEY_OBJ;
    if (obj->mpCtx == (VoltMpIntCtx *)0)
      break;

    /* Make sure the key data is there.
     * This check demands a 1024-bit primeP and a 160-bit subprimeQ.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_INVALID_ASSOCIATED_INFO;
    if ( (keyInfo->primeP.data == (unsigned char *)0) ||
         (keyInfo->primeP.len != 128) ||
         (keyInfo->subprimeQ.data == (unsigned char *)0) ||
         (keyInfo->subprimeQ.len != 20) ||
         (keyInfo->baseG.data == (unsigned char *)0) )
      break;

    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = SetObjectDSAPrivate (obj, keyInfo);
    if (status != 0)
      break;

    /* Set the FIPS bit in the object type, this object is a FIPS
     * object.
     */
    obj->voltObject.objectType |= VOLT_OBJECT_TYPE_FIPS;

  } while (0);

  /* If everything worked, return 0.
   */
  if (status == 0)
    return (0);

  /* If something went wrong, indicate that this object is not usable.
   */
  obj->keyType = 0;

  VOLT_LOG_ERROR (
    obj->voltObject.libraryCtx, status, errorType, fnctLine,
    "VtKeyParamDSAPrivate", (char *)0)

  return (status);
}

static int VoltKeyGetDsaPublic (
   VtKeyObject object,
   Pointer *getInfo
   )
{
  int status;
  unsigned int bufferSize;
  VoltKeyObject *obj = (VoltKeyObject *)object;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  unsigned char *buffer = (unsigned char *)0;
  VoltDsaPublicKey *pubKey;
  VoltDsaKeyPair *theKeyPair;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Is there data?
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_GET_INFO_UNAVAILABLE;
    if (obj->keyData == (Pointer)0)
      break;

    /* Is the algorithm DSA?
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    if ((obj->keyType & VOLT_KEY_TYPE_MASK_ASYM_ALG) != VOLT_KEY_ALG_DSA)
      break;

    /* Check the keyType in the object, if it contains
     * VOLT_KEY_ALG_ASYM_PAIR, the contents are a key pair.
     */
    if ((obj->keyType & VOLT_KEY_TYPE_ASYM_PAIR) != 0)
    {
      VOLT_SET_FNCT_LINE (fnctLine)
      theKeyPair = (VoltDsaKeyPair *)(obj->keyData);
      if (theKeyPair->pubKey == (VtKeyObject)0)
        break;

      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtGetKeyParam (
        theKeyPair->pubKey, VtKeyParamDSAPublic, getInfo);
      break;
    }

    /* It's not a key pair.
     * We can get the public key data out of a private key object as well.
     */
    if ((obj->keyType & VOLT_KEY_TYPE_PRIVATE) != 0)
    {
      /* If this is a private key, we want to build the private keyItems
       * struct internally. Externally it looks just like the public.
       */
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = VtGetKeyParam (
        (VtKeyObject)obj, VtKeyParamDSAPrivate, getInfo);
      break;
    }

    /* It's not a pair, it's not private, if it's not public, error.
     */
    VOLT_SET_FNCT_LINE (fnctLine)
    if ((obj->keyType & VOLT_KEY_TYPE_PUBLIC) == 0)
      break;

    /* Is the key in data form?
     */
    if ((obj->keyType & VOLT_KEY_TYPE_MASK_DATA) != VOLT_KEY_TYPE_DATA)
    {
      /* The data is not available, does the object have a GetData
       * function?
       */
      VOLT_SET_FNCT_LINE (fnctLine)
      *getInfo = (Pointer)0;
      if (obj->GetKeyData == (VGetKeyData)0)
        break;

      /* Call the Get function.
       */
      VOLT_SET_ERROR_TYPE (errorType, 0)
      VOLT_SET_FNCT_LINE (fnctLine)
      status = obj->GetKeyData ((VtKeyObject)obj, getInfo);
      break;
    }

    /* Do we have the data in the appropriate format already?
     */
    status = 0;
    pubKey = (VoltDsaPublicKey *)(obj->keyData);
    *getInfo = (Pointer)(pubKey->keyItems);
    if (pubKey->keyItems != (VtDSAPubKeyInfo *)0)
      break;

    /* Call the routine that builds the VtDSAPubKeyInfo struct.
     * This routine actually will return BufferTooSmall and set
     * bufferSize to the space needed. We'll allocate the space and
     * call it again.
     */
    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    bufferSize = 0;
    status = BuildPubKeyInfo (obj, pubKey, buffer, &bufferSize);
    if (status == 0)
      status = VT_ERROR_INVALID_KEY_OBJ;
    if (status != VT_ERROR_BUFFER_TOO_SMALL)
      break;

    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = VT_ERROR_MEMORY;
    buffer = (unsigned char *)Z2Malloc (bufferSize, 0);
    if (buffer == (unsigned char *)0)
      break;
    Z2Memset (buffer, 0, bufferSize);

    VOLT_SET_ERROR_TYPE (errorType, 0)
    VOLT_SET_FNCT_LINE (fnctLine)
    status = BuildPubKeyInfo (obj, pubKey, buffer, &bufferSize);
    if (status != 0)
      break;

    pubKey->keyItems = (VtDSAPubKeyInfo *)buffer;
    *getInfo = (Pointer)buffer;

  } while (0);

  /* If no error, we're done.
   */
  if (status == 0)
    return (0);

  /* If there was an error, free memory we allocated.
   */
  if (buffer != (unsigned char *)0)
    Z2Free (buffer);

  VOLT_LOG_ERROR (
    libCtx, status, errorType, fnctLine, "VoltKeyGetDsaPublic", (char *)0)

  return (status);
}

static int VoltKeyGetDsaPrivate (
   VtKeyObject object,
   Pointer *getInfo
   )
{
  int status;
  unsigned int bufferSize;
  VoltKeyObject *obj = (VoltKeyObject *)object;
  VoltLibCtx *libCtx = (VoltLibCtx *)(obj->voltObject.libraryCtx);
  unsigned char *buffer = (unsigned char *)0;
  VoltDsaPrivateKey *priKey;
  VoltDsaKeyPair *theKeyPair;
  VOLT_DECLARE_ERROR_TYPE (errorType)
  VOLT_DECLARE_FNCT_LINE (fnctLine)

  do
  {
    /* Is there data?
     */
    VOLT_SET_ERROR_TYPE (errorType, VT_ERROR_TYPE_PRIMARY)
    VOLT_SET_FNCT_LINE (fnctLine)

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产3级a| 日韩午夜激情视频| 国产福利精品导航| 国产福利电影一区二区三区| 国产毛片精品视频| 粉嫩av亚洲一区二区图片| 大桥未久av一区二区三区中文| 国产夫妻精品视频| 91免费看视频| 欧美精品久久99| 日韩女优制服丝袜电影| 精品国产免费视频| 日本一区二区成人在线| 日韩理论在线观看| 日韩不卡手机在线v区| 韩国av一区二区| 99久久精品国产麻豆演员表| 91国偷自产一区二区使用方法| 欧美日韩中文字幕一区| 日韩情涩欧美日韩视频| 国产网红主播福利一区二区| 国产精品久久国产精麻豆99网站 | 国产精品久久夜| 亚洲黄一区二区三区| 日韩va亚洲va欧美va久久| 国产精品综合久久| 欧美最新大片在线看| 精品日韩一区二区三区 | 欧美理论在线播放| 久久综合色天天久久综合图片| 国产精品少妇自拍| 日韩精品电影一区亚洲| 国产乱国产乱300精品| 99精品欧美一区二区三区小说 | 国产98色在线|日韩| 欧美在线观看一区| 2017欧美狠狠色| 一区二区三区免费观看| 欧美精品xxxxbbbb| 国产精品人妖ts系列视频| 亚洲一卡二卡三卡四卡五卡| 国产乱码精品一品二品| 欧美日韩免费电影| 一区二区中文字幕在线| 国产一区二区视频在线| 欧美日韩不卡一区| 亚洲欧美精品午睡沙发| 国产成人免费xxxxxxxx| 日韩欧美色综合网站| 亚洲一区二区三区爽爽爽爽爽| 国产一区二区三区免费观看 | 极品瑜伽女神91| 91福利社在线观看| 国产精品视频一区二区三区不卡| 日本91福利区| 欧美日韩精品一区二区三区四区| 亚洲欧洲日韩av| 99精品视频免费在线观看| 久久精品视频网| 国产酒店精品激情| 久久亚区不卡日本| 国产在线观看一区二区| 日韩一区二区三区三四区视频在线观看 | 久久精品久久综合| 91.com视频| 日韩和欧美的一区| 欧美精品三级日韩久久| 性久久久久久久久| 欧美日韩另类一区| 五月天中文字幕一区二区| 在线观看欧美精品| 亚洲国产成人av网| 91.com在线观看| 日韩va亚洲va欧美va久久| 欧美一区二区三区思思人| 免费在线一区观看| 日韩精品一区在线| 国产一区二区91| 国产精品青草综合久久久久99| 成人中文字幕合集| 中文字幕一区视频| 日本高清无吗v一区| 亚洲综合激情另类小说区| 欧美在线制服丝袜| 日韩成人一级片| 精品国产精品一区二区夜夜嗨| 国产九色精品成人porny| 国产精品天天摸av网| 91久久精品一区二区三| 亚洲狠狠爱一区二区三区| 91精品国产91热久久久做人人| 久久爱www久久做| 中文字幕一区二区在线观看| 在线观看日韩一区| 麻豆一区二区三区| 国产无人区一区二区三区| 91日韩精品一区| 理论片日本一区| 国产精品国产a| 欧美久久久一区| 国产一区二三区| 亚洲图片自拍偷拍| 久久久久久9999| 欧美视频一区二区三区四区| 奇米777欧美一区二区| 欧美国产成人精品| 欧美一区二区三区四区久久 | 国产一区中文字幕| 亚洲色图都市小说| 2023国产精品自拍| 色噜噜狠狠成人网p站| 日韩精品五月天| 国产精品久久久久天堂| 欧美日韩高清一区二区三区| 国产精品一区二区免费不卡| 亚洲另类一区二区| 久久久久久影视| 欧美日韩mp4| 99国产精品久久久久久久久久久 | 婷婷国产v国产偷v亚洲高清| 久久久欧美精品sm网站| 欧美色图免费看| 成人免费高清视频在线观看| 日本91福利区| 亚洲sss视频在线视频| 国产精品乱人伦中文| 精品第一国产综合精品aⅴ| 欧美在线一二三四区| 99久久久久免费精品国产| 国产精一区二区三区| 日本女人一区二区三区| 亚洲香肠在线观看| 一区二区三区四区高清精品免费观看 | 欧美精品18+| 在线视频国内自拍亚洲视频| 成人午夜电影小说| 国产suv精品一区二区三区| 久久精品二区亚洲w码| 婷婷久久综合九色综合伊人色| 亚洲乱码中文字幕| 美女视频黄久久| 亚洲二区视频在线| 一区二区三区不卡在线观看| 亚洲欧洲日韩女同| 亚洲色图一区二区| 亚洲免费在线播放| 亚洲综合色丁香婷婷六月图片| 亚洲视频在线观看一区| 国产精品视频一区二区三区不卡| 26uuu成人网一区二区三区| 久久久天堂av| 国产精品色哟哟网站| **网站欧美大片在线观看| 1区2区3区国产精品| 亚洲视频1区2区| 亚洲一区免费在线观看| 亚洲成人精品一区| 蜜臀精品久久久久久蜜臀| 麻豆成人在线观看| 国产精品一区一区| a美女胸又www黄视频久久| 91蜜桃网址入口| 欧美视频三区在线播放| 欧美一区二区视频在线观看2020| 精品精品国产高清一毛片一天堂| 久久免费精品国产久精品久久久久| 久久精品一二三| 亚洲激情中文1区| 乱一区二区av| 波多野结衣一区二区三区| 91精品福利视频| 欧美一级电影网站| 中文一区二区完整视频在线观看| 亚洲色欲色欲www| 午夜精品久久久久久久蜜桃app| 免费观看成人av| 成人午夜精品在线| 欧美精品亚洲二区| 亚洲国产精品成人综合色在线婷婷| 一区二区三区在线视频观看58| 欧美96一区二区免费视频| 成人天堂资源www在线| 欧美无砖专区一中文字| 久久久久久久网| 韩国欧美国产1区| 色综合久久综合中文综合网| 91精品国产色综合久久不卡电影| 国产日韩成人精品| 午夜电影网一区| 成人ar影院免费观看视频| 在线成人免费观看| 国产精品高潮久久久久无| 日韩中文字幕亚洲一区二区va在线 | 91麻豆精品国产自产在线观看一区| 国产欧美日韩亚州综合 | 亚洲va欧美va人人爽午夜| 成人免费福利片| 精品少妇一区二区三区视频免付费 | 久久精品欧美一区二区三区不卡 | 欧美一级生活片|