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

PRCPSSQA.m

Go to the documentation of this file.
  1. PRCPSSQA ;WISC/CC-Enter/edit privileged secondary IP users ;04/01
  1. V ;;5.1;IFCAP;**24**;Oct 20, 2000
  1. ;Per VHA Directive 10-93-142, this routine should not be modified.
  1. Q
  1. ;
  1. AC ;I 'application coordinator W "You do not have access to this option" Q
  1. I '$$KEY^PRCPUREP("PRCPAQOH",DUZ) D EN^DDIOL("You are not authorized to give staff access to replace quantities.") Q
  1. ;
  1. N D,D0,D1,DA,DIC,DIDEL,DIE,DIK,DLAYGO,DQ,DR,INVPT,PRCF,PRCPPRIV,USER,X,Y,%
  1. ; ask site
  1. S %=0 F I="FY","PARAM","PER","QTR","SITE" I '+$G(PRC(I)) S %=1 Q
  1. I % S PRCF("X")="S" D ^PRCFSITE I '+$G(PRC("SITE")) K PRC,PRCP Q
  1. ;
  1. ; ask inventory point
  1. I '$D(PRCP("DPTYPE")) S PRCP("DPTYPE")="S"
  1. S DIC="^PRCP(445,",DIC(0)="AEQMOZ"
  1. S DIC("S")="I +^(0)=PRC(""SITE"")"
  1. S DIC("S")=DIC("S")_",PRCP(""DPTYPE"")[$P(^PRCP(445,+Y,0),U,3)"
  1. S DIC("A")="Select Secondary Inventory Point: "
  1. S D="C",PRCPPRIV=1
  1. D IX^DIC K PRCPPRIV,DIC
  1. I Y<0 K PRC,PRCP Q
  1. S INVPT=Y Q:'$G(INVPT)
  1. I PRCP("DPTYPE")'="S" Q
  1. I '$D(^PRCP(445,+INVPT,0)) Q
  1. I $P($G(^PRCP(445,+INVPT,5)),"^",1)']"" D EN^DDIOL("This secondary is not linked to a supply station") Q
  1. ;
  1. L +^PRCP(445,+INVPT,8):3 I $T=0 D EN^DDIOL("The authorized user file is busy. Please try again later.") Q
  1. ;
  1. ; purge inappropriate users
  1. S USER=0
  1. F S USER=$O(^PRCP(445,+INVPT,8,USER)) Q:'+USER D
  1. . S X=USER D CHK(+INVPT,.X) I X="" D
  1. . . D EN^DDIOL("Removing "_$P(^VA(200,USER,0),"^")_".....")
  1. . . S DIK="^PRCP(445,"_+INVPT_",8,",DA(1)=+INVPT,DA=+USER D ^DIK K DIK
  1. . . W "User DELETED !"
  1. ;
  1. USERS ; ask users
  1. I '$D(^PRCP(445,+INVPT,0)) D EN^DDIOL("This inventory point is not on file") Q
  1. I '$D(^PRCP(445,+INVPT,8,0)) S ^(0)="^445.026P^^"
  1. S DIC(0)="AEMQO"
  1. S DA=+INVPT,(DIC,DIE)="^PRCP(445,",DIDEL=445,DR=26,PRCPPRIV=1
  1. D ^DIE K PRCPPRIV,DIC,DIE
  1. Q
  1. ;
  1. ;
  1. ; invoked from this routine and input transform of .01 field in file 445.026
  1. CHK(INVPT,USER) ; verify user has proper qualifications
  1. ; INVPT is the ien to file 445 (Inventory Point)
  1. ; USER is the ien to file 200
  1. ;
  1. I $P($G(^VA(200,USER,0)),"^",11),$P(^(0),"^",11)<DT D EN^DDIOL("You cannot ADD a terminated user.") S USER="" Q
  1. I '$D(^PRCP(445,INVPT,4,USER)) D EN^DDIOL("User has no access to this inventory point. Contact the manager.") S USER="" Q
  1. I '$$KEY^PRCPUREP("PRCP2 MGRKEY",USER) S USER="" D EN^DDIOL("User needs the PRCP2 MGRKEY.") Q
  1. I '$$KEY^PRCPUREP("PRCPSSQOH",USER) S USER="" D EN^DDIOL("User needs the PRCPSSQOH key.") Q
  1. ;
  1. EXIT L -^PRCP(445,+INVPT,8)
  1. Q