189 lines
4.5 KiB
C
189 lines
4.5 KiB
C
/*
|
|
* pqstat.c
|
|
*
|
|
* List the jobs in a print queue on a server
|
|
*
|
|
* Copyright (C) 1998 by David Woodhouse
|
|
* Derived from pqlist.c, (C) 1996 Volker Lendecke
|
|
*
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <ctype.h>
|
|
#include <stdlib.h>
|
|
#include <time.h>
|
|
#include "ncplib.h"
|
|
|
|
/* move this to library ? */
|
|
int
|
|
ncp_time_to_tm(struct tm* out, __u8* netwareTime)
|
|
{
|
|
struct tm tmp;
|
|
|
|
tmp.tm_year = netwareTime[0];
|
|
if (tmp.tm_year < 80) tmp.tm_year += 100;
|
|
tmp.tm_mon = netwareTime[1]-1;
|
|
if ((tmp.tm_mon < 0) || (tmp.tm_mon >= 12)) return 1;
|
|
tmp.tm_mday = netwareTime[2];
|
|
if ((tmp.tm_mday < 1) || (tmp.tm_mday >= 32)) return 1;
|
|
tmp.tm_hour = netwareTime[3];
|
|
if (tmp.tm_hour >= 24) return 1;
|
|
tmp.tm_min = netwareTime[4];
|
|
if (tmp.tm_min >= 60) return 1;
|
|
tmp.tm_sec = netwareTime[5];
|
|
if (tmp.tm_sec >= 60) return 1;
|
|
memcpy(out, &tmp, sizeof(tmp));
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
ncp_cmp_time(struct tm* tm1, struct tm* tm2)
|
|
{
|
|
#undef XTST
|
|
#define XTST(Y) if (tm1->tm_##Y## != tm2->tm_##Y##) { \
|
|
return (tm1->tm_##Y## > tm2->tm_##Y##) ? 1 : -1; \
|
|
}
|
|
XTST(year);
|
|
XTST(mon);
|
|
XTST(mday);
|
|
XTST(hour);
|
|
XTST(min);
|
|
XTST(sec);
|
|
#undef XTST
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
struct ncp_conn *conn;
|
|
struct ncp_bindery_object q,u;
|
|
unsigned long maxqlen=~0;
|
|
long err;
|
|
|
|
__u32 qlen, idl1,idl2, job_id;
|
|
struct nw_queue_job_entry j;
|
|
|
|
if ((conn = ncp_initialize(&argc, argv, 1, &err)) == NULL)
|
|
{
|
|
com_err(argv[0], err, "when initializing");
|
|
return 1;
|
|
}
|
|
|
|
if (argc == 3)
|
|
{
|
|
char *end;
|
|
|
|
maxqlen=strtoul(argv[2], &end, 10);
|
|
if (*end != 0)
|
|
argc = 4;
|
|
|
|
}
|
|
if (argc < 2 || argc > 3)
|
|
{
|
|
fprintf(stderr, "usage: %s <queue> [<qlen>]\n", argv[0]);
|
|
return 1;
|
|
}
|
|
|
|
|
|
if (ncp_get_bindery_object_id(conn, NCP_BINDERY_PQUEUE,
|
|
argv[1], &q) != 0)
|
|
{
|
|
printf("Queue \"%s\" on server %s not found.\n",
|
|
argv[1], conn->server);
|
|
ncp_close(conn);
|
|
exit(1);
|
|
|
|
}
|
|
|
|
if (isatty(1))
|
|
{
|
|
printf("\nServer: %s\tQueue: %s\tQueue ID: %8.8X\n", conn->server, q.object_name, q.object_id);
|
|
printf(" %5s %-12s %-32s %-7s %-4s %-8s\n"
|
|
|
|
"-----------------------------------------------"
|
|
"--------------------------------\n",
|
|
"Seq","Name",
|
|
"Description", "Status", "Form", "Job ID");
|
|
}
|
|
|
|
|
|
if ((err=ncp_get_queue_length(conn, q.object_id, &qlen)) != 0)
|
|
{
|
|
if (conn->completion == 0xD3) {
|
|
fprintf(stderr, "You have insufficient rights to list queue jobs\n");
|
|
} else {
|
|
com_err(argv[0], err, ": cannot get queue length");
|
|
}
|
|
ncp_close(conn);
|
|
exit(1);
|
|
}
|
|
/* printf("There are %d jobs in the queue.\n",qlen); */
|
|
|
|
idl1=1;
|
|
job_id =0;
|
|
|
|
if ((err=ncp_get_queue_job_ids(conn, q.object_id, 1,
|
|
&idl1, &idl2, &job_id)) != 0)
|
|
{
|
|
printf("Error getting queue jobs ids: %ld\n",err);
|
|
ncp_close(conn);
|
|
exit(1);
|
|
}
|
|
|
|
/* printf("First queue job ID is %8X\n",job_id);*/
|
|
|
|
while (maxqlen-- && job_id && (ncp_get_queue_job_info(conn, q.object_id, job_id, &j) == 0))
|
|
{
|
|
const char* jst;
|
|
|
|
char user[50];
|
|
if ((ncp_get_bindery_object_name
|
|
(conn, ntohl(j.ClientObjectID), &u))
|
|
== 0)
|
|
{
|
|
memcpy(user,u.object_name,48);
|
|
user[48]=0;
|
|
}
|
|
else
|
|
{
|
|
sprintf(user,"<Unknown>");
|
|
}
|
|
|
|
j.JobFileName[j.FileNameLen]=0;
|
|
|
|
if (j.JobControlFlags & 0xC0) {
|
|
jst = "Held";
|
|
} else if (j.JobControlFlags & 0x20) {
|
|
jst = "Adding";
|
|
} else if (j.ServerStation) {
|
|
jst = "Active";
|
|
} else {
|
|
struct tm jobtime;
|
|
|
|
jst = "Ready";
|
|
if (!ncp_time_to_tm(&jobtime, j.TargetExecTime)) {
|
|
time_t ltime;
|
|
struct tm* loctime;
|
|
|
|
time(<ime);
|
|
loctime = localtime(<ime);
|
|
|
|
if (ncp_cmp_time(&jobtime, loctime) >= 0)
|
|
jst = "Waiting";
|
|
}
|
|
}
|
|
|
|
printf(" %5d %-12s %-32.32s %-7s %4d %08X\n",
|
|
j.JobPosition, user, j.JobTextDescription, jst, ntohs(j.JobType), j.JobNumber);
|
|
if (j.next == job_id)
|
|
job_id = 0;
|
|
else job_id = j.next;
|
|
}
|
|
|
|
ncp_close(conn);
|
|
return 0;
|
|
}
|
|
|