1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
/*
* ffproxy (c) 2002, 2003 Niklas Olmes <niklas@noxa.de>
* http://faith.eu.org
*
* $Id: msg.c,v 2.1 2004/12/31 08:59:15 niklas Exp $
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 2 of the License, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this program; if not, write to the Free Software Foundation, Inc., 675
* Mass Ave, Cambridge, MA 02139, USA.
*/
#include "configure.h"
#ifdef HAVE_SYS_TYPES_H
# include <sys/types.h>
#endif
#include <stdio.h>
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif
#include "req.h"
#include "dbs.h"
#include "msg.h"
#include "poll.h"
void
err_msg(int s, struct req * r, int m)
{
char msg[8192];
char *p;
size_t i;
int j;
p = NULL;
switch (m) {
case E_INV:
p = e_inv.c;
break;
case E_RES:
p = e_res.c;
break;
case E_CON:
p = e_con.c;
break;
case E_POST:
p = e_post.c;
break;
case E_FIL:
p = e_fil.c;
break;
}
*msg = '\0';
i = 0;
while (p != NULL && *p != '\0' && i < sizeof(msg) - 1)
if (*p == '$') {
switch (*(p + 1)) {
case 'u':
j = 0;
while (i < sizeof(msg) - 1 && r->url[j] != '\0')
msg[i++] = r->url[j++];
p += 2;
break;
case 'h':
j = 0;
while (i < sizeof(msg) - 1 && r->host[j] != '\0')
msg[i++] = r->host[j++];
p += 2;
break;
case 'c':
j = 0;
while (i < sizeof(msg) - 1 && r->cl->name[j] != '\0')
msg[i++] = r->cl->name[j++];
p += 2;
break;
default:
msg[i++] = *(p++);
break;
}
} else
msg[i++] = *(p++);
msg[i] = '\0';
if (i > 0 && my_poll(s, OUT))
(void) write(s, msg, i - 1);
}
|