00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027 #include <stdio.h>
00028 #include <stdlib.h>
00029 #include <string.h>
00030 #include <ctype.h>
00031 #include <time.h>
00032 #include <unistd.h>
00033 #include <sys/time.h>
00034 #include <sys/types.h>
00035 #include <netinet/in.h>
00036 #include <errno.h>
00037
00038 #include "logparse.h"
00039 #include "utils.h"
00040
00041
00042
00055 int lf_get_next_entry(int logfile_fd, lf_entry *nextentry, int vers)
00056 {
00057 unsigned char blockbuf[60], *tmp;
00058 int uln, ret;
00059
00060 if ((ret = correct_read(logfile_fd, (char *)blockbuf, (size_t) 60)) != 60) {
00061 if (ret == 0)
00062 return 1;
00063
00064 return 2;
00065 }
00066
00067
00068 nextentry->version = vers;
00069 memcpy( &(nextentry->crs), blockbuf+0, 4);
00070 memcpy( &(nextentry->cru), blockbuf+4, 4);
00071 memcpy( &(nextentry->srs), blockbuf+8, 4);
00072 memcpy( &(nextentry->sru), blockbuf+12, 4);
00073 memcpy( &(nextentry->sls), blockbuf+16, 4);
00074 memcpy( &(nextentry->slu), blockbuf+20, 4);
00075 memcpy( &(nextentry->cip), blockbuf+24, 4);
00076 memcpy( &(nextentry->cpt), blockbuf+28, 2);
00077 memcpy( &(nextentry->sip), blockbuf+30, 4);
00078 memcpy( &(nextentry->spt), blockbuf+34, 2);
00079 memcpy( &(nextentry->cprg), blockbuf+36, 1);
00080 memcpy( &(nextentry->sprg), blockbuf+37, 1);
00081 memcpy( &(nextentry->cims), blockbuf+38, 4);
00082 memcpy( &(nextentry->sexp), blockbuf+42, 4);
00083 memcpy( &(nextentry->slmd), blockbuf+46, 4);
00084 memcpy( &(nextentry->rhl), blockbuf+50, 4);
00085 memcpy( &(nextentry->rdl), blockbuf+54, 4);
00086 memcpy( &(nextentry->urllen), blockbuf+58, 2);
00087
00088
00089 uln = ntohs(nextentry->urllen);
00090 nextentry->url = (unsigned char *) malloc(sizeof(char) *
00091 (int) (uln + 1));
00092 if (nextentry->url == NULL) {
00093 fprintf(stderr, "out of memory in lf_get_next_netry!\n");
00094 exit(1);
00095 }
00096 if ((ret = correct_read(logfile_fd, (char *) (nextentry->url), (size_t) uln))
00097 != uln ) {
00098 if (ret == 0) {
00099 free(nextentry->url);
00100 return 1;
00101 }
00102 fprintf(stderr, "read of %d failed %d\n", (size_t) uln, ret);
00103 perror("aargh.");
00104 free(nextentry->url);
00105 return 2;
00106 }
00107 tmp = nextentry->url;
00108 *(tmp + uln) = '\0';
00109 return 0;
00110 }
00111
00118 void lf_convert_order(lf_entry *convertme)
00119 {
00120 convertme->crs = ntohl(convertme->crs);
00121 convertme->cru = ntohl(convertme->cru);
00122 convertme->srs = ntohl(convertme->srs);
00123 convertme->sru = ntohl(convertme->sru);
00124 convertme->sls = ntohl(convertme->sls);
00125 convertme->slu = ntohl(convertme->slu);
00126 convertme->cip = ntohl(convertme->cip);
00127 convertme->cpt = ntohs(convertme->cpt);
00128 convertme->sip = ntohl(convertme->sip);
00129 convertme->spt = ntohs(convertme->spt);
00130 convertme->cims = ntohl(convertme->cims);
00131 convertme->sexp = ntohl(convertme->sexp);
00132 convertme->slmd = ntohl(convertme->slmd);
00133 convertme->rhl = ntohl(convertme->rhl);
00134 convertme->rdl = ntohl(convertme->rdl);
00135 convertme->urllen = ntohs(convertme->urllen);
00136 }
00137
00143 int lf_write(FILE *outf, lf_entry *writeme)
00144 {
00145 unsigned char blockbuf[60];
00146 int uln, ret;
00147
00148 memcpy( blockbuf+0, &(writeme->crs), 4);
00149 memcpy( blockbuf+4, &(writeme->cru), 4);
00150 memcpy( blockbuf+8, &(writeme->srs), 4);
00151 memcpy( blockbuf+12, &(writeme->sru), 4);
00152 memcpy( blockbuf+16, &(writeme->sls), 4);
00153 memcpy( blockbuf+20, &(writeme->slu), 4);
00154 memcpy( blockbuf+24, &(writeme->cip), 4);
00155 memcpy( blockbuf+28, &(writeme->cpt), 2);
00156 memcpy( blockbuf+30, &(writeme->sip), 4);
00157 memcpy( blockbuf+34, &(writeme->spt), 2);
00158 memcpy( blockbuf+36, &(writeme->cprg), 1);
00159 memcpy( blockbuf+37, &(writeme->sprg), 1);
00160 memcpy( blockbuf+38, &(writeme->cims), 4);
00161 memcpy( blockbuf+42, &(writeme->sexp), 4);
00162 memcpy( blockbuf+46, &(writeme->slmd), 4);
00163 memcpy( blockbuf+50, &(writeme->rhl), 4);
00164 memcpy( blockbuf+54, &(writeme->rdl), 4);
00165 memcpy( blockbuf+58, &(writeme->urllen), 2);
00166
00167 ret = fwrite(&(blockbuf[0]), 60, 1, outf);
00168 if (ret != 1) {
00169 fprintf(stderr, "write 60 failed...%d\n", ret);
00170 perror("arrgh1");
00171 return 1;
00172 }
00173
00174
00175 uln = ntohs(writeme->urllen);
00176 ret = fwrite(writeme->url, (size_t) uln, 1, outf);
00177 if (ret != 1) {
00178 fprintf(stderr, "write of %d failed %d\n", (size_t) uln, ret);
00179 perror("aargh.");
00180 return 2;
00181 }
00182 return 0;
00183 }
00184
00190 void lf_dump(FILE *dumpf, lf_entry *dumpme)
00191 {
00192 char addr1buf[128], addr2buf[128];
00193
00194 lf_convert_order(dumpme);
00195 lf_ntoa(dumpme->cip, addr1buf);
00196 lf_ntoa(dumpme->sip, addr2buf);
00197 fprintf(dumpf, "%lu:%lu %lu:%lu %lu:%lu %s:%hu %s:%hu %u %u ",
00198 dumpme->crs, dumpme->cru, dumpme->srs, dumpme->sru,
00199 dumpme->sls, dumpme->slu, addr1buf, dumpme->cpt,
00200 addr2buf, dumpme->spt, dumpme->cprg, dumpme->sprg);
00201 fprintf(dumpf, "%lu %lu %lu %lu %lu %u %s\n",
00202 dumpme->cims, dumpme->sexp, dumpme->slmd, dumpme->rhl,
00203 dumpme->rdl, dumpme->urllen, dumpme->url);
00204 lf_convert_order(dumpme);
00205 }
00206
00212 void lf_ntoa(unsigned long addr, char *addrbuf)
00213 {
00214 sprintf(addrbuf, "%lu.%lu.%lu.%lu",
00215 (addr >> 24),
00216 (addr >> 16) % 256,
00217 (addr >> 8) % 256,
00218 (addr) % 256);
00219 }