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

RORTSITE.m

Go to the documentation of this file.
RORTSITE ;HCIOFO/SG - PREPARE TEST SITES FOR GOING LIVE ; 5/10/02 11:43am
 ;;1.0;CLINICAL CASE REGISTRIES;;May 14, 2002
 ;
 Q
 ;
 ;***** PREPARE TEST SITE
START ;
 N RORERROR      ; Error processing data
 N RORLOG        ; Log subsystem constants & variables
 N RORPARM       ; Application parameters
 ;
 N DA,DATE,DIR,DIROUT,DIRUT,DTOUT,DUOUT,RC,REGIEN,X,Y
 K DIR  S DIR(0)="Y",DIR("B")="NO"
 S DIR("A")="Prepare the site for going live"
 D ^DIR  W !  Q:$D(DIRUT)!'$G(Y)
 ;
 S RORPARM("DEBUG")=2       ; Debug mode (display messages)
 S RORPARM("ERR")=1         ; Enable error processing
 S RORPARM("LOG")=1         ; Enable error recording
 D INIT^RORUTL01("ROR",1)
 ;
 S REGIEN=$$REGIEN^RORUTL02("VA HEPC")
 I REGIEN<0  D:REGIEN>-3  G ERROR
 . S RC=$$ERROR^RORERR(REGIEN,"START^RORTSITE")
 ;
 W !,"Updating registry records...",!
 S RC=$$RECORDS(REGIEN,.DATE)  G:RC<0 ERROR
 W "Processed records: "_+RC_", Errors: "_+$P(RC,U,2),!
 ;
 W !,"Updating registry parameters..."
 G:$$REGPARM(REGIEN,DATE)<0 ERROR
 W !,"Ok",!
 Q
 ;
 ;***** DISPLAYS THE ERRORS
ERROR ;
 D DSPSTK^RORERR()
 Q
 ;
 ;***** PREPARE REGISTRY RECORDS
RECORDS(REGIEN,BNDRYDT) ;
 N CNT,DATE,ECNT,IEN,IENS,LD1,PATIEN,RC,ROOT,RORBUF,RORFDA,RORMSG,TMP
 S ROOT=$$ROOT^DILFD(798,,1)
 ;--- Get the lag period
 S LD1=$$GET1^DIQ(798.1,REGIEN_",",15.1,,,"RORMSG")
 S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE")  Q:RC<0 RC
 ;--- Calculate the date
 S BNDRYDT=$$FMADD^XLFDT($$DT^XLFDT,-$S(LD1>0:LD1,1:1)-1)
 ;--- Store the date into the records of the registry
 S IEN="",(CNT,ECNT)=0
 F  S IEN=$O(@ROOT@("AC",REGIEN,IEN))  Q:IEN=""  D
 . S CNT=CNT+1  W:'(CNT#10) *13,CNT
 . S IENS=IEN_",",DATE=BNDRYDT
 . K RORBUF,RORMSG
 . D GETS^DIQ(798,IENS,"2;8","EI","RORBUF","RORMSG")
 . I $G(DIERR)  D  S ECNT=ECNT+1  Q
 . . S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE")
 . ;--- Check the inactivation date if the record is not active
 . I '$G(RORBUF(798,IENS,8,"E"))  D  S:DATE>TMP DATE=TMP
 . . S TMP=$G(RORBUF(798,IENS,2,"I"))
 . ;--- Update the record
 . S RORFDA(798,IENS,3)=1               ; NEW PATIENT
 . S RORFDA(798,IENS,4)=1               ; UPDATE DEMOGRAPHICS
 . S RORFDA(798,IENS,5)=1               ; UPDATE LOCAL REGISTRY DATA
 . S RORFDA(798,IENS,9.1)=DATE          ; DATA ACKNOWLEDGED UNTIL
 . S RORFDA(798,IENS,9.2)=DATE          ; DATA EXTRACTED UNTIL
 . S RORFDA(798,IENS,10)="@"            ; MESSAGE ID
 . D FILE^DIE(,"RORFDA","RORMSG")
 . I $G(DIERR)  D  S ECNT=ECNT+1  Q
 . . S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE")
 W:IEN="" *13
 Q $S(RC<0:-9,1:CNT_U_ECNT)
 ;
 ;***** PREPARE REGISTRY PARAMETERS
REGPARM(REGIEN,DATE) ;
 N IENS,RC,RORFDA,RORMSG
 S IENS=REGIEN_","
 S RORFDA(798.1,IENS,2)=2960101         ; DATA EXTRACTED UNTIL
 S RORFDA(798.1,IENS,2.1)="@"           ; LAST BATCH ID
 S RORFDA(798.1,IENS,2.2)="@"           ; AWAITING ACKNOWLEDGEMENT
 S RORFDA(798.1,IENS,2.3)="@"           ; LAST MESSAGE ID
 S RORFDA(798.1,IENS,15.9)=1            ; DAYS TO WAIT FOR ACK
 S RORFDA(798.1,IENS,21.02)=DATE        ; HDT END DATE
 S RORFDA(798.1,IENS,21.05)=$$NOW^XLFDT ; HDT DATE/TIME
 S RORFDA(798.1,IENS,25)=1              ; ENABLE PROTOCOLS
 D FILE^DIE(,"RORFDA","RORMSG")
 Q $$DBS^RORERR("RORMSG",-9,"REGPARM^RORTSITE",,798.1,IENS)