-
Notifications
You must be signed in to change notification settings - Fork 3
LPR over SSH Driver
License
xkjyeah/sshlpr2
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
sshlpr2 INTRODUCTION When your printer is connected to your SSH server, but not to you, you can use sshlpr2 to create a CUPS printer that behaves like a remote server. Similar work was done by Andre Masella. His original sshlpr script can be found at http://www.masella.name/technical/sshlpr.html The original version of sshlpr has two problems: (1) Requires your SSH server to accept public key authentication. Password authentication will certainly fail, because when ssh is run by CUPS it is not able to open a terminal. (2) Requires CUPS to run su, which will also fail because CUPS is not connected to a terminal. To avoid the su problems, sshlpr2 has a simple server daemon that accepts jobs submitted to it (via the sshlpr backend) and forwards the jobs to clients attached to it (via sshlpr_client). sshlpr_client can be run in an X environment, so that you can launch xterm and key in your password. sshlpr_client is setuid lp, in order to allow you to connect to sshlprd. INSTALLATION On a regular Ubuntu system, type: $ ./configure; make; sudo make install If you are on other Linux/Mac system, have a look at the configure options specific to sshlpr2: --with-cups-backend CUPS backend directory, e.g. /usr/lib/cups/backend --with-socket-dir Socket directory, e.g. /var/sshlpr --with-lpuser Username to setuid the CUPS backend and client HOW IT WORKS 0. Initialization a) sshlprd is running. b) Some user runs sshlpr_client, which connects to sshlprd 1. sshlpr a) Creates a FIFO in /tmp b) Submits job request to sshlprd 2. sshlpr_client a) Receives the job request from sshlprd b) Executes sshlpr_helper, passing parameters from the job request to sshlpr_helper 3. sshlpr_helper a) Reads the parameters b) Starts an xterm process that: i] Reads from the FIFO, and pipes the output to... ii] ... an ssh process that runs the ... iii] ... lpr process on the remote end HOW TO USE IT After installation, create a printer based on the sshlpr2 backend on sshlpr://abc123@linux.pwf.cam.ac.uk/Pem_CC_1_BW Unlike the original sshlpr, the local user does not have to be specified, because you will always execute ssh as the user that created the print job. SPECIAL NOTE TO UNIVERSITY OF CAMBRIDGE USERS To discover your list of printers: ssh <CRSID>@linux.pwf.cam.ac.uk 'lpstat -P -a'
About
LPR over SSH Driver
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published