XTVSSVR ;ALB/GTS - VistA Package Sizing Manager; 26-FEB-2020
;;7.3;TOOLKIT;**143**;Apr 25, 1995;Build 116
;
SRVREXT ; Entry point - Server Package File extract
; -- Server Option: XTVS PKG EXTRACT SERVER
;
; Message Form:
; REQUESTED BY: {Email address} - Recipient of size report
; Extract Indicator: {0 OR 1} - 0 means no extract; 1 means extract Package file data
; Report Indicator: {1 or 2} - 1 means All Packages Size rpt; 2 means Single Package Size rpt
; Package Parameters: Line 1 is the package parameters for the selected package to report
; followed by parameters for all packages
;
NEW XTVSLN,XMRG,XMY,XMER,XTVSEXTP,XTVSSNDR,XTVSRPTP,XTVSPRML,SELPKGPM,LNITMCT
SET SELPKGPM=""
SET (LNITMCT,XTVSPRML,PARMEXRT)=0
SET XMER=1
FOR Q:XMER<0 X XMREC DO
. IF XMER'<0 DO
.. SET XTVSLN=XMRG
.. IF XTVSLN["REQUESTED BY:" SET XTVSSNDR=$P(XTVSLN,"REQUESTED BY: ",2) ;Addressee for report
.. ;
.. IF XTVSLN["Extract Indicator:" SET XTVSEXTP=+($PIECE($GET(XTVSLN),": ",2)) ;1 - Extract Packages
.. IF XTVSLN["Report Indicator:" SET XTVSRPTP=+($PIECE($GET(XTVSLN),": ",2)) ;1 - All Packages Size rpt; 2 - Single Package Size rpt
.. ;
.. ; Parse out all packages in server message
.. ; If SELPKGPM not = NULL, 1oad XTVSLN into ^TMP("XTVS-FORUMPKG",$J,TMPSUB)
.. IF SELPKGPM]"" SET LNITMCT=LNITMCT+1 SET ^TMP("XTVS-FORUMPKG",$J,LNITMCT)=XTVSLN ; Create Package Parameter Array
.. ;
.. ; If XTVSLN["Package Parameters:", SET SELPKGPM = 2nd piece of "Package Parameters: "
.. IF XTVSLN["Package Parameters:" SET SELPKGPM=$P(XTVSLN,"Package Parameters: ",2) ;The Package Parameters used for Size Rpt
;
IF XTVSEXTP=1 DO EXTPKG(XTVSSNDR,$GET(XTVSRPTP)) ; Extract Package
;
IF $GET(XTVSRPTP)=2 DO
. IF SELPKGPM]"" DO ONEPKGSZ(XTVSSNDR,SELPKGPM) ; Return size report for single package
. IF SELPKGPM="" DO WRERR("SRVREXT^XTVSSVR : Package Size Rpt error","Parameters for a selected package not sent in server request.",XTVSSNDR,"{MISSING PACKAGE NAME}")
;
KILL ^TMP("XTVS-FORUMPKG",$J)
QUIT
;
EXTPKG(XTVSSNDR,XTVSRPTP) ; Extract Package File
;
;Input
; XTVSSNDR - Requesters VA Mailman address
; XTVSRPTP - 1: Create Size Report for all package; Null: No report
;
NEW VPNAME,VPIEN
KILL ^XTMP("XTSIZE",$J)
;NOTE: First pce of 0 node sets ^XTMP purge date 90 days from 'Today'
SET ^XTMP("XTSIZE",$J,0)=$$FMADD^XLFDT($P($$NOW^XLFDT,"."),90)_"^"_$P($$NOW^XLFDT,".")_"^"_$$NOW^XLFDT_"-Kernel ToolKit Package File Extract by "_$S($G(XTVSUNME)]"":XTVSUNME,1:"{unknown user}")_"^"_^%ZOSF("PROD")
;
SET VPIEN=0
FOR SET VPIEN=$ORDER(^DIC(9.4,VPIEN)) QUIT:'VPIEN SET VPNAME=$P($G(^DIC(9.4,VPIEN,0)),"^") IF VPNAME]"" DO
. IF $P($G(^DIC(9.4,VPIEN,15002)),"^",3)'="X" DO ;If CURRENT STATUS '= NO LONGER USED
.. IF VPNAME["""" DO
... SET VPNAME=$REPLACE(VPNAME,"""","''")
... DO NOTCE^XTVSLAPI("Double Quotes changed to 2 single quotes in the "_VPNAME_" Package name.",XTVSSNDR,VPNAME)
.. DO SETXTMP^XTVSLNA1 ;Extract Packages
;
DO EEXT(XTVSSNDR,XTVSRPTP)
QUIT
;
EEXT(XTVSSNDR,XTVSSIZE) ; Email ^XTMP("XTSIZE") extract global
;
NEW XPID,QCHK
SET QCHK=0
SET XPID=$JOB ;Process ID
SET XTVSSIZE=+$GET(XTVSSIZE)
;
IF '$D(^XTMP("XTSIZE",XPID)) DO WRERR("EEXT^XTVSSVR : Package extract error","Extract failed! ^XTMP(""XTSIZE"","_XPID_") not created on Server!",XTVSSNDR,"")
IF $D(^XTMP("XTSIZE",XPID)) DO
. NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB,XDATE
. SET XMDUZ=DUZ
. SET XMY(XTVSSNDR)=""
. SET XMTEXT="^XTMP(""XTSIZE"","_XPID_","
. SET XDATE=$P($P(^XTMP("XTSIZE",XPID,0),"^",3),"-")
. SET XDATE=$$FMTE^XLFDT(XDATE,"1P")
. SET XMSUB="PACKAGE FILE EXTRACT ("_$P(^XTMP("XTSIZE",XPID,0),"^",4)_" ; "_XDATE_" ; $JOB#: "_XPID_")"
. DO ENT^XMPG
. IF +XMZ'>0 DO WRERR("EEXT^XTVSSVR : Package extract error","Error: ^XTMP(""XTSIZE"","_XPID_") not sent in Packman to "_XTVSSNDR_"!",XTVSSNDR,"")
. IF XTVSSIZE=1 DO SIZERPT(XTVSSNDR) ; Create size report for all packages
KILL ^XTMP("XTSIZE",XPID)
;
QUIT
;
WRERR(HDRTEXT,ERRTEXT,XTVSSNDR,PKGNAME) ; Write Server Mail extract send error to Error Trap & return msg to requester
DO APPERROR^%ZTER(HDRTEXT) ;Write error to Error Trap
;
; Send size report request failure message
NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB
KILL ^TMP("XTVS-REMOTE-ERROR",$JOB)
IF PKGNAME]"" DO
. SET ^TMP("XTVS-REMOTE-ERROR",$JOB,1)="Notice for Remote Package size report on "_^%ZOSF("PROD")_"."
. SET ^TMP("XTVS-REMOTE-ERROR",$JOB,2)="Remote size report request FAILED for "_PKGNAME_"."
. SET ^TMP("XTVS-REMOTE-ERROR",$JOB,3)=ERRTEXT
IF PKGNAME']"" DO
. SET ^TMP("XTVS-REMOTE-ERROR",$JOB,1)="Remote package size report on "_^%ZOSF("PROD")_" failed!!"
. SET ^TMP("XTVS-REMOTE-ERROR",$JOB,2)=ERRTEXT
SET XMDUZ=DUZ
SET XMY(XTVSSNDR)=""
SET XMTEXT="^TMP(""XTVS-REMOTE-ERROR"","_$JOB_","
SET XMSUB="PACKAGE SIZE REPORT ("_^%ZOSF("PROD")_") ; remote request FAILED!"
DO ^XMD
IF +XMZ'>0 DO
. SET ERRTEXT="'Failed extract error message' FAILED to return to "_XTVSSNDR_"."
. DO APPERROR^%ZTER("WRERR^XTVSSVR : Package extract error")
KILL ^TMP("XTVS-REMOTE-ERROR",$JOB)
QUIT
;
SIZERPT(XTVSSNDR) ; Create Size Report and return to user
; Requires ^XTMP("XTSIZE")
NEW PKGNMEL1,PKGNMEL2,PKGNMEL3,LNNUM
DO XTMPORD^XTVSLNA1($JOB,0,1) ; Create ^TMP("XTSIZE") Parameter file, Do Not create Change Report arrays, Create ^TMP("XTVS-FORUMPKG",$J)
;
DO KIDSIDX^XTVSRFL1 ;Create Prefix-Package Indicies from KIDS
;
DO TALLYRPT^XTVSRFL(1,1) ; Needs ^TMP("XTVS-FORUMPKG",$J,TMPSUB) and DO KIDSIDX^XTVSRFL1
DO RPTSIZE(XTVSSNDR) ; Set report into Mail Message array
;
KILL ^XTMP("XTSIZE",$J)
KILL ^TMP("XTVS-VPS",$JOB),^TMP("XTVS-FORUMPKG",$JOB),^TMP("XTVS-PREFIX-IDX",$JOB),^TMP("XTVS-FORUM-PFXS",$JOB)
KILL ^TMP("XTVS-VPS0",$JOB),^TMP("XTVS-IDX-PKG",$JOB),^TMP("XTVS-KIDSPFX-IDX",$JOB),^TMP("XTVS-FORUM2TMP",$JOB) ;,^TMP("XTSIZE","IDX",$JOB)
KILL ^TMP("XTVS-FILERPT",$JOB),^TMP("XTSIZE",$JOB),^TMP("XTSIZE","IDX",$JOB),^TMP("XTVS-REMOTE-SIZE",$JOB) ; KILL ^TMP globals
QUIT
;
RPTSIZE(XTVSSNDR) ; Create message with report
NEW LINECNT,RUNDT
SET LINECNT=0
;
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"VistA Application Sizing Information Sort Type: 1")
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Site Domain: "_$P($$NETNAME^XMXUTIL(DUZ),"@",2))
DO NOW^%DTC S Y=X D DD^%DT
SET RNDT=Y
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Run Date: "_RNDT)
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," ")
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Total")
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"Application Rtn")
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"(Namespace) Routines Size Files Fields Options Protocols RPCs Templates")
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"===============================================================================")
;
; Add report lines to display array
NEW PKGNAME,PKGPFX
SET PKGNAME=""
FOR SET PKGNAME=$O(^TMP("XTVS-VPS",$J,PKGNAME)) QUIT:PKGNAME="" SET PKGPFX="" DO
. FOR SET PKGPFX=$O(^TMP("XTVS-VPS",$J,PKGNAME,PKGPFX)) QUIT:PKGPFX="" DO
.. DO PDAD($G(^(PKGPFX)),PKGNAME,PKGPFX,.LINECNT)
;
; Send size report message
NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB
SET XMDUZ=DUZ
SET XMY(XTVSSNDR)=""
SET XMTEXT="^TMP(""XTVS-REMOTE-SIZE"","_$JOB_","
SET XMSUB="PACKAGE SIZE REPORT ("_^%ZOSF("PROD")_" ; "_$$FMTE^XLFDT($$NOW^XLFDT,"1P")_" ; $JOB#: "_$JOB_")"
DO ^XMD
IF +XMZ'>0 DO WRERR("RPTSIZE^XTVSSVR : Package extract error","Error: ^XTMP(""XTVS-REMOTE-SIZE"","_$JOB_") not sent in Packman to "_XTVSSNDR_"!",XTVSSNDR,"ALL Packages")
;
QUIT
;
PDAD(DATA,PKGNAME,PKGPFX,LINECNT) ; Add data to message global
NEW RTOT,TLCNT,FTOT,FLDTOT,OTOT,PTOT,RPTOT,TPLTTOT,DATANDE,SPCT
SET RTOT=+DATA
SET TLCNT=$P(DATA,"^",2)
SET FTOT=$P(DATA,"^",3)
SET FLDTOT=$P(DATA,"^",4)
SET OTOT=$P(DATA,"^",5)
SET PTOT=$P(DATA,"^",6)
SET RPTOT=$P(DATA,"^",7)
SET TPLTTOT=$P(DATA,"^",8)
;
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,PKGNAME)
SET DATANDE=""
SET DATANDE="("_PKGPFX_")"
FOR SPCT=1:1:11-$LENGTH(DATANDE) SET DATANDE=DATANDE_" " ;Space out 2nd data element
SET DATANDE=DATANDE_$J(RTOT,6)_" "_$J(TLCNT,9)_" "_$J(FTOT,4)_" "_$J(FLDTOT,6)_" "_$J(OTOT,6)_" "_$J(PTOT,6)_" "_$J(RPTOT,6)_" "_$J(TPLTTOT,6)
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,DATANDE)
DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"-------------------------------------------------------------------------------")
QUIT
;
ADDLNE(TMPARY,LINECNT,MSG) ; Add line to global
;Input
; TMMPARY - Array name to add a line (Closed root)
; LINECNT - Current array node number
; MSG - Message to add to ListMan Display
;
SET LINECNT=LINECNT+1
SET @TMPARY@($J,LINECNT)=MSG
QUIT
;
; Called by SRVREXT for a single package, SELPKGPM contains package parameters
ONEPKGSZ(XTVSSNDR,SELPKGPM) ; Report Package
;Input
; XTVSSNDR - Requesters VA Mailman address
; SELPKGPM - Selected package parameters
;
NEW PKGNAME,PKGNUM,PKGPFX,PKGERR,PCENUM,PREFIX,ADDPRFX
SET PKGERR=0
KILL ^TMP("XTVS-PREFIX-IDX",$J),^TMP("XTVS-FORUM-PFXS",$J),^TMP("XTVS-IDX-PKG",$J)
;
;Create Prefix Indicies
SET PKGNAME=$P(SELPKGPM,"^")
;
SET PKGPFX=$P(SELPKGPM,"^",2)
IF PKGPFX="" DO
. SET PKGERR=1
. DO WRERR("ONEPKGSZ^XTVSSVR : Package Size Rpt error","PREFIX not found for package selected.",XTVSSNDR,PKGNAME)
IF 'PKGERR DO
. ;
. DO KIDSIDX^XTVSRFL1 ;Create Prefix-Package Indicies from KIDS
. ;
. DO TALLYRPT^XTVSRFL(1,1,PKGNAME) ; Needs ^TMP("XTVS-FORUMPKG",$J,TMPSUB) and DO KIDSIDX^XTVSRFL1
. ;
. DO ONERPT(XTVSSNDR,SELPKGPM,PKGNAME,PKGPFX) ;Report stat's for a single package
;
KILL ^TMP("XTVS-VPS",$JOB),^TMP("XTVS-PREFIX-IDX",$JOB),^TMP("XTVS-FORUM-PFXS",$JOB)
KILL ^TMP("XTVS-VPS0",$JOB),^TMP("XTVS-IDX-PKG",$JOB),^TMP("XTVS-KIDSPFX-IDX",$JOB)
KILL ^TMP("XTVS-FILERPT",$JOB),^TMP("XTSIZE","IDX",$JOB),^TMP("XTVS-REMOTE-SIZE",$JOB)
QUIT
;
ONERPT(XTVSSNDR,SELPKGPM,PKGNAME,PKGPFX) ; Report a single package
;;INPUT:
; XTVSSNDR - Requesting user Email address
; SELPKGPM - Package Parameters (single package)
; PKGNAME - Package name to report
; PKGPFX - Package Prefix
;
NEW Q,PCENUM,ADP,RDP,FTOT,FLDTOT,FFCTRSLT,RTOT,OTOT,PRCTOT,RPTOT,TPLTTOT,PKGIEN,RNDT,TLCNT
NEW PARMDAT,PARMDAT3,PARMDAT4,PARMDAT7,PARMDAT8,LINECNT
SET (PKGIEN,LINECNT)=0
IF PKGNAME["''" DO
. IF $D(^DIC(9.4,"B",$REPLACE(PKGNAME,"''",""""))) SET PKGIEN=$O(^DIC(9.4,"B",$REPLACE(PKGNAME,"''",""""),""))
. IF '$D(^DIC(9.4,"B",$REPLACE(PKGNAME,"''",""""))),$D(^DIC(9.4,"B",PKGNAME)) SET PKGIEN=$O(^DIC(9.4,"B",PKGNAME,""))
IF PKGNAME'["''" SET PKGIEN=+$O(^DIC(9.4,"B",PKGNAME,""))
;
; Piece # on SELPKGPM = node # on ^TMP("XTVS-PARAM-CAP",$J)
;
SET PARMDAT=$P(SELPKGPM,"^",5) ;Additional Prefixes
SET (ADP,Q,PCENUM)=0
FOR SET PCENUM=PCENUM+1 SET Q=$P(PARMDAT,"|",PCENUM) Q:Q="" IF $$MULTX^XTVSRFL1(Q,PKGNAME) SET ADP=ADP+1 SET ADP(ADP)=Q
;
SET PARMDAT=$P(SELPKGPM,"^",6) ;Excepted Prefixes
SET (RDP,Q,PCENUM)=0
FOR SET PCENUM=PCENUM+1 SET Q=$P(PARMDAT,"|",PCENUM) Q:Q="" SET RDP=RDP+1 SET RDP(RDP)=Q
;
; counting files and fields
SET PARMDAT3=$P(SELPKGPM,"^",3) ;*Lowest File#
SET PARMDAT4=$P(SELPKGPM,"^",4) ;*Highest File#
SET PARMDAT7=$P(SELPKGPM,"^",7) ;File Numbers
SET PARMDAT8=$P(SELPKGPM,"^",8) ;File Ranges
SET FFCTRSLT=$$COUNTFLS^XTVSRFL1(PKGPFX,PARMDAT3,PARMDAT4,PARMDAT7,PARMDAT8) ; Count Files^Fields
SET FTOT=$P(FFCTRSLT,"^") ;Extract File ctr
SET FLDTOT=$P(FFCTRSLT,"^",2) ;Extract Field ctr
;
; counting routines
S TLCNT=0
S RTOT=$$ROUTINE^XTVSRFL1(PKGPFX,.TLCNT,.RDP,.ADP)
I ADP F Q=1:1:ADP I ADP(Q)'="" S RTOT=RTOT+$$ROUTINE^XTVSRFL1(ADP(Q),.TLCNT,.RDP,.ADP) ;ADP(Q) added prefixes called individually
;
; counting options
S OTOT=0
D CNTR^XTVSRFL1("^DIC(19,",.OTOT,PKGPFX,.RDP,.ADP)
I ADP F Q=1:1:ADP I ADP(Q)'="" D CNTR^XTVSRFL1("^DIC(19,",.OTOT,ADP(Q),.RDP,.ADP)
;
; counting protocols
S PRCTOT=$$PROTOCOL^XTVSRFL1(PKGPFX,PKGIEN,.RDP)
I ADP F Q=1:1:ADP I ADP(Q)'="" S PRCTOT=PRCTOT+$$PROTOCOL^XTVSRFL1(ADP(Q),PKGIEN,.RDP)
;
; counting remote procedures
S RPTOT=0
D CNTR^XTVSRFL1("^XWB(8994,",.RPTOT,PKGPFX,.RDP,.ADP)
I ADP F Q=1:1:ADP I ADP(Q)'="" D CNTR^XTVSRFL1("^XWB(8994,",.RPTOT,ADP(Q),.RDP,.ADP)
;
; counting edit, print, & sort templates
S TPLTTOT=0
D CNTR^XTVSRFL1("^DIPT(",.TPLTTOT,PKGPFX,.RDP,.ADP) ;Print Templates
I ADP F Q=1:1:ADP I ADP(Q)'="" D CNTR^XTVSRFL1("^DIPT(",.TPLTTOT,ADP(Q),.RDP,.ADP)
;
D CNTR^XTVSRFL1("^DIBT(",.TPLTTOT,PKGPFX,.RDP) ;Sort Templates
I ADP F Q=1:1:ADP I ADP(Q)'="" D CNTR^XTVSRFL1("^DIBT(",.TPLTTOT,ADP(Q),.RDP,.ADP)
;
D CNTR^XTVSRFL1("^DIE(",.TPLTTOT,PKGPFX,.RDP) ;Input Templates
I ADP F Q=1:1:ADP I ADP(Q)'="" D CNTR^XTVSRFL1("^DIE(",.TPLTTOT,ADP(Q),.RDP,.ADP)
;
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," ")
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," VistA Application Sizing Information")
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," ")
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," Site Domain: "_$P($$NETNAME^XMXUTIL(DUZ),"@",2))
DO NOW^%DTC S Y=X D DD^%DT
SET RNDT=Y
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," Run Date: "_RNDT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT," ")
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"VistA Application: "_PKGNAME)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"==================")
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Routines: "_RTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Size of Routines: "_TLCNT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Files: "_FTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Fields: "_FLDTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Options: "_OTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Protocols: "_PRCTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of RPCs: "_RPTOT)
DO ADDLNE("^TMP(""XTVS-REMOTE-RPT"")",.LINECNT,"Number of Templates: "_TPLTTOT)
;
; Send size report message
NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB
SET XMDUZ=DUZ
SET XMY(XTVSSNDR)=""
SET XMTEXT="^TMP(""XTVS-REMOTE-RPT"","_$JOB_","
SET XMSUB="PACKAGE SIZE REPORT ("_^%ZOSF("PROD")_" ; "_$$FMTE^XLFDT($$NOW^XLFDT,"1P")_" ; $JOB#: "_$JOB_")"
DO ^XMD
IF +XMZ'>0 DO WRERR("ONERPT^XTVSSVR : Package extract error","Error: ^XTMP(""XTVS-REMOTE-RPT"") not sent in Packman to "_XTVSSNDR_"!",XTVSSNDR,PKGNAME)
;
QUIT
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HXTVSSVR 14774 printed Apr 09, 2024@21:43:56 Page 2
XTVSSVR ;ALB/GTS - VistA Package Sizing Manager; 26-FEB-2020
+1 ;;7.3;TOOLKIT;**143**;Apr 25, 1995;Build 116
+2 ;
SRVREXT ; Entry point - Server Package File extract
+1 ; -- Server Option: XTVS PKG EXTRACT SERVER
+2 ;
+3 ; Message Form:
+4 ; REQUESTED BY: {Email address} - Recipient of size report
+5 ; Extract Indicator: {0 OR 1} - 0 means no extract; 1 means extract Package file data
+6 ; Report Indicator: {1 or 2} - 1 means All Packages Size rpt; 2 means Single Package Size rpt
+7 ; Package Parameters: Line 1 is the package parameters for the selected package to report
+8 ; followed by parameters for all packages
+9 ;
+10 NEW XTVSLN,XMRG,XMY,XMER,XTVSEXTP,XTVSSNDR,XTVSRPTP,XTVSPRML,SELPKGPM,LNITMCT
+11 SET SELPKGPM=""
+12 SET (LNITMCT,XTVSPRML,PARMEXRT)=0
+13 SET XMER=1
+14 FOR
if XMER<0
QUIT
XECUTE XMREC
Begin DoDot:1
+15 IF XMER'<0
Begin DoDot:2
+16 SET XTVSLN=XMRG
+17 ;Addressee for report
IF XTVSLN["REQUESTED BY:"
SET XTVSSNDR=$PIECE(XTVSLN,"REQUESTED BY: ",2)
+18 ;
+19 ;1 - Extract Packages
IF XTVSLN["Extract Indicator:"
SET XTVSEXTP=+($PIECE($GET(XTVSLN),": ",2))
+20 ;1 - All Packages Size rpt; 2 - Single Package Size rpt
IF XTVSLN["Report Indicator:"
SET XTVSRPTP=+($PIECE($GET(XTVSLN),": ",2))
+21 ;
+22 ; Parse out all packages in server message
+23 ; If SELPKGPM not = NULL, 1oad XTVSLN into ^TMP("XTVS-FORUMPKG",$J,TMPSUB)
+24 ; Create Package Parameter Array
IF SELPKGPM]""
SET LNITMCT=LNITMCT+1
SET ^TMP("XTVS-FORUMPKG",$JOB,LNITMCT)=XTVSLN
+25 ;
+26 ; If XTVSLN["Package Parameters:", SET SELPKGPM = 2nd piece of "Package Parameters: "
+27 ;The Package Parameters used for Size Rpt
IF XTVSLN["Package Parameters:"
SET SELPKGPM=$PIECE(XTVSLN,"Package Parameters: ",2)
End DoDot:2
End DoDot:1
+28 ;
+29 ; Extract Package
IF XTVSEXTP=1
DO EXTPKG(XTVSSNDR,$GET(XTVSRPTP))
+30 ;
+31 IF $GET(XTVSRPTP)=2
Begin DoDot:1
+32 ; Return size report for single package
IF SELPKGPM]""
DO ONEPKGSZ(XTVSSNDR,SELPKGPM)
+33 IF SELPKGPM=""
DO WRERR("SRVREXT^XTVSSVR : Package Size Rpt error","Parameters for a selected package not sent in server request.",XTVSSNDR,"{MISSING PACKAGE NAME}")
End DoDot:1
+34 ;
+35 KILL ^TMP("XTVS-FORUMPKG",$JOB)
+36 QUIT
+37 ;
EXTPKG(XTVSSNDR,XTVSRPTP) ; Extract Package File
+1 ;
+2 ;Input
+3 ; XTVSSNDR - Requesters VA Mailman address
+4 ; XTVSRPTP - 1: Create Size Report for all package; Null: No report
+5 ;
+6 NEW VPNAME,VPIEN
+7 KILL ^XTMP("XTSIZE",$JOB)
+8 ;NOTE: First pce of 0 node sets ^XTMP purge date 90 days from 'Today'
+9 SET ^XTMP("XTSIZE",$JOB,0)=$$FMADD^XLFDT($PIECE($$NOW^XLFDT,"."),90)_"^"_$PIECE($$NOW^XLFDT,".")_"^"_$$NOW^XLFDT_"-Kernel ToolKit Package File Extract by "_$S($GET(XTVSUNME)]"":XTVSUNME,1:"{unknown user}")_"^"_^%ZOSF("PROD")
+10 ;
+11 SET VPIEN=0
+12 FOR
SET VPIEN=$ORDER(^DIC(9.4,VPIEN))
if 'VPIEN
QUIT
SET VPNAME=$PIECE($GET(^DIC(9.4,VPIEN,0)),"^")
IF VPNAME]""
Begin DoDot:1
+13 ;If CURRENT STATUS '= NO LONGER USED
IF $PIECE($GET(^DIC(9.4,VPIEN,15002)),"^",3)'="X"
Begin DoDot:2
+14 IF VPNAME[""""
Begin DoDot:3
+15
*** ERROR ***
SET VPNAME=$REPLACE(VPNAME,"""","''")
+16 DO NOTCE^XTVSLAPI("Double Quotes changed to 2 single quotes in the "_VPNAME_" Package name.",XTVSSNDR,VPNAME)
End DoDot:3
+17 ;Extract Packages
DO SETXTMP^XTVSLNA1
End DoDot:2
End DoDot:1
+18 ;
+19 DO EEXT(XTVSSNDR,XTVSRPTP)
+20 QUIT
+21 ;
EEXT(XTVSSNDR,XTVSSIZE) ; Email ^XTMP("XTSIZE") extract global
+1 ;
+2 NEW XPID,QCHK
+3 SET QCHK=0
+4 ;Process ID
SET XPID=$JOB
+5 SET XTVSSIZE=+$GET(XTVSSIZE)
+6 ;
+7 IF '$DATA(^XTMP("XTSIZE",XPID))
DO WRERR("EEXT^XTVSSVR : Package extract error","Extract failed! ^XTMP(""XTSIZE"","_XPID_") not created on Server!",XTVSSNDR,"")
+8 IF $DATA(^XTMP("XTSIZE",XPID))
Begin DoDot:1
+9 NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB,XDATE
+10 SET XMDUZ=DUZ
+11 SET XMY(XTVSSNDR)=""
+12 SET XMTEXT="^XTMP(""XTSIZE"","_XPID_","
+13 SET XDATE=$PIECE($PIECE(^XTMP("XTSIZE",XPID,0),"^",3),"-")
+14 SET XDATE=$$FMTE^XLFDT(XDATE,"1P")
+15 SET XMSUB="PACKAGE FILE EXTRACT ("_$PIECE(^XTMP("XTSIZE",XPID,0),"^",4)_" ; "_XDATE_" ; $JOB#: "_XPID_")"
+16 DO ENT^XMPG
+17 IF +XMZ'>0
DO WRERR("EEXT^XTVSSVR : Package extract error","Error: ^XTMP(""XTSIZE"","_XPID_") not sent in Packman to "_XTVSSNDR_"!",XTVSSNDR,"")
+18 ; Create size report for all packages
IF XTVSSIZE=1
DO SIZERPT(XTVSSNDR)
End DoDot:1
+19 KILL ^XTMP("XTSIZE",XPID)
+20 ;
+21 QUIT
+22 ;
WRERR(HDRTEXT,ERRTEXT,XTVSSNDR,PKGNAME) ; Write Server Mail extract send error to Error Trap & return msg to requester
+1 ;Write error to Error Trap
DO APPERROR^%ZTER(HDRTEXT)
+2 ;
+3 ; Send size report request failure message
+4 NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB
+5 KILL ^TMP("XTVS-REMOTE-ERROR",$JOB)
+6 IF PKGNAME]""
Begin DoDot:1
+7 SET ^TMP("XTVS-REMOTE-ERROR",$JOB,1)="Notice for Remote Package size report on "_^%ZOSF("PROD")_"."
+8 SET ^TMP("XTVS-REMOTE-ERROR",$JOB,2)="Remote size report request FAILED for "_PKGNAME_"."
+9 SET ^TMP("XTVS-REMOTE-ERROR",$JOB,3)=ERRTEXT
End DoDot:1
+10 IF PKGNAME']""
Begin DoDot:1
+11 SET ^TMP("XTVS-REMOTE-ERROR",$JOB,1)="Remote package size report on "_^%ZOSF("PROD")_" failed!!"
+12 SET ^TMP("XTVS-REMOTE-ERROR",$JOB,2)=ERRTEXT
End DoDot:1
+13 SET XMDUZ=DUZ
+14 SET XMY(XTVSSNDR)=""
+15 SET XMTEXT="^TMP(""XTVS-REMOTE-ERROR"","_$JOB_","
+16 SET XMSUB="PACKAGE SIZE REPORT ("_^%ZOSF("PROD")_") ; remote request FAILED!"
+17 DO ^XMD
+18 IF +XMZ'>0
Begin DoDot:1
+19 SET ERRTEXT="'Failed extract error message' FAILED to return to "_XTVSSNDR_"."
+20 DO APPERROR^%ZTER("WRERR^XTVSSVR : Package extract error")
End DoDot:1
+21 KILL ^TMP("XTVS-REMOTE-ERROR",$JOB)
+22 QUIT
+23 ;
SIZERPT(XTVSSNDR) ; Create Size Report and return to user
+1 ; Requires ^XTMP("XTSIZE")
+2 NEW PKGNMEL1,PKGNMEL2,PKGNMEL3,LNNUM
+3 ; Create ^TMP("XTSIZE") Parameter file, Do Not create Change Report arrays, Create ^TMP("XTVS-FORUMPKG",$J)
DO XTMPORD^XTVSLNA1($JOB,0,1)
+4 ;
+5 ;Create Prefix-Package Indicies from KIDS
DO KIDSIDX^XTVSRFL1
+6 ;
+7 ; Needs ^TMP("XTVS-FORUMPKG",$J,TMPSUB) and DO KIDSIDX^XTVSRFL1
DO TALLYRPT^XTVSRFL(1,1)
+8 ; Set report into Mail Message array
DO RPTSIZE(XTVSSNDR)
+9 ;
+10 KILL ^XTMP("XTSIZE",$JOB)
+11 KILL ^TMP("XTVS-VPS",$JOB),^TMP("XTVS-FORUMPKG",$JOB),^TMP("XTVS-PREFIX-IDX",$JOB),^TMP("XTVS-FORUM-PFXS",$JOB)
+12 ;,^TMP("XTSIZE","IDX",$JOB)
KILL ^TMP("XTVS-VPS0",$JOB),^TMP("XTVS-IDX-PKG",$JOB),^TMP("XTVS-KIDSPFX-IDX",$JOB),^TMP("XTVS-FORUM2TMP",$JOB)
+13 ; KILL ^TMP globals
KILL ^TMP("XTVS-FILERPT",$JOB),^TMP("XTSIZE",$JOB),^TMP("XTSIZE","IDX",$JOB),^TMP("XTVS-REMOTE-SIZE",$JOB)
+14 QUIT
+15 ;
RPTSIZE(XTVSSNDR) ; Create message with report
+1 NEW LINECNT,RUNDT
+2 SET LINECNT=0
+3 ;
+4 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"VistA Application Sizing Information Sort Type: 1")
+5 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Site Domain: "_$PIECE($$NETNAME^XMXUTIL(DUZ),"@",2))
+6 DO NOW^%DTC
SET Y=X
DO DD^%DT
+7 SET RNDT=Y
+8 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Run Date: "_RNDT)
+9 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," ")
+10 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT," Total")
+11 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"Application Rtn")
+12 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"(Namespace) Routines Size Files Fields Options Protocols RPCs Templates")
+13 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"===============================================================================")
+14 ;
+15 ; Add report lines to display array
+16 NEW PKGNAME,PKGPFX
+17 SET PKGNAME=""
+18 FOR
SET PKGNAME=$ORDER(^TMP("XTVS-VPS",$JOB,PKGNAME))
if PKGNAME=""
QUIT
SET PKGPFX=""
Begin DoDot:1
+19 FOR
SET PKGPFX=$ORDER(^TMP("XTVS-VPS",$JOB,PKGNAME,PKGPFX))
if PKGPFX=""
QUIT
Begin DoDot:2
+20 DO PDAD($GET(^(PKGPFX)),PKGNAME,PKGPFX,.LINECNT)
End DoDot:2
End DoDot:1
+21 ;
+22 ; Send size report message
+23 NEW XMERR,XMY,XMTEXT,XMDUZ,XMSUB
+24 SET XMDUZ=DUZ
+25 SET XMY(XTVSSNDR)=""
+26 SET XMTEXT="^TMP(""XTVS-REMOTE-SIZE"","_$JOB_","
+27 SET XMSUB="PACKAGE SIZE REPORT ("_^%ZOSF("PROD")_" ; "_$$FMTE^XLFDT($$NOW^XLFDT,"1P")_" ; $JOB#: "_$JOB_")"
+28 DO ^XMD
+29 IF +XMZ'>0
DO WRERR("RPTSIZE^XTVSSVR : Package extract error","Error: ^XTMP(""XTVS-REMOTE-SIZE"","_$JOB_") not sent in Packman to "_XTVSSNDR_"!",XTVSSNDR,"ALL Packages")
+30 ;
+31 QUIT
+32 ;
PDAD(DATA,PKGNAME,PKGPFX,LINECNT) ; Add data to message global
+1 NEW RTOT,TLCNT,FTOT,FLDTOT,OTOT,PTOT,RPTOT,TPLTTOT,DATANDE,SPCT
+2 SET RTOT=+DATA
+3 SET TLCNT=$PIECE(DATA,"^",2)
+4 SET FTOT=$PIECE(DATA,"^",3)
+5 SET FLDTOT=$PIECE(DATA,"^",4)
+6 SET OTOT=$PIECE(DATA,"^",5)
+7 SET PTOT=$PIECE(DATA,"^",6)
+8 SET RPTOT=$PIECE(DATA,"^",7)
+9 SET TPLTTOT=$PIECE(DATA,"^",8)
+10 ;
+11 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,PKGNAME)
+12 SET DATANDE=""
+13 SET DATANDE="("_PKGPFX_")"
+14 ;Space out 2nd data element
FOR SPCT=1:1:11-$LENGTH(DATANDE)
SET DATANDE=DATANDE_" "
+15 SET DATANDE=DATANDE_$JUSTIFY(RTOT,6)_" "_$JUSTIFY(TLCNT,9)_" "_$JUSTIFY(FTOT,4)_" "_$JUSTIFY(FLDTOT,6)_" "_$JUSTIFY(OTOT,6)_" "_$JUSTIFY(PTOT,6)_" "_$JUSTIFY(RPTOT,6)_" "_$JUSTIFY(TPLTTOT,6)
+16 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,DATANDE)
+17 DO ADDLNE("^TMP(""XTVS-REMOTE-SIZE"")",.LINECNT,"-------------------------------------------------------------------------------")
+18 QUIT
+19 ;
ADDLNE(TMPARY,LINECNT,MSG) ; Add line to global
+1 ;Input
+2 ; TMMPARY - Array name to add a line (Closed root)
+3 ; LINECNT - Current array node number
+4 ; MSG - Message to add to ListMan Display
+5 ;
+6 SET LINECNT=LINECNT+1
+7 SET @TMPARY@($JOB,LINECNT)=MSG
+8 QUIT
+9 ;
+10 ; Called by SRVREXT for a single package, SELPKGPM contains package parameters
ONEPKGSZ(XTVSSNDR,SELPKGPM) ; Report Package
+1 ;Input
+2 ; XTVSSNDR - Requesters VA Mailman address
+3 ; SELPKGPM - Selected package parameters
+4 ;
+5 NEW PKGNAME,PKGNUM,PKGPFX,PKGERR,PCENUM,PREFIX,ADDPRFX
+6 SET PKGERR=0
+7 KILL ^TMP("XTVS-PREFIX-IDX",$JOB),^TMP("XTVS-FORUM-PFXS",$JOB),^TMP("XTVS-IDX-PKG",$JOB)
+8 ;
+9 ;Create Prefix Indicies
+10 SET PKGNAME=$PIECE(SELPKGPM,"^")
+11 ;
+12 SET PKGPFX=$PIECE(SELPKGPM,"^",2)
+13 IF PKGPFX=""
Begin DoDot:1
+14 SET PKGERR=1
+15 DO WRERR("ONEPKGSZ^XTVSSVR : Package Size Rpt error","PREFIX not found for package selected.",XTVSSNDR,PKGNAME)
End DoDot:1
+16 IF 'PKGERR
Begin DoDot:1
+17 ;
+18 ;Create Prefix-Package Indicies from KIDS
DO KIDSIDX^XTVSRFL1
+19 ;
+20 ; Needs ^TMP("XTVS-FORUMPKG",$J,TMPSUB) and DO KIDSIDX^XTVSRFL1
DO TALLYRPT^XTVSRFL(1,1,PKGNAME)
+21 ;
+22 ;Report stat's for a single package
DO ONERPT(XTVSSNDR,SELPKGPM,PKGNAME,PKGPFX)
End DoDot:1
+23 ;
+24 KILL ^TMP("XTVS-VPS",$JOB),^TMP("XTVS-PREFIX-IDX",$JOB),^TMP("XTVS-FORUM-PFXS",$JOB)
+25 KILL ^TMP("XTVS-VPS0",$JOB),^TMP("XTVS-IDX-PKG",$JOB),^TMP("XTVS-KIDSPFX-IDX",$JOB)
+26 KILL ^TMP("XTVS-FILERPT",$JOB),^TMP("XTSIZE","IDX",$JOB),^TMP("XTVS-REMOTE-SIZE",$JOB)
+27 QUIT
+28 ;
ONERPT(XTVSSNDR,SELPKGPM,PKGNAME,PKGPFX) ; Report a single package
+1 ;;INPUT:
+2 ; XTVSSNDR - Requesting user Email address
+3 ; SELPKGPM - Package Parameters (single package)
+4 ; PKGNAME - Package name to report
+5 ; PKGPFX - Package Prefix
+6 ;
+7 NEW Q,PCENUM,ADP,RDP,FTOT,FLDTOT,FFCTRSLT,RTOT,OTOT,PRCTOT,RPTOT,TPLTTOT,PKGIEN,RNDT,TLCNT
+8 NEW PARMDAT,PARMDAT3,PARMDAT4,PARMDAT7,PARMDAT8,LINECNT
+9 SET (PKGIEN,LINECNT)=0
+10 IF PKGNAME["''"
Begin DoDot:1
+11
*** ERROR ***
IF $DATA(^DIC(9.4,"B",$REPLACE(PKGNAME,"''","""")))