| [613] | 1 | RORRP023 ;HCIOFO/SG - RPC: REGISTRY COORDINATORS ; 7/16/03 11:25am | 
|---|
|  | 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | ; This routine uses the following IAs: | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ; #10060        Read access (FileMan) to the file #200 (supported) | 
|---|
|  | 7 | ; | 
|---|
|  | 8 | Q | 
|---|
|  | 9 | ; | 
|---|
|  | 10 | ;***** RETURNS THE LIST OF REGISTRY COORDINATORS | 
|---|
|  | 11 | ; RPC: [ROR LIST COORDINATORS] | 
|---|
|  | 12 | ; | 
|---|
|  | 13 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 14 | ;               are returned to. | 
|---|
|  | 15 | ; | 
|---|
|  | 16 | ; REGIEN        Registry IEN | 
|---|
|  | 17 | ; | 
|---|
|  | 18 | ; The ^TMP("DILIST",$J) global node is used by the procedure. | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | ; Return Values: | 
|---|
|  | 21 | ; | 
|---|
|  | 22 | ; A negative value of the first "^"-piece of the RESULTS(0) | 
|---|
|  | 23 | ; indicates an error (see the RPCSTK^RORERR procedure for more | 
|---|
|  | 24 | ; details). | 
|---|
|  | 25 | ; | 
|---|
|  | 26 | ; Otherwise, number of coordinators is returned in the | 
|---|
|  | 27 | ; @RESULTS@(0) and the subsequent nodes of the global array | 
|---|
|  | 28 | ; contain the coordinators. | 
|---|
|  | 29 | ; | 
|---|
|  | 30 | ; @RESULTS@(0)          Number of Coordinators | 
|---|
|  | 31 | ; | 
|---|
|  | 32 | ; @RESULTS@(i)          Coordinator's Descriptor | 
|---|
|  | 33 | ;                         ^01: IEN | 
|---|
|  | 34 | ;                         ^02: Name | 
|---|
|  | 35 | ; | 
|---|
|  | 36 | RCLIST(RESULTS,REGIEN) ; | 
|---|
|  | 37 | N IENS,RC,RORERRDL,RORMSG,TMP | 
|---|
|  | 38 | D CLEAR^RORERR("RCLIST^RORRP023",1) | 
|---|
|  | 39 | K RESULTS  S RESULTS=$NA(^TMP("DILIST",$J))  K @RESULTS | 
|---|
|  | 40 | ;--- Check the parameters | 
|---|
|  | 41 | S RC=0  D  I RC<0  D RPCSTK^RORERR(.RESULTS,RC)  Q | 
|---|
|  | 42 | . ;--- Registry IEN | 
|---|
|  | 43 | . I $G(REGIEN)'>0  D  Q | 
|---|
|  | 44 | . . S RC=$$ERROR^RORERR(-88,,,,"REGIEN",$G(REGIEN)) | 
|---|
|  | 45 | . S REGIEN=+REGIEN | 
|---|
|  | 46 | ;--- Get the list of coordinators | 
|---|
|  | 47 | S IENS=","_REGIEN_",",TMP="@;.01E" | 
|---|
|  | 48 | D LIST^DIC(798.114,IENS,TMP,"PU",,,,"B",,,,"RORMSG") | 
|---|
|  | 49 | I $G(DIERR)  D  D RPCSTK^RORERR(.RESULTS,RC)  Q | 
|---|
|  | 50 | . S RC=$$DBS^RORERR("RORMSG",-9,,,798.114,IENS) | 
|---|
|  | 51 | ;--- Success | 
|---|
|  | 52 | S TMP=+$G(^TMP("DILIST",$J,0)) | 
|---|
|  | 53 | K ^TMP("DILIST",$J,0)  S @RESULTS@(0)=TMP | 
|---|
|  | 54 | Q | 
|---|
|  | 55 | ; | 
|---|
|  | 56 | ;***** UPDATES THE LIST OF REGISTRY COORDINATORS | 
|---|
|  | 57 | ; RPC: [ROR UPDATE COORDINATORS] | 
|---|
|  | 58 | ; | 
|---|
|  | 59 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 60 | ;               are returned to. | 
|---|
|  | 61 | ; | 
|---|
|  | 62 | ; REGIEN        Registry IEN | 
|---|
|  | 63 | ; | 
|---|
|  | 64 | ; .RCLST(       Reference to a local variable that contains | 
|---|
|  | 65 | ;               a list of registry coordinators | 
|---|
|  | 66 | ;   i)            User IEN (DUZ) | 
|---|
|  | 67 | ; | 
|---|
|  | 68 | ; Return Values: | 
|---|
|  | 69 | ; | 
|---|
|  | 70 | ; A negative value of the first "^"-piece of the RESULTS(0) | 
|---|
|  | 71 | ; indicates an error (see the RPCSTK^RORERR procedure for more | 
|---|
|  | 72 | ; details). | 
|---|
|  | 73 | ; | 
|---|
|  | 74 | ; Otherwise, zero is returned in the RESULTS(0). | 
|---|
|  | 75 | ; | 
|---|
|  | 76 | RCLUPD(RESULTS,REGIEN,RCLST) ; | 
|---|
|  | 77 | N DA,DIK,ECNT,IEN,IENS,RC,RCL,ROOT,RORERRDL,RORFDA,RORIEN,RORMSG,TMP | 
|---|
|  | 78 | D CLEAR^RORERR("RCLUPD^RORRP023",1)  K RESULTS | 
|---|
|  | 79 | ;--- Check the parameters | 
|---|
|  | 80 | S RC=0  D  I RC<0  D RPCSTK^RORERR(.RESULTS,RC)  Q | 
|---|
|  | 81 | . ;--- Registry IEN | 
|---|
|  | 82 | . I $G(REGIEN)'>0  D  Q | 
|---|
|  | 83 | . . S RC=$$ERROR^RORERR(-88,,,,"REGIEN",$G(REGIEN)) | 
|---|
|  | 84 | . S REGIEN=+REGIEN | 
|---|
|  | 85 | ; | 
|---|
|  | 86 | ;--- Lock the COORDINATOR multiple | 
|---|
|  | 87 | S IENS=","_REGIEN_"," | 
|---|
|  | 88 | S RC=$$LOCK^RORLOCK(798.114,IENS) | 
|---|
|  | 89 | I RC  D:RC>0  D RPCSTK^RORERR(.RESULTS,RC)  Q | 
|---|
|  | 90 | . S RC=$$ERROR^RORERR(-11,,,,"the COORDINATOR multiple") | 
|---|
|  | 91 | ;--- | 
|---|
|  | 92 | S ROOT=$$ROOT^DILFD(798.114,IENS,1) | 
|---|
|  | 93 | ; | 
|---|
|  | 94 | ;--- Create a list of coordinators' IENs | 
|---|
|  | 95 | S TMP="" | 
|---|
|  | 96 | F  S TMP=$O(RCLST(TMP))  Q:TMP=""  D | 
|---|
|  | 97 | . S IEN=+RCLST(TMP) | 
|---|
|  | 98 | . S:$$FIND1^DIC(200,,,"`"_IEN,,,"RORMSG")>0 RCL(IEN)="" | 
|---|
|  | 99 | ; | 
|---|
|  | 100 | ;--- Delete the coordinators | 
|---|
|  | 101 | S DIK=$$OREF^DILF(ROOT),DA(1)=REGIEN,DA=0 | 
|---|
|  | 102 | F  S DA=$O(@ROOT@(DA))  Q:DA'>0  D:'$D(RCL(DA)) ^DIK | 
|---|
|  | 103 | ;--- Update the coordinators | 
|---|
|  | 104 | S (ECNT,IEN)=0,IENS="?+1,"_REGIEN_"," | 
|---|
|  | 105 | F  S IEN=$O(RCL(IEN))  Q:IEN'>0  D | 
|---|
|  | 106 | . S RORFDA(798.114,IENS,.01)=IEN | 
|---|
|  | 107 | . S RORIEN(1)=IEN | 
|---|
|  | 108 | . D UPDATE^DIE(,"RORFDA","RORIEN","RORMSG") | 
|---|
|  | 109 | . I $G(DIERR)  D  S ECNT=ECNT+1  Q | 
|---|
|  | 110 | . . S RC=$$DBS^RORERR("RORMSG",-9,,,798.114,IENS) | 
|---|
|  | 111 | ; | 
|---|
|  | 112 | ;--- Unlock the multiple and check for errors | 
|---|
|  | 113 | D UNLOCK^RORLOCK(798.114,","_REGIEN_",") | 
|---|
|  | 114 | I ECNT>0  D RPCSTK^RORERR(.RESULTS,-9)  Q | 
|---|
|  | 115 | ;--- Success | 
|---|
|  | 116 | S RESULTS(0)=0 | 
|---|
|  | 117 | Q | 
|---|