/* $Id: comm_info.c,v 1.666 2004/09/20 10:50:15 shrike Exp $ */
/************************************************************************************
* Copyright 2004 Astrum Metaphora consortium *
* *
* Licensed under the Apache License, Version 2.0 (the "License"); *
* you may not use this file except in compliance with the License. *
* You may obtain a copy of the License at *
* *
* http://www.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, software *
* distributed under the License is distributed on an "AS IS" BASIS, *
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
* See the License for the specific language governing permissions and *
* limitations under the License. *
* *
************************************************************************************/
/************************************************************************************
* ANATOLIA 2.1 is copyright 1996-1997 Serdar BULUT, Ibrahim CANPUNAR *
* ANATOLIA has been brought to you by ANATOLIA consortium *
* Serdar BULUT {Chronos} bulut@rorqual.cc.metu.edu.tr *
* Ibrahim Canpunar {Asena} canpunar@rorqual.cc.metu.edu.tr *
* Murat BICER {KIO} mbicer@rorqual.cc.metu.edu.tr *
* D.Baris ACAR {Powerman} dbacar@rorqual.cc.metu.edu.tr *
* By using this code, you have agreed to follow the terms of the *
* ANATOLIA license, in the file Anatolia/anatolia.licence *
***********************************************************************************/
/************************************************************************************
* Original Diku Mud copyright (C) 1990, 1991 by Sebastian Hammer, *
* Michael Seifert, Hans Henrik St{rfeldt, Tom Madsen, and Katja Nyboe. *
* *
* Merc Diku Mud improvments copyright (C) 1992, 1993 by Michael *
* Chastain, Michael Quan, and Mitchell Tse. *
* *
* In order to use any part of this Merc Diku Mud, you must comply with *
* both the original Diku license in 'license.doc' as well the Merc *
* license in 'license.txt'. In particular, you may not remove either of *
* these copyright notices. *
* *
* Much time and thought has gone into this software and you are *
* benefitting. We hope that you share your changes too. What goes *
* around, comes around. *
************************************************************************************/
/************************************************************************************
* ROM 2.4 is copyright 1993-1995 Russ Taylor *
* ROM has been brought to you by the ROM consortium *
* Russ Taylor (rtaylor@pacinfo.com) *
* Gabrielle Taylor (gtaylor@pacinfo.com) *
* Brian Moore (rom@rom.efn.org) *
* By using this code, you have agreed to follow the terms of the *
* ROM license, in the file Rom24/doc/rom.license *
*************************************************************************************/
/************************************************************************************
* Copyright (c) 1998 fjoe <fjoe@iclub.nsu.ru> *
* All rights reserved. *
* *
* Redistribution and use in source and binary forms, with or without *
* modification, are permitted provided that the following conditions *
* are met: *
* 1. Redistributions of source code must retain the above copyright *
* notice, this list of conditions and the following disclaimer. *
* 2. Redistributions in binary form must reproduce the above copyright *
* notice, this list of conditions and the following disclaimer in the *
* documentation and/or other materials provided with the distribution. *
* *
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND *
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE *
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE *
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE *
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL *
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS *
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) *
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT *
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY *
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF *
* SUCH DAMAGE. *
************************************************************************************/
#include <sys/types.h>
#if !defined (WIN32)
# include <sys/socket.h>
# include <netinet/in.h>
# include <arpa/inet.h>
# include <unistd.h>
#else
# include <winsock.h>
#endif
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "merc.h"
#include "comm_info.h"
#include "comm_colors.h"
extern int max_on;
INFO_DESC * id_list;
int top_id;
static INFO_DESC * id_free_list;
static INFO_DESC * info_desc_new(int fd);
static void info_desc_free(INFO_DESC *id);
void info_newconn(int infofd)
{
int fd;
struct sockaddr_in sock;
int size = sizeof(sock);
INFO_DESC *id;
getsockname(infofd, (struct sockaddr*) &sock, &size);
if ((fd = accept(infofd, (struct sockaddr*) &sock, &size)) < 0) {
log_printf("info_newconn: accept: %s", strerror(errno));
return;
}
if (getpeername(fd, (struct sockaddr *) &sock, &size) < 0) {
log_printf("info_newconn: getpeername: %s", strerror(errno));
#ifdef WIN32
closesocket(fd);
#else
close(fd);
#endif
return;
}
log_printf("info_newconn: sock.sin_addr: %s", inet_ntoa(sock.sin_addr));
#if !defined (WIN32)
if (fcntl(fd, F_SETFL, FNDELAY) < 0) {
log_printf("info_newconn: fcntl: FNDELAY: %s", strerror(errno));
close(fd);
return;
}
#endif
id = info_desc_new(fd);
id->next = id_list;
id_list = id;
}
void info_process_cmd(INFO_DESC *id)
{
BUFFER *output;
char buf[MAX_STRING_LENGTH * 2];
char *p;
char *q;
int format;
DESCRIPTOR_DATA *d;
int nread;
#if !defined (WIN32)
if ((nread = read(id->fd, buf, sizeof(buf))) < 0)
{
if (errno == EWOULDBLOCK)
#else
if ((nread = recv(id->fd, buf, sizeof(buf), 0)) < 0)
{
if ( WSAGetLastError() == WSAEWOULDBLOCK)
#endif
return;
log_printf("info_input: read: %s", strerror(errno));
goto bail_out;
}
buf[nread] = '\0';
for (p = buf; *p && strchr(" \n\r\t", *p); p++)
;
if ((q = strpbrk(p, " \n\r\t")))
*q = '\0';
log_printf("process_who: output format requested: '%s'", p);
format = format_lookup(p);
output = buf_new(-1);
buf_printf(output, "%d\n", max_on);
p = buf_string(output);
#if !defined (WIN32)
write(id->fd, p, strlen(p));
#else
send(id->fd, p, strlen(p), 0);
#endif
for (d = descriptor_list; d; d = d->next) {
CHAR_DATA *wch = d->original ? d->original : d->character;
if (!wch
|| d->connected != CON_PLAYING
|| wch->invis_level
|| wch->incog_level
|| IS_AFFECTED(wch, AFF_FADE | AFF_HIDE | AFF_CAMOUFLAGE |
AFF_INVIS | AFF_IMP_INVIS | AFF_TRAP))
continue;
buf_clear(output);
do_who_raw(NULL, wch, output);
parse_colors(buf_string(output), buf, sizeof(buf), format);
#if !defined (WIN32)
write(id->fd, buf, strlen(buf));
#else
send(id->fd, buf, strlen(buf), 0);
#endif
}
buf_free(output);
bail_out:
info_desc_free(id);
}
static INFO_DESC *info_desc_new(int fd)
{
INFO_DESC *id;
if (id_free_list) {
id = id_free_list;
id_free_list = id_free_list->next;
}
else {
top_id++;
id = malloc(sizeof(*id));
}
id->fd = fd;
return id;
}
static void info_desc_free(INFO_DESC *id)
{
if (id == id_list)
id_list = id_list->next;
else {
INFO_DESC *prev;
for (prev = id_list; prev; prev = prev->next)
if (prev->next == id)
break;
if (!prev) {
log("info_desc_free: descriptor not found");
return;
}
prev->next = id->next;
}
#ifdef WIN32
closesocket(id->fd);
#else
close(id->fd);
#endif
id->next = id_free_list;
id_free_list = id;
}