XQSRV4 ;SEA/MJM - Server utilities;;2/6/92 2:13 PM ;3/10/92 07:55;11/9/93 2:58 PM
;;8.0;KERNEL;;Jul 10, 1995
;
;This routine takes a pointer to a bulletin in X and looks to
;see if there is an active user reachable through it's mail group.
;If the site has chosen a bulletin other than XQSERVER then it
;checks that one first, if it fails it defaults to XQSERVER. If
;that fails too the routine returns Y="".
;
I '$D(X) S Y="" Q
S U="^",Y=1,%XQGO=0
I X]"" S X=$P($G(^XMB(3.6,+X,0)),U) I X]"" D GRP I %XQGO S XQMB=%XQB,Y=1 G KILL
S (X,XQMB)="XQSERVER" S %=$O(^XMB(3.6,"B","XQSERVER",0)) I %="" S Y="",XQER1=" is not in bulletin file." G KILL
D GRP
I %XQGO S Y=1
E S Y=""
;
KILL ;Clean up and depart
K %XQB,%XQG,%XQGO,%XQI,%XQJ,%XQN,%XQT,%XQU,X
Q
;
GRP ;See if there is a legitimate mail group
S %XQB=X,%XQN=$O(^XMB(3.6,"B",%XQB,0)) I %XQN="" S Y="" Q
F %XQI=0:0 Q:%XQGO S %XQI=$O(^XMB(3.6,%XQN,2,"B",%XQI)) Q:%XQI="" I $D(^XMB(3.8,%XQI,0))#2 S %XQU="" F %XQJ=0:0 S %XQU=$O(^XMB(3.8,%XQI,1,"B",%XQU)) Q:%XQU="" D USER Q:%XQGO
I %XQGO S Y=%XQU
E S Y=""
Q
;
BULL ;Set up the bulletin parameters and/or reply mail and fire 'em off
S XMB=XQMB,XMB(1)=XQDATE,XMB(2)=XMFROM,XMB(3)=XQSOP,XMB(4)=XQSUB,XMB(5)=XQMSG
S:XQER[";;" XQER=$P(XQER,";;",2)
S XMB(6)=XQMB6,XMB=XQMB
I XMB(6)=" " S XMB(6)="No errors detected by the Menu System.",XMB(7)="OK"
E S XMB(7)="ERROR"
I $D(XQSTXT) S XMTEXT="XQSTXT("
S XQJ=$P(XQ220,U,3) I $L(XQJ),$D(^XMB(3.8,XQJ,0)) S XQN="" F XQI=0:0 S XQN=$O(^XMB(3.8,XQJ,1,"B",XQN)) Q:XQN="" S XMY(XQN)=""
I $D(XMFROM),XMFROM=+XMFROM,$D(^VA(200,XMFROM,0)) S XMFROM=$P(^(0),U)
D:'XQNOUSR ^XMB K XMY
Q
;
USER ;See if this User is still active
Q:'$D(^VA(200,%XQU,0))#2 Q:$P(^(.1),U,2)="" S %XQT=$P(^(0),U,11) I %XQT'="" Q:DT>%XQT
S %XQGO=1
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HXQSRV4 1844 printed Dec 13, 2024@02:06:43 Page 2
XQSRV4 ;SEA/MJM - Server utilities;;2/6/92 2:13 PM ;3/10/92 07:55;11/9/93 2:58 PM
+1 ;;8.0;KERNEL;;Jul 10, 1995
+2 ;
+3 ;This routine takes a pointer to a bulletin in X and looks to
+4 ;see if there is an active user reachable through it's mail group.
+5 ;If the site has chosen a bulletin other than XQSERVER then it
+6 ;checks that one first, if it fails it defaults to XQSERVER. If
+7 ;that fails too the routine returns Y="".
+8 ;
+9 IF '$DATA(X)
SET Y=""
QUIT
+10 SET U="^"
SET Y=1
SET %XQGO=0
+11 IF X]""
SET X=$PIECE($GET(^XMB(3.6,+X,0)),U)
IF X]""
DO GRP
IF %XQGO
SET XQMB=%XQB
SET Y=1
GOTO KILL
+12 SET (X,XQMB)="XQSERVER"
SET %=$ORDER(^XMB(3.6,"B","XQSERVER",0))
IF %=""
SET Y=""
SET XQER1=" is not in bulletin file."
GOTO KILL
+13 DO GRP
+14 IF %XQGO
SET Y=1
+15 IF '$TEST
SET Y=""
+16 ;
KILL ;Clean up and depart
+1 KILL %XQB,%XQG,%XQGO,%XQI,%XQJ,%XQN,%XQT,%XQU,X
+2 QUIT
+3 ;
GRP ;See if there is a legitimate mail group
+1 SET %XQB=X
SET %XQN=$ORDER(^XMB(3.6,"B",%XQB,0))
IF %XQN=""
SET Y=""
QUIT
+2 FOR %XQI=0:0
if %XQGO
QUIT
SET %XQI=$ORDER(^XMB(3.6,%XQN,2,"B",%XQI))
if %XQI=""
QUIT
IF $DATA(^XMB(3.8,%XQI,0))#2
SET %XQU=""
FOR %XQJ=0:0
SET %XQU=$ORDER(^XMB(3.8,%XQI,1,"B",%XQU))
if %XQU=""
QUIT
DO USER
if %XQGO
QUIT
+3 IF %XQGO
SET Y=%XQU
+4 IF '$TEST
SET Y=""
+5 QUIT
+6 ;
BULL ;Set up the bulletin parameters and/or reply mail and fire 'em off
+1 SET XMB=XQMB
SET XMB(1)=XQDATE
SET XMB(2)=XMFROM
SET XMB(3)=XQSOP
SET XMB(4)=XQSUB
SET XMB(5)=XQMSG
+2 if XQER[";;"
SET XQER=$PIECE(XQER,";;",2)
+3 SET XMB(6)=XQMB6
SET XMB=XQMB
+4 IF XMB(6)=" "
SET XMB(6)="No errors detected by the Menu System."
SET XMB(7)="OK"
+5 IF '$TEST
SET XMB(7)="ERROR"
+6 IF $DATA(XQSTXT)
SET XMTEXT="XQSTXT("
+7 SET XQJ=$PIECE(XQ220,U,3)
IF $LENGTH(XQJ)
IF $DATA(^XMB(3.8,XQJ,0))
SET XQN=""
FOR XQI=0:0
SET XQN=$ORDER(^XMB(3.8,XQJ,1,"B",XQN))
if XQN=""
QUIT
SET XMY(XQN)=""
+8 IF $DATA(XMFROM)
IF XMFROM=+XMFROM
IF $DATA(^VA(200,XMFROM,0))
SET XMFROM=$PIECE(^(0),U)
+9 if 'XQNOUSR
DO ^XMB
KILL XMY
+10 QUIT
+11 ;
USER ;See if this User is still active
+1 if '$DATA(^VA(200,%XQU,0))#2
QUIT
if $PIECE(^(.1),U,2)=""
QUIT
SET %XQT=$PIECE(^(0),U,11)
IF %XQT'=""
if DT>%XQT
QUIT
+2 SET %XQGO=1
+3 QUIT