ds2.9a12/bin/
ds2.9a12/extra/
ds2.9a12/extra/crat/
ds2.9a12/extra/creremote/
ds2.9a12/extra/mingw/
ds2.9a12/extra/wolfpaw/
ds2.9a12/fluffos-2.14-ds13/
ds2.9a12/fluffos-2.14-ds13/Win32/
ds2.9a12/fluffos-2.14-ds13/compat/
ds2.9a12/fluffos-2.14-ds13/compat/simuls/
ds2.9a12/fluffos-2.14-ds13/include/
ds2.9a12/fluffos-2.14-ds13/testsuite/
ds2.9a12/fluffos-2.14-ds13/testsuite/clone/
ds2.9a12/fluffos-2.14-ds13/testsuite/command/
ds2.9a12/fluffos-2.14-ds13/testsuite/data/
ds2.9a12/fluffos-2.14-ds13/testsuite/etc/
ds2.9a12/fluffos-2.14-ds13/testsuite/include/
ds2.9a12/fluffos-2.14-ds13/testsuite/inherit/
ds2.9a12/fluffos-2.14-ds13/testsuite/inherit/master/
ds2.9a12/fluffos-2.14-ds13/testsuite/log/
ds2.9a12/fluffos-2.14-ds13/testsuite/single/
ds2.9a12/fluffos-2.14-ds13/testsuite/single/tests/compiler/
ds2.9a12/fluffos-2.14-ds13/testsuite/single/tests/efuns/
ds2.9a12/fluffos-2.14-ds13/testsuite/single/tests/operators/
ds2.9a12/fluffos-2.14-ds13/testsuite/u/
ds2.9a12/lib/cmds/admins/
ds2.9a12/lib/cmds/common/
ds2.9a12/lib/cmds/creators/include/
ds2.9a12/lib/daemon/services/
ds2.9a12/lib/daemon/tmp/
ds2.9a12/lib/doc/
ds2.9a12/lib/doc/bguide/
ds2.9a12/lib/doc/efun/all/
ds2.9a12/lib/doc/efun/arrays/
ds2.9a12/lib/doc/efun/buffers/
ds2.9a12/lib/doc/efun/compile/
ds2.9a12/lib/doc/efun/floats/
ds2.9a12/lib/doc/efun/functions/
ds2.9a12/lib/doc/efun/general/
ds2.9a12/lib/doc/efun/mixed/
ds2.9a12/lib/doc/efun/numbers/
ds2.9a12/lib/doc/efun/parsing/
ds2.9a12/lib/doc/hbook/
ds2.9a12/lib/doc/help/classes/
ds2.9a12/lib/doc/help/races/
ds2.9a12/lib/doc/lfun/
ds2.9a12/lib/doc/lfun/all/
ds2.9a12/lib/doc/lfun/lib/abilities/
ds2.9a12/lib/doc/lfun/lib/armor/
ds2.9a12/lib/doc/lfun/lib/bank/
ds2.9a12/lib/doc/lfun/lib/bot/
ds2.9a12/lib/doc/lfun/lib/clay/
ds2.9a12/lib/doc/lfun/lib/clean/
ds2.9a12/lib/doc/lfun/lib/clerk/
ds2.9a12/lib/doc/lfun/lib/client/
ds2.9a12/lib/doc/lfun/lib/combat/
ds2.9a12/lib/doc/lfun/lib/connect/
ds2.9a12/lib/doc/lfun/lib/container/
ds2.9a12/lib/doc/lfun/lib/corpse/
ds2.9a12/lib/doc/lfun/lib/creator/
ds2.9a12/lib/doc/lfun/lib/daemon/
ds2.9a12/lib/doc/lfun/lib/damage/
ds2.9a12/lib/doc/lfun/lib/deterioration/
ds2.9a12/lib/doc/lfun/lib/donate/
ds2.9a12/lib/doc/lfun/lib/door/
ds2.9a12/lib/doc/lfun/lib/equip/
ds2.9a12/lib/doc/lfun/lib/file/
ds2.9a12/lib/doc/lfun/lib/fish/
ds2.9a12/lib/doc/lfun/lib/fishing/
ds2.9a12/lib/doc/lfun/lib/flashlight/
ds2.9a12/lib/doc/lfun/lib/follow/
ds2.9a12/lib/doc/lfun/lib/ftp_client/
ds2.9a12/lib/doc/lfun/lib/ftp_data_connection/
ds2.9a12/lib/doc/lfun/lib/fuel/
ds2.9a12/lib/doc/lfun/lib/furnace/
ds2.9a12/lib/doc/lfun/lib/genetics/
ds2.9a12/lib/doc/lfun/lib/holder/
ds2.9a12/lib/doc/lfun/lib/id/
ds2.9a12/lib/doc/lfun/lib/interactive/
ds2.9a12/lib/doc/lfun/lib/lamp/
ds2.9a12/lib/doc/lfun/lib/leader/
ds2.9a12/lib/doc/lfun/lib/light/
ds2.9a12/lib/doc/lfun/lib/limb/
ds2.9a12/lib/doc/lfun/lib/living/
ds2.9a12/lib/doc/lfun/lib/load/
ds2.9a12/lib/doc/lfun/lib/look/
ds2.9a12/lib/doc/lfun/lib/manipulate/
ds2.9a12/lib/doc/lfun/lib/meal/
ds2.9a12/lib/doc/lfun/lib/messages/
ds2.9a12/lib/doc/lfun/lib/player/
ds2.9a12/lib/doc/lfun/lib/poison/
ds2.9a12/lib/doc/lfun/lib/position/
ds2.9a12/lib/doc/lfun/lib/post_office/
ds2.9a12/lib/doc/lfun/lib/potion/
ds2.9a12/lib/doc/lfun/lib/room/
ds2.9a12/lib/doc/lfun/lib/server/
ds2.9a12/lib/doc/lfun/lib/spell/
ds2.9a12/lib/doc/lfun/lib/torch/
ds2.9a12/lib/doc/lfun/lib/vendor/
ds2.9a12/lib/doc/lfun/lib/virt_sky/
ds2.9a12/lib/doc/lfun/lib/weapon/
ds2.9a12/lib/doc/lfun/lib/worn_storage/
ds2.9a12/lib/doc/lpc/basic/
ds2.9a12/lib/doc/lpc/concepts/
ds2.9a12/lib/doc/lpc/constructs/
ds2.9a12/lib/doc/lpc/etc/
ds2.9a12/lib/doc/lpc/intermediate/
ds2.9a12/lib/doc/lpc/types/
ds2.9a12/lib/doc/misc/
ds2.9a12/lib/doc/old/
ds2.9a12/lib/domains/
ds2.9a12/lib/domains/Praxis/adm/
ds2.9a12/lib/domains/Praxis/attic/
ds2.9a12/lib/domains/Praxis/cemetery/mon/
ds2.9a12/lib/domains/Praxis/data/
ds2.9a12/lib/domains/Praxis/death/
ds2.9a12/lib/domains/Praxis/mountains/
ds2.9a12/lib/domains/Praxis/obj/armour/
ds2.9a12/lib/domains/Praxis/obj/magic/
ds2.9a12/lib/domains/Praxis/obj/weapon/
ds2.9a12/lib/domains/Praxis/orc_valley/
ds2.9a12/lib/domains/Ylsrim/
ds2.9a12/lib/domains/Ylsrim/adm/
ds2.9a12/lib/domains/Ylsrim/armor/
ds2.9a12/lib/domains/Ylsrim/broken/
ds2.9a12/lib/domains/Ylsrim/fish/
ds2.9a12/lib/domains/Ylsrim/meal/
ds2.9a12/lib/domains/Ylsrim/npc/
ds2.9a12/lib/domains/Ylsrim/obj/
ds2.9a12/lib/domains/Ylsrim/virtual/
ds2.9a12/lib/domains/Ylsrim/weapon/
ds2.9a12/lib/domains/campus/adm/
ds2.9a12/lib/domains/campus/etc/
ds2.9a12/lib/domains/campus/meals/
ds2.9a12/lib/domains/campus/save/
ds2.9a12/lib/domains/campus/txt/ai/charles/
ds2.9a12/lib/domains/campus/txt/ai/charles/bak2/
ds2.9a12/lib/domains/campus/txt/ai/charles/bak2/bak1/
ds2.9a12/lib/domains/campus/txt/ai/charly/
ds2.9a12/lib/domains/campus/txt/ai/charly/bak/
ds2.9a12/lib/domains/campus/txt/jenny/
ds2.9a12/lib/domains/cave/doors/
ds2.9a12/lib/domains/cave/etc/
ds2.9a12/lib/domains/cave/meals/
ds2.9a12/lib/domains/cave/weap/
ds2.9a12/lib/domains/default/creator/
ds2.9a12/lib/domains/default/doors/
ds2.9a12/lib/domains/default/etc/
ds2.9a12/lib/domains/default/vehicles/
ds2.9a12/lib/domains/default/virtual/
ds2.9a12/lib/domains/default/weap/
ds2.9a12/lib/domains/town/txt/shame/
ds2.9a12/lib/domains/town/virtual/
ds2.9a12/lib/domains/town/virtual/bottom/
ds2.9a12/lib/domains/town/virtual/space/
ds2.9a12/lib/estates/
ds2.9a12/lib/ftp/
ds2.9a12/lib/lib/comp/
ds2.9a12/lib/lib/daemons/
ds2.9a12/lib/lib/daemons/include/
ds2.9a12/lib/lib/lvs/
ds2.9a12/lib/lib/user/
ds2.9a12/lib/lib/virtual/
ds2.9a12/lib/log/
ds2.9a12/lib/log/adm/
ds2.9a12/lib/log/archive/
ds2.9a12/lib/log/chan/
ds2.9a12/lib/log/errors/
ds2.9a12/lib/log/law/adm/
ds2.9a12/lib/log/law/email/
ds2.9a12/lib/log/law/names/
ds2.9a12/lib/log/law/sites-misc/
ds2.9a12/lib/log/law/sites-register/
ds2.9a12/lib/log/law/sites-tempban/
ds2.9a12/lib/log/law/sites-watch/
ds2.9a12/lib/log/open/
ds2.9a12/lib/log/reports/
ds2.9a12/lib/log/router/
ds2.9a12/lib/log/secure/
ds2.9a12/lib/log/watch/
ds2.9a12/lib/obj/book_source/
ds2.9a12/lib/obj/include/
ds2.9a12/lib/powers/prayers/
ds2.9a12/lib/powers/spells/
ds2.9a12/lib/realms/template/adm/
ds2.9a12/lib/realms/template/area/armor/
ds2.9a12/lib/realms/template/area/npc/
ds2.9a12/lib/realms/template/area/obj/
ds2.9a12/lib/realms/template/area/room/
ds2.9a12/lib/realms/template/area/weap/
ds2.9a12/lib/realms/template/bak/
ds2.9a12/lib/realms/template/cmds/
ds2.9a12/lib/save/kills/o/
ds2.9a12/lib/secure/cfg/classes/
ds2.9a12/lib/secure/cmds/builders/
ds2.9a12/lib/secure/cmds/creators/include/
ds2.9a12/lib/secure/cmds/players/
ds2.9a12/lib/secure/cmds/players/include/
ds2.9a12/lib/secure/daemon/imc2server/
ds2.9a12/lib/secure/daemon/include/
ds2.9a12/lib/secure/lib/
ds2.9a12/lib/secure/lib/include/
ds2.9a12/lib/secure/lib/net/include/
ds2.9a12/lib/secure/lib/std/
ds2.9a12/lib/secure/log/adm/
ds2.9a12/lib/secure/log/bak/
ds2.9a12/lib/secure/log/intermud/
ds2.9a12/lib/secure/log/network/
ds2.9a12/lib/secure/modules/
ds2.9a12/lib/secure/npc/
ds2.9a12/lib/secure/obj/include/
ds2.9a12/lib/secure/room/
ds2.9a12/lib/secure/save/
ds2.9a12/lib/secure/save/backup/
ds2.9a12/lib/secure/save/boards/
ds2.9a12/lib/secure/tmp/
ds2.9a12/lib/secure/upgrades/files/
ds2.9a12/lib/secure/verbs/creators/
ds2.9a12/lib/std/board/
ds2.9a12/lib/std/lib/
ds2.9a12/lib/tmp/
ds2.9a12/lib/verbs/admins/include/
ds2.9a12/lib/verbs/builders/
ds2.9a12/lib/verbs/common/
ds2.9a12/lib/verbs/common/include/
ds2.9a12/lib/verbs/creators/
ds2.9a12/lib/verbs/creators/include/
ds2.9a12/lib/verbs/rooms/
ds2.9a12/lib/verbs/rooms/include/
ds2.9a12/lib/www/client/
ds2.9a12/lib/www/errors/
ds2.9a12/lib/www/images/
ds2.9a12/lib/www/lpmuds/downloads_files/
ds2.9a12/lib/www/lpmuds/intermud_files/
ds2.9a12/lib/www/lpmuds/links_files/
ds2.9a12/win32/
/*    /daemon/intermud.c
 *    from the Dead Souls LPC Library
 *    daemon handling the InterMUD-3 Protocol
 *    created by Descartes of Borg 950506
 *    Version: @(#) intermud.c 1.7@(#)
 *    Last modified: 96/12/14
 */

#ifndef __PACKAGE_SOCKETS__
#error You should not try and load /daemon/intermud.c with no sockets package.
#else

#include <lib.h>
#include <dirs.h>
#include <logs.h>
#include <privs.h>
#include <save.h>
#include <config.h>
#include <daemons.h>
#include <network.h>
#include <rooms.h>
#include "include/intermud.h"

inherit LIB_CLIENT;

private int Password;
private mapping MudList, ChannelList;
private mapping Banned;
private mixed *Nameservers;
private static int Tries;
private static int SocketStat = -1;
private static int Online = 0;

mapping ExtraInfo();
void ConvertLists();

static void create(){
    client::create();
    tn("INTERMUD_D: prev: "+identify(previous_object(-1)),"red");
    Password = 0;
    Tries = 0;
    Banned = ([]);
    MudList = ([]);
    ChannelList = ([]);
    MudList["ID"] = -1;
    MudList["List"] = ([]);
    ChannelList["ID"] = -1;
    ChannelList["List"] = ([]);
    if( file_size( SAVE_INTERMUD __SAVE_EXTENSION__ ) > 0 )
        unguarded( (: restore_object, SAVE_INTERMUD, 1 :) );
    ConvertLists();
    Nameservers = ({ ({ "*i4", "204.209.44.3 8080" }) });
    SetNoClean(1);
    tn("INTERMUD_D reloaded.");
    tn("Loading object stack: "+get_stack(),"red");
    tn("Loading object trail: "+identify(previous_object(-1)),"red");
    SetDestructOnClose(1);
    SetSocketType(MUD);
    if(DISABLE_INTERMUD == 1){
        call_out( (: eventDestruct :), 2);
    }
    else call_out( (: Setup :), 2);
}

void FirstPing(){
    PING_D->eventPing();
}

static void Setup(){
    string ip;
    int port;

    if( !Nameservers || !sizeof(Nameservers) ) return;
    sscanf(Nameservers[0][1], "%s %d", ip, port);
    SocketStat = eventCreateSocket(ip, port);
    if( SocketStat < 0 ) return;
    tn("INTERMUD_D: SocketStat: "+SocketStat);
    eventWrite( ({ "startup-req-3", 5, mud_name(), 0, Nameservers[0][0], 0,
        Password, MudList["ID"], ChannelList["ID"], query_host_port(),
        PORT_OOB, PORT_UDP, mudlib() + " " + mudlib_version(), 
        mudlib() + " " + mudlib_version(), version(), "LPMud",
        MUD_STATUS, ADMIN_EMAIL,
        (mapping)SERVICES_D->GetServices(), ExtraInfo() }) );
    tn("INTERMUD_D setup: "+identify( ({
          "startup-req-3", 5, mud_name(), 0, Nameservers[0][0], 0,
          Password, MudList["ID"], ChannelList["ID"], query_host_port(),
          PORT_OOB, PORT_UDP, mudlib() + " " + mudlib_version(),
          mudlib() + " " + mudlib_version(), version(), "LPMud",
          MUD_STATUS, ADMIN_EMAIL,
          (mapping)SERVICES_D->GetServices(), ([]) }) ), "red");;
    call_out( (: FirstPing :), 5);
    call_out( (: load_object :), 5, IMC2_D);
}

int GetConnectedStatus(){
    return Online;
}

void eventClearVars(){
    if( !((int)master()->valid_apply(({ PRIV_ASSIST, INTERMUD_D }))) )
        error("Illegal attempt to reset intermud: "+get_stack()+" "+identify(previous_object(-1)));
    Tries = 0;
    MudList = ([]);
    ChannelList = ([]);
    MudList["ID"] = -1;
    MudList["List"] = ([]);
    ChannelList["ID"] = -1;
    ChannelList["List"] = ([]);
    save_object(SAVE_INTERMUD);
}

static void eventRead(mixed *packet){
    mixed val;
    string cle;
    Online = 1;

    if( !packet || sizeof(packet) < 6 ) return; /* should send error */
    if( Banned[packet[2]] ){

        eventWrite(({ "error", 5, mud_name(), 0, packet[2],
            packet[3], "unk-user", 
            "Your mud is not allowed to send to "+mud_name()+".",
            packet }));

        return;
    }
    switch(packet[0]){
    case "startup-reply":
        log_file(LOG_I3,identify(packet));
        tn("INTERMUD_D: "+identify(packet),"red");
        if( sizeof(packet) != 8 ){
            //tn("We don't like the mudlist packet size.","red");
            return;  
        }
        if( !sizeof(packet[6]) ){
            //tn("We don't like an absence of packet element 6.","red");
            return;
        }
        /* Start of Tricky's patch */
        if( packet[2] != Nameservers[0][0] ){
            tn("Illegal startup-reply from mud " + packet[2], "red");
            return;
        }
        /* End of Tricky's patch */ 
        if( packet[6][0][0] == Nameservers[0][0] ){
            Nameservers = packet[6];
            Password = packet[7];
            save_object(SAVE_INTERMUD);
        }
        else {
            Nameservers = packet[6];
            Setup();
        }
        return;
    case "mudlist":
        tn("INTERMUD_D mudlist received.","red");
        //log_file(LOG_I3,identify(packet),1);
        if( sizeof(packet) != 8 ){
            //tn("We don't like the mudlist packet size.","red");
            return;  
        }
        if( packet[6] == MudList["ID"] )  {
            //tn("We don't like packet element 6. It is: "+identify(packet[6]),"red");
            //tn("We will continue anyway.","red");
        }
        if( packet[2] != Nameservers[0][0] ){
            //tn("We don't like packet element 2. It is: "+identify(packet[2]),"red");
            return;
        }

        MudList["ID"] = packet[6];
        foreach(cle, val in packet[7]){
            string tmp = "";
            if(cle){
                string lib = "unknown";
                if(val && sizeof(val) > 5 && arrayp(val)) lib = val[5];
                tmp += "%^BOLD%^CYAN%^Processing mud: "+identify(cle)+
                ", lib: "+lib;
                if(val){
                    if(!val[0]) tmp += " %^RED%^BOLD%^offline%^RESET%^";
                    else tmp += " %^GREEN%^BOLD%^ONLINE%^RESET%^";
                }
                else tmp += " removed from mudlist";
                tn(tmp);
                //tn(tmp,"cyan",ROOM_ARCH);
                if(val && sizeof(val) > 5 && arrayp(val))
                    tmp = (val[0] ? "%^GREEN%^online" : "%^RED%^offline")+ 
                    "%^RESET%^, lib: "+lib+", driver: "+val[7];
                else tmp = "removed from mudlist.";
                CHAT_D->eventSendChannel(cle+"@i3","muds",tmp,0);
            }
            if( !val && MudList["List"][cle] != 0 ) 
                map_delete(MudList["List"], cle);
            else if( val ) MudList["List"][cle] = val;
        }
        save_object(SAVE_INTERMUD);
        return;
    case "ping-req":
        SERVICES_D->eventReceiveAuthRequest(packet);
        break;
    case "ping-reply":
        SERVICES_D->eventReceiveAuthReply(packet);
        break;
    case "auth-mud-req":
        SERVICES_D->eventReceiveAuthRequest(packet);
        break;
    case "auth-mud-reply":
        SERVICES_D->eventReceiveAuthReply(packet);
        break;
    case "channel-t":
        SERVICES_D->eventReceiveChannelTargettedEmote(packet);
        break;
    case "channel-e":
        SERVICES_D->eventReceiveChannelEmote(packet);
        break;
    case "channel-m":
        SERVICES_D->eventReceiveChannelMessage(packet);
        break;
    case "chan-who-reply":
        SERVICES_D->eventReceiveChannelWhoReply(packet);
        break;
    case "chan-who-req":
        SERVICES_D->eventReceiveChannelWhoRequest(packet);
        break;
    case "chan-user-req":
        SERVICES_D->eventReceiveChannelUserRequest(packet);
        break;
    case "chanlist-reply":
        tn("chanlist reply: "+identify(packet), "blue");
        if( packet[2] != Nameservers[0][0] ) return;
        ChannelList["ID"] = packet[6];
        foreach(cle, val in packet[7]){ 
            if( !val && ChannelList["List"] != 0 ){ 
                map_delete(ChannelList["List"], cle);
                CHAT_D->RemoveRemoteChannel(cle);
            }
            else if( val ){
                ChannelList["List"][cle] = val;
                CHAT_D->AddRemoteChannel(cle);
            }
        } 
        save_object(SAVE_INTERMUD);
        SERVICES_D->eventRegisterChannels(packet[7]);
        return;
    case "emoteto":
        SERVICES_D->eventReceiveEmote(packet);
        break;
    case "finger-req":
        SERVICES_D->eventReceiveFingerRequest(packet);
        break;
    case "finger-reply":
        SERVICES_D->eventReceiveFingerReply(packet);
        break;
    case "locate-req":
        SERVICES_D->eventReceiveLocateRequest(packet);
        break;
    case "locate-reply":
        SERVICES_D->eventReceiveLocateReply(packet);
        break;
    case "tell":
        SERVICES_D->eventReceiveTell(packet);
        break;
    case "chan-user-reply":
        tn("INTERMUD_D: chan-user-reply received.","red");
    case "ucache-update":
        SERVICES_D->eventReceiveUcacheUpdate(packet);
        break;
    case "who-req":
        SERVICES_D->eventReceiveWhoRequest(packet);
        break;
    case "who-reply":
        SERVICES_D->eventReceiveWhoReply(packet);
        break;
    case "news":
        SERVICES_D->eventReceiveNews(packet);
        break;
    case "mail":
        SERVICES_D->eventReceiveMail(packet);
        break;
    case "mail-ok":
        SERVICES_D->eventReceiveMailOk(packet);
        break;
    case "file":
        tn("INTERMUD_D: file packet received.","red");
        break;
    case "error":
        SERVICES_D->eventReceiveError(packet);
        break;
    default:
        break;
    }
}

static void eventSocketClose(){
    Online = 0;
}

static void eventConnectionFailure(){
    Online = 0;
    tn("INTERMUD_D: CONNECTION FAILED","red");
    error("Failed to find a useful name server.\n");
}

int SetDestructOnClose(int x){ return 0; }

static void eventClose(mixed arg){
    SocketStat = -1;
    Online = 0;
    tn("INTERMUD_D: socket closing!");
    ::eventClose(arg);
}

int SetSocketType(int x){ return client::SetSocketType(MUD); }

string GetMudName(string mud){
    string *lc, *uc;
    mapping mudses = GetMudList();
    int x;

    if( MudList["List"][mud] ) return mud;
    lc = map(uc = keys(MudList["List"]), function(string str){
          if( !str ) return "";
          else return lower_case(str);
        });
      x = member_array(lower_case(mud), lc);
      if( x < 0 ){
          foreach(string name in GetMuds()){
              if(mudses[name][1] +" "+mudses[name][2] == mud) return name;
          }
          return 0;
      }
      else return uc[x];
  }

    mapping GetMudList(){ 
        if(sizeof(MudList) && MudList["List"])
            return copy(MudList["List"]); 
        else return ([]);
    }

    string *GetMuds(){
        if(sizeof(MudList) && MudList["List"])
            return keys(MudList["List"]);
        else return ({});
    }

    string *GetLCMuds(){
        string *orig_arr, *new_arr;
        orig_arr = GetMuds();
        new_arr = ({});
        foreach(string namen in orig_arr){
            new_arr += ({ lower_case(namen) });
        }
        return new_arr;
    }

    mapping GetChannelList(){ return copy(ChannelList["List"]); }

    string *GetChannels(){ return keys(ChannelList["List"]); }

    string *GetMatch(string mud){
        string *uc, *lc;

        mud = lower_case(mud);
        lc = map(uc = keys(MudList["List"]), (: lower_case :));
        return map(filter(regexp(lc, "^"+mud, 1), (: intp :)), (: $(uc)[$1] :));
    }

    string GetNameserver(){ return Nameservers[0][0]; }

    mixed *GetNameservers(){ return copy(Nameservers); }

    int AddBanned(string mud, string reason){
        if( !master()->valid_apply(({})) ){
            return 0;
        }
        if( !(mud = GetMudName(mud)) ){
            return 0;
        }
        Banned[mud] = reason;
        save_object(SAVE_INTERMUD);
        return 1;
    }

    mapping GetBanned(){ return copy(Banned); }

    int RawSend(string *packet){
        if(!this_player() || !archp(this_player())) return 0;
        eventWrite(packet);
        return 1;
    }

    string nextboot(){
        string str;
        int x, offset;

        if(DISABLE_REBOOTS){
            return "never";
        }

        offset = (int)TIME_D->GetOffset(local_time()[9]);
        offset += EXTRA_TIME_OFFSET;

        x = (int)EVENTS_D->GetRebootInterval() * 3600;
        x = (time() - uptime()) + x;
        if(!LOCAL_TIME) 
            x += offset * 3600;
        str = query_tz()+ " " + ctime(x);
        return str;
    }

    //This new packet element data added to be able
    //to handle liveupgrade stuff more sensibly.
    mapping ExtraInfo(){
        return ([
          "native version" : native_version(),
          "os build" : query_os_type(),
          "architecture" : architecture(),
          "upsince" : ctime(time() - uptime()),
          "next boot" : nextboot(),
          "ip" : HOST_IP,
          "oob port" : PORT_OOB,
        ]);
    }

    void ConvertLists(){
        if(classp(MudList)){
            mapping TmpMap = ([]);
            MudList = TmpMap;
            MudList["ID"] = -1;
            MudList["List"] = ([]);
            save_object(SAVE_INTERMUD);
        }
        if(classp(ChannelList)){
            mapping TmpMap = ([]);
            ChannelList = TmpMap;
            ChannelList["ID"] = -1;
            ChannelList["List"] = ([]);
            save_object(SAVE_INTERMUD);
        }
    }

    int GetEnabled(){
        return !(DISABLE_INTERMUD);
    }

#endif /* __PACKAGE_SOCKETS__ */