summaryrefslogtreecommitdiffstats
path: root/examples/printer-accounting/hp5-redir
blob: 98c2b72edd2249be2c1a7b03d1b4840354f520b4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#!/usr/bin/perl
#
# $Source: /data/src/mirror/cvs/samba/examples/printer-accounting/hp5-redir,v $
# $Id: hp5-redir,v 1.1 1996/07/23 03:30:56 samba-bugs Exp $
#
# 0 == stdin  == docuement
# 1 == stdout == printer
# 2 == stderr == logging
#
# With redirection to another valid /etc/printcap entry
#

umask(002);

# -w132 -l66 -i0 -n pkelly -h master.fcp.oypi.com /var/log/lp-acct
require "getopts.pl";
&Getopts("w:l:i:n:h:");

chomp($date = `date '+%Y-%m-%d.%T'`);

($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size,
        $atime,$mtime,$ctime,$blksize,$blocks)
 = stat(STDIN);

# send to the real printer now.
open(P, "|lpr -Pmgmt0") || die "Can't print to hp5-real ($!)\n";
$cnt = 0;
while (sysread(STDIN, $buf, 10240)) {
        print P $buf;
	# this is ugly, but it gives the approx in pages.  We
	# don't print graphics, so ...  There must be a better way :)
        $cnt += ($buf =~ /^L/g);
}
close(P);

$acct = shift;
if (open(ACCT, ">>$acct")) {
        print ACCT "$date $opt_n $opt_h $size $cnt\n";
        close(ACCT);
} else {
        warn "Err: Can't account for it ($!)\n";
        warn "Log: $date $opt_n $opt_h $size $cnt\n";
}