version 1.1, 2010/03/04 17:42:46
|
version 1.75, 2025/04/15 10:17:50
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.12 |
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 20
|
Line 20
|
*/ |
*/ |
|
|
|
|
#include "rpl.conv.h" |
#include "rpl-conv.h" |
|
|
|
|
/* |
/* |
================================================================================ |
================================================================================ |
Calcul des sommes de contrôle avant le lancement d'un exécutable |
Calcul des sommes de contrôle avant le lancement d'un exécutable |
de la famille RPL/2 (rpliconv, rplconvert, rplfile et rplpp). |
de la famille RPL/2 (rpliconv, rplconvert, rplfile et rplpp). |
================================================================================ |
================================================================================ |
Entrée : |
Entrée : |
- chaîne de caractères sur le fichier à contrôler |
- chaîne de caractères sur le fichier à contrôler |
- chaîne de caractères contenant la somme à contrôler |
- chaîne de caractères contenant la somme à contrôler |
- type de somme de contrôle |
- type de somme de contrôle |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
Sortie : drapeau |
Sortie : drapeau |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
Effets de bord : néant |
Effets de bord : néant |
================================================================================ |
================================================================================ |
*/ |
*/ |
|
|
|
|
logical1 |
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 i_rval = 0; |
int in_fd; |
int in_fd = -1; |
|
|
|
logical1 drapeau; |
logical1 drapeau; |
|
|
Line 58 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; |
|
|
i_rval = stat(fichier, &stat_buf); |
registre = fichier; |
|
|
|
# ifdef OS2 |
|
unsigned char *tampon; |
|
|
|
if ((tampon = malloc((strlen(fichier) + 5) * sizeof(unsigned char))) |
|
== NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(d_faux); |
|
} |
|
|
|
sprintf(tampon, "%s.exe", fichier); |
|
fichier = tampon; |
|
# endif |
|
|
|
if (stat(fichier, &stat_buf) != 0) |
|
{ |
|
# ifdef OS2 |
|
free(fichier); |
|
# endif |
|
|
|
(*s_etat_processus).erreur_systeme = d_es_erreur_fichier; |
|
return(d_faux); |
|
} |
|
|
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 |
|
free(fichier); |
|
# endif |
|
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if ((in_fd = open(fichier, 0, O_RDONLY)) < 0) |
if ((in_fd = open(fichier, 0, O_RDONLY)) < 0) |
{ |
{ |
|
# ifdef OS2 |
|
free(fichier); |
|
# endif |
|
|
free(chaine); |
free(chaine); |
|
|
(*s_etat_processus).erreur_systeme = d_es_erreur_fichier; |
(*s_etat_processus).erreur_systeme = d_es_erreur_fichier; |
return(d_faux); |
return(d_faux); |
} |
} |
|
|
if ((octets_lus = read(in_fd, chaine, taille_fichier)) != taille_fichier) |
# ifdef OS2 |
|
free(fichier); |
|
# endif |
|
|
|
if ((octets_lus = read(in_fd, chaine, (size_t) taille_fichier)) |
|
!= (ssize_t) taille_fichier) |
{ |
{ |
|
# ifndef OS2 |
close(in_fd); |
close(in_fd); |
free(chaine); |
free(chaine); |
|
|
(*s_etat_processus).erreur_systeme = d_es_erreur_fichier; |
(*s_etat_processus).erreur_systeme = d_es_erreur_fichier; |
return(d_faux); |
return(d_faux); |
|
# endif |
} |
} |
|
|
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 103 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 112 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 123 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 132 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 141 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 150 controle(struct_processus *s_etat_proces
|
Line 201 controle(struct_processus *s_etat_proces
|
return(d_faux); |
return(d_faux); |
} |
} |
} |
} |
|
else |
|
{ |
|
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 165 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; |
} |
} |
|
|