-/*
- * set_wtmpsupp() - alter the session listing
- */
-void set_wtmpsupp(char *newtext)
-{
- strncpy(CC->cs_room,newtext,sizeof CC->cs_room);
- CC->cs_room[sizeof CC->cs_room - 1] = 0;
- time(&CC->cs_lastupdt);
-
- /* Run any routines registered by loadable modules */
- PerformSessionHooks(EVT_NEWROOM);
- }
-
-
-/*
- * call set_wtmpsupp() with the name of the current room, modified a bit...
- */
-void set_wtmpsupp_to_current_room() {
- if (CC->quickroom.QRflags & QR_PRIVATE) {
- set_wtmpsupp("<private room>");
- }
- else if (CC->quickroom.QRflags & QR_MAILBOX) {
- set_wtmpsupp(&CC->quickroom.QRname[11]);
- }
- else {
- set_wtmpsupp(CC->quickroom.QRname);
- }
- }
-
-
/*
* cmd_info() - tell the client about this server
}
}
- lprintf(9, "Setting wtmpsupp\n");
- set_wtmpsupp_to_current_room();
-
syslog(LOG_NOTICE,"client %d/%d/%01d.%02d (%s)\n",
dev_code,
cli_code,
CC->cs_flags = CC->cs_flags|CS_STEALTH;
}
- set_wtmpsupp_to_current_room();
cprintf("%d Ok\n",OK);
}
}
+/* Don't show the names of private rooms unless the viewing
+ * user also knows the rooms.
+ */
+void GenerateRoomDisplay(char *real_room,
+ struct CitContext *viewed,
+ struct CitContext *viewer) {
+
+ strcpy(real_room, viewed->quickroom.QRname);
+ if (viewed->quickroom.QRflags & QR_PRIVATE) {
+ if ( (CtdlRoomAccess(&viewed->quickroom, &viewer->usersupp)
+ & UA_KNOWN) == 0) {
+ strcpy(real_room, "<private room>");
+ }
+ }
+
+ if (viewed->cs_flags & CS_CHAT) {
+ while (strlen(real_room) < 14)
+ strcat(real_room, " ");
+
+ strcpy(&real_room[15], "<chat>");
+ }
+
+}
+
+
/*
* who's online
*/
struct CitContext *cptr;
int spoofed = 0;
int aide;
- char un[40], room[40], host[40], flags[5];
+ char un[40];
+ char real_room[ROOMNAMELEN], room[ROOMNAMELEN];
+ char host[40], flags[5];
aide = CC->usersupp.axlevel >= 6;
cprintf("%d%c \n", LISTING_FOLLOWS, check_express() );
else
strcpy(host, cptr->cs_host);
- if (cptr->fake_roomname[0])
- {
- strcpy(room, cptr->fake_roomname);
- spoofed = 1;
+ GenerateRoomDisplay(real_room, cptr, CC);
+
+ if (cptr->fake_roomname[0]) {
+ strcpy(room, cptr->fake_roomname);
+ spoofed = 1;
+ }
+ else {
+ strcpy(room, real_room);
}
- else
- strcpy(room, cptr->cs_room);
-
if ((aide) && (spoofed))
strcat(flags, "+");
if ((spoofed) && (aide))
{
cprintf("%d|%s|%s|%s|%s|%ld|%s|%s\n",
- cptr->cs_pid, cptr->curr_user, cptr->cs_room,
+ cptr->cs_pid, cptr->curr_user,
+ real_room,
cptr->cs_host, cptr->cs_clientname,
(long)(cptr->lastidle),
cptr->lastcmdname, flags);
strcpy(CC->curr_user,"(not logged in)");
strcpy(CC->net_node,"");
snprintf(CC->temp, sizeof CC->temp, tmpnam(NULL));
- strcpy(CC->cs_room, "(no room)");
strncpy(CC->cs_host, config.c_fqdn, sizeof CC->cs_host);
CC->cs_host[sizeof CC->cs_host - 1] = 0;
len = sizeof sin;
{
struct CitContext *ccptr;
int count = 0;
+ char roomname[ROOMNAMELEN];
if ((allflag == 0) || (allflag == 1))
cprintf(":|\n:| Users currently in chat:\n");
begin_critical_section(S_SESSION_TABLE);
for (ccptr = ContextList; ccptr != NULL; ccptr = ccptr->next) {
- if (!strcasecmp(ccptr->cs_room, "<chat>")) ++count;
- if ((!strcasecmp(ccptr->cs_room, "<chat>"))
+ if (ccptr->cs_flags & CS_CHAT) ++count;
+ if ((ccptr->cs_flags & CS_CHAT)
&& ((ccptr->cs_flags & CS_STEALTH) == 0)) {
if ((allflag == 0) || (allflag == 1))
cprintf(":| %-25s <%s>\n", (ccptr->fake_username[0]) ? ccptr->fake_username : ccptr->curr_user, ccptr->chat_room);
if (allflag == 1) {
cprintf(":|\n:| Users not in chat:\n");
for (ccptr = ContextList; ccptr != NULL; ccptr = ccptr->next) {
- if ((strcasecmp(ccptr->cs_room, "<chat>"))
+ GenerateRoomDisplay(roomname, ccptr, CC);
+ if (((ccptr->cs_flags & CS_CHAT) == 0)
&& ((ccptr->cs_flags & CS_STEALTH) == 0)) {
- cprintf(":| %-25s <%s>:\n", (ccptr->fake_username[0]) ? ccptr->fake_username : ccptr->curr_user, (ccptr->fake_roomname[0]) ? ccptr->fake_roomname : ccptr->cs_room);
+ cprintf(":| %-25s <%s>:\n",
+ (ccptr->fake_username[0]) ? ccptr->fake_username : ccptr->curr_user,
+ roomname);
}
}
}
char cmdbuf[256];
char *un;
char *strptr1;
- char hold_cs_room[ROOMNAMELEN];
int MyLastMsg, ThisLastMsg;
struct ChatLine *clptr;
struct CitContext *t_context;
}
strcpy(CC->chat_room, "Main room");
- safestrncpy(hold_cs_room, CC->cs_room, sizeof hold_cs_room);
CC->cs_flags = CC->cs_flags | CS_CHAT;
- set_wtmpsupp("<chat>");
cprintf("%d Entering chat mode (type '/help' for available commands)\n",
START_CHAT_MODE);
sleep(1);
cprintf("000\n");
CC->cs_flags = CC->cs_flags - CS_CHAT;
- set_wtmpsupp(hold_cs_room);
return;
}
if ((!strcasecmp(cmdbuf, "/help"))