Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSBRPC1

PSBRPC1.m

Go to the documentation of this file.
  1. PSBRPC1 ;BIRMINGHAM/VN - BCMA RPC BROKER CALLS ;12/3/12 1:17pm
  1. ;;3.0;BAR CODE MED ADMIN;**42,70**;Mar 2004;Build 101
  1. ;
  1. ; Reference/IA
  1. ; ^%ZIS/812
  1. ; ^XUSEC/10076
  1. ; File 200/10060
  1. ;
  1. ;*70 - Add new RPC at tag MEDSONPT, to return true/false flags for 3
  1. ; key med types and actions: IV Infusing, IV Stopped, and
  1. ; Patch on not removed.
  1. ; - add Tags to perform Witness verification, RPC:PSB WITNESS
  1. ;
  1. DEVICE(RESULTS,FROM,DIR) ;
  1. ;
  1. ; RPC: PSB DEVICE
  1. ;
  1. ; Return a subset of entries from the Device file
  1. ;
  1. ; .LST(n)=IEN;Name^DisplayName^Location^RMar^PLen
  1. ; FROM=text to $O from, DIR=$O direction
  1. K RESULTS
  1. N I,IEN,SHOW,X S I=0,CNT=20
  1. I FROM["<" S FROM=$RE($P($RE(FROM),"< ",2))
  1. F Q:I'<CNT S FROM=$O(^%ZIS(1,"B",FROM),DIR) Q:FROM="" D
  1. . S IEN=0 F S IEN=$O(^%ZIS(1,"B",FROM,IEN)) Q:'IEN D
  1. .. N X0,X1,X90,X91,X95,XTYPE,XSTYPE,XTIME,%A,%X,POP
  1. .. Q:'$D(^%ZIS(1,IEN,0))
  1. .. S X0=$G(^%ZIS(1,IEN,0)),X1=$G(^(1)),X90=$G(^(90)),X91=$G(^(91)),X95=$G(^(95)),XSTYPE=$G(^("SUBTYPE")),XTIME=$G(^("TIME")),XTYPE=$G(^("TYPE"))
  1. .. I $E($G(^%ZIS(2,+XSTYPE,0)))'="P" Q ;Printers only
  1. .. S X=$P(XTYPE,"^") ;Device Types
  1. .. I $G(DUZ("AG"))="V",X'="TRM",X'="HG",X'="HFS",X'="CHAN" Q
  1. .. I $G(DUZ("AG"))="I",X'="OTH" Q
  1. .. S X=X0 I ($P(X,U,2)="0")!($P(X,U,12)=2) Q ;Queuing allowed
  1. .. S X=+X90 I X,(X'>DT) Q ;Out of Service
  1. .. I XTIME]"" S %A=$P(XTIME,"^"),%X=$P($H,",",2),%=%X\60#60+(%X\3600*100),%X=$P(%A,"-",2) I %X'<%A&(%'>%X&(%'<%A))!(%X<%A&(%'<%A!(%'>%X))) Q ;Prohibited Times
  1. .. S POP=0
  1. .. I X95]"" S %X=$G(DUZ(0)) I %X'="@" S POP=1 F %A=1:1:$L(%X) I X95[$E(%X,%A) S POP=0 Q
  1. .. Q:POP ;Security check
  1. .. S SHOW=$P(X0,U) I SHOW'=FROM S SHOW=FROM_" <"_SHOW_">"
  1. .. S I=I+1,RESULTS(I)=IEN_";"_$P(X0,U)_U_SHOW_U_$P(X1,U)_U_$P(X91,U)_U_$P(X91,U,3)
  1. .. S RESULTS(0)=I
  1. I '$D(RESULTS(0)) S RESULTS(0)=1,RESULTS(1)="-1^No printers on file"
  1. Q
  1. ;
  1. GPROV(RESULTS,DUMMY) ;
  1. K ^TMP("PSB",$J)
  1. S RESULTS=$NAME(^TMP("PSB",$J)),PSBCNT=1,^TMP("PSB",$J,0)=0
  1. D NOW^%DTC
  1. S X="" F S X=$O(^XUSEC("PROVIDER",X)) Q:X="" D
  1. .S PSBIACT=$$GET1^DIQ(200,X_",",53.4,"I") I PSBIACT'="",+PSBIACT'<% Q ;if Inactive date and date is less than now Q
  1. .S PSBTERM=$$GET1^DIQ(200,X_",",9.2,"I") I PSBTERM'="",+PSBTERM'<% Q ;if termination date and date is less than now Q
  1. .Q:'$$GET1^DIQ(200,X_",",53.1,"I") ;is authorized to write med orders
  1. .Q:'$$GET1^DIQ(200,X_",",53.2) ;must have DEA#
  1. .S ^TMP("PSBL",$J,$$GET1^DIQ(200,X_",",.01),X)=""
  1. S X="^TMP(""PSBL"","_$J_")",PSBCNT=1,^TMP("PSB",$J,0)=0
  1. F S X=$Q(@X) Q:$QS(X,1)'="PSBL" S ^TMP("PSB",$J,PSBCNT)=$QS(X,3)_"^"_$QS(X,4),^TMP("PSB",$J,0)=PSBCNT,PSBCNT=PSBCNT+1
  1. K ^TMP("PSBL",$J),PSBIACT,PSBTERM,PSBAUTH,PSBCNT,DUMMY
  1. Q
  1. ;
  1. ;*70 new tag below attached to RPC: PSB MEDS ON PATIENT
  1. MEDSONPT(RESULTS,DFN) ; Return indicators for 3 types of meds on the patient
  1. S RESULTS(0)=1
  1. S $P(RESULTS(1),U,1)=$$INFUSING^PSBVDLU1(DFN) ;IV's infusing flag
  1. S $P(RESULTS(1),U,2)=$$STOPPED^PSBVDLU1(DFN) ;IV's stopped flag
  1. S $P(RESULTS(1),U,3)=$$PATCHON^PSBVDLU1(DFN) ;patch on flag
  1. Q
  1. ;
  1. WITNESS(RESULTS,PSBACC,PSBVER) ; Validate a witness to a BCMA action ;*70
  1. ;
  1. ; RPC: PSB WITNESS
  1. ; Descr: RPC for validating Acces and Verify codes for a Witness
  1. ; Used by: frmWitness to validate an witness(s) at the client via
  1. ; encrypted A/V Code.
  1. ;
  1. N LOGPERS,WITNESS,GUIIEN,PSBGUI,ERR
  1. S PSBACC=$$DECRYP^XUSRB1(PSBACC)
  1. S PSBVER=$$DECRYP^XUSRB1(PSBVER)
  1. S PSBWITN=$$CHECKAV^XUSRB(PSBACC_";"_PSBVER)
  1. ;
  1. ; valid ACC & VER code test
  1. I PSBWITN<1 D WITERR("Invalid Witness sign-on") K PSBWITN Q
  1. ;
  1. ; authorized tests
  1. I $D(^XUSEC("PSB STUDENT",PSBWITN)) D Q
  1. . D WITERR("A student does not have authority to witness a High Risk/High Alert administration.")
  1. I $D(^XUSEC("PSB NO WITNESS",PSBWITN)) D Q
  1. . D WITERR("You do not have authority to witness a High Risk/High Alert administration.")
  1. I $D(^XUSEC("PSB READ ONLY",PSBWITN)) D Q
  1. . D WITERR("Read-Only users do not have authority to witness a High Risk/High Alert administration.")
  1. I DUZ=PSBWITN D WITERR("Cannot Witness for yourself") K PSBWITN Q
  1. ;** workaround bug in kernel XQCHK, if fixed remove logic ref to
  1. ;** checking "AP" xref and quits thereof
  1. N ACCESS
  1. S ACCESS=$$ACCESS^XQCHK(PSBWITN,"PSB GUI CONTEXT - USER")
  1. I ACCESS="N" D Q
  1. . D WITERR("Invalid VistA user - No Primary menu setup for this user in the NEW PERSON file.")
  1. ;
  1. ;Code with ;** comments are extra checks to work around a bug in the
  1. ;Kernel API used above, and can be removed when this API is fixed.
  1. I +ACCESS<1 D Q:ERR ;can be 0 or negative
  1. . S ERR=1 ;**
  1. . S PSBGUI=$O(^DIC(19,"B","PSB GUI CONTEXT - USER","")) ;**
  1. . I $D(^VA(200,"AP",PSBGUI,PSBWITN)) S ERR=0 Q ;**
  1. . D WITERR("A non-BCMA user does not have authority to witness a High Risk/High Alert administration.")
  1. ;
  1. ;error - instructor trying to witness for their student, is handled
  1. ; by the gui client.
  1. ;
  1. ; passed all tests
  1. S PSBWITN(0)=$$GET1^DIQ(200,PSBWITN_",",.01)
  1. S RESULTS(0)=PSBWITN_U_PSBWITN(0)
  1. Q
  1. ;
  1. WITERR(MSG) ;build witness error msg ;*70
  1. S RESULTS(0)="-1^"_MSG
  1. K PSBWITN
  1. Q