smbprint
来自「samba-3.0.22.tar.gz 编译smb服务器的源码」· 代码 · 共 177 行
TXT
177 行
#!/bin/bash# This script is an input filter for printcap printing on a unix machine. It# uses the smbclient program to print the file to the specified smb-based # server and service.# For example you could have a printcap entry like this## smb:lp=/dev/null:sd=/usr/spool/smb:sh:if=/usr/local/samba/smbprint## which would create a unix printer called "smb" that will print via this # script. You will need to create the spool directory /usr/spool/smb with# appropriate permissions and ownerships for your system.# Set these to the server and service you wish to print to # In this example I have a WfWg PC called "lapland" that has a printer # exported called "printer" with no password.## Script further altered by hamiltom@ecnz.co.nz (Michael Hamilton)# so that the server, service, and password can be read from # a /usr/var/spool/lpd/PRINTNAME/.config file.## Script further modified by Richard Sharpe to fix some things.# Get rid of the -x on the first line, and add parameters## -t now causes translate to be used when sending files## Further modifications by Alfred Perlstein to fix some problems and# improve the quality of the code (3-Dec-2001).## More hacking by Richard Sharpe to improve portability. 9-Dec-2001.## In order for this to work the /etc/printcap entry must include an # accounting file (af=...):## cdcolour:\# :cm=CD IBM Colorjet on 6th:\# :sd=/var/spool/lpd/cdcolour:\# :af=/var/spool/lpd/cdcolour/acct:\# :if=/usr/local/etc/smbprint:\# :mx=0:\# :lp=/dev/null:## The /usr/var/spool/lpd/PRINTNAME/.config file should contain:# server=PC_SERVER# service=PR_SHARENAME# password="password"## E.g.# server=PAULS_PC# service=CJET_371# password=""#smbclient=/usr/pkg/bin/smbclient# Assume that smbclient will be in the same place as smbprintsmbclient="`dirname $0`/smbclient"## The last parameter to the filter is the accounting file name.# Extract the directory name from the file name.# Concat this with /.config to get the config file.#TRANS=0eval acct_file=\${$#}spool_dir=`dirname $acct_file` config_file=$spool_dir/.config# Should read the following variables set in the config file:# server# service# password# username (optional)# IP (optional)# debug (optional)# debugsmb (optional)# debugfile (optional). $config_fileif [ "x$password" = "x" ] ; then password="-N"fiif [ "x$username" == "x" ] ; then username="$server";fiwhile test $# -gt 0; do case "$1" in -t) TRANS=1 ;; *) # Bad Parameters, ignore them ... ;; esac shiftdonecommand="print - ;"if [ $TRANS -eq 1 ]; then command="translate;$command";fi#### Some security checks on the logfile if we are using it#### make the directory containing the logfile is necessary ## and set the permissions to be rwx for owner only##debugfile="/tmp/smb-print/logfile"logdir=`dirname $debugfile`if [ ! -d $logdir ]; then mkdir -m 0700 $logdirfi#### check ownership. If I don't own it refuse to ## create the logfile##if [ ! -O $logdir ]; then echo "user running script does not own $logdir. Ignoring any debug options." debug=""fitouch $debugfileif [ -h $debugfile ]; then echo "$debugful is a symlink. Turning off debugging!" debug=""fi#### We should be safe at this point to create the log file## without fear of a symlink attack -- move on to more script work.##if [ "x$debug" = "x" ] ; then debugfile=/dev/null debugargs=else if [ $debug -eq 0 ] ; then debugfile=/dev/null debugargs= else set -x; exec >>$debugfile 2>&1 debugargs="$debugfile." #[ "x$debugsmb" == "x" ] || debugargs="$debugargs -d $debugsmb" fifiif [ "x$smbconf" != "x" ]; then smbconf="-s $smbconf"fiif [ "x$IP" != "x" ]; then IP="-I $IP"fiif [ "x$debugargs" != "x" ]; then debugargs="-l $debugargs"fi$smbclient \ "\\\\$server\\$service" \ $password \ $smbconf \ $IP \ $debugargs \ -U $username \ -c "$command"#
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?