| [613] | 1 | RORRP012 ;HCIOFO/SG - RPC: MISCELLANEOUS ; 12/15/05 4:03pm | 
|---|
|  | 2 | ;;1.5;CLINICAL CASE REGISTRIES;;Feb 17, 2006 | 
|---|
|  | 3 | ; | 
|---|
|  | 4 | Q | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ;***** RETURNS THE CURRENT DATE/TIME ON THE SERVER | 
|---|
|  | 7 | ; RPC: [ROR GET SERVER TIME] | 
|---|
|  | 8 | ; | 
|---|
|  | 9 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 10 | ;               are returned to. | 
|---|
|  | 11 | ; | 
|---|
|  | 12 | ; Return Values: | 
|---|
|  | 13 | ; | 
|---|
|  | 14 | ; The current dat/time (in internal FileMan format) is returned | 
|---|
|  | 15 | ; in the RESULTS(1). RESULTS(0) alwais contains 0. | 
|---|
|  | 16 | ; | 
|---|
|  | 17 | GETSRVDT(RESULTS) ; | 
|---|
|  | 18 | S RESULTS(0)=0 | 
|---|
|  | 19 | S RESULTS(1)=$$NOW^XLFDT | 
|---|
|  | 20 | Q | 
|---|
|  | 21 | ; | 
|---|
|  | 22 | ;***** RETURNS A LIST OF ITEMS FROM THE 'ROR LIST ITEM' FILE | 
|---|
|  | 23 | ; RPC: [ROR LIST ITEMS] | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 26 | ;               are returned to. | 
|---|
|  | 27 | ; | 
|---|
|  | 28 | ; REGIEN        Registry IEN | 
|---|
|  | 29 | ; | 
|---|
|  | 30 | ; TYPE          Type of the items: | 
|---|
|  | 31 | ;                 3  Lab Group | 
|---|
|  | 32 | ;                 4  Drug Group | 
|---|
|  | 33 | ; | 
|---|
|  | 34 | ; Return Values: | 
|---|
|  | 35 | ; | 
|---|
|  | 36 | ; A negative value of the first "^"-piece of the RESULTS(0) | 
|---|
|  | 37 | ; indicates an error (see the RPCSTK^RORERR procedure for more | 
|---|
|  | 38 | ; details). | 
|---|
|  | 39 | ; | 
|---|
|  | 40 | ; Otherwise, number of items is returned in the RESULTS(0) | 
|---|
|  | 41 | ; and the subsequent nodes of the array contain the items. | 
|---|
|  | 42 | ; | 
|---|
|  | 43 | ; RESULTS(0)            Number of item | 
|---|
|  | 44 | ; | 
|---|
|  | 45 | ; RESULTS(i)            List Item | 
|---|
|  | 46 | ;                         ^01: IEN | 
|---|
|  | 47 | ;                         ^02: Text | 
|---|
|  | 48 | ;                         ^03: Code | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | LSTITEMS(RESULTS,REGIEN,TYPE) ; | 
|---|
|  | 51 | N CNT,CODE,ITEMS,RC,RORERRDL | 
|---|
|  | 52 | D CLEAR^RORERR("LSTITEMS^RORRP012",1) | 
|---|
|  | 53 | K RESULTS  S RESULTS(0)=0 | 
|---|
|  | 54 | ;--- Check the parameters | 
|---|
|  | 55 | S RC=0  D  I RC<0  D RPCSTK^RORERR(.RESULTS,RC)  Q | 
|---|
|  | 56 | . ;--- Registry IEN | 
|---|
|  | 57 | . I $G(REGIEN)'>0  D  Q | 
|---|
|  | 58 | . . S RC=$$ERROR^RORERR(-88,,,,"REGIEN",$G(REGIEN)) | 
|---|
|  | 59 | . S REGIEN=+REGIEN | 
|---|
|  | 60 | . ;--- Type | 
|---|
|  | 61 | . I $G(TYPE)'>0  D  Q | 
|---|
|  | 62 | . . S RC=$$ERROR^RORERR(-88,,,,"TYPE",$G(TYPE)) | 
|---|
|  | 63 | . S TYPE=+TYPE | 
|---|
|  | 64 | ;--- Load the list items | 
|---|
|  | 65 | S RC=$$ITEMLIST^RORUTL09(TYPE,REGIEN,.ITEMS) | 
|---|
|  | 66 | ;--- Populate the output array | 
|---|
|  | 67 | S CODE="",CNT=0 | 
|---|
|  | 68 | F  S CODE=$O(ITEMS(CODE))  Q:CODE=""  D | 
|---|
|  | 69 | . S CNT=CNT+1,RESULTS(CNT)=$P(ITEMS(CODE),U,1,2) | 
|---|
|  | 70 | . S $P(RESULTS(CNT),U,3)=CODE | 
|---|
|  | 71 | S RESULTS(0)=CNT | 
|---|
|  | 72 | Q | 
|---|
|  | 73 | ; | 
|---|
|  | 74 | ;***** CHECKS FOR PRODUCTION ACCOUNT | 
|---|
|  | 75 | ; RPC: [ROR PRODUCTION ACCOUNT] | 
|---|
|  | 76 | ; | 
|---|
|  | 77 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 78 | ;               are returned to. | 
|---|
|  | 79 | ; | 
|---|
|  | 80 | ; Return Values: | 
|---|
|  | 81 | ; | 
|---|
|  | 82 | ; 1 is returned in RESULTS(0) in case of a production account. | 
|---|
|  | 83 | ; Otherwise, zero is returned. | 
|---|
|  | 84 | ; | 
|---|
|  | 85 | PROD(RESULTS) ; | 
|---|
|  | 86 | S RESULTS(0)=+$$PROD^XUPROD() | 
|---|
|  | 87 | Q | 
|---|
|  | 88 | ; | 
|---|
|  | 89 | ;***** CHECKS IF THE RESCHEDULING CODE IS VALID | 
|---|
|  | 90 | ; ROR: [ROR TASK VALIDATE RESCHEDULING] | 
|---|
|  | 91 | ; | 
|---|
|  | 92 | ; .RESULTS      Reference to a local variable where the results | 
|---|
|  | 93 | ;               are returned to. | 
|---|
|  | 94 | ; | 
|---|
|  | 95 | ; SCHCODE       Rescheduling code | 
|---|
|  | 96 | ; | 
|---|
|  | 97 | ; [SCHDT]       Date when a task is scheduled to run for the | 
|---|
|  | 98 | ;               first time (FileMan). By default (if $G(SCHDT)'>0), | 
|---|
|  | 99 | ;               the current date/time is used. | 
|---|
|  | 100 | ; | 
|---|
|  | 101 | ; Return Values: | 
|---|
|  | 102 | ; | 
|---|
|  | 103 | ; A negative value of the first "^"-piece of the RESULTS(0) indicates | 
|---|
|  | 104 | ; an error (see the RPCSTK^RORERR procedure for more details). | 
|---|
|  | 105 | ; | 
|---|
|  | 106 | ; Otherwise, either 1 (the rescheduling code is valid) or 0 (the | 
|---|
|  | 107 | ; code is not valid) is returned in the RESULTS(0). If the code is | 
|---|
|  | 108 | ; valid then the next date/time to run the task (FileMan format) | 
|---|
|  | 109 | ; is returned in the RESULTS(1). | 
|---|
|  | 110 | ; | 
|---|
|  | 111 | VALIDSCH(RESULTS,SCHCODE,SCHDT) ; | 
|---|
|  | 112 | N NEXT,RORMSG,TMP  K RESULTS | 
|---|
|  | 113 | I $G(SCHCODE)=""  S RESULTS(0)=1  Q | 
|---|
|  | 114 | S RESULTS(0)=0 | 
|---|
|  | 115 | ;--- Check if the rescheduling code is correct | 
|---|
|  | 116 | S:$G(SCHDT)'>0 SCHDT=$$NOW^XLFDT | 
|---|
|  | 117 | S NEXT=$$SCH^XLFDT(SCHCODE,SCHDT,1) | 
|---|
|  | 118 | Q:NEXT'>0 | 
|---|
|  | 119 | ;--- Make sure that a task will not be rescheduled in less | 
|---|
|  | 120 | ;--- than 60 seconds (to be able to delete it if necessary) | 
|---|
|  | 121 | S TMP=$$SCH^XLFDT(SCHCODE,NEXT,1) | 
|---|
|  | 122 | S:$$FMDIFF^XLFDT(TMP,NEXT,2)'<60 RESULTS(0)=1,RESULTS(1)=NEXT | 
|---|
|  | 123 | Q | 
|---|