/* $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; }