File:  [local] / rpl / src / chiffrement.c
Revision 1.45: download - view: text, annotated - select for diffs - revision graph
Tue Apr 15 10:17:49 2025 UTC (2 weeks, 4 days ago) by bertrand
Branches: MAIN
CVS tags: HEAD
Mise à jour du copyright.

    1: /*
    2: ================================================================================
    3:   RPL/2 (R) version 4.1.36
    4:   Copyright (C) 1989-2025 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(struct_processus *s_etat_processus,
   40:         const EVP_CIPHER *type_chiffrement, logical1 encodage,
   41:         unsigned char *message, integer8 longueur_message,
   42:         unsigned char *clef, integer8 longueur_clef,
   43:         unsigned char *vecteur_initialisation,
   44:         integer8 *longueur_message_chiffre,
   45:         unsigned char padding)
   46: {
   47:     int                         longueur_bloc_de_chiffrement;
   48:     int                         longueur_message_1;
   49:     int                         longueur_message_2;
   50: 
   51:     integer8                    nombre_blocs;
   52: 
   53:     unsigned char               *message_chiffre;
   54: 
   55:     EVP_CIPHER_CTX              *contexte;
   56: 
   57:     if ((contexte = EVP_CIPHER_CTX_new()) == NULL)
   58:     {
   59:         return(NULL);
   60:     }
   61: 
   62:     EVP_CIPHER_CTX_reset(contexte);
   63: 
   64:     longueur_bloc_de_chiffrement = EVP_CIPHER_block_size(type_chiffrement);
   65: 
   66:     if (EVP_CipherInit_ex(contexte, type_chiffrement, NULL, clef,
   67:             vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)
   68:     {
   69:         EVP_CIPHER_CTX_free(contexte);
   70:         return(NULL);
   71:     }
   72: 
   73:     nombre_blocs = longueur_message / longueur_bloc_de_chiffrement;
   74: 
   75:     if ((longueur_message % longueur_bloc_de_chiffrement) != 0)
   76:     {
   77:         nombre_blocs++;
   78:     }
   79:     else if (padding == 'N')
   80:     {
   81:         // Pas de padding si la longueur du message est un multiple
   82:         // entier de la longueur du bloc.
   83: 
   84:         EVP_CIPHER_CTX_set_padding(contexte, 0);
   85:     }
   86: 
   87:     (*longueur_message_chiffre) = nombre_blocs * longueur_bloc_de_chiffrement;
   88: 
   89:     if (padding == 'Y')
   90:     {
   91:         // On prévoit une zone de garde pour EVP_CipherFinal_ex() qui rajoute
   92:         // TOUJOURS un bloc complet même s'il la taille chiffrée par
   93:         // EVP_CipherUpdate() est un nombre exact de blocs !
   94: 
   95:         if ((message_chiffre = malloc(((size_t) ((*longueur_message_chiffre)
   96:                 + longueur_bloc_de_chiffrement)) *
   97:                 sizeof(unsigned char))) == NULL)
   98:         {
   99:             EVP_CIPHER_CTX_free(contexte);
  100:             return(NULL);
  101:         }
  102:     }
  103:     else
  104:     {
  105:         if ((message_chiffre = malloc(((size_t) (*longueur_message_chiffre)
  106:                 ) * sizeof(unsigned char))) == NULL)
  107:         {
  108:             EVP_CIPHER_CTX_free(contexte);
  109:             return(NULL);
  110:         }
  111:     }
  112: 
  113:     if (EVP_CipherUpdate(contexte, message_chiffre, &longueur_message_1,
  114:             message, (int) longueur_message) != 1)
  115:     {
  116:         free(message_chiffre);
  117:         EVP_CIPHER_CTX_free(contexte);
  118:         return(NULL);
  119:     }
  120: 
  121:     if (EVP_CipherFinal_ex(contexte, message_chiffre + longueur_message_1,
  122:             &longueur_message_2) != 1)
  123:     {
  124:         free(message_chiffre);
  125:         EVP_CIPHER_CTX_free(contexte);
  126:         return(NULL);
  127:     }
  128: 
  129:     (*longueur_message_chiffre) = longueur_message_1 + longueur_message_2;
  130: 
  131:     // Mise à jour du vecteur d'initialisation
  132:     
  133:     EVP_CIPHER_CTX_get_updated_iv(contexte, vecteur_initialisation,
  134:             (size_t) EVP_CIPHER_iv_length(type_chiffrement));
  135: 
  136:     EVP_CIPHER_CTX_free(contexte);
  137: 
  138:     return(message_chiffre);
  139: }
  140: 
  141: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>