tmi2_fluffos_v2/
tmi2_fluffos_v2/bin/
tmi2_fluffos_v2/etc/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/ChangeLog.old/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/Win32/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/compat/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/compat/simuls/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/include/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/clone/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/command/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/data/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/etc/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/include/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/inherit/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/inherit/master/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/log/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/single/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/single/tests/compiler/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/single/tests/efuns/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/single/tests/operators/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/testsuite/u/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/tmp/
tmi2_fluffos_v2/fluffos-2.7-ds2.018/windows/
tmi2_fluffos_v2/lib/
tmi2_fluffos_v2/lib/adm/
tmi2_fluffos_v2/lib/adm/daemons/languages/
tmi2_fluffos_v2/lib/adm/daemons/network/I3/
tmi2_fluffos_v2/lib/adm/daemons/virtual/
tmi2_fluffos_v2/lib/adm/daemons/virtual/template/
tmi2_fluffos_v2/lib/adm/news/
tmi2_fluffos_v2/lib/adm/obj/
tmi2_fluffos_v2/lib/adm/obj/master/
tmi2_fluffos_v2/lib/adm/priv/
tmi2_fluffos_v2/lib/adm/shell/
tmi2_fluffos_v2/lib/adm/tmp/
tmi2_fluffos_v2/lib/cmds/
tmi2_fluffos_v2/lib/d/
tmi2_fluffos_v2/lib/d/Conf/
tmi2_fluffos_v2/lib/d/Conf/adm/
tmi2_fluffos_v2/lib/d/Conf/boards/
tmi2_fluffos_v2/lib/d/Conf/cmds/
tmi2_fluffos_v2/lib/d/Conf/data/
tmi2_fluffos_v2/lib/d/Conf/logs/
tmi2_fluffos_v2/lib/d/Conf/obj/
tmi2_fluffos_v2/lib/d/Conf/text/help/
tmi2_fluffos_v2/lib/d/Fooland/adm/
tmi2_fluffos_v2/lib/d/Fooland/data/
tmi2_fluffos_v2/lib/d/Fooland/data/attic/
tmi2_fluffos_v2/lib/d/Fooland/items/
tmi2_fluffos_v2/lib/d/TMI/
tmi2_fluffos_v2/lib/d/TMI/adm/
tmi2_fluffos_v2/lib/d/TMI/boards/
tmi2_fluffos_v2/lib/d/TMI/data/
tmi2_fluffos_v2/lib/d/TMI/rooms/
tmi2_fluffos_v2/lib/d/grid/
tmi2_fluffos_v2/lib/d/grid/adm/
tmi2_fluffos_v2/lib/d/grid/data/
tmi2_fluffos_v2/lib/d/std/
tmi2_fluffos_v2/lib/d/std/adm/
tmi2_fluffos_v2/lib/data/adm/
tmi2_fluffos_v2/lib/data/adm/daemons/
tmi2_fluffos_v2/lib/data/adm/daemons/doc_d/
tmi2_fluffos_v2/lib/data/adm/daemons/emoted/
tmi2_fluffos_v2/lib/data/adm/daemons/network/http/
tmi2_fluffos_v2/lib/data/adm/daemons/network/services/mail_q/
tmi2_fluffos_v2/lib/data/adm/daemons/network/smtp/
tmi2_fluffos_v2/lib/data/adm/daemons/news/archives/
tmi2_fluffos_v2/lib/data/attic/connection/
tmi2_fluffos_v2/lib/data/attic/user/
tmi2_fluffos_v2/lib/data/std/connection/b/
tmi2_fluffos_v2/lib/data/std/connection/l/
tmi2_fluffos_v2/lib/data/std/user/a/
tmi2_fluffos_v2/lib/data/std/user/b/
tmi2_fluffos_v2/lib/data/std/user/d/
tmi2_fluffos_v2/lib/data/std/user/f/
tmi2_fluffos_v2/lib/data/std/user/l/
tmi2_fluffos_v2/lib/data/std/user/x/
tmi2_fluffos_v2/lib/data/u/d/dm/working/doc_d/
tmi2_fluffos_v2/lib/data/u/l/leto/doc_d/
tmi2_fluffos_v2/lib/data/u/l/leto/smtp/
tmi2_fluffos_v2/lib/doc/
tmi2_fluffos_v2/lib/doc/driverdoc/applies/
tmi2_fluffos_v2/lib/doc/driverdoc/applies/interactive/
tmi2_fluffos_v2/lib/doc/driverdoc/concepts/
tmi2_fluffos_v2/lib/doc/driverdoc/driver/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/arrays/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/buffers/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/compile/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/ed/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/filesystem/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/floats/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/functions/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/general/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/mappings/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/numbers/
tmi2_fluffos_v2/lib/doc/driverdoc/efuns/parsing/
tmi2_fluffos_v2/lib/doc/driverdoc/lpc/constructs/
tmi2_fluffos_v2/lib/doc/driverdoc/lpc/preprocessor/
tmi2_fluffos_v2/lib/doc/driverdoc/lpc/types/
tmi2_fluffos_v2/lib/doc/driverdoc/platforms/
tmi2_fluffos_v2/lib/doc/mudlib/
tmi2_fluffos_v2/lib/ftp/
tmi2_fluffos_v2/lib/include/driver/
tmi2_fluffos_v2/lib/log/
tmi2_fluffos_v2/lib/log/driver/
tmi2_fluffos_v2/lib/obj/net/
tmi2_fluffos_v2/lib/obj/shells/
tmi2_fluffos_v2/lib/obj/tools/
tmi2_fluffos_v2/lib/std/adt/
tmi2_fluffos_v2/lib/std/board/
tmi2_fluffos_v2/lib/std/body/
tmi2_fluffos_v2/lib/std/fun/
tmi2_fluffos_v2/lib/std/living/
tmi2_fluffos_v2/lib/std/object/
tmi2_fluffos_v2/lib/std/shop/
tmi2_fluffos_v2/lib/std/socket/
tmi2_fluffos_v2/lib/std/user/
tmi2_fluffos_v2/lib/std/virtual/
tmi2_fluffos_v2/lib/student/
tmi2_fluffos_v2/lib/student/kalypso/
tmi2_fluffos_v2/lib/student/kalypso/armor/
tmi2_fluffos_v2/lib/student/kalypso/rooms/
tmi2_fluffos_v2/lib/student/kalypso/weapons/
tmi2_fluffos_v2/lib/u/l/leto/
tmi2_fluffos_v2/lib/u/l/leto/cmds/
tmi2_fluffos_v2/lib/www/errors/
tmi2_fluffos_v2/lib/www/gateways/
tmi2_fluffos_v2/lib/www/images/
tmi2_fluffos_v2/old/
tmi2_fluffos_v2/win32/
 
//	File	:  /cmd/xtra/_snoop.c
//	Created	:  Buddha@TMI  (2/19/92)
//	Help by	:  Mobydick@TMI
//	Updated	:  Watcher@TMI (3/27/93)
//
//	This is the standard wizard snoop command.
 

#include <mudlib.h>
#include <logs.h>

inherit DAEMON ;

static int query_notify(object who);
 
 
int cmd_snoop(string str) {
   object ob, snooping;
   int flag;
 
   if(str == "-n") {  flag = 1;  str = "";  }
 
   if(str && sscanf(str, "-n %s", str) == 1)  flag = 1;
 
   snooping = query_snooping(this_player());
 
   if(!str || str == "") {
     if(snoop(this_player()))  write("Snoop disabled.\n");
     else write("Snoop: Could not disable snoop.\n");
 
    if(snooping && (query_notify(snooping) || flag))
     tell_object(snooping, bold((string)this_player()->query("cap_name") +
		 " stops snooping you.\n"));
   return 1; }
 
   if(!(ob = find_player(str = lower_case(str)))) {
    notify_fail("Snoop: No such player.\n");
   return 0; }
 
   if(ob == this_player()) {
    notify_fail("Snoop: You cannot snoop yourself.\n");
   return 0; }
 
   if(query_snoop(ob)) {
 
   	if(query_snoop(ob) == this_player()) {
	printf("Snoop: You are already snooping %s.\n", capitalize(str));
	return 1; }

    	if(adminp(geteuid(this_player()))) {
	write("\n" + capitalize(str) + " is presently being snooped by " +
	      (string)query_snoop(ob)->query("cap_name") + ".\n" +
	      "Do you wish to override? [y/n] ");
 	input_to("snoop_override", 0, ob, flag);
	return 1; }

    notify_fail("Snoop: Attempt to snoop " + capitalize(str) + " failed.\n");
   return 0; }
 
    if(snoop(this_player(), ob)) {
	write("Now snooping.\n");
	if(snooping && (query_notify(snooping) || flag))
	tell_object(snooping, bold((string)this_player()->query("cap_name") +
		    " stops snooping you.\n"));
	if(query_notify(ob) || flag)
	tell_object(ob, bold((string)this_player()->query("cap_name") +
		    " starts to snoop you.\n"));
    }

    else write("Snoop: Attempt to snoop " + capitalize(str) + " failed.\n");
 
#ifdef SNOOP_LOG
   log_file(SNOOP_LOG, (string)this_player()->query("cap_name") + 
	" snooped " + (string)ob->query("cap_name") + " [" +
	extract(ctime(time()), 4, 15) + "]\n");
#endif
 
return 1; }

static int snoop_override(string str, object who, int flag) {
   object snooping;
 
   snooping = query_snooping(this_player());

   if(str != "yes" && str != "y") {
   write("Snoop: Attempt aborted.\n");
   return 1; }

   if(query_snoop(who))
     tell_object(query_snoop(who), "[Snoop channel closed]\n");

    if(snoop(this_player(), who)) {
        write("Now snooping.\n");
	if(snooping && (query_notify(snooping) || flag))
	tell_object(snooping, bold((string)this_player()->query("cap_name") +
                    " stops snooping you.\n"));
	if(query_notify(who) || flag)
	tell_object(who, bold((string)this_player()->query("cap_name") +
                    " starts to snoop you.\n"));
    }

    else write("Snoop: Attempt to snoop " + (string)who->query("cap_name") +
	       " failed.\n");
 
#ifdef SNOOP_LOG
   log_file(SNOOP_LOG, (string)this_player()->query("cap_name") +
        " snooped " + (string)ob->query("cap_name") + " [" +
        extract(ctime(time()), 4, 15) + "]\n");
#endif
 
return 1; }
 
//   This function decides if the snoopee should get notified when
//   the snooper starts and stops snooping.
 
static int query_notify(object who) {
 
   if(!who || !wizardp(who))  return 0;
 
   if(adminp(geteuid(this_player()))) {
	if(adminp(geteuid(who)))  return 1;
   return 0; }
 
   if((int)who->query("snoopable"))  return 1;

return 0; }
 
 
 
int help() {
	write("Usage: snoop [-n] <player>\n\n" +
"The snoop command will let you overhear everything heard by the player\n"+
"specified in the argument. All messages received by that player get\n"+
"a % prepended and are echoed to the snooper.\n"+
"It is generally considered impolite to snoop players without their\n"+
"knowledge and consent. The principal two reasons to snoop a player are\n"+
"to let them demonstrate a bug, or verify that another player is harassing\n"+
"them. Other uses of the snoop command are frowned upon. Check with your\n"+
"administrators to see what their policy on snooping is.\n"+
"You can only snoop people who set themselves to be snoopable, unless you\n"+
"are an administrator. If the -n flag is used, the snoopee will notified\n" +
"that you are starting/stopping snooping them. This option is present for\n" +
"those, as a courtesy, wish to notify the snoopee.\n" +
"\nSee also: snoopable.\n") ;
	return 1 ;
}