Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: XUSC1S

XUSC1S.m

Go to the documentation of this file.
  1. XUSC1S ;ISCSF/RWF - Interface to Server services. ;10/09/2002 16:59
  1. ;;8.0;KERNEL;**283**;Jul 10, 1995
  1. Q
  1. ;XUSC is used to pass data around.
  1. ; 5224 is the standard VA port for the Services Server.
  1. LISTEN ;only for OpenM
  1. S $ETRAP="D ^%ZTER H"
  1. D LISTEN^%ZISTCPS(5500,"ONT^XUSC1S")
  1. Q
  1. DSM ;Test listener
  1. S IO=% O IO:(SHARE) U IO ;Setup TCP port
  1. S IO(0)="_NLA0:" O IO(0) ;Setup null device
  1. D SVR
  1. Q
  1. MSM ;Entry point from MSERVER
  1. S IO=56,IO(0)=46 O 46 ;Null device
  1. D SVR C IO
  1. Q
  1. ONT ;Cache/OpenM
  1. S IO=$I,IO(0)="//./nul" O IO(0)
  1. D SVR
  1. Q
  1. ;
  1. SVR ;Entry point when we have a connect
  1. ;See that IO=TCP device, and IO(0) is Null device and Open.
  1. N XUSC11,XUSCER,XUSCEXIT,XUSCCMD,XUSCDAT,ZTQUEUED D SETUP
  1. N $ESTACK,$ETRAP S $ETRAP="D ^%ZTER H"
  1. K ^XUTL("XQ",$J) S ^XUTL("XQ",$J,0)=$$NOW^XLFDT
  1. F D CREAD Q:XUSCEXIT D Q:XUSCEXIT
  1. . I XUSCCMD="" S XUSC11("TCNT")=$G(XUSC11("TCNT"))+1 S:$$STOP!(XUSC11("TCNT")>10) XUSCEXIT=1 Q
  1. . I XUSCCMD'?4A D SEND("500 Bad CMD: "_$E(XUSCCMD,1,20)) Q
  1. . I $T(@XUSCCMD)="" D SEND("500 ") Q
  1. . S XUSC11("TCNT")=0
  1. . D @XUSCCMD I $G(XUSCER) D TRACE("ERROR: "_XUSCER)
  1. . Q
  1. S:XUSCEXIT IO("C")=1
  1. I '$G(XUSCDBUG) K ^TMP("XUSCI",$J),^TMP("XUSCO",$J) ;Clean up
  1. D TRACE("Exit")
  1. Q
  1. HELO ;Process HELO
  1. S XUSC11("SITE")=$P(XUSCDAT," ")
  1. ;Do any check on who is sending
  1. D SEND("220 "_$$KSP^XUPARAM("WHERE")_" Ready for "_XUSCDAT)
  1. Q
  1. ;
  1. NOOP ;
  1. D SEND("250 OK")
  1. Q
  1. ;
  1. DATA ;Process DATA
  1. ; The DATA cmd can pass some parameters as well, this could be passed
  1. ; to the processing routine also.
  1. N XUSCRTN,P,I,DUZ S DUZ=0,DUZ(0)="@"
  1. D TRACE("Get Data")
  1. S (XUSCRTN,XUSC11("DATA"))=XUSCDAT K @XUSCIN,@XUSCOUT
  1. D DATA^XUSC1S1(XUSCIN,.XUSC11)
  1. S P="" F I=1:1 Q:'$D(XUSC11("P"_I)) S P=P_"P"_I_"="_XUSC11("P"_I)_", "
  1. D TRACE("PARAM "_P)
  1. ;Use the Null Device
  1. U IO(0)
  1. ;Now call soneone to process the data
  1. ;I XUSC11("P1")="SERVER" D SERVER^XUSC1S2
  1. I XUSC11("P1")="PING" M @XUSCOUT=@XUSCIN
  1. U IO ;Back to the TCP device
  1. Q
  1. TURN ;Turn and send responce
  1. D SEND("220 OK")
  1. D SDATA^XUSC1S1(XUSCOUT,XUSC11("P1"))
  1. D CREAD,TRACE("Data Sent ") ;Look for 220 ok
  1. Q
  1. QUIT ;Process QUIT
  1. D TRACE("QUIT")
  1. S XUSCMSG="",XUSCEXIT=1
  1. Q
  1. ;
  1. CREAD ;Read a string
  1. N $ETRAP S $ETRAP="S $EC="""" G CREX"
  1. N I S (Y,XUSCDAT,XUSCCMD)="",XUSCER=0
  1. F I=0:1:255 R X#1:XUSCTIME S:'$T XUSCER=1 D TRACE("Char "_$A(X)) Q:X=$C(10)!XUSCER S Y=Y_X
  1. S Y=$TR(Y,$C(13,10)),XUSCCMD=$P(Y," "),XUSCDAT=$P(Y," ",2,99)
  1. D TRACE("Cmd Read "_Y)
  1. Q
  1. CREX S XUSCEXIT=1,XUSCER="1 Error"
  1. D TRACE("CREAD error: "_$$EC^%ZOSV_" Y="_Y)
  1. Q
  1. ;
  1. SEND(MSG) ;Send a cmd MSG
  1. N $ETRAP S $ETRAP="S $EC="""" D CREX"
  1. D TRACE("Cmd Send "_MSG)
  1. W MSG,$C(13,10),!
  1. Q
  1. ;
  1. SETUP ;Setup needed variables
  1. K IO("C") S (XUSCER,XUSCEXIT)=0,XUSCTIME=345,ZTQUEUED=.5 ;**** CHANGE BACK
  1. S XUSCTRC="S: ",XUSC11("P1")="TEXT"
  1. S XUSCIN=$NA(^TMP("XUSCI",$J)),XUSCOUT=$NA(^TMP("XUSCO",$J))
  1. S XUSCDBUG=$$GET^XPAR("SYS","XUSC1 DEBUG",,"Q")
  1. D TRACE(-1),TRACE("Server Setup")
  1. Q
  1. STOP(%) ;Should the server stop.
  1. I $G(%)=1 S ^TMP("XUSC1","STOP")=1 Q
  1. I $G(%)=-1 K ^TMP("XUSC1","STOP") Q
  1. I $D(^TMP("XUSC1","STOP")) Q 1
  1. Q 0
  1. ;
  1. TRACE(S1) ;
  1. N H,%
  1. I S1=-1 K ^TMP("XUSC1",$J) Q
  1. Q:'$G(XUSCDBUG)
  1. S H=$P($H,",",2),H=(H\3600)_":"_(H#3600\60)_":"_(H#60)_" "
  1. L +^TMP("XUSC1",$J)
  1. S %=$G(^TMP("XUSC1",$J,0))+1,^(0)=%,^(%)=H_$G(XUSCTRC)_S1
  1. L -^TMP("XUSC1",$J)
  1. Q
  1. ;