/usr/share/hplip/config_usb_printer.py is in hplip-data 3.14.3-0ubuntu3.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
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 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 | #! /usr/bin/python
# -*- coding: utf-8 -*-
#
# (c) Copyright 2011-2014 Hewlett-Packard Development Company, L.P.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# Author: Amarnath Chitumalla
#
__version__ = '1.2'
__title__ = 'HP device config using USB'
__mod__ = 'hp-config_usb_printer'
__doc__ = "Udev invokes this tool. Tool detects the plugin, Smart Install (C/DVD-ROM) issues and notifies to logged-in user. Tool also downloads firmware to the device."
# Std Lib
import sys
import os
# Local
from base.g import *
from base import device, utils, module, services
from installer import pluginhandler
DBUS_SERVICE = 'com.hplip.StatusService'
DBUS_AVIALABLE = False
##### METHODS #####
# Send dbus event to hpssd on dbus system bus
def send_message(device_uri, printer_name, event_code, username, job_id, title, pipe_name=''):
if DBUS_AVIALABLE == False:
return
log.debug("send_message() entered")
args = [device_uri, printer_name, event_code, username, job_id, title, pipe_name]
msg = lowlevel.SignalMessage('/', DBUS_SERVICE, 'Event')
msg.append(signature='ssisiss', *args)
SystemBus().send_message(msg)
log.debug("send_message() returning")
# Usage function
def usage(typ='text'):
utils.format_text(USAGE, typ, __title__, __mod__, __version__)
sys.exit(0)
# Systray service. If hp-systray is not running, starts.
def start_systray():
if DBUS_AVIALABLE == False:
return False
Systray_Is_Running=False
status,output = utils.Is_Process_Running('hp-systray')
if status is False:
if os.getuid() == 0:
log.error(" hp-systray must be running.\n Run \'hp-systray &\' in a terminal. ")
else:
log.info("Starting hp-systray service")
services.run_systray()
status,output = utils.Is_Process_Running('hp-systray')
if status == True:
Systray_Is_Running=True
log.debug("hp-systray service is running\n")
return Systray_Is_Running
USAGE = [ (__doc__, "", "name", True),
("Usage: %s [OPTIONS] [USB bus:device]" % __mod__, "", "summary", True),
utils.USAGE_OPTIONS,
utils.USAGE_LOGGING1, utils.USAGE_LOGGING2, utils.USAGE_LOGGING3,
utils.USAGE_HELP,
("[USB bus:device]", "", "heading", False),
("USB bus:device :", """"xxx:yyy" where 'xxx' is the USB bus and 'yyy' is the USB device. (Note: The ':' and all leading zeros must be present.)""", 'option', False),
("", "Use the 'lsusb' command to obtain this information.", "option", False),
utils.USAGE_EXAMPLES,
("USB, IDs specified:", "$%s 001:002"%(__mod__), "example", False),
utils.USAGE_SPACE,
utils.USAGE_NOTES,
("1. Using 'lsusb' to obtain USB IDs: (example)", "", 'note', False),
(" $ lsusb", "", 'note', False),
(" Bus 003 Device 011: ID 03f0:c202 Hewlett-Packard", "", 'note', False),
(" $ %s 003:011"%(__mod__), "", 'note', False),
(" (Note: You may have to run 'lsusb' from /sbin or another location. Use '$ locate lsusb' to determine this.)", "", 'note', True),
]
mod = module.Module(__mod__, __title__, __version__, __doc__, USAGE, (INTERACTIVE_MODE,), None, run_as_root_ok=True, quiet=True)
opts, device_uri, printer_name, mode, ui_toolkit, loc = mod.parseStdOpts('gh',['time-out=', 'timeout='],handle_device_printer=False)
LOG_FILE = "%s/hplip_config_usb_printer.log"%prop.user_dir
if os.path.exists(LOG_FILE):
try:
os.remove(LOG_FILE)
except OSError:
pass
log.set_logfile(LOG_FILE)
log.set_where(log.LOG_TO_CONSOLE_AND_FILE)
try:
import dbus
from dbus import SystemBus, lowlevel
except ImportError:
log.warn("Failed to Import DBUS ")
DBUS_AVIALABLE = False
else:
DBUS_AVIALABLE = True
try:
param = mod.args[0]
except IndexError:
param = ''
log.debug("param=%s" % param)
if len(param) < 1:
usage()
sys.exit()
try:
# ******************************* MAKEURI
if param:
device_uri, sane_uri, fax_uri = device.makeURI(param)
if not device_uri:
log.error("This is not a valid device")
sys.exit(0)
# ******************************* QUERY MODEL AND CHECKING SUPPORT
log.debug("\nSetting up device: %s\n" % device_uri)
mq = device.queryModelByURI(device_uri)
if not mq or mq.get('support-type', SUPPORT_TYPE_NONE) == SUPPORT_TYPE_NONE:
log.error("Unsupported printer model.")
sys.exit(1)
printer_name = ""
username = prop.username
job_id = 0
# ******************************* Detecting smart install /CD-DVD ROM enable.
if "SMART_INSTALL_ENABLED" in device_uri:
if start_systray():
send_message( device_uri, printer_name, EVENT_DIAGNOSE_PRINTQUEUE, username, job_id,'')
else:
log.error("SMART INSTALL (CD/DVD-ROM) is enabled in the system. Refer http://hplipopensource.com/hplip-web/index.html for more information.")
# ******************************* TRIGGERING PLUGIN POP-UP FOR PLUGING SUPPORTED PRINTER'S
plugin = mq.get('plugin', PLUGIN_NONE)
if plugin != PLUGIN_NONE:
pluginObj = pluginhandler.PluginHandle()
plugin_sts = pluginObj.getStatus()
if plugin_sts == pluginhandler.PLUGIN_INSTALLED:
log.info("Device Plugin is already installed")
elif plugin_sts == pluginhandler.PLUGIN_NOT_INSTALLED :
log.info("HP Device Plug-in is not found")
else:
log.info("HP Device Plug-in version mismatch or some files are corrupted")
if plugin_sts != pluginhandler.PLUGIN_INSTALLED:
if start_systray():
send_message( device_uri, printer_name, EVENT_AUTO_CONFIGURE, username, job_id, "AutoConfig")
else:
log.error("HP Device plugin's are not installed. Please install plugin's using hp-plugin command.")
# ******************************* RUNNING FIRMWARE DOWNLOAD TO DEVICE FOR SUPPORTED PRINTER'S
fw_download_req = mq.get('fw-download', False)
if fw_download_req:
fw_cmd = "hp-firmware -y3 -s %s"%param
log.info(fw_cmd)
fw_sts, fw_out = utils.run(fw_cmd)
if fw_sts == 0:
log.debug("Firmware downloaded to %s "%device_uri)
else:
log.warn("Failed to download firmware to %s device"%device_uri)
except KeyboardInterrupt:
log.error("User exit")
log.debug("Done.")
|