Annotation of rpl/src/chiffrement.c, revision 1.43

1.1       bertrand    1: /*
                      2: ================================================================================
1.41      bertrand    3:   RPL/2 (R) version 4.1.36
1.40      bertrand    4:   Copyright (C) 1989-2024 Dr. BERTRAND Joël
1.1       bertrand    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: 
1.43    ! bertrand   22: 
1.4       bertrand   23: #include "rpl-conv.h"
1.43    ! bertrand   24: 
1.1       bertrand   25: 
                     26: /*
                     27: ================================================================================
1.4       bertrand   28:   Fonction de chiffrement d'un séquence d'octets
1.1       bertrand   29: ================================================================================
1.4       bertrand   30:   Entrées : pointeur sur une structure
1.1       bertrand   31: --------------------------------------------------------------------------------
1.4       bertrand   32:   Sorties :
1.1       bertrand   33: --------------------------------------------------------------------------------
                     34:   Effets de bord : néant
                     35: ================================================================================
                     36: */
                     37: 
1.4       bertrand   38: unsigned char *
1.19      bertrand   39: chiffrement(struct_processus *s_etat_processus,
                     40:        const EVP_CIPHER *type_chiffrement, logical1 encodage,
1.9       bertrand   41:        unsigned char *message, integer8 longueur_message,
                     42:        unsigned char *clef, integer8 longueur_clef,
1.4       bertrand   43:        unsigned char *vecteur_initialisation,
1.9       bertrand   44:        integer8 *longueur_message_chiffre)
1.4       bertrand   45: {
1.6       bertrand   46:    int                         longueur_bloc_de_chiffrement;
1.4       bertrand   47:    int                         longueur_message_1;
                     48:    int                         longueur_message_2;
                     49: 
1.42      bertrand   50:    integer8                    nombre_blocs;
                     51: 
1.4       bertrand   52:    unsigned char               *message_chiffre;
                     53: 
1.25      bertrand   54:    EVP_CIPHER_CTX              *contexte;
1.4       bertrand   55: 
1.25      bertrand   56:    if ((contexte = EVP_CIPHER_CTX_new()) == NULL)
                     57:    {
                     58:        return(NULL);
                     59:    }
                     60: 
                     61:    EVP_CIPHER_CTX_reset(contexte);
1.4       bertrand   62: 
1.6       bertrand   63:    longueur_bloc_de_chiffrement = EVP_CIPHER_block_size(type_chiffrement);
                     64: 
1.25      bertrand   65:    if (EVP_CipherInit_ex(contexte, type_chiffrement, NULL, clef,
1.4       bertrand   66:            vecteur_initialisation, (encodage == d_vrai) ? 1 : 0) != 1)
                     67:    {
1.25      bertrand   68:        EVP_CIPHER_CTX_free(contexte);
1.4       bertrand   69:        return(NULL);
                     70:    }
                     71: 
1.42      bertrand   72:    nombre_blocs = longueur_message / longueur_bloc_de_chiffrement;
                     73: 
                     74:    if ((longueur_message % longueur_bloc_de_chiffrement) != 0)
                     75:    {
                     76:        nombre_blocs++;
                     77:    }
                     78: 
                     79:    (*longueur_message_chiffre) = nombre_blocs * longueur_bloc_de_chiffrement;
1.4       bertrand   80: 
1.42      bertrand   81:    // On prévoit une zone de garde pour EVP_CipherFinal_ex() en espérant
                     82:    // qu'il ne faille pas plus qu'une longueur de bloc de chiffrement.
                     83:    if ((message_chiffre = malloc(((size_t) ((*longueur_message_chiffre)
                     84:            + longueur_bloc_de_chiffrement)) *
1.4       bertrand   85:            sizeof(unsigned char))) == NULL)
                     86:    {
1.25      bertrand   87:        EVP_CIPHER_CTX_free(contexte);
1.4       bertrand   88:        return(NULL);
                     89:    }
                     90: 
1.25      bertrand   91:    if (EVP_CipherUpdate(contexte, message_chiffre, &longueur_message_1,
1.9       bertrand   92:            message, (int) longueur_message) != 1)
1.4       bertrand   93:    {
                     94:        free(message_chiffre);
1.25      bertrand   95:        EVP_CIPHER_CTX_free(contexte);
1.4       bertrand   96:        return(NULL);
                     97:    }
                     98: 
1.25      bertrand   99:    if (EVP_CipherFinal_ex(contexte, message_chiffre + longueur_message_1,
1.4       bertrand  100:            &longueur_message_2) != 1)
                    101:    {
                    102:        free(message_chiffre);
1.25      bertrand  103:        EVP_CIPHER_CTX_free(contexte);
1.4       bertrand  104:        return(NULL);
                    105:    }
                    106: 
                    107:    (*longueur_message_chiffre) = longueur_message_1 + longueur_message_2;
1.6       bertrand  108: 
                    109:    // Mise à jour du vecteur d'initialisation
                    110:    
1.38      bertrand  111:    EVP_CIPHER_CTX_get_updated_iv(contexte, vecteur_initialisation,
                    112:            (size_t) EVP_CIPHER_iv_length(type_chiffrement));
1.6       bertrand  113: 
1.25      bertrand  114:    EVP_CIPHER_CTX_free(contexte);
1.4       bertrand  115: 
                    116:    return(message_chiffre);
                    117: }
                    118: 
1.1       bertrand  119: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>