| 1 | XMXMSGS2 ;ISC-SF/GMB-Message APIs (cont.) ;03/25/2003  15:04
 | 
|---|
| 2 |  ;;8.0;MailMan;**16**;Jun 28, 2002
 | 
|---|
| 3 | DEL(XMDUZ,XMK,XMZ,XMCNT) ; For many messages, pass in XMCNT; for 1, don't
 | 
|---|
| 4 | XDEL ;
 | 
|---|
| 5 |  I '$G(XMK) S XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,"")) Q:'XMK
 | 
|---|
| 6 |  I XMDUZ'=DUZ,'$$DELETE^XMXSEC(XMDUZ,XMK,XMZ) Q
 | 
|---|
| 7 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 8 |  D ZAPIT(XMDUZ,XMK,XMZ,.XMCNT)
 | 
|---|
| 9 |  D WASTEIT(XMDUZ,XMK,XMZ)
 | 
|---|
| 10 |  Q
 | 
|---|
| 11 | FLTR(XMDUZ,XMK,XMKN,XMZ,XMCNT,XMKTO,XMKNTO) ; Filter message
 | 
|---|
| 12 | XFLTR ;
 | 
|---|
| 13 |  ; XMK    (in) the basket # the message is currently in.  (May be 0 if
 | 
|---|
| 14 |  ;             the message isn't currently in a basket.)
 | 
|---|
| 15 |  ; XMKN   (in) the name of basket XMK
 | 
|---|
| 16 |  ; XMKTO  (out) the basket # this routine decides to put the message in
 | 
|---|
| 17 |  ; XMKNTO (out) the name of basket XMKTO
 | 
|---|
| 18 |  ; This routine decides which basket the message belongs in.
 | 
|---|
| 19 |  ; If this is the same basket it is currently in, it sets XMKTO and
 | 
|---|
| 20 |  ; XMKNTO to the current basket.
 | 
|---|
| 21 |  ; Otherwise, it moves the message (from the current basket) to the
 | 
|---|
| 22 |  ; decided-upon basket and sets XMKTO and XMKNTO to that basket.
 | 
|---|
| 23 |  ; If the message is in the WASTE basket, and no filters are defined,
 | 
|---|
| 24 |  ; it will be moved to the IN basket.
 | 
|---|
| 25 |  I '$G(XMK) D
 | 
|---|
| 26 |  . S XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,""))
 | 
|---|
| 27 |  . S:XMK XMKN=$P(^XMB(3.7,XMDUZ,2,XMK,0),U,1)
 | 
|---|
| 28 |  I XMDUZ=.6,XMK'=.5,'$$MOVE^XMXSEC(XMDUZ,XMZ) Q
 | 
|---|
| 29 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 30 |  I $D(^XMB(3.7,XMDUZ,15,"AF")) D
 | 
|---|
| 31 |  . N XMZREC
 | 
|---|
| 32 |  . S XMZREC=$G(^XMB(3.9,XMZ,0))
 | 
|---|
| 33 |  . D FILTER^XMTDF(XMDUZ,XMZ,$P(XMZREC,U,1),$P(XMZREC,U,2),.XMKTO,.XMKNTO)
 | 
|---|
| 34 |  . I XMKTO=1,XMK>1 S XMKTO=XMK,XMKNTO=XMKN
 | 
|---|
| 35 |  E  I XMK>1 S XMKTO=XMK,XMKNTO=XMKN
 | 
|---|
| 36 |  E  S XMKTO=1,XMKNTO=$$EZBLD^DIALOG(37005) ; "IN"
 | 
|---|
| 37 |  Q:XMK=XMKTO
 | 
|---|
| 38 |  I XMK D MOVEIT(XMDUZ,XMK,XMZ,XMKTO,.XMCNT) Q
 | 
|---|
| 39 |  D PUTMSG(XMDUZ,XMKTO,XMKNTO,XMZ)
 | 
|---|
| 40 |  Q
 | 
|---|
| 41 | LATER(XMDUZ,XMZ,XMWHEN,XMCNT) ;
 | 
|---|
| 42 | XLATER ;
 | 
|---|
| 43 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 44 |  D LTRADD^XMJMD(XMDUZ,XMZ,XMWHEN)
 | 
|---|
| 45 |  Q
 | 
|---|
| 46 | MOVE(XMDUZ,XMK,XMZ,XMKTO,XMCNT) ;
 | 
|---|
| 47 | XMOVE ;
 | 
|---|
| 48 |  I XMDUZ=.6,'$$MOVE^XMXSEC(XMDUZ,XMZ) Q
 | 
|---|
| 49 |  ; If 2 users are reading the same msg at the same time, one may get an
 | 
|---|
| 50 |  ; abort if tries to save msg to another bskt, if the msg has already
 | 
|---|
| 51 |  ; been moved by the other user.  So this next line makes sure no abort.
 | 
|---|
| 52 |  I '$D(^XMB(3.7,"M",XMZ,XMDUZ,+$G(XMK))) S XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,""))
 | 
|---|
| 53 |  Q:XMK=XMKTO
 | 
|---|
| 54 |  I XMKTO=.5,'$$DELETE^XMXSEC(XMDUZ,"",XMZ) Q  ; Can't save confidential to WASTE bskt.
 | 
|---|
| 55 |  D MOVEIT(XMDUZ,XMK,XMZ,XMKTO,.XMCNT)
 | 
|---|
| 56 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 57 |  Q
 | 
|---|
| 58 | MOVEIT(XMDUZ,XMK,XMZ,XMKTO,XMCNT) ;
 | 
|---|
| 59 |  I XMK D
 | 
|---|
| 60 |  . D COPYIT(XMDUZ,XMK,XMZ,XMKTO,.XMCNT)
 | 
|---|
| 61 |  . D ZAPIT(XMDUZ,XMK,XMZ,.XMCNT)
 | 
|---|
| 62 |  ; The message is not in the user's mailbox
 | 
|---|
| 63 |  E  D PUTMSG(XMDUZ,XMKTO,$P(^XMB(3.7,XMDUZ,2,XMKTO,0),U),XMZ)
 | 
|---|
| 64 |  Q
 | 
|---|
| 65 | NTOGL(XMDUZ,XMK,XMKN,XMZ,XMCNT,XMKTO,XMKNTO) ;
 | 
|---|
| 66 | XNTOGL ;
 | 
|---|
| 67 |  ; If XMK>.5, then it's simple.  Just toggle the 'new' flag.
 | 
|---|
| 68 |  ; If XMK<1, we know the message is not new, and we need to make it new.
 | 
|---|
| 69 |  ; Filter it, but if it filters to the WASTE basket put it in the IN.
 | 
|---|
| 70 |  ; Then make it new.
 | 
|---|
| 71 |  I '$G(XMK) D
 | 
|---|
| 72 |  . S XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,""))
 | 
|---|
| 73 |  . S:XMK XMKN=$P(^XMB(3.7,XMDUZ,2,XMK,0),U,1)
 | 
|---|
| 74 |  I XMK<1 D
 | 
|---|
| 75 |  . I $D(^XMB(3.7,XMDUZ,15,"AF")) D
 | 
|---|
| 76 |  . . N XMZREC
 | 
|---|
| 77 |  . . S XMZREC=$G(^XMB(3.9,XMZ,0))
 | 
|---|
| 78 |  . . D FILTER^XMTDF(XMDUZ,XMZ,$P(XMZREC,U,1),$P(XMZREC,U,2),.XMKTO,.XMKNTO)
 | 
|---|
| 79 |  . . I XMKTO=1,XMK>1 S XMKTO=XMK,XMKNTO=XMKN Q
 | 
|---|
| 80 |  . . I XMKTO<1 S XMKTO=1,XMKNTO=$$EZBLD^DIALOG(37005) ; "IN"
 | 
|---|
| 81 |  . E  I XMK>1 S XMKTO=XMK,XMKNTO=XMKN
 | 
|---|
| 82 |  . E  S XMKTO=1,XMKNTO=$$EZBLD^DIALOG(37005) ; "IN"
 | 
|---|
| 83 |  . Q:XMK=XMKTO
 | 
|---|
| 84 |  . I XMK D MOVEIT(XMDUZ,XMK,XMZ,XMKTO,.XMCNT) Q
 | 
|---|
| 85 |  . D PUTMSG(XMDUZ,XMKTO,XMKNTO,XMZ)
 | 
|---|
| 86 |  E  S XMKTO=XMK,XMKNTO=XMKN
 | 
|---|
| 87 |  I $D(XMCNT) D  Q
 | 
|---|
| 88 |  . N XMFDA
 | 
|---|
| 89 |  . I $$NEW^XMXUTIL2(XMDUZ,XMKTO,XMZ) D
 | 
|---|
| 90 |  . . S XMFDA(3.702,XMZ_","_XMKTO_","_XMDUZ_",",3)="@" ; no longer new
 | 
|---|
| 91 |  . . S XMCNT(XMKTO,"DECR")=$G(XMCNT(XMKTO,"DECR"))+1
 | 
|---|
| 92 |  . E  D
 | 
|---|
| 93 |  . . S XMFDA(3.702,XMZ_","_XMKTO_","_XMDUZ_",",3)="1" ; new
 | 
|---|
| 94 |  . . S XMCNT(XMKTO,"INCR")=$G(XMCNT(XMKTO,"INCR"))+1
 | 
|---|
| 95 |  . D FILE^DIE("","XMFDA")
 | 
|---|
| 96 |  . S XMCNT=XMCNT+1
 | 
|---|
| 97 |  I $$NEW^XMXUTIL2(XMDUZ,XMKTO,XMZ) D NONEW^XMXUTIL(XMDUZ,XMKTO,XMZ) Q
 | 
|---|
| 98 |  D MAKENEW^XMXUTIL(XMDUZ,XMKTO,XMZ)
 | 
|---|
| 99 |  Q
 | 
|---|
| 100 | TERM(XMDUZ,XMK,XMZ,XMCNT) ;
 | 
|---|
| 101 | XTERM ;
 | 
|---|
| 102 |  N XMIEN
 | 
|---|
| 103 |  S:'$G(XMK) XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,""))
 | 
|---|
| 104 |  I XMDUZ'=DUZ,'$$DELETE^XMXSEC(XMDUZ,XMK,XMZ) Q
 | 
|---|
| 105 |  I XMK D
 | 
|---|
| 106 |  . D ZAPIT(XMDUZ,XMK,XMZ,.XMCNT)
 | 
|---|
| 107 |  . D WASTEIT(XMDUZ,XMK,XMZ)
 | 
|---|
| 108 |  S XMIEN=+$O(^XMB(3.9,XMZ,1,"C",XMDUZ,0))
 | 
|---|
| 109 |  S:XMIEN ^XMB(3.9,XMZ,1,XMIEN,"D")=DT
 | 
|---|
| 110 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 111 |  Q
 | 
|---|
| 112 | VAPOR(XMDUZ,XMK,XMZ,XMWHEN,XMCNT) ;
 | 
|---|
| 113 | XVAPOR ;
 | 
|---|
| 114 |  I '$G(XMK) S XMK=$O(^XMB(3.7,"M",XMZ,XMDUZ,"")) Q:'XMK
 | 
|---|
| 115 |  I XMDUZ'=DUZ,'$$DELETE^XMXSEC(XMDUZ,XMK,XMZ) Q
 | 
|---|
| 116 |  S:$D(XMCNT) XMCNT=XMCNT+1
 | 
|---|
| 117 |  D KVAPOR^XMXUTIL(XMDUZ,XMK,XMZ,XMWHEN)
 | 
|---|
| 118 |  Q
 | 
|---|
| 119 | PUTMSG(XMDUZ,XMK,XMKN,XMZ) ; For internal MM use only.
 | 
|---|
| 120 |  ; Replaces SETSB^XMA1C, SET^XMS1, & part of MAIL^XMR0B
 | 
|---|
| 121 |  ; Put a msg in the Postmaster's (or anyone else's) basket.
 | 
|---|
| 122 |  ; The msg is NOT made new.
 | 
|---|
| 123 |  ; The basket has a specific name and number.
 | 
|---|
| 124 |  ; If the basket doesn't exist, create it.
 | 
|---|
| 125 |  ; XMK      Basket number
 | 
|---|
| 126 |  ; XMKN     Basket name
 | 
|---|
| 127 |  ; XMZ      Msg number
 | 
|---|
| 128 |  N XMFDA,XMIEN,XMTRIES
 | 
|---|
| 129 |  Q:$D(^XMB(3.7,XMDUZ,2,XMK,1,XMZ,0))
 | 
|---|
| 130 |  I XMDUZ'=.5 D RESURECT(XMDUZ,XMZ)
 | 
|---|
| 131 |  I $D(^XMB(3.7,XMDUZ,2,XMK)) D
 | 
|---|
| 132 |  . S XMFDA(3.702,"+1,"_XMK_","_XMDUZ_",",.01)=XMZ
 | 
|---|
| 133 |  . S XMIEN(1)=XMZ
 | 
|---|
| 134 |  E  D
 | 
|---|
| 135 |  . S XMFDA(3.701,"+1,"_XMDUZ_",",.01)=XMKN
 | 
|---|
| 136 |  . S XMFDA(3.702,"+2,+1,"_XMDUZ_",",.01)=XMZ
 | 
|---|
| 137 |  . S XMIEN(1)=XMK
 | 
|---|
| 138 |  . S XMIEN(2)=XMZ
 | 
|---|
| 139 | PTRY D UPDATE^DIE("S","XMFDA","XMIEN") Q:'$D(DIERR)
 | 
|---|
| 140 |  S XMTRIES=$G(XMTRIES)+1
 | 
|---|
| 141 |  I $D(^TMP("DIERR",$J,"E",110)) H 1 G PTRY ; Try again if can't lock
 | 
|---|
| 142 |  Q
 | 
|---|
| 143 | COPYIT(XMDUZ,XMK,XMZ,XMKTO,XMCNT) ;
 | 
|---|
| 144 |  Q:$D(^XMB(3.7,XMDUZ,2,XMKTO,1,XMZ))  ; Message already exists at destination
 | 
|---|
| 145 |  N XMFDA,XMKREC,XMIENS,XMIEN,XMTRIES
 | 
|---|
| 146 |  S XMKREC=^XMB(3.7,XMDUZ,2,XMK,1,XMZ,0)
 | 
|---|
| 147 |  S XMIENS="+1,"_XMKTO_","_XMDUZ_","
 | 
|---|
| 148 |  S XMIEN(1)=XMZ
 | 
|---|
| 149 |  S XMFDA(3.702,XMIENS,.01)=XMZ
 | 
|---|
| 150 |  I XMKTO'=.5 D
 | 
|---|
| 151 |  . I $P(XMKREC,U,3) S XMFDA(3.702,XMIENS,3)=$P(XMKREC,U,3) ; new flag
 | 
|---|
| 152 |  . I '$P(XMKREC,U,7),$P(XMKREC,U,5) S XMFDA(3.702,XMIENS,5)=$P(XMKREC,U,5) ; vapor date
 | 
|---|
| 153 |  S:$P(XMKREC,U,4) XMFDA(3.702,XMIENS,4)=$P(XMKREC,U,4) ; date last accessed
 | 
|---|
| 154 |  S:$P(XMKREC,U,6) XMFDA(3.702,XMIENS,6)=$P(XMKREC,U,6) ; ntwk msg flag
 | 
|---|
| 155 | CTRY D UPDATE^DIE("S","XMFDA","XMIEN")
 | 
|---|
| 156 |  I '$D(DIERR) D  Q
 | 
|---|
| 157 |  . I XMK=.5 D RESURECT(XMDUZ,XMZ) Q
 | 
|---|
| 158 |  . Q:'$G(XMFDA(3.702,XMIENS,3))  ; quit if not new
 | 
|---|
| 159 |  . I $D(XMCNT) S XMCNT(XMKTO,"INCR")=$G(XMCNT(XMKTO,"INCR"))+1 Q
 | 
|---|
| 160 |  . D INCRNEW^XMXUTIL(XMDUZ,XMKTO) ; Increment new counts
 | 
|---|
| 161 |  S XMTRIES=$G(XMTRIES)+1
 | 
|---|
| 162 |  I $D(^TMP("DIERR",$J,"E",110)) H 1 G CTRY ; Try again if can't lock
 | 
|---|
| 163 |  Q
 | 
|---|
| 164 | RESURECT(XMDUZ,XMZ) ; If msg was terminated, "unterminate" it.
 | 
|---|
| 165 |  N XMIEN
 | 
|---|
| 166 |  S XMIEN=+$O(^XMB(3.9,XMZ,1,"C",XMDUZ,0))
 | 
|---|
| 167 |  K:$D(^XMB(3.9,XMZ,1,XMIEN,"D")) ^XMB(3.9,XMZ,1,XMIEN,"D")
 | 
|---|
| 168 |  Q
 | 
|---|
| 169 | ZAPIT(XMDUZ,XMK,XMZ,XMCNT) ;
 | 
|---|
| 170 |  I $D(^XMB(3.7,XMDUZ,"N0",XMK,XMZ)) D
 | 
|---|
| 171 |  . I $D(XMCNT) S XMCNT(XMK,"DECR")=$G(XMCNT(XMK,"DECR"))+1 Q
 | 
|---|
| 172 |  . D DECRNEW^XMXUTIL(XMDUZ,XMK)
 | 
|---|
| 173 |  N DA,DIK
 | 
|---|
| 174 |  S DA(2)=XMDUZ,DA(1)=XMK,DA=XMZ
 | 
|---|
| 175 |  S DIK="^XMB(3.7,"_XMDUZ_",2,"_XMK_",1,"
 | 
|---|
| 176 |  D ^DIK
 | 
|---|
| 177 |  Q
 | 
|---|
| 178 | WASTEIT(XMDUZ,XMK,XMZ) ;
 | 
|---|
| 179 |  Q:XMK=.5
 | 
|---|
| 180 |  Q:$D(^XMB(3.7,XMDUZ,2,.5,1,XMZ))  ; Already in wastebasket
 | 
|---|
| 181 |  N XMFDA,XMIENS,XMIEN,XMTRIES
 | 
|---|
| 182 |  S XMK=.5
 | 
|---|
| 183 |  D:'$D(^XMB(3.7,XMDUZ,2,.5,0)) MAKEBSKT^XMXBSKT(XMDUZ,.5,$$EZBLD^DIALOG(37004)) ; WASTE
 | 
|---|
| 184 |  S XMIENS="+1,"_XMK_","_XMDUZ_","
 | 
|---|
| 185 |  S XMIEN(1)=XMZ
 | 
|---|
| 186 |  S XMFDA(3.702,XMIENS,.01)=XMZ
 | 
|---|
| 187 |  S XMFDA(3.702,XMIENS,4)=$$NOW^XLFDT  ; date/time last accessed
 | 
|---|
| 188 | WTRY D UPDATE^DIE("S","XMFDA","XMIEN") Q:'$D(DIERR)
 | 
|---|
| 189 |  S XMTRIES=$G(XMTRIES)+1
 | 
|---|
| 190 |  I $D(^TMP("DIERR",$J,"E",110)) H 1 G WTRY ; Try again if can't lock
 | 
|---|
| 191 |  Q
 | 
|---|