Newer
Older
/* js_bbs.cpp */
/* Synchronet JavaScript "bbs" Object */
/* $Id$ */
/****************************************************************************
* @format.tab-size 4 (Plain Text/Source Code File Header) *
* @format.use-tabs true (see http://www.synchro.net/ptsc_hdr.html) *
* *
* Copyright Rob Swindell - http://www.synchro.net/copyright.html *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* See the GNU General Public License for more details: gpl.txt or *
* http://www.fsf.org/copyleft/gpl.html *
* *
* Anonymous FTP access to the most recent released source is available at *
* ftp://vert.synchro.net, ftp://cvs.synchro.net and ftp://ftp.synchro.net *
* *
* Anonymous CVS access to the development source and modification history *
* is available at cvs.synchro.net:/cvsroot/sbbs, example: *
* cvs -d :pserver:anonymous@cvs.synchro.net:/cvsroot/sbbs login *
* (just hit return, no password is necessary) *
* cvs -d :pserver:anonymous@cvs.synchro.net:/cvsroot/sbbs checkout src *
* *
* For Synchronet coding style and modification guidelines, see *
* http://www.synchro.net/source.html *
* *
* You are encouraged to submit any modifications (preferably in Unix diff *
* format) via e-mail to mods@synchro.net *
* *
* Note: If this box doesn't appear square, then you need to fix your tabs. *
****************************************************************************/
#include "sbbs.h"
#include "js_request.h"
#ifdef JAVASCRIPT
/*****************************/
/* BBS Object Properites */
/*****************************/
enum {
BBS_PROP_SYS_STATUS
,BBS_PROP_STARTUP_OPT
,BBS_PROP_ANSWER_TIME
,BBS_PROP_LOGON_TIME
,BBS_PROP_START_TIME
,BBS_PROP_NS_TIME
,BBS_PROP_LAST_NS_TIME
,BBS_PROP_ONLINE
,BBS_PROP_TIMELEFT
,BBS_PROP_EVENT_TIME
,BBS_PROP_EVENT_CODE
,BBS_PROP_NODE_SETTINGS
,BBS_PROP_NODE_STATUS
,BBS_PROP_NODE_ERRORS
,BBS_PROP_NODE_USERON
,BBS_PROP_NODE_CONNECTION
,BBS_PROP_NODE_MISC
,BBS_PROP_NODE_AUX
,BBS_PROP_NODE_EXTAUX
,BBS_PROP_NODE_VAL_USER
,BBS_PROP_LOGON_ULB
,BBS_PROP_LOGON_DLB
,BBS_PROP_LOGON_ULS
,BBS_PROP_LOGON_DLS
,BBS_PROP_LOGON_POSTS
,BBS_PROP_LOGON_EMAILS
,BBS_PROP_LOGON_FBACKS
,BBS_PROP_POSTS_READ
,BBS_PROP_MENU_DIR
,BBS_PROP_MENU_FILE
,BBS_PROP_MAIN_CMDS
,BBS_PROP_CURGRP
,BBS_PROP_CURSUB
,BBS_PROP_CURSUB_CODE
,BBS_PROP_CURLIB
,BBS_PROP_CURDIR
,BBS_PROP_CURDIR_CODE
,BBS_PROP_CONNECTION /* READ ONLY */
,BBS_PROP_RLOGIN_NAME
,BBS_PROP_RLOGIN_PASS
,BBS_PROP_RLOGIN_TERM
,BBS_PROP_ALTUL
,BBS_PROP_ERRORLEVEL /* READ ONLY */
/* READ ONLY */
,BBS_PROP_SMB_GROUP
,BBS_PROP_SMB_GROUP_DESC
,BBS_PROP_SMB_GROUP_NUM
,BBS_PROP_SMB_SUB
,BBS_PROP_SMB_SUB_DESC
,BBS_PROP_SMB_SUB_CODE
,BBS_PROP_SMB_SUB_NUM
,BBS_PROP_SMB_ATTR
,BBS_PROP_SMB_LAST_MSG
,BBS_PROP_SMB_TOTAL_MSGS
,BBS_PROP_SMB_MSGS
,BBS_PROP_SMB_CURMSG
/* READ ONLY */
,BBS_PROP_MSG_TO
,BBS_PROP_MSG_TO_EXT
,BBS_PROP_MSG_TO_NET
,BBS_PROP_MSG_TO_AGENT
,BBS_PROP_MSG_FROM
,BBS_PROP_MSG_FROM_EXT
,BBS_PROP_MSG_FROM_NET
,BBS_PROP_MSG_FROM_AGENT
,BBS_PROP_MSG_REPLYTO
,BBS_PROP_MSG_REPLYTO_EXT
,BBS_PROP_MSG_REPLYTO_NET
,BBS_PROP_MSG_REPLYTO_AGENT
,BBS_PROP_MSG_SUBJECT
,BBS_PROP_MSG_DATE
,BBS_PROP_MSG_TIMEZONE
,BBS_PROP_MSG_DATE_IMPORTED
,BBS_PROP_MSG_ATTR
,BBS_PROP_MSG_AUXATTR
,BBS_PROP_MSG_NETATTR
,BBS_PROP_MSG_OFFSET
,BBS_PROP_MSG_NUMBER
,BBS_PROP_MSG_EXPIRATION
,BBS_PROP_MSG_FORWARDED
,BBS_PROP_MSG_THREAD_ID
,BBS_PROP_MSG_THREAD_BACK
,BBS_PROP_MSG_THREAD_NEXT
,BBS_PROP_MSG_THREAD_FIRST
,BBS_PROP_MSG_ID
,BBS_PROP_MSG_REPLY_ID
/* READ ONLY */
,BBS_PROP_BATCH_UPLOAD_TOTAL
,BBS_PROP_BATCH_DNLOAD_TOTAL
/* READ ONLY */
,BBS_PROP_FILE_NAME
,BBS_PROP_FILE_DESC
,BBS_PROP_FILE_DIR
,BBS_PROP_FILE_ATTR
,BBS_PROP_FILE_DATE
,BBS_PROP_FILE_SIZE
,BBS_PROP_FILE_CREDITS
,BBS_PROP_FILE_ULER
,BBS_PROP_FILE_DATE_ULED
,BBS_PROP_FILE_DATE_DLED
,BBS_PROP_FILE_TIMES_DLED
,BBS_PROP_COMMAND_STR
#ifdef BUILD_JSDOCS
static const char* bbs_prop_desc[] = {
"system status bitfield (see <tt>SS_*</tt> in <tt>sbbsdefs.js</tt> for bit definitions)"
,"startup options bitfield (see <tt>BBS_OPT_*</tt> in <tt>sbbsdefs.js</tt> for bit definitions)"
,"answer time, in <i>time_t</i> format"
,"logon time, in <i>time_t</i> format"
,"time from which user's time left is calculated, in <i>time_t</i> format"
,"current file new-scan time, in <i>time_t</i> format"
,"previous file new-scan time, in <i>time_t</i> format"
,"online (see <tt>ON_*</tt> in <tt>sbbsdefs.js</tt> for valid values)"
,"time left (in seconds)"
,"time of next exclusive event (in <i>time_t</i> format), or 0 if none"
,"internal code of next exclusive event"
,"current node settings bitfield (see <tt>NM_*</tt> in <tt>sbbsdefs.js</tt> for bit definitions)"
,"current node status value (see <tt>nodedefs.js</tt> for valid values)"
,"current node error counter"
,"current node action (see <tt>nodedefs.js</tt> for valid values)"
,"current node user number (<i>useron</i> value)"
,"current node connection type (see <tt>nodedefs.js</tt> for valid values)"
,"current node misc value (see <tt>nodedefs.js</tt> for valid values)"
,"current node aux value"
,"current node extended aux (<i>extaux</i>) value"
,"validation feedback user for this node (or 0 for no validation feedback required)"
,"bytes uploaded during this session"
,"bytes downloaded during this session"
,"files uploaded during this session"
,"files downloaded during this session"
,"messages posted during this session"
,"e-mails sent during this session"
,"feedback messages sent during this session"
,"messages read during this session"
,"menu subdirectory (overrides default)"
,"menu file (overrides default)"
,"total main menu commands received from user during this session"
,"total file menu commands received from user during this session"
,"current message group"
,"current message sub-board"
,"current message sub-board internal code"
,"current file library"
,"current file directory"
,"current file directory internal code"
,"login name given during RLogin negotiation"
,"password specified during RLogin negotiation"
,"terminal specified during RLogin negotiation"
,"client name"
,"current alternate upload path number"
,"error level returned from last executed external program"
,"message group name of message being read"
,"message group description of message being read"
,"message group number of message being read"
,"sub-board name of message being read"
,"sub-board description of message being read"
,"sub-board internal code of message being read"
,"sub-board number of message being read"
,"message base attributes"
,"highest message number in message base"
,"total number of messages in message base"
,"number of messages loaded from message base"
,"current message number in message base"
,"message recipient name"
,"message recipient extension"
,"message recipient network address"
,"message recipient agent type"
,"message sender name"
,"message sender extension"
,"message sender network address"
,"message sender agent type"
,"message reply-to name"
,"message reply-to extension"
,"message reply-to network address"
,"message reply-to agent type"
,"message subject"
,"message date/time"
,"message time zone"
,"message date/time imported"
,"message attributes"
,"message network attributes"
,"message header offset"
,"message number (unique, monotonically incrementing)"
,"message expiration"
,"message forwarded"
,"message thread identifier (0 if unknown)"
,"message thread, back message number"
,"message thread, next message number"
,"message thread, message number of first reply to this message"
,"message identifier"
,"message replied-to identifier"
,"message delivery attempt counter"
,"file name"
,"file description"
,"file directory (number)"
,"file attribute flags"
,"file date"
,"file size (in bytes)"
,"file credit value"
,"file uploader (user name)"
,"file upload date"
,"file last-download date"
,"file download count"
,"number of files in batch upload queue"
,"number of files in batch download queue"
,"current command shell/module <i>command string</i> value"
static sbbs_t *js_GetPrivate(JSContext *cx, JSObject *obj)
sbbs_t *ret=(sbbs_t *)JS_GetPrivate(cx, obj);
if(ret==NULL)
JS_ReportError(cx, "Internal Error: No Private Data.");
return ret;
}
static JSBool js_bbs_get(JSContext *cx, JSObject *obj, jsid id, jsval *vp)
jsval idval;
char tmp[128];
const char* p=NULL;
const char* nulstr="";
uint32 val=0;
if((sbbs=js_GetPrivate(cx, obj))==NULL)
JS_IdToValue(cx, id, &idval);
tiny = JSVAL_TO_INT(idval);
case BBS_PROP_SYS_STATUS:
val=sbbs->sys_status;
break;
case BBS_PROP_STARTUP_OPT:
val=sbbs->startup->options;
break;
case BBS_PROP_ANSWER_TIME:
val=(uint32)sbbs->answertime;
break;
case BBS_PROP_LOGON_TIME:
val=(uint32)sbbs->logontime;
case BBS_PROP_START_TIME:
val=(uint32)sbbs->starttime;
val=(uint32)sbbs->ns_time;
break;
case BBS_PROP_LAST_NS_TIME:
val=(uint32)sbbs->last_ns_time;
case BBS_PROP_ONLINE:
val=sbbs->online;
break;
rc=JS_SUSPENDREQUEST(cx);
val=sbbs->gettimeleft(false);
JS_RESUMEREQUEST(cx, rc);
case BBS_PROP_EVENT_TIME:
val=(uint32)sbbs->event_time;
break;
case BBS_PROP_EVENT_CODE:
p=sbbs->event_code;
break;
case BBS_PROP_NODE_NUM:
val=sbbs->cfg.node_num;
case BBS_PROP_NODE_ACTION:
val=sbbs->action;
break;
case BBS_PROP_NODE_USERON:
val=sbbs->thisnode.useron;
break;
case BBS_PROP_NODE_CONNECTION:
val=sbbs->thisnode.connection;
break;
case BBS_PROP_NODE_MISC:
val=sbbs->thisnode.misc;
break;
case BBS_PROP_NODE_AUX:
val=sbbs->thisnode.aux;
break;
case BBS_PROP_NODE_EXTAUX:
val=sbbs->thisnode.extaux;
break;
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
case BBS_PROP_NODE_VAL_USER:
val=sbbs->cfg.node_valuser;
break;
case BBS_PROP_LOGON_ULB:
val=sbbs->logon_ulb;
break;
case BBS_PROP_LOGON_DLB:
val=sbbs->logon_dlb;
break;
case BBS_PROP_LOGON_ULS:
val=sbbs->logon_uls;
break;
case BBS_PROP_LOGON_DLS:
val=sbbs->logon_dls;
break;
case BBS_PROP_LOGON_POSTS:
val=sbbs->logon_posts;
break;
case BBS_PROP_LOGON_EMAILS:
val=sbbs->logon_emails;
break;
case BBS_PROP_LOGON_FBACKS:
val=sbbs->logon_fbacks;
break;
case BBS_PROP_POSTS_READ:
val=sbbs->posts_read;
break;
case BBS_PROP_MENU_DIR:
p=sbbs->menu_dir;
case BBS_PROP_MENU_FILE:
p=sbbs->menu_file;
case BBS_PROP_MAIN_CMDS:
val=sbbs->main_cmds;
case BBS_PROP_CURGRP:
val=sbbs->curgrp;
break;
case BBS_PROP_CURSUB:
if(sbbs->curgrp<sbbs->usrgrps)
val=sbbs->cursub[sbbs->curgrp];
break;
case BBS_PROP_CURSUB_CODE:
if(sbbs->cursubnum<sbbs->cfg.total_subs)
p=sbbs->cfg.sub[sbbs->cursubnum]->code;
else
p=nulstr;
case BBS_PROP_CURLIB:
val=sbbs->curlib;
break;
case BBS_PROP_CURDIR:
if(sbbs->curlib<sbbs->usrlibs)
val=sbbs->curdir[sbbs->curlib];
break;
case BBS_PROP_CURDIR_CODE:
if(sbbs->curdirnum<sbbs->cfg.total_dirs)
p=sbbs->cfg.dir[sbbs->curdirnum]->code;
else
p=nulstr;
case BBS_PROP_CONNECTION:
p=sbbs->connection;
case BBS_PROP_RLOGIN_NAME:
p=sbbs->rlogin_name;
break;
case BBS_PROP_RLOGIN_PASS:
p=sbbs->rlogin_pass;
break;
case BBS_PROP_RLOGIN_TERM:
p=sbbs->rlogin_term;
break;
case BBS_PROP_CLIENT_NAME:
p=sbbs->client_name;
break;
case BBS_PROP_ALTUL:
val=sbbs->altul;
break;
case BBS_PROP_ERRORLEVEL:
val=sbbs->errorlevel;
break;
/* Currently Open Message Base (sbbs.smb) */
case BBS_PROP_SMB_GROUP:
if(sbbs->smb.subnum==INVALID_SUB || sbbs->smb.subnum>=sbbs->cfg.total_subs)
p=nulstr;
else
p=sbbs->cfg.grp[sbbs->cfg.sub[sbbs->smb.subnum]->grp]->sname;
break;
case BBS_PROP_SMB_GROUP_DESC:
if(sbbs->smb.subnum==INVALID_SUB || sbbs->smb.subnum>=sbbs->cfg.total_subs)
p=nulstr;
else
p=sbbs->cfg.grp[sbbs->cfg.sub[sbbs->smb.subnum]->grp]->lname;
break;
case BBS_PROP_SMB_GROUP_NUM:
if(sbbs->smb.subnum!=INVALID_SUB && sbbs->smb.subnum<sbbs->cfg.total_subs) {
uint ugrp;
for(ugrp=0;ugrp<sbbs->usrgrps;ugrp++)
if(sbbs->usrgrp[ugrp]==sbbs->cfg.sub[sbbs->smb.subnum]->grp)
break;
val=ugrp+1;
}
break;
case BBS_PROP_SMB_SUB:
if(sbbs->smb.subnum==INVALID_SUB || sbbs->smb.subnum>=sbbs->cfg.total_subs)
p=nulstr;
else
p=sbbs->cfg.sub[sbbs->smb.subnum]->sname;
break;
case BBS_PROP_SMB_SUB_DESC:
if(sbbs->smb.subnum==INVALID_SUB || sbbs->smb.subnum>=sbbs->cfg.total_subs)
p=nulstr;
else
p=sbbs->cfg.sub[sbbs->smb.subnum]->lname;
break;
case BBS_PROP_SMB_SUB_CODE:
if(sbbs->smb.subnum==INVALID_SUB || sbbs->smb.subnum>=sbbs->cfg.total_subs)
p=nulstr;
else
p=sbbs->cfg.sub[sbbs->smb.subnum]->code;
break;
case BBS_PROP_SMB_SUB_NUM:
if(sbbs->usrsubs && sbbs->smb.subnum!=INVALID_SUB && sbbs->smb.subnum<sbbs->cfg.total_subs) {
uint ugrp;
for(ugrp=0;ugrp<sbbs->usrgrps;ugrp++)
if(sbbs->usrgrp[ugrp]==sbbs->cfg.sub[sbbs->smb.subnum]->grp)
break;
uint usub;
for(usub=0;usub<sbbs->usrsubs[ugrp];usub++)
if(sbbs->usrsub[ugrp][usub]==sbbs->smb.subnum)
break;
val=usub+1;
}
break;
case BBS_PROP_SMB_ATTR:
val=sbbs->smb.status.attr;
break;
case BBS_PROP_SMB_LAST_MSG:
val=sbbs->smb.status.last_msg;
break;
case BBS_PROP_SMB_TOTAL_MSGS:
val=sbbs->smb.status.total_msgs;
break;
case BBS_PROP_SMB_MSGS:
val=sbbs->smb.msgs;
break;
case BBS_PROP_SMB_CURMSG:
val=sbbs->smb.curmsg;
break;
/* Currently Displayed Message Header (sbbs.current_msg) */
case BBS_PROP_MSG_TO:
if(sbbs->current_msg==NULL || sbbs->current_msg->to==NULL)
p=nulstr;
else
p=sbbs->current_msg->to;
break;
case BBS_PROP_MSG_TO_EXT:
if(sbbs->current_msg==NULL || sbbs->current_msg->to_ext==NULL)
p=nulstr;
else
p=sbbs->current_msg->to_ext;
break;
case BBS_PROP_MSG_TO_NET:
if(sbbs->current_msg==NULL || sbbs->current_msg->to_net.type==NET_NONE)
p=nulstr;
else
p=smb_netaddrstr(&sbbs->current_msg->to_net,tmp);
break;
case BBS_PROP_MSG_TO_AGENT:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->to_agent;
break;
case BBS_PROP_MSG_FROM:
if(sbbs->current_msg==NULL || sbbs->current_msg->from==NULL)
p=nulstr;
else
p=sbbs->current_msg->from;
break;
case BBS_PROP_MSG_FROM_EXT:
if(sbbs->current_msg==NULL || sbbs->current_msg->from_ext==NULL)
p=nulstr;
else
p=sbbs->current_msg->from_ext;
break;
case BBS_PROP_MSG_FROM_NET:
if(sbbs->current_msg==NULL || sbbs->current_msg->from_net.type==NET_NONE)
p=nulstr;
else
p=smb_netaddrstr(&sbbs->current_msg->from_net,tmp);
break;
case BBS_PROP_MSG_FROM_AGENT:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->from_agent;
break;
case BBS_PROP_MSG_REPLYTO:
if(sbbs->current_msg==NULL || sbbs->current_msg->replyto==NULL)
p=nulstr;
else
p=sbbs->current_msg->replyto;
break;
case BBS_PROP_MSG_REPLYTO_EXT:
if(sbbs->current_msg==NULL || sbbs->current_msg->replyto_ext==NULL)
p=nulstr;
else
p=sbbs->current_msg->replyto_ext;
break;
case BBS_PROP_MSG_REPLYTO_NET:
if(sbbs->current_msg==NULL || sbbs->current_msg->replyto_net.type==NET_NONE)
p=nulstr;
else
p=smb_netaddrstr(&sbbs->current_msg->replyto_net,tmp);
break;
case BBS_PROP_MSG_REPLYTO_AGENT:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->replyto_agent;
break;
case BBS_PROP_MSG_SUBJECT:
if(sbbs->current_msg==NULL || sbbs->current_msg->subj==NULL)
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
p=nulstr;
else
p=sbbs->current_msg->subj;
break;
case BBS_PROP_MSG_DATE:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.when_written.time;
break;
case BBS_PROP_MSG_TIMEZONE:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.when_written.zone;
break;
case BBS_PROP_MSG_DATE_IMPORTED:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.when_imported.time;
break;
case BBS_PROP_MSG_ATTR:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.attr;
break;
case BBS_PROP_MSG_AUXATTR:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.auxattr;
break;
case BBS_PROP_MSG_NETATTR:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.netattr;
break;
case BBS_PROP_MSG_OFFSET:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->offset;
break;
case BBS_PROP_MSG_NUMBER:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.number;
break;
case BBS_PROP_MSG_EXPIRATION:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->expiration;
break;
case BBS_PROP_MSG_FORWARDED:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->forwarded;
break;
case BBS_PROP_MSG_THREAD_ID:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.thread_id;
break;
case BBS_PROP_MSG_THREAD_BACK:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.thread_back;
break;
case BBS_PROP_MSG_THREAD_NEXT:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.thread_next;
break;
case BBS_PROP_MSG_THREAD_FIRST:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.thread_first;
break;
case BBS_PROP_MSG_DELIVERY_ATTEMPTS:
if(sbbs->current_msg!=NULL)
val=sbbs->current_msg->hdr.delivery_attempts;
break;
case BBS_PROP_MSG_ID:
if(sbbs->current_msg==NULL || sbbs->current_msg->id==NULL)
p=nulstr;
else
p=sbbs->current_msg->id;
break;
case BBS_PROP_MSG_REPLY_ID:
if(sbbs->current_msg==NULL || sbbs->current_msg->reply_id==NULL)
p=nulstr;
else
p=sbbs->current_msg->reply_id;
break;
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
/* Currently Displayed File (sbbs.current_file) */
case BBS_PROP_FILE_NAME:
if(sbbs->current_file==NULL)
p=nulstr;
else
p=sbbs->current_file->name;
break;
case BBS_PROP_FILE_DESC:
if(sbbs->current_file==NULL)
p=nulstr;
else
p=sbbs->current_file->desc;
break;
case BBS_PROP_FILE_ULER:
if(sbbs->current_file==NULL)
p=nulstr;
else
p=sbbs->current_file->uler;
break;
case BBS_PROP_FILE_DATE:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->date;
break;
case BBS_PROP_FILE_DATE_ULED:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->dateuled;
break;
case BBS_PROP_FILE_DATE_DLED:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->datedled;
break;
case BBS_PROP_FILE_TIMES_DLED:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->timesdled;
break;
case BBS_PROP_FILE_SIZE:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->size;
break;
case BBS_PROP_FILE_CREDITS:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->cdt;
break;
case BBS_PROP_FILE_DIR:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->dir;
break;
case BBS_PROP_FILE_ATTR:
if(sbbs->current_file==NULL)
p=nulstr;
else
val=sbbs->current_file->misc;
break;
case BBS_PROP_BATCH_UPLOAD_TOTAL:
val=sbbs->batup_total;
break;
case BBS_PROP_BATCH_DNLOAD_TOTAL:
val=sbbs->batdn_total;
case BBS_PROP_COMMAND_STR:
p=sbbs->main_csi.str;
break;
if(p!=NULL) {
JSString* js_str=JS_NewStringCopyZ(cx, p);
if(js_str==NULL)
return(JS_FALSE);
*vp = STRING_TO_JSVAL(js_str);
} else
*vp = UINT_TO_JSVAL(val);
static JSBool js_bbs_set(JSContext *cx, JSObject *obj, jsid id, JSBool strict, jsval *vp)
jsval idval;
if((sbbs=js_GetPrivate(cx, obj))==NULL)
JS_IdToValue(cx, id, &idval);
tiny = JSVAL_TO_INT(idval);
if(JSVAL_IS_NUMBER(*vp) || JSVAL_IS_BOOLEAN(*vp)) {
if(!JS_ValueToInt32(cx, *vp, &val))
return(JS_FALSE);
}
else if(JSVAL_IS_STRING(*vp)) {
if((js_str = JS_ValueToString(cx, *vp))==NULL)
return(JS_FALSE);
HANDLE_PENDING(cx, p);
case BBS_PROP_SYS_STATUS:
sbbs->sys_status=val;
break;
case BBS_PROP_STARTUP_OPT:
sbbs->startup->options=val;
break;
case BBS_PROP_ANSWER_TIME:
sbbs->answertime=val;
break;
case BBS_PROP_LOGON_TIME:
sbbs->logontime=val;
break;
case BBS_PROP_START_TIME:
sbbs->starttime=val;
break;
case BBS_PROP_NS_TIME:
sbbs->ns_time=val;
break;
case BBS_PROP_LAST_NS_TIME:
sbbs->last_ns_time=val;
break;
case BBS_PROP_ONLINE:
sbbs->online=val;
break;
sbbs->cfg.node_misc=val;
break;
case BBS_PROP_NODE_ACTION:
sbbs->action=(uchar)val;
break;
case BBS_PROP_NODE_VAL_USER:
sbbs->cfg.node_valuser=(ushort)val;
break;
case BBS_PROP_LOGON_ULB:
sbbs->logon_ulb=val;
break;
case BBS_PROP_LOGON_DLB:
sbbs->logon_dlb=val;
break;
case BBS_PROP_LOGON_ULS:
sbbs->logon_uls=val;
break;
case BBS_PROP_LOGON_DLS:
sbbs->logon_dls=val;
break;
case BBS_PROP_LOGON_POSTS:
sbbs->logon_posts=val;
break;
case BBS_PROP_LOGON_EMAILS:
sbbs->logon_emails=val;
case BBS_PROP_LOGON_FBACKS:
sbbs->logon_fbacks=val;
case BBS_PROP_POSTS_READ:
sbbs->posts_read=val;
SAFECOPY(sbbs->menu_dir,p);
SAFECOPY(sbbs->menu_file,p);
case BBS_PROP_MAIN_CMDS:
sbbs->main_cmds=val;
sbbs->xfer_cmds=val;
break;
case BBS_PROP_CURGRP:
if(p!=NULL) { /* set by name */
uint i;
for(i=0;i<sbbs->usrgrps;i++)
if(!stricmp(sbbs->cfg.grp[sbbs->usrgrp[i]]->sname,p))
break;
if(i<sbbs->usrgrps)
sbbs->curgrp=i;
break;
}
if((uint)val<sbbs->cfg.total_grps && (uint)val<sbbs->usrgrps)
sbbs->curgrp=val;
break;
case BBS_PROP_CURSUB:
case BBS_PROP_CURSUB_CODE:
if(p!=NULL) { /* set by code */
for(uint i=0;i<sbbs->usrgrps;i++)
for(uint j=0;j<sbbs->usrsubs[i];j++)
if(!stricmp(sbbs->cfg.sub[sbbs->usrsub[i][j]]->code,p)) {
sbbs->curgrp=i;
sbbs->cursub[i]=j;
}
break;
}
if(sbbs->curgrp<sbbs->cfg.total_grps && (uint)val<sbbs->usrsubs[sbbs->curgrp])
sbbs->cursub[sbbs->curgrp]=val;
break;
case BBS_PROP_CURLIB:
if(p!=NULL) { /* set by name */
uint i;
for(i=0;i<sbbs->usrlibs;i++)
if(!stricmp(sbbs->cfg.lib[sbbs->usrlib[i]]->sname,p))
break;
if(i<sbbs->usrlibs)
sbbs->curlib=i;
break;
}
if((uint)val<sbbs->cfg.total_libs && (uint)val<sbbs->usrlibs)
sbbs->curlib=val;
break;
case BBS_PROP_CURDIR:
case BBS_PROP_CURDIR_CODE:
if(p!=NULL) { /* set by code */
for(uint i=0;i<sbbs->usrlibs;i++)
for(uint j=0;j<sbbs->usrdirs[i];j++)
if(!stricmp(sbbs->cfg.dir[sbbs->usrdir[i][j]]->code,p)) {
sbbs->curlib=i;
sbbs->curdir[i]=j;
}
break;
}
if(sbbs->curlib<sbbs->cfg.total_libs && (uint)val<sbbs->usrdirs[sbbs->curlib])
sbbs->curdir[sbbs->curlib]=val;
break;
SAFECOPY(sbbs->rlogin_name,p);
case BBS_PROP_RLOGIN_PASS:
SAFECOPY(sbbs->rlogin_pass,p);
break;
case BBS_PROP_RLOGIN_TERM:
SAFECOPY(sbbs->rlogin_term,p);
break;
SAFECOPY(sbbs->client_name,p);
case BBS_PROP_ALTUL:
if(val<sbbs->cfg.altpaths)
sbbs->altul=(ushort)val;
break;
case BBS_PROP_COMMAND_STR:
sprintf(sbbs->main_csi.str, "%.*s", 1024, p);
break;
if(sbbs->usrgrps)
sbbs->cursubnum=sbbs->usrsub[sbbs->curgrp][sbbs->cursub[sbbs->curgrp]]; /* Used for ARS */
else
sbbs->cursubnum=INVALID_SUB;
if(sbbs->usrlibs)
sbbs->curdirnum=sbbs->usrdir[sbbs->curlib][sbbs->curdir[sbbs->curlib]]; /* Used for ARS */
sbbs->curdirnum=INVALID_DIR;
#define PROP_READONLY JSPROP_ENUMERATE|JSPROP_READONLY
static jsSyncPropertySpec js_bbs_properties[] = {
/* name ,tinyid ,flags ,ver */
{ "sys_status" ,BBS_PROP_SYS_STATUS ,JSPROP_ENUMERATE ,310},
{ "startup_options" ,BBS_PROP_STARTUP_OPT ,JSPROP_ENUMERATE ,310},
{ "answer_time" ,BBS_PROP_ANSWER_TIME ,JSPROP_ENUMERATE ,310},
{ "logon_time" ,BBS_PROP_LOGON_TIME ,JSPROP_ENUMERATE ,310},
{ "start_time" ,BBS_PROP_START_TIME ,JSPROP_ENUMERATE ,314},
{ "new_file_time" ,BBS_PROP_NS_TIME ,JSPROP_ENUMERATE ,310},
{ "last_new_file_time",BBS_PROP_LAST_NS_TIME ,JSPROP_ENUMERATE ,310},
{ "online" ,BBS_PROP_ONLINE ,JSPROP_ENUMERATE ,310},
{ "timeleft" ,BBS_PROP_TIMELEFT ,JSPROP_READONLY ,310}, /* alias */
{ "time_left" ,BBS_PROP_TIMELEFT ,PROP_READONLY ,311},
{ "event_time" ,BBS_PROP_EVENT_TIME ,PROP_READONLY ,311},