Skip to content
This repository has been archived by the owner on Jun 17, 2022. It is now read-only.

Install

Jacob Marble edited this page Jan 2, 2016 · 29 revisions

Summary

These instructions will result in sharing all printers on your CUPS server with Chrome, on the local subnet (mDNS broadcast domain) only. This is accomplished without creating/maintaining any config file.

If you need to share the printers with Google Cloud Print clients on Android, iOS, or Windows, or if you need to share the printers with clients not on the local subnet, then visit Configuration after completing these steps.

Get the binaries

Visit https://github.com/google/cups-connector/releases/latest to download binaries for your platform. Note: There is a dependency on Openssl 1.0.0 for the binary builds. Not all distros ship with Openssl 1.0.0

If binaries aren't available for your platform, then visit Build from source.

Extract the .tar.gz file you downloaded. You'll find two binary executables:

  • gcp-cups-connector
  • shares CUPS printers
  • processes print jobs
  • runs for long periods of time
  • gcp-cups-connector-util
  • create a new config file
  • upgrade a config file after a release
  • delete all printers
  • collect monitoring values

Prepare the platform

Before running the connector, make sure that the necessary client libraries are available: CUPS and Avahi. Also, git and bzr are needed to fetch some Go dependencies.

If your distro is based on Debian (Ubuntu, Raspbian, Mint, others) then this one-liner will get all dependencies:

$ sudo apt-get install libcups2 libavahi-client3 avahi-daemon libsnmp30

OpenSUSE 13.2:

$ sudo zypper install cups-libs libavahi-client3 avahi libsnmp30

The binaries don't work on Fedora currently, due to a difference in the name of libcrypto.so. You can still Build from source.

Run the CUPS Connector

You will also need a running CUPS server. The standard CUPS client configuration applies:

Run the connector:

$ gcp-cups-connector

The connector logs to to /tmp/connector.INFO (and others) by default.

If any printers are installed on the CUPS server, then they should now be available locally via Google Cloud Print. Test this by printing to the newly available GCP printer(s) from a Chrome browser.

Ctrl-C will stop the connector.

Create a config file

This would be a good time to create a config file, if you need one.

Run automatically on boot

There are many ways to do this. This is a simple method that works well for a Raspberry Pi.

Edit /etc/rc.local, add these lines at the end, just before exit 0

# CUPS Connector:
#   sleep:                                      hack to wait for the network interface to come up
#   su ... pi:                                  run as user "pi"
#   --login:                                    environment similar to "pi" instead of "root"
#   --command:                                  run this thing
#   /home/pi/cups-connector/gcp-cups-connector: thing to run
#   &:                                          run the command "in the background"
sleep 60
su --login --command /home/pi/cups-connector/gcp-cups-connector pi &