• Ubuntu 14.04 Server
  • Samsung CLX-3185 USB Printer (no wifi module)


Setup Ubuntu 14.04 Server as Print server for the Ipads/Iphones/Android phones in the house.

Prep CUPS Server

Install CUPS and necessary dependencies

sudo apt-get install cups
sudo apt-get install python-cups
sudo apt-get install avahi-discover

Setup CUPs with remote admin access

By default, CUPS Admin Portal at port 631 runs only on localhost. The following command allows you to control it from any device on the subnet.

sudo cupsctl --remote-admin
sudo service cups restart

When all configuration was finished, and test pages from Android and Apple mobile devices worked, the remote-admin access was disabled.

sudo cupsctl --no-remote-admin
sudo service cups restart

Add the Printer to CUPS

Click on:

  • "Adding Printers and Classes" then

  • "Add Printer". Clicking this may prompt a Basic Auth prompt. Use the credentials for the user that ran sudo when installing CUPS. CUPS is able to do this, by checking if the user belongs to the lpadmin group. If this step fails you will get the Error "User Forbidden". When adding the printer make sure to click on the Share Printer radio button.

  • In my case, the Samsung printer was not in the default set of printer PPDs. Installing the Linux Samsung Installer and restarting the CUPS service resolved that issue.

  • Send a Test Page to the Printer from the "Manage Printers" section, to confirm that the installation works.

Configuring AirPrint Support

AirPrint support is enabled via the Avahi service. By default, when the avahi-discover deb is installed, no print services are advertised.

Adding Printer to Avahi

Download this handy python script that loads all the CUPS printers into the Avahi service. Restart the Avahi daemon when this is done.

sudo python -d /etc/avahi/services
sudo service avahi-daemon restart

The printer should now be viewable by the Macbook Print Utility and the Print utilities on Apple mobile devices.

Configuring Google Print Support

Google provides a CUPS connector written in GoLang. The connector by default runs in local mode. This mode means that on the same subnet, the Android device will able to see the printer. This mode requires no configuration. Just start the connector app.

There is another mode, where it connects fully, to Google Print Web service and you can print from anywhere. There is no need for that in this setup. That mode does require a config file and authorization from a Google account.

Install the CUPS connector

In the wiki mentioned in the README is an INSTALL section that describes how to install the connector.

tar xvfz gcp-cups-connector-linux-amd64-2015.10.05.tar.gz
sudo mv cups-connector/gcp-cups-connector /usr/bin

Create a simple init script to start the connector

Here is the simple init script to start the Google Print CUPs connector on bootup. Just install the mentioned file. Nothing else needs to be done. Upstart will do the rest. For those running systemd, I'm sure an equivalent systemd startup file is easy to create.


400: Invalid request

Start the Google Print CUPs connector

sudo service gcp-cups-connector start