File:  [local] / rpl / src / chiffrement.c
Revision 1.6: download - view: text, annotated - select for diffs - revision graph
Wed Feb 27 14:12:57 2013 UTC (11 years, 2 months ago) by bertrand
Branches: MAIN
CVS tags: HEAD
Ajout de la commande CIPHER pour la génération des clefs de chiffrement
et les opérations de chiffrement et déchiffrement.

    1: /*
    2: ================================================================================
    3:   RPL/2 (R) version 4.1.12
    4:   Copyright (C) 1989-2013 Dr. BERTRAND Joël
    5: 
    6:   This file is part of RPL/2.
    7: 
    8:   RPL/2 is free software; you can redistribute it and/or modify it
    9:   under the terms of the CeCILL V2 License as published by the french
   10:   CEA, CNRS and INRIA.
   11:  
   12:   RPL/2 is distributed in the hope that it will be useful, but WITHOUT
   13:   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   14:   FITNESS FOR A PARTICULAR PURPOSE.  See the CeCILL V2 License
   15:   for more details.
   16:  
   17:   You should have received a copy of the CeCILL License
   18:   along with RPL/2. If not, write to info@cecill.info.
   19: ================================================================================
   20: */
   21: 
   22: 
   23: #include "rpl-conv.h"
   24: 
   25: 
   26: /*
   27: ================================================================================
   28:   Fonction de chiffrement d'un séquence d'octets
   29: ================================================================================
   30:   Entrées : pointeur sur une structure
   31: --------------------------------------------------------------------------------
   32:   Sorties :
   33: --------------------------------------------------------------------------------
   34:   Effets de bord : néant
   35: ================================================================================
   36: */
   37: 
   38: unsigned char *
   39: chiffrement(const EVP_CIPHER *type_chiffrement, logical1 encodage,
   40:         unsigned char *message, unsigned int longueur_message,
   41:         unsigned char *clef, unsigned int longueur_clef,
   42:         unsigned char *vecteur_initialisation,
   43:         unsigned int *longueur_message_chiffre)
   44: {
   45:     int                         i;
   46:     int                         longueur_bloc_de_chiffrement;
   47:     int                         longueur_message_1;
   48:     int                         longueur_message_2;
   49: 
   50:     unsigned char               *message_chiffre;
   51: 
   52:     EVP_CIPHER_CTX              contexte;
   53: 
   54:     EVP_CIPHER_CTX_init(&contexte);
   55: 
   56:     longueur_bloc_de_chiffrement = EVP_CIPHER_block_size(type_chiffrement);
   57: 
   58:     if (EVP_CipherInit_ex(&contexte, type_chiffrement, NULL, clef,
   59:             vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)
   60:     {
   61:         EVP_CIPHER_CTX_cleanup(&contexte);
   62:         return(NULL);
   63:     }
   64: 
   65:     (*longueur_message_chiffre) = ((longueur_message /
   66:             longueur_bloc_de_chiffrement) + 1) * longueur_bloc_de_chiffrement;
   67: 
   68:     if ((message_chiffre = malloc((*longueur_message_chiffre) *
   69:             sizeof(unsigned char))) == NULL)
   70:     {
   71:         return(NULL);
   72:     }
   73: 
   74:     if (EVP_CipherUpdate(&contexte, message_chiffre, &longueur_message_1,
   75:             message, longueur_message) != 1)
   76:     {
   77:         free(message_chiffre);
   78:         EVP_CIPHER_CTX_cleanup(&contexte);
   79:         return(NULL);
   80:     }
   81: 
   82:     if (EVP_CipherFinal_ex(&contexte, message_chiffre + longueur_message_1,
   83:             &longueur_message_2) != 1)
   84:     {
   85:         free(message_chiffre);
   86:         EVP_CIPHER_CTX_cleanup(&contexte);
   87:         return(NULL);
   88:     }
   89: 
   90:     (*longueur_message_chiffre) = longueur_message_1 + longueur_message_2;
   91: 
   92:     // Mise à jour du vecteur d'initialisation
   93:     
   94:     for(i =0; i < EVP_CIPHER_iv_length(type_chiffrement); i++)
   95:     {
   96:         vecteur_initialisation[i] = contexte.iv[i];
   97:     }
   98: 
   99:     EVP_CIPHER_CTX_cleanup(&contexte);
  100: 
  101:     return(message_chiffre);
  102: }
  103: 
  104: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>