piler/src/digest.c

104 lines
2.1 KiB
C
Raw Normal View History

2011-11-14 15:57:52 +01:00
/*
* digest.c, SJ
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <syslog.h>
#include <piler.h>
#include <openssl/evp.h>
2011-12-29 12:11:28 +01:00
int make_digests(struct session_data *sdata, struct __config *cfg){
2011-12-09 15:24:15 +01:00
int i=0, n, fd, offset=3;
char *p, *body=NULL;
2011-12-29 12:11:28 +01:00
unsigned char buf[BIGBUFSIZE], md[DIGEST_LENGTH], md2[DIGEST_LENGTH];
SHA256_CTX context, context2;
2011-11-14 15:57:52 +01:00
memset(sdata->bodydigest, 0, 2*DIGEST_LENGTH+1);
2011-12-29 12:11:28 +01:00
memset(sdata->digest, 0, 2*DIGEST_LENGTH+1);
2011-11-16 14:47:47 +01:00
SHA256_Init(&context);
2011-12-29 12:11:28 +01:00
SHA256_Init(&context2);
2011-11-14 15:57:52 +01:00
fd = open(sdata->ttmpfile, O_RDONLY);
if(fd == -1) return -1;
2011-11-28 14:21:14 +01:00
while((n = read(fd, buf, sizeof(buf))) > 0){
2011-12-09 15:24:15 +01:00
2011-12-29 12:11:28 +01:00
SHA256_Update(&context2, buf, n);
2011-11-14 15:57:52 +01:00
body = (char *)&buf[0];
2011-11-22 12:31:54 +01:00
if(i == 0){
2011-12-09 15:24:15 +01:00
p = strstr(body, "\n\r\n");
if(!p){
p = strstr(body, "\n\n");
if(p){
offset = 2;
2011-11-22 12:31:54 +01:00
2011-12-09 15:24:15 +01:00
}
}
2011-11-22 12:31:54 +01:00
2011-12-09 15:24:15 +01:00
if(p){
sdata->hdr_len = p - body + offset;
body += sdata->hdr_len;
2011-11-22 12:31:54 +01:00
2011-12-09 15:24:15 +01:00
n -= sdata->hdr_len;
2011-11-22 12:31:54 +01:00
2011-12-09 15:24:15 +01:00
if(cfg->verbosity >= _LOG_DEBUG) syslog(LOG_PRIORITY, "%s: hdr_len: %d, offset: %d", sdata->ttmpfile, sdata->hdr_len, offset);
2011-11-14 15:57:52 +01:00
}
}
2011-11-22 12:31:54 +01:00
2011-11-16 14:47:47 +01:00
SHA256_Update(&context, body, n);
2011-11-14 15:57:52 +01:00
2011-11-22 12:31:54 +01:00
i++;
2011-11-14 15:57:52 +01:00
}
close(fd);
2011-11-16 14:47:47 +01:00
SHA256_Final(md, &context);
2011-12-29 12:11:28 +01:00
SHA256_Final(md2, &context2);
2011-11-14 15:57:52 +01:00
2011-12-29 12:11:28 +01:00
for(i=0;i<DIGEST_LENGTH;i++){
2011-11-16 14:47:47 +01:00
snprintf(sdata->bodydigest + i*2, 2*DIGEST_LENGTH, "%02x", md[i]);
2011-12-29 12:11:28 +01:00
snprintf(sdata->digest + i*2, 2*DIGEST_LENGTH, "%02x", md2[i]);
}
2011-11-14 15:57:52 +01:00
return 0;
}
2011-11-19 21:25:44 +01:00
void digest_file(char *filename, char *digest){
int fd, i, n;
unsigned char buf[MAXBUFSIZE], md[DIGEST_LENGTH];
SHA256_CTX context;
memset(digest, 0, 2*DIGEST_LENGTH+1);
fd = open(filename, O_RDONLY);
if(fd == -1) return;
SHA256_Init(&context);
2011-11-28 14:21:14 +01:00
while((n = read(fd, buf, sizeof(buf))) > 0){
2011-11-19 21:25:44 +01:00
SHA256_Update(&context, buf, n);
}
close(fd);
SHA256_Final(md, &context);
for(i=0;i<DIGEST_LENGTH;i++)
snprintf(digest + i*2, 2*DIGEST_LENGTH, "%02x", md[i]);
}