source: WorldVistAEHR/trunk/r/E_CLAIMS_MGMT_ENGINE-BPS/BPSECMC2.m@ 1361

Last change on this file since 1361 was 613, checked in by George Lilly, 15 years ago

initial load of WorldVistAEHR

File size: 4.8 KB
Line 
1BPSECMC2 ;BHAM ISC/SAB - ENTER/EDIT OUTPATIENT SITE PARAMETERS ;09/18/92 9:11
2 ;;1.0;E CLAIMS MGMT ENGINE;**1,2,5**;JUN 2004;Build 45
3 ;;Per VHA Directive 2004-038, this routine should not be modified.
4 ;
5 ; CHOP - Final processing prio to submitting a claim to HL7;
6 ; Input
7 ; HLA - HL7 packet (local array)
8 ; CLAIMIEN - BPS Claims
9 ; IEN59 - BPS Transactions
10CHOP(HLA,CLAIMIEN,IEN59) ;
11 ;
12 N TCNT,CNT,RNLNGTH,TRANID,V2DTG,RTN,MSG
13 N BPSRESLT,HL
14 S CNT=0,RTN=$T(+0)
15 ;
16 ; Crash proofing - Need to put better error handling in
17 I '$D(HLA)!'$L($G(CLAIMIEN)) D ERROR^BPSOSU(RTN,IEN59,511,"Invalid Claim Data") Q
18 ;
19 ; Initialize HL7 environment
20 D INIT^HLFNC2("BPS ECMECL1 NTE",.HL)
21 ;
22 ; Handle failure if variables were not initialized
23 I $G(HL) D ERROR^BPSOSU(RTN,IEN59,512,"Call to INIT^HLFNC2 failed") Q
24 ;
25 ; Determine run length of the transmission & pad with zeroes
26 S RNLNGTH=0
27 F TCNT=1:1 Q:$G(HLA("HLS",TCNT))="" S RNLNGTH=RNLNGTH+$L(HLA("HLS",TCNT))
28 S RNLNGTH=$RE($E($RE("0000"_(RNLNGTH+32)),1,4))
29 S CNT=TCNT-1
30 ;
31 S TRANID=$P($G(^BPSC(CLAIMIEN,0)),"^")
32 S HLA("HLS",1)="\X02\"_RNLNGTH_TRANID_$G(HLA("HLS",1))
33 ;
34 ; Translate non-printable to printable & Set OBX segs
35 F TCNT=1:1:CNT Q:$G(HLA("HLS",TCNT))="" D
36 . F D Q:$P(HLA("HLS",TCNT),$C(29))=HLA("HLS",TCNT)
37 .. S:HLA("HLS",TCNT)[$C(29) HLA("HLS",TCNT)=$P(HLA("HLS",TCNT),$C(29))_"\X1D\"_$P(HLA("HLS",TCNT),$C(29),2,999)
38 . F D Q:$P(HLA("HLS",TCNT),$C(30))=HLA("HLS",TCNT)
39 .. S:HLA("HLS",TCNT)[$C(30) HLA("HLS",TCNT)=$P(HLA("HLS",TCNT),$C(30))_"\X1E\"_$P(HLA("HLS",TCNT),$C(30),2,999)
40 . F D Q:$P(HLA("HLS",TCNT),$C(28))=HLA("HLS",TCNT)
41 .. S:HLA("HLS",TCNT)[$C(28) HLA("HLS",TCNT)=$P(HLA("HLS",TCNT),$C(28))_"\X1C\"_$P(HLA("HLS",TCNT),$C(28),2,999)
42 . I TCNT=CNT S HLA("HLS",CNT)=$P(HLA("HLS",CNT),$C(3))_"\X03\"
43 . S HLA("HLS",TCNT)="OBX||FT|NCPDP|"_TCNT_"|"_HLA("HLS",TCNT)_"||||||F"
44 ;
45 ; Set OBR seg
46 ; Get fileman date/time, ensuring seconds are included: 3031029.135636
47 S V2DTG=$E($$HTFM^XLFDT($H)_"000000",1,14)
48 ;
49 ; Set HL7 Date/Time format: 20031029135636-0400
50 S HLA("HLS",.5)="OBR||||NCPDP|||"_$$FMTHL7^XLFDT(V2DTG)_"|||||||||||"_$E(TRANID,1,32)
51 K HLA("HLS",0)
52 ;
53 ; Change status to 60 and call HL7 to transmit a single message
54 D SETSTAT^BPSOSU(IEN59,60)
55 D GENERATE^HLMA("BPS ECMESV1 NTE","LM",1,.BPSRESLT,"")
56 ;
57 ; If error, log error and quit
58 I +BPSRESLT'>0 D Q
59 . S MSG="HL7 error for "_$P($G(^BPSC(CLAIMIEN,0)),U)_". Error message-"_$P(BPSRESLT,U,3)_"-Error code: "_+$P(BPSRESLT,U,2)
60 . D ERROR^BPSOSU(RTN,IEN59,601,MSG)
61 ;
62 ; If successful, log message
63 ; Needed for Turn-Around Stats - Do NOT delete/alter!!
64 D LOG^BPSOSL(IEN59,RTN_"-Claim Sent - "_$P($G(^BPSC(CLAIMIEN,0)),U))
65 ;
66 ; Update Transmitted On field in BPS Claim
67 N FDA,MSG
68 S FDA(9002313.02,CLAIMIEN_",",.05)=$$NOW^XLFDT
69 D FILE^DIE("","FDA","MSG")
70 ;
71 ; If filing did not work, log it
72 I $D(MSG) D LOG^BPSOSL(IEN59,$T(+0)_"-Failed to update Transmitted On field")
73 Q
74 ;
75 ; STORESP - The HL7 Response Processing Routine calls this procedure. This module reads the
76 ; the information and stores it into BPS Responses
77 ; Note the code below assumes that there will only be one Claim per Transaction.
78 ; If the VA ever bundles multiple transactions into a single claim, the code
79 ; below will need to be change to walk the AE/AER index to handle each transaction
80 ;
81 ; HLNODE and HLNEXT are 'passed-in' by the HL7 application
82STORESP ;
83 ;
84 ; Initialize variables
85 N RI,TMSG,RMSG,RESPIEN,TRANTYPE,VANUM,CLAIMIEN,IEN59
86 ;
87 ; Get the OBX segment
88 S TMSG=""
89 F RI=1:1 X HLNEXT Q:HLNODE="" I $E(HLNODE,1,3)="OBX" D
90 . S TMSG=HLNODE,RMSG=""
91 . F S RMSG=$O(HLNODE(RMSG)) Q:RMSG="" S TMSG=TMSG_HLNODE(RMSG)
92 ;
93 ; Strip off HL7, STX, ETX, NTE, and Byte Count
94 S TMSG=$P(TMSG,$E(TMSG,4),6),TMSG=$E(TMSG,10,$L(TMSG)-5)
95 ;
96 ; Get the claim ID (external and internal)
97 S TRANTYPE=$E(TMSG,35,36),VANUM=$E(TMSG,1,32)
98 S CLAIMIEN=$O(^BPSC("B",VANUM,""))
99 ;
100 ; Using the Claim ID, get the BPS transaction IEN
101 ; If CLAIMIEN is null, next line will crash ungracefully
102 ; We should log an error, but we need the Transaction IEN to
103 ; do so. So, the next best thing is to log an error in the error
104 ; trap.
105 S IEN59=$O(^BPST("AE",CLAIMIEN,""))
106 I IEN59="" S IEN59=$O(^BPST("AER",CLAIMIEN,""))
107 ;
108 ; Update the status to 70 (Receiving Response)
109 D SETSTAT^BPSOSU(IEN59,70)
110 ;
111 ; Store the response in BPS Response
112 D LOG^BPSOSL(IEN59,$T(+0)_"-Parsing Response "_$P($G(^BPSC(CLAIMIEN,0)),U))
113 ;
114 ; Parse the response and store it into BPS Responses
115 ; If the testing tool is on, BPSECMPS will need variable TRANTYPE as well
116 D PARSE^BPSECMPS(TMSG,CLAIMIEN,.RESPIEN)
117 ;
118 ; Log that parsing is done
119 ; Needed for Turn-Around Stats - Do NOT delete/alter!!
120 D LOG^BPSOSL(IEN59,$T(+0)_"-Response stored "_$P($G(^BPSC(CLAIMIEN,0)),U))
121 ;
122 ; Call BPSOSQL for final processing
123 D ONE^BPSOSQL(CLAIMIEN,$G(RESPIEN))
124 Q
Note: See TracBrowser for help on using the repository browser.