Diff for /rpl/src/chiffrement.c between versions 1.1 and 1.25

version 1.1, 2010/03/07 17:03:29 version 1.25, 2016/09/27 10:43:23
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.12    RPL/2 (R) version 4.1.25
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2016 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
 ================================================================================  ================================================================================
   Calcul des sommes de contrôle avant le lancement d'un exécutable    Fonction de chiffrement d'un séquence d'octets
   de la famille RPL/2 (rpliconv, rplconvert, rplfile et rplpp).  
 ================================================================================  ================================================================================
   Entrée :    Entrées : pointeur sur une structure
     - chaîne de caractères sur le fichier à contrôler  
     - chaîne de caractères contenant la somme à contrôler  
     - type de somme de contrôle  
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
   Sortie : drapeau    Sorties :
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
   Effets de bord : néant    Effets de bord : néant
 ================================================================================  ================================================================================
 */  */
   
   unsigned char *
   chiffrement(struct_processus *s_etat_processus,
           const EVP_CIPHER *type_chiffrement, logical1 encodage,
           unsigned char *message, integer8 longueur_message,
           unsigned char *clef, integer8 longueur_clef,
           unsigned char *vecteur_initialisation,
           integer8 *longueur_message_chiffre)
   {
       int                         i;
       int                         longueur_bloc_de_chiffrement;
       int                         longueur_message_1;
       int                         longueur_message_2;
   
       unsigned char               *message_chiffre;
   
       EVP_CIPHER_CTX              *contexte;
   
       if ((contexte = EVP_CIPHER_CTX_new()) == NULL)
       {
           return(NULL);
       }
   
       EVP_CIPHER_CTX_reset(contexte);
   
       longueur_bloc_de_chiffrement = EVP_CIPHER_block_size(type_chiffrement);
   
       if (EVP_CipherInit_ex(contexte, type_chiffrement, NULL, clef,
               vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)
       {
           EVP_CIPHER_CTX_free(contexte);
           return(NULL);
       }
   
       (*longueur_message_chiffre) = ((longueur_message /
               longueur_bloc_de_chiffrement) + 1) * longueur_bloc_de_chiffrement;
   
       if ((message_chiffre = malloc(((size_t) (*longueur_message_chiffre)) *
               sizeof(unsigned char))) == NULL)
       {
           EVP_CIPHER_CTX_free(contexte);
           return(NULL);
       }
   
       if (EVP_CipherUpdate(contexte, message_chiffre, &longueur_message_1,
               message, (int) longueur_message) != 1)
       {
           free(message_chiffre);
           EVP_CIPHER_CTX_free(contexte);
           return(NULL);
       }
   
       if (EVP_CipherFinal_ex(contexte, message_chiffre + longueur_message_1,
               &longueur_message_2) != 1)
       {
           free(message_chiffre);
           EVP_CIPHER_CTX_free(contexte);
           return(NULL);
       }
   
       (*longueur_message_chiffre) = longueur_message_1 + longueur_message_2;
   
       // Mise à jour du vecteur d'initialisation
       
       for(i = 0; i < EVP_CIPHER_iv_length(type_chiffrement); i++)
       {
           vecteur_initialisation[i] = EVP_CIPHER_CTX_iv(contexte)[i];
       }
   
       EVP_CIPHER_CTX_free(contexte);
   
       return(message_chiffre);
   }
   
 // vim: ts=4  // vim: ts=4

Removed from v.1.1  
changed lines
  Added in v.1.25


CVSweb interface <joel.bertrand@systella.fr>