version 1.13, 2010/08/26 19:07:35
|
version 1.75, 2025/04/15 10:17:50
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.19 |
RPL/2 (R) version 4.1.36 |
Copyright (C) 1989-2010 Dr. BERTRAND Joël |
Copyright (C) 1989-2025 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 43 logical1
|
Line 43 logical1
|
controle(struct_processus *s_etat_processus, unsigned char *fichier, |
controle(struct_processus *s_etat_processus, unsigned char *fichier, |
unsigned char *type, unsigned char *somme_candidate) |
unsigned char *type, unsigned char *somme_candidate) |
{ |
{ |
EVP_MD_CTX contexte; |
EVP_MD_CTX *contexte; |
|
|
int in_fd; |
int in_fd; |
|
|
Line 56 controle(struct_processus *s_etat_proces
|
Line 56 controle(struct_processus *s_etat_proces
|
struct stat stat_buf; |
struct stat stat_buf; |
|
|
unsigned char *chaine; |
unsigned char *chaine; |
|
unsigned char *registre; |
unsigned char somme[EVP_MAX_MD_SIZE]; |
unsigned char somme[EVP_MAX_MD_SIZE]; |
unsigned char somme_hexadecimale[2 * EVP_MAX_MD_SIZE]; |
unsigned char somme_hexadecimale[2 * EVP_MAX_MD_SIZE]; |
|
|
unsigned int i; |
unsigned int i; |
unsigned int longueur_somme; |
unsigned int longueur_somme; |
|
|
|
registre = fichier; |
|
|
# ifdef OS2 |
# ifdef OS2 |
unsigned char *tampon; |
unsigned char *tampon; |
|
|
Line 88 controle(struct_processus *s_etat_proces
|
Line 91 controle(struct_processus *s_etat_proces
|
|
|
taille_fichier = stat_buf.st_size; |
taille_fichier = stat_buf.st_size; |
|
|
if ((chaine = malloc(taille_fichier)) == NULL) |
if ((chaine = malloc((size_t) taille_fichier)) == NULL) |
{ |
{ |
# ifdef OS2 |
# ifdef OS2 |
free(fichier); |
free(fichier); |
Line 114 controle(struct_processus *s_etat_proces
|
Line 117 controle(struct_processus *s_etat_proces
|
free(fichier); |
free(fichier); |
# endif |
# endif |
|
|
if ((octets_lus = read(in_fd, chaine, taille_fichier)) != taille_fichier) |
if ((octets_lus = read(in_fd, chaine, (size_t) taille_fichier)) |
|
!= (ssize_t) taille_fichier) |
{ |
{ |
# ifndef OS2 |
# ifndef OS2 |
close(in_fd); |
close(in_fd); |
Line 127 controle(struct_processus *s_etat_proces
|
Line 131 controle(struct_processus *s_etat_proces
|
|
|
close(in_fd); |
close(in_fd); |
|
|
|
if ((contexte = EVP_MD_CTX_new()) == NULL) |
|
{ |
|
close(in_fd); |
|
return(d_faux); |
|
} |
|
|
if (strcmp(type, "md5") == 0) |
if (strcmp(type, "md5") == 0) |
{ |
{ |
if (EVP_DigestInit(&contexte, EVP_md5()) != 1) |
if (EVP_DigestInit(contexte, EVP_md5()) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 138 controle(struct_processus *s_etat_proces
|
Line 149 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1) |
if (EVP_DigestUpdate(contexte, chaine, (size_t) taille_fichier) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 147 controle(struct_processus *s_etat_proces
|
Line 159 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if (EVP_DigestFinal_ex(&contexte, somme, &longueur_somme) != 1) |
if (EVP_DigestFinal_ex(contexte, somme, &longueur_somme) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 158 controle(struct_processus *s_etat_proces
|
Line 171 controle(struct_processus *s_etat_proces
|
} |
} |
else if (strcmp(type, "sha1") == 0) |
else if (strcmp(type, "sha1") == 0) |
{ |
{ |
if (EVP_DigestInit(&contexte, EVP_sha1()) != 1) |
if (EVP_DigestInit(contexte, EVP_sha1()) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 167 controle(struct_processus *s_etat_proces
|
Line 181 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if (EVP_DigestUpdate(&contexte, chaine, taille_fichier) != 1) |
if (EVP_DigestUpdate(contexte, chaine, (size_t) taille_fichier) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 176 controle(struct_processus *s_etat_proces
|
Line 191 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if (EVP_DigestFinal_ex(&contexte, somme, &longueur_somme) != 1) |
if (EVP_DigestFinal_ex(contexte, somme, &longueur_somme) != 1) |
{ |
{ |
|
EVP_MD_CTX_free(contexte); |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
Line 190 controle(struct_processus *s_etat_proces
|
Line 206 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
|
|
EVP_MD_CTX_cleanup(&contexte); |
EVP_MD_CTX_free(contexte); |
free(chaine); |
free(chaine); |
|
|
for(i = 0; i < longueur_somme; i++) |
for(i = 0; i < longueur_somme; i++) |
Line 204 controle(struct_processus *s_etat_proces
|
Line 220 controle(struct_processus *s_etat_proces
|
} |
} |
else |
else |
{ |
{ |
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
printf("+++Fatal : Somme de contrôle invalide\n"); |
|
printf("Fonction %s(%s)\n", type, registre); |
|
printf("Résultat obtenu : %s\n", somme_hexadecimale); |
|
printf("Résultat attendu : %s\n", somme_candidate); |
|
} |
|
else |
|
{ |
|
printf("+++Fatal : Hash code mismatch\n"); |
|
printf("Function %s(%s)\n", type, registre); |
|
printf("Computed hash code : %s\n", somme_hexadecimale); |
|
printf("Expected hash code : %s\n", somme_candidate); |
|
} |
|
|
drapeau = d_faux; |
drapeau = d_faux; |
} |
} |
|
|