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

version 1.24, 2016/03/01 22:12:26 version 1.25, 2016/09/27 10:43:23
Line 50  chiffrement(struct_processus *s_etat_pro Line 50  chiffrement(struct_processus *s_etat_pro
   
     unsigned char               *message_chiffre;      unsigned char               *message_chiffre;
   
     EVP_CIPHER_CTX              contexte;      EVP_CIPHER_CTX              *contexte;
   
     EVP_CIPHER_CTX_init(&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);      longueur_bloc_de_chiffrement = EVP_CIPHER_block_size(type_chiffrement);
   
     if (EVP_CipherInit_ex(&contexte, type_chiffrement, NULL, clef,      if (EVP_CipherInit_ex(contexte, type_chiffrement, NULL, clef,
             vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)              vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)
     {      {
         EVP_CIPHER_CTX_cleanup(&contexte);          EVP_CIPHER_CTX_free(contexte);
         return(NULL);          return(NULL);
     }      }
   
Line 69  chiffrement(struct_processus *s_etat_pro Line 74  chiffrement(struct_processus *s_etat_pro
     if ((message_chiffre = malloc(((size_t) (*longueur_message_chiffre)) *      if ((message_chiffre = malloc(((size_t) (*longueur_message_chiffre)) *
             sizeof(unsigned char))) == NULL)              sizeof(unsigned char))) == NULL)
     {      {
           EVP_CIPHER_CTX_free(contexte);
         return(NULL);          return(NULL);
     }      }
   
     if (EVP_CipherUpdate(&contexte, message_chiffre, &longueur_message_1,      if (EVP_CipherUpdate(contexte, message_chiffre, &longueur_message_1,
             message, (int) longueur_message) != 1)              message, (int) longueur_message) != 1)
     {      {
         free(message_chiffre);          free(message_chiffre);
         EVP_CIPHER_CTX_cleanup(&contexte);          EVP_CIPHER_CTX_free(contexte);
         return(NULL);          return(NULL);
     }      }
   
     if (EVP_CipherFinal_ex(&contexte, message_chiffre + longueur_message_1,      if (EVP_CipherFinal_ex(contexte, message_chiffre + longueur_message_1,
             &longueur_message_2) != 1)              &longueur_message_2) != 1)
     {      {
         free(message_chiffre);          free(message_chiffre);
         EVP_CIPHER_CTX_cleanup(&contexte);          EVP_CIPHER_CTX_free(contexte);
         return(NULL);          return(NULL);
     }      }
   
Line 94  chiffrement(struct_processus *s_etat_pro Line 100  chiffrement(struct_processus *s_etat_pro
           
     for(i = 0; i < EVP_CIPHER_iv_length(type_chiffrement); i++)      for(i = 0; i < EVP_CIPHER_iv_length(type_chiffrement); i++)
     {      {
         vecteur_initialisation[i] = contexte.iv[i];          vecteur_initialisation[i] = EVP_CIPHER_CTX_iv(contexte)[i];
     }      }
   
     EVP_CIPHER_CTX_cleanup(&contexte);      EVP_CIPHER_CTX_free(contexte);
   
     return(message_chiffre);      return(message_chiffre);
 }  }

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


CVSweb interface <joel.bertrand@systella.fr>