Subversion Repositories Kolibri OS

Rev

Go to most recent revision | Blame | Last modification | View Log | RSS feed

  1. /**
  2.  * \file pem.h
  3.  *
  4.  * \brief Privacy Enhanced Mail (PEM) decoding
  5.  *
  6.  *  Copyright (C) 2006-2010, Brainspark B.V.
  7.  *
  8.  *  This file is part of PolarSSL (http://www.polarssl.org)
  9.  *  Lead Maintainer: Paul Bakker <polarssl_maintainer at polarssl.org>
  10.  *
  11.  *  All rights reserved.
  12.  *
  13.  *  This program is free software; you can redistribute it and/or modify
  14.  *  it under the terms of the GNU General Public License as published by
  15.  *  the Free Software Foundation; either version 2 of the License, or
  16.  *  (at your option) any later version.
  17.  *
  18.  *  This program is distributed in the hope that it will be useful,
  19.  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  20.  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  21.  *  GNU General Public License for more details.
  22.  *
  23.  *  You should have received a copy of the GNU General Public License along
  24.  *  with this program; if not, write to the Free Software Foundation, Inc.,
  25.  *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  26.  */
  27. #ifndef POLARSSL_PEM_H
  28. #define POLARSSL_PEM_H
  29.  
  30. #include <string.h>
  31.  
  32. /**
  33.  * \name PEM Error codes
  34.  * These error codes are returned in case of errors reading the
  35.  * PEM data.
  36.  * \{
  37.  */
  38. #define POLARSSL_ERR_PEM_NO_HEADER_PRESENT                 -0x1080  /**< No PEM header found. */
  39. #define POLARSSL_ERR_PEM_INVALID_DATA                      -0x1100  /**< PEM string is not as expected. */
  40. #define POLARSSL_ERR_PEM_MALLOC_FAILED                     -0x1180  /**< Failed to allocate memory. */
  41. #define POLARSSL_ERR_PEM_INVALID_ENC_IV                    -0x1200  /**< RSA IV is not in hex-format. */
  42. #define POLARSSL_ERR_PEM_UNKNOWN_ENC_ALG                   -0x1280  /**< Unsupported key encryption algorithm. */
  43. #define POLARSSL_ERR_PEM_PASSWORD_REQUIRED                 -0x1300  /**< Private key password can't be empty. */
  44. #define POLARSSL_ERR_PEM_PASSWORD_MISMATCH                 -0x1380  /**< Given private key password does not allow for correct decryption. */
  45. #define POLARSSL_ERR_PEM_FEATURE_UNAVAILABLE               -0x1400  /**< Unavailable feature, e.g. hashing/encryption combination. */
  46. /* \} name */
  47.  
  48. /**
  49.  * \brief       PEM context structure
  50.  */
  51. typedef struct
  52. {
  53.     unsigned char *buf;     /*!< buffer for decoded data             */
  54.     size_t buflen;          /*!< length of the buffer                */
  55.     unsigned char *info;    /*!< buffer for extra header information */
  56. }
  57. pem_context;
  58.  
  59. #ifdef __cplusplus
  60. extern "C" {
  61. #endif
  62.  
  63. /**
  64.  * \brief       PEM context setup
  65.  *
  66.  * \param ctx   context to be initialized
  67.  */
  68. void pem_init( pem_context *ctx );
  69.  
  70. /**
  71.  * \brief       Read a buffer for PEM information and store the resulting
  72.  *              data into the specified context buffers.
  73.  *
  74.  * \param ctx       context to use
  75.  * \param header    header string to seek and expect
  76.  * \param footer    footer string to seek and expect
  77.  * \param data      source data to look in
  78.  * \param pwd       password for decryption (can be NULL)
  79.  * \param pwdlen    length of password
  80.  * \param use_len   destination for total length used
  81.  *
  82.  * \return          0 on success, ior a specific PEM error code
  83.  */
  84. int pem_read_buffer( pem_context *ctx, char *header, char *footer,
  85.                      const unsigned char *data,
  86.                      const unsigned char *pwd,
  87.                      size_t pwdlen, size_t *use_len );
  88.  
  89. /**
  90.  * \brief       PEM context memory freeing
  91.  *
  92.  * \param ctx   context to be freed
  93.  */
  94. void pem_free( pem_context *ctx );
  95.  
  96. #ifdef __cplusplus
  97. }
  98. #endif
  99.  
  100. #endif /* pem.h */
  101.