[613] | 1 | MHVRQI ;WAS/GPM - Request Manager Immediate Mode ; 7/28/05 11:49pm [12/14/06 11:38am]
|
---|
| 2 | ;;1.0;My HealtheVet;**2**;Aug 23, 2005;Build 22
|
---|
| 3 | ;;Per VHA Directive 2004-038, this routine should not be modified.
|
---|
| 4 | ;
|
---|
| 5 | ;
|
---|
| 6 | REALTIME(REQ,XMT,HL) ; Manage immediate mode / real time requests
|
---|
| 7 | ;
|
---|
| 8 | ; Triage, execute/extract and respond to real time requests and
|
---|
| 9 | ; queries. If the request is rejected (blocked, or doesn't support
|
---|
| 10 | ; real time access), send a negative acknowledgement, otherwise call
|
---|
| 11 | ; the execute/extraction routine. If there are no errors transmit
|
---|
| 12 | ; the results, send a negative acknowledgement if there are errors.
|
---|
| 13 | ;
|
---|
| 14 | ; Input:
|
---|
| 15 | ; REQ - Parsed query and query parameters
|
---|
| 16 | ; XMT - Transmission parameters
|
---|
| 17 | ; HL - HL7 package array variable
|
---|
| 18 | ;
|
---|
| 19 | ; Output:
|
---|
| 20 | ; Extract information and respond to query
|
---|
| 21 | ;
|
---|
| 22 | N ERR,DATAROOT,MHVDATA
|
---|
| 23 | S DATAROOT="^TMP(""MHVEXTRACT"","_$J_","_REQ("TYPE")_")"
|
---|
| 24 | S ERR=""
|
---|
| 25 | ;
|
---|
| 26 | D LOG^MHVUL2("REQUEST MGR - IMMEDIATE","BEGIN","S","TRACE")
|
---|
| 27 | ;
|
---|
| 28 | I $$REJECT(.REQ,.ERR) D Q
|
---|
| 29 | . D LOG^MHVUL2("REQUEST CHECK","REJECT^"_ERR,"S","ERROR")
|
---|
| 30 | . D XMIT^MHV7T(.REQ,.XMT,ERR,"",.HL)
|
---|
| 31 | D LOG^MHVUL2("REQUEST CHECK","PROCESS","S","TRACE")
|
---|
| 32 | ;
|
---|
| 33 | I '$$EXECUTE(.REQ,.ERR,.DATAROOT) D Q
|
---|
| 34 | . D LOG^MHVUL2("REQUEST EXECUTE","ERROR^"_ERR,"S","ERROR")
|
---|
| 35 | . D XMIT^MHV7T(.REQ,.XMT,ERR,DATAROOT,.HL)
|
---|
| 36 | D LOG^MHVUL2("REQUEST EXECUTE","COMPLETE","S","TRACE")
|
---|
| 37 | ;
|
---|
| 38 | D XMIT^MHV7T(.REQ,.XMT,ERR,DATAROOT,.HL)
|
---|
| 39 | K @DATAROOT
|
---|
| 40 | ;
|
---|
| 41 | D LOG^MHVUL2("REQUEST MGR - IMMEDIATE","END","S","TRACE")
|
---|
| 42 | ;
|
---|
| 43 | Q
|
---|
| 44 | ;
|
---|
| 45 | REJECT(REQ,ERR) ;Check to see if request can be processed
|
---|
| 46 | S ERR=""
|
---|
| 47 | I REQ("BLOCKED") D Q 1
|
---|
| 48 | . S ERR="^207^AR^Request Type Blocked by Site"
|
---|
| 49 | . I $D(REQ("QPD")) S ERR="QPD^1^4"_ERR Q ;QBP query flag the QPD
|
---|
| 50 | . I $D(REQ("QRD")) S ERR="QRD^1^10"_ERR Q ;old style query flag QRD
|
---|
| 51 | . S ERR="MSH^1^9"_ERR ;not a query flag MSH
|
---|
| 52 | . Q
|
---|
| 53 | I 'REQ("REALTIME") D Q 1
|
---|
| 54 | . S ERR="^207^AR^Real Time Calls Not Supported By Request Type"
|
---|
| 55 | . I $D(REQ("QPD")) S ERR="RCP^1^1"_ERR Q ;QBP query flag RCP
|
---|
| 56 | . I $D(REQ("QRD")) S ERR="QRD^1^3"_ERR Q ;old style query flag QRD
|
---|
| 57 | . S ERR="MSH^1^9"_ERR ;not a query flag MSH
|
---|
| 58 | . Q
|
---|
| 59 | Q 0
|
---|
| 60 | ;
|
---|
| 61 | EXECUTE(REQ,ERR,DATAROOT) ;Execute action or extraction
|
---|
| 62 | ;Calls the execute routine for this request type
|
---|
| 63 | ;For queries this is the extraction routine
|
---|
| 64 | ;Parameters can be passed on REQ
|
---|
| 65 | ;Errors are passed on ERR
|
---|
| 66 | ;
|
---|
| 67 | ; DATAROOT is passed by reference because extractors are permitted
|
---|
| 68 | ; to change the root referenced. This allows on the fly use of
|
---|
| 69 | ; local variables and globals produced by calls to other packages.
|
---|
| 70 | ; Care must be given when using locals because they cannot be NEWed.
|
---|
| 71 | ; MHVDATA is NEWed above, and can be safely used.
|
---|
| 72 | ; The KILL in the main loop above will clean up.
|
---|
| 73 | ;
|
---|
| 74 | S ERR=""
|
---|
| 75 | D @(REQ("EXECUTE")_"(.REQ,.ERR,.DATAROOT)")
|
---|
| 76 | I ERR D Q 0
|
---|
| 77 | . S ERR="^207^AR^"_$P(ERR,"^",2)
|
---|
| 78 | . I $D(REQ("QPD")) S ERR="QPD^1^4"_ERR Q ;QBP query flag the QPD
|
---|
| 79 | . I $D(REQ("QRD")) S ERR="QRD^1^10"_ERR Q ;old style query flag QRD
|
---|
| 80 | . S ERR="MSH^1^9"_ERR ;not a query flag MSH
|
---|
| 81 | . Q
|
---|
| 82 | Q 1
|
---|
| 83 | ;
|
---|