source: FOIAVistA/trunk/r/CMOP-PSX/PSXRSYU.m@ 1397

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

initial load of FOIAVistA 6/30/08 version

File size: 4.6 KB
Line 
1PSXRSYU ;BIR/WPB,BAB-CMOP SYSTEM File Utility ;09 SEP 1998 6:48 AM
2 ;;2.0;CMOP;**1,18,41**;11 Apr 97
3BATCH ;sets up the variables and makes the entry to PSX(550.2
4 I $G(PSXRTRN)=1 G EN
5 ;Q:'$D(^TMP($J,"PSX"))
6EN D NOW^%DTC S (PSXTDT,DTTM)=% K %
7 K DD,DO
8 S PSXDUZ=DUZ
9L L +^PSX(550.2,0):600 I '$T S PSXFILE="CMOP Transmission" D RALRT^PSXUTL Q
10F S X=$O(^PSX(550.2,"B","A"),-1)+1 ; later use Julian number for batch name
11 S DIC="^PSX(550.2,",DIC(0)="Z"
12 S DIC("DR")="1////1;2////"_PSOSITE_";3////"_+PSXSYS_";4////"_PSXDUZ_";6////"_DTTM_";17////"_$S($G(PSXCS)=1:"C",1:"N")
13 D FILE^DICN G:$P($G(Y),U,3)'=1 F S PSXBAT=+Y
14 L -^PSX(550.2,0)
15 K DA,DIC,DUOUT,DTOUT,X,Y,DTTM
16 Q
17BATCHNM() ;
18 ;Make batch number as YYJDTHHMMSS where JDT is 3 digit julian date
19 ;make julian date: get current year append 1st month 1st day compute diff from today.
20 N J1,J2,JDT,X1,X2
21 D NOW^%DTC
22 S X1=$E(%,1,3)_"0101",X2=DT+1,JDT=$$FMDIFF^XLFDT(X1,X2,1)
23 ;change sign - to +
24 S JDT=(JDT*-1)
25 ;pad with 0s
26 I $L(JDT)<3 F I=1:1:(3-$L(JDT)) S JDT="0"_JDT
27 S J1=$E(%,2,3),J2=$E(%,9,12),BATCH=J1_JDT_J2
28 K %
29 Q BATCH
30AFTER L +^PSX(550.2,PSXBAT):600 Q:'$T
31 S DA=PSXBAT,DIE="^PSX(550.2,"
32 S DR="1////2" D ^DIE K DA,DIE,DR
33 L -^PSX(550.2,PSXBAT)
34AFTER1 L +^PSX(550,+PSXSYS):600 Q:'$T
35 S DA=+PSXSYS,DIE="^PSX(550,",DR="6////"_PSXBAT D ^DIE K DIE,DA,DR
36 L -^PSX(550,+PSXSYS)
37 Q
38PSXSTAT ;
39 L +^PSX(550,+PSXSYS,0):30 I '$T,$E(IOST)="C" W !!,"The CMOP System file is in use, try again later." S PSXLOCK=1 Q
40 N TSK K DIC,DA,DR,DIE
41 S TSK=$S($G(PSXSTAT)="H":"@",$G(PSXSTAT)="T":$G(PSXZTSK),1:"@")
42 S DA=+PSXSYS
43 S DIE=550,DR="2////^S X=PSXSTAT;9///^S X=TSK"
44 D ^DIE
45 L -^PSX(550,+PSXSYS,0)
46 K PSXSTAT
47 Q
48 ;Called by Taskman to update file 550.2 for transmissions.
49ACK S ZTREQ="@"
50 F YY="PSXBATNM^2","BMSG^4","EMSG^5","ADT^6","PSXSENDR^8","PSXMSGCT^9","PSXRXCT^10","PSXRTRN^11","PSXDIV^12","PSXREF^13" D PIECE^PSXUTL(XMRG,U,YY)
51 ;
52 S PSXSER="S."_XQSOP,PSXXMZ=XQMSG,PSXSTART=BMSG,PSXEND=EMSG
53 S PSXBAT=$O(^PSX(550.2,"B",PSXBATNM,0))
54 ;
55 ;S PSXBAT=$P(XMRG,U,2),ADT=$P(XMRG,U,6),BMSG=$P(XMRG,U,4),EMSG=$P(XMRG,U,5),PSXSENDR=$P(XMRG,U,8),PSXMSGCT=$P(XMRG,U,9),PSXRXCT=$P(XMRG,U,10),PSXRTRN=$P(XMRG,U,11),PSXSER="S."_XQSOP,PSXXMZ=XQMSG
56 ;S PSXDIV=$P(XMRG,U,12),PSXSTART=BMSG,PSXEND=EMSG,PSXREF=$P(XMRG,U,13)
57 D SET^PSXSYS S PSXSYST=+PSXSYS
58 S ZX=$$KSP^XUPARAM("INST"),DIC="4",DIC(0)="OMXZ",X=ZX D ^DIC S PSXSITE=$P(Y,"^",2) K DIC,X,Y
59 L +^PSX(550.2,PSXBAT):600 Q:'$T
60 K DA,DIE,DR
61 S DA=PSXBAT,DIE="^PSX(550.2,",DR="1////3;7////"_ADT D ^DIE K DA,DIE,DR
62 L -^PSX(550.2,PSXBAT)
63 S:$P($G(^PSX(550.2,PSXBAT,1)),U,3)'="" PSXRTRN=1
64 K XMZ
65 I $P(XMRG,U,1)="$$ACKN" S PSXFLAG=3 D EN^PSXNOTE S XMSER=PSXSER,XMZ=PSXXMZ D REMSBMSG^XMA1C K ADT G EX1
66 G:$P(XMRG,U,1)="$$VACK" ACKN^PSXRXQU
67EX1 K PSXBAT,ADT,BMSG,EMSG,PSXSENDR,PSXMSGCT,PSXRXCT,PSXRTRN,PSXSER,PSXDIV,PSXSTART,PSXEND,PSXREF,PSXFLAG Q
68ACT ;actives/inactivates the systems status in PSX(550
69 S SYSTEM=$P(XMRG,U,3),STAT=$P(XMRG,U,2),DTTM=$P(XMRG,U,4),NAME=$P(XMRG,U,5),OLDDTTM=$P(XMRG,U,6),XMSER="S."_XQSOP,TXMZ=XQMSG,OFF=$P(XMRG,U,7),ZTREQ="@"
70 I (STAT="A")!(STAT="I") D
71 .S RESP=$S(STAT="A":"A",STAT="I":"D",1:"")
72 .L +^PSX(550,SYSTEM):DTIME Q:'$T
73 .S DA=SYSTEM,DIE="^PSX(550,",DR="1////"_STAT D ^DIE K DIE,DA
74 .F RECD=0:0 S RECD=$O(^PSX(550,"AC",RECD)) Q:RECD'>0 S RC=RECD,TYPE=$P($G(^PSX(550,SYSTEM,1,RC,0)),U,1) I TYPE=OLDDTTM S DA(1)=SYSTEM,DA=RC,DIE="^PSX(550,"_SYSTEM_",1,",DR="2////"_DTTM_";3////"_RESP_";4////"_STAT D ^DIE K DIE,DA,DR,X
75 .L -^PSX(550,SYSTEM)
76 I STAT="D" D
77 .L +^PSX(550,SYSTEM):DTIME Q:'$T
78 .F RECD=0:0 S RECD=$O(^PSX(550,"AC",RECD)) Q:RECD'>0 S RC=RECD,TYPE=$P($G(^PSX(550,SYSTEM,1,RC,0)),U,1) Q:TYPE'=OLDDTTM S DA(1)=SYSTEM,DA=RC,DIE="^PSX(550,"_SYSTEM_",1,",DR="2////"_DTTM_";3////N" D ^DIE K DIE,DA,DR,X
79 .L -^PSX(550,SYSTEM)
80 K RECD,RC
81 S SYS=$P($G(^PSX(550,SYSTEM,0)),U,1)
82 D GRP^PSXNOTE
83 S XQAMSG=$S(STAT="A":"Permission to transmit to "_SYS_" has been received.",STAT="I":"Permission to transmit to "_SYS_" has been denied.",1:"") D GRP1^PSXNOTE,SETUP^XQALERT
84 S Y=DTTM X ^DD("DD") S DTTM=Y
85 S XMZ=$G(TXMZ),XMSER="S.PSXX CMOP SERVER" D:$G(XMZ)>0 REMSBMSG^XMA1C K XMZ,XMSER
86 Q:$G(STAT)="D"
87MSG S XMSUB=($S(STAT="A":"CMOP Activation Approved",STAT="I":"CMOP Activation Disapproved",1:"")),LCNT=6,XMDUZ=.5
88 D XMZ^XMA2 G:XMZ<1 MSG
89 S ^XMB(3.9,XMZ,2,1,0)="Request to activate CMOP processing."
90 S ^XMB(3.9,XMZ,2,2,0)=""
91 S ^XMB(3.9,XMZ,2,3,0)="CMOP : "_SYS
92 S ^XMB(3.9,XMZ,2,4,0)="Approving Official: "_$P(NAME,",",2)_" "_$P(NAME,",",1)
93 S ^XMB(3.9,XMZ,2,5,0)="Action Date/Time : "_$P(DTTM,":",1,2)
94 S ^XMB(3.9,XMZ,2,6,0)="Action : "_$S(STAT="A":"Approved",STAT="I":"Disapproved",1:"")
95 S ^XMB(3.9,XMZ,2,0)="^3.92A^"_LCNT_U_LCNT_U_DT,XMDUN="CMOP MANAGER"
96 K XMY S XMDUZ=.5
97 D GRP^PSXNOTE,ENT1^XMD
98 Q
Note: See TracBrowser for help on using the repository browser.