| 1 | RORTSITE ;HCIOFO/SG - PREPARE TEST SITES FOR GOING LIVE ; 5/10/02 11:43am | 
|---|
| 2 | ;;1.0;CLINICAL CASE REGISTRIES;;May 14, 2002 | 
|---|
| 3 | ; | 
|---|
| 4 | Q | 
|---|
| 5 | ; | 
|---|
| 6 | ;***** PREPARE TEST SITE | 
|---|
| 7 | START ; | 
|---|
| 8 | N RORERROR      ; Error processing data | 
|---|
| 9 | N RORLOG        ; Log subsystem constants & variables | 
|---|
| 10 | N RORPARM       ; Application parameters | 
|---|
| 11 | ; | 
|---|
| 12 | N DA,DATE,DIR,DIROUT,DIRUT,DTOUT,DUOUT,RC,REGIEN,X,Y | 
|---|
| 13 | K DIR  S DIR(0)="Y",DIR("B")="NO" | 
|---|
| 14 | S DIR("A")="Prepare the site for going live" | 
|---|
| 15 | D ^DIR  W !  Q:$D(DIRUT)!'$G(Y) | 
|---|
| 16 | ; | 
|---|
| 17 | S RORPARM("DEBUG")=2       ; Debug mode (display messages) | 
|---|
| 18 | S RORPARM("ERR")=1         ; Enable error processing | 
|---|
| 19 | S RORPARM("LOG")=1         ; Enable error recording | 
|---|
| 20 | D INIT^RORUTL01("ROR",1) | 
|---|
| 21 | ; | 
|---|
| 22 | S REGIEN=$$REGIEN^RORUTL02("VA HEPC") | 
|---|
| 23 | I REGIEN<0  D:REGIEN>-3  G ERROR | 
|---|
| 24 | . S RC=$$ERROR^RORERR(REGIEN,"START^RORTSITE") | 
|---|
| 25 | ; | 
|---|
| 26 | W !,"Updating registry records...",! | 
|---|
| 27 | S RC=$$RECORDS(REGIEN,.DATE)  G:RC<0 ERROR | 
|---|
| 28 | W "Processed records: "_+RC_", Errors: "_+$P(RC,U,2),! | 
|---|
| 29 | ; | 
|---|
| 30 | W !,"Updating registry parameters..." | 
|---|
| 31 | G:$$REGPARM(REGIEN,DATE)<0 ERROR | 
|---|
| 32 | W !,"Ok",! | 
|---|
| 33 | Q | 
|---|
| 34 | ; | 
|---|
| 35 | ;***** DISPLAYS THE ERRORS | 
|---|
| 36 | ERROR ; | 
|---|
| 37 | D DSPSTK^RORERR() | 
|---|
| 38 | Q | 
|---|
| 39 | ; | 
|---|
| 40 | ;***** PREPARE REGISTRY RECORDS | 
|---|
| 41 | RECORDS(REGIEN,BNDRYDT) ; | 
|---|
| 42 | N CNT,DATE,ECNT,IEN,IENS,LD1,PATIEN,RC,ROOT,RORBUF,RORFDA,RORMSG,TMP | 
|---|
| 43 | S ROOT=$$ROOT^DILFD(798,,1) | 
|---|
| 44 | ;--- Get the lag period | 
|---|
| 45 | S LD1=$$GET1^DIQ(798.1,REGIEN_",",15.1,,,"RORMSG") | 
|---|
| 46 | S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE")  Q:RC<0 RC | 
|---|
| 47 | ;--- Calculate the date | 
|---|
| 48 | S BNDRYDT=$$FMADD^XLFDT($$DT^XLFDT,-$S(LD1>0:LD1,1:1)-1) | 
|---|
| 49 | ;--- Store the date into the records of the registry | 
|---|
| 50 | S IEN="",(CNT,ECNT)=0 | 
|---|
| 51 | F  S IEN=$O(@ROOT@("AC",REGIEN,IEN))  Q:IEN=""  D | 
|---|
| 52 | . S CNT=CNT+1  W:'(CNT#10) *13,CNT | 
|---|
| 53 | . S IENS=IEN_",",DATE=BNDRYDT | 
|---|
| 54 | . K RORBUF,RORMSG | 
|---|
| 55 | . D GETS^DIQ(798,IENS,"2;8","EI","RORBUF","RORMSG") | 
|---|
| 56 | . I $G(DIERR)  D  S ECNT=ECNT+1  Q | 
|---|
| 57 | . . S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE") | 
|---|
| 58 | . ;--- Check the inactivation date if the record is not active | 
|---|
| 59 | . I '$G(RORBUF(798,IENS,8,"E"))  D  S:DATE>TMP DATE=TMP | 
|---|
| 60 | . . S TMP=$G(RORBUF(798,IENS,2,"I")) | 
|---|
| 61 | . ;--- Update the record | 
|---|
| 62 | . S RORFDA(798,IENS,3)=1               ; NEW PATIENT | 
|---|
| 63 | . S RORFDA(798,IENS,4)=1               ; UPDATE DEMOGRAPHICS | 
|---|
| 64 | . S RORFDA(798,IENS,5)=1               ; UPDATE LOCAL REGISTRY DATA | 
|---|
| 65 | . S RORFDA(798,IENS,9.1)=DATE          ; DATA ACKNOWLEDGED UNTIL | 
|---|
| 66 | . S RORFDA(798,IENS,9.2)=DATE          ; DATA EXTRACTED UNTIL | 
|---|
| 67 | . S RORFDA(798,IENS,10)="@"            ; MESSAGE ID | 
|---|
| 68 | . D FILE^DIE(,"RORFDA","RORMSG") | 
|---|
| 69 | . I $G(DIERR)  D  S ECNT=ECNT+1  Q | 
|---|
| 70 | . . S RC=$$DBS^RORERR("RORMSG",-9,"RECORDS^RORTSITE") | 
|---|
| 71 | W:IEN="" *13 | 
|---|
| 72 | Q $S(RC<0:-9,1:CNT_U_ECNT) | 
|---|
| 73 | ; | 
|---|
| 74 | ;***** PREPARE REGISTRY PARAMETERS | 
|---|
| 75 | REGPARM(REGIEN,DATE) ; | 
|---|
| 76 | N IENS,RC,RORFDA,RORMSG | 
|---|
| 77 | S IENS=REGIEN_"," | 
|---|
| 78 | S RORFDA(798.1,IENS,2)=2960101         ; DATA EXTRACTED UNTIL | 
|---|
| 79 | S RORFDA(798.1,IENS,2.1)="@"           ; LAST BATCH ID | 
|---|
| 80 | S RORFDA(798.1,IENS,2.2)="@"           ; AWAITING ACKNOWLEDGEMENT | 
|---|
| 81 | S RORFDA(798.1,IENS,2.3)="@"           ; LAST MESSAGE ID | 
|---|
| 82 | S RORFDA(798.1,IENS,15.9)=1            ; DAYS TO WAIT FOR ACK | 
|---|
| 83 | S RORFDA(798.1,IENS,21.02)=DATE        ; HDT END DATE | 
|---|
| 84 | S RORFDA(798.1,IENS,21.05)=$$NOW^XLFDT ; HDT DATE/TIME | 
|---|
| 85 | S RORFDA(798.1,IENS,25)=1              ; ENABLE PROTOCOLS | 
|---|
| 86 | D FILE^DIE(,"RORFDA","RORMSG") | 
|---|
| 87 | Q $$DBS^RORERR("RORMSG",-9,"REGPARM^RORTSITE",,798.1,IENS) | 
|---|