|
API Fun Time
Published: July 16, 2008
Hey, Ted:
We have a job that is designed to run periodically to collect XML files from a third party via FTP. Rather than have a program that is constantly active, it was decided that the very first action of the program would be to re-submit itself to a single entry job queue with a scheduled run time derived from a maintainable value held on a file. The benefit of this approach is that if for some reason the program fails there is no need to worry about re-starting the process--unless of course the program failed at the self-submit stage!
When an initial start of the process is required the program can be called in "startup" mode. The routine for this first checks to make sure there isn't an instance on the job queue with a status of scheduled. If there is, a suitable message is sent. Now it would be convenient if this message included the time of the next run of the program so I turned for help to the Retrieve Job Information QUSRJOBI API.
The good news is that there is a format (JOBI0400) that provides "Date and time job is scheduled to run"; the less good news is that it is returned in a strange eight character field. In a corner of the Work Management API Attribute Descriptions manual I eventually found a clue: "The format for this field is the system time-stamp format." So how do I use it? Some determined Googling turned up the answer, call the Convert Date and Time Format (QWCCVTDT) API with an input format of *DTS (system time-stamp) and an output format of *YYMD. Below is some code to do the trick:
************************************************************
*Program to retrieve the scheduled run time of a queued job*
*Input parameter : qualified job name of scheduled job *
*Output parameter: scheduled run time in format hh:mm:ss *
************************************************************
D SCD001 PR extpgm('SCD001')
D pJob 26
D pStime 8
D SDX001 PI
D pJob 26
D pStime 8
D CvtDatTim PR extpgm('QWCCVTDT')
D pInpFmt 10
D pInpVal 8
D pOutFmt 10
D pOutVal 17
D ErrorData 32766 options(*varsize)
D RtvJobInf PR extpgm('QUSRJOBI')
D RcvVar 32766 options(*varsize)
D RcvVarLen 10i 0 const
D Format 8 const
D JobName 26 const
D IntJobID 16 const
D ErrorData 32766 options(*varsize)
* API error data structure
D erDs DS
D erDsBytesP 10i 0 inz(0)
D erDsBytesA 10i 0 inz(0)
D erDsMsgID 9 15
D erDsReserv 16 16
D erDsMsgDta 17 256
* Definitions for QUSRJOBI formats
/COPY QSYSINC/QRPGLESRC,QUSRJOBI
D ScdDatTim DS
D ScdDat 8s 0
D ScdHMS 6s 0
D ScdMS 3s 0
* Convert date/time (QWCCVTDT) API input/output formats
D InpFmt S 10 inz( '*DTS' )
D OutFmt S 10 inz( '*YYMD' )
* Edit word constant to format the time
D editwd C ' : : '
* Monitor for errors eg job not found
C monitor
* Retrieve job attribute information
C callp RtvJobInf(QUSI0400:%size(QUSI0400):
C 'JOBI0400':pJob:*blank:erDs)
C if erDsBytesA > 0
C eval pStime = 'unknown'
C else
* Convert from system timestamp to something readable!
C callp CvtDatTim(InpFmt:QUSSDT:OutFmt:
C ScdDatTim:erDs)
* Return scheduled run time in the format hh:mm:ss
C eval pStime = %editw(ScdHMS:editwd
C endif
C on-error
C eval pStime = 'unknown'
C endmon
C eval *Inlr = *on
C return
--Phil Hope
Thanks to Phil for sharing his code with the rest of us. I have fought similar battles, but never arrived at Phil's graceful solution.
--Ted
Post this story to del.icio.us
Post this story to Digg
Post this story to Slashdot
|
|
Do you need area code information?
Do you need ZIP Code information?
Do you need ZIP+4 information?
Do you need city name information?
Do you need county information?
Do you need a nearest dealer locator system?
We can HELP! We have affordable AS/400 software and data to do all of the above. Whether you need a simple city name retrieval system or a sophisticated CASS postal coding system, we have it for you!
The ZIP/CITY system is based on 5-digit ZIP Codes. You can retrieve city names, state names, county names, area codes, time zones, latitude, longitude, and more just by knowing the ZIP Code. We supply information on all the latest area code changes. A nearest dealer locator function is also included. ZIP/CITY includes software, data, monthly updates, and unlimited support. The cost is $495 per year.
PER/ZIP4 is a sophisticated CASS certified postal coding system for assigning ZIP Codes, ZIP+4, carrier route, and delivery point codes. PER/ZIP4 also provides county names and FIPS codes. PER/ZIP4 can be used interactively, in batch, and with callable programs. PER/ZIP4 includes software, data, monthly updates, and unlimited support. The cost is $3,900 for the first year, and $1,950 for renewal.
Just call us and we'll arrange for 30 days FREE use of either ZIP/CITY or PER/ZIP4.
WorksRight Software, Inc.
Phone: 601-856-8337
Fax: 601-856-9432
E-mail: software@worksright.com
Web site: www.worksright.com
|
Senior Technical Editor: Ted Holt
Technical Editor: Joe Hertvik
Contributing Technical Editors: Edwin Earley, Brian Kelly, Michael Sansoterra
Publisher and Advertising Director: Jenny Thomas
Advertising Sales Representative: Kim Reed
|
IT Jungle Store Top Book Picks
Easy Steps to Internet Programming for AS/400, iSeries, and System i: List Price, $49.95
Getting Started with PHP for i5/OS: List Price, $59.95
The System i RPG & RPG IV Tutorial and Lab Exercises: List Price, $59.95
The System i Pocket RPG & RPG IV Guide: List Price, $69.95
The iSeries Pocket Database Guide: List Price, $59.00
The iSeries Pocket Developers' Guide: List Price, $59.00
The iSeries Pocket SQL Guide: List Price, $59.00
The iSeries Pocket Query Guide: List Price, $49.00
The iSeries Pocket WebFacing Primer: List Price, $39.00
Migrating to WebSphere Express for iSeries: List Price, $49.00
iSeries Express Web Implementer's Guide: List Price, $59.00
Getting Started with WebSphere Development Studio for iSeries: List Price, $79.95
Getting Started With WebSphere Development Studio Client for iSeries: List Price, $89.00
Getting Started with WebSphere Express for iSeries: List Price, $49.00
WebFacing Application Design and Development Guide: List Price, $55.00
Can the AS/400 Survive IBM?: List Price, $49.00
The All-Everything Machine: List Price, $29.95
Chip Wars: List Price, $29.95
|
|
July 12, 2008: Volume 10, Number 28
July 5, 2008: Volume 10, Number 27
June 28, 2008: Volume 10, Number 26
June 21, 2008: Volume 10, Number 25
June 14, 2008: Volume 10, Number 24
June 7, 2008: Volume 10, Number 23
|
|
|
|