__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# -*- coding: utf-8 -*-
#
# (c) Copyright 2001-2015 HP 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
#
# Authors: Don Welch
#
# StdLib
import operator
import signal
# Local
from base.g import *
from base import device, utils
from prnt import cups
from base.codes import *
from .ui_utils import *
from base.sixext import to_unicode
# Qt
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
# Ui
from .faxsetupdialog_base import Ui_Dialog
from .deviceuricombobox import DEVICEURICOMBOBOX_TYPE_FAX_ONLY
fax_enabled = prop.fax_build
if fax_enabled:
try:
from fax import fax
except ImportError:
# This can fail on Python < 2.3 due to the datetime module
# or if fax was diabled during the build
fax_enabled = False
if not fax_enabled:
log.warn("Fax disabled.")
class PasswordDialog(QDialog):
def __init__(self, prompt, parent=None, name=None, modal=0, fl=0):
QDialog.__init__(self, parent)
# Application icon
self.setWindowIcon(QIcon(load_pixmap('hp_logo', '128x128')))
self.prompt = prompt
Layout = QGridLayout(self)
Layout.setContentsMargins(11, 11, 11, 11)
Layout.setSpacing(6)
self.PromptTextLabel = QLabel(self)
Layout.addWidget(self.PromptTextLabel, 0, 0, 1, 3)
self.UsernameTextLabel = QLabel(self)
Layout.addWidget(self.UsernameTextLabel, 1, 0)
self.UsernameLineEdit = QLineEdit(self)
self.UsernameLineEdit.setEchoMode(QLineEdit.Normal)
Layout.addWidget(self.UsernameLineEdit, 1, 1, 1, 2)
self.PasswordTextLabel = QLabel(self)
Layout.addWidget(self.PasswordTextLabel, 2, 0)
self.PasswordLineEdit = QLineEdit(self)
self.PasswordLineEdit.setEchoMode(QLineEdit.Password)
Layout.addWidget(self.PasswordLineEdit, 2, 1, 1, 2)
self.OkPushButton = QPushButton(self)
Layout.addWidget(self.OkPushButton, 3, 2)
self.CancelPushButton = QPushButton(self)
Layout.addWidget(self.CancelPushButton, 3, 1)
self.languageChange()
self.resize(QSize(420, 163).expandedTo(self.minimumSizeHint()))
self.OkPushButton.clicked.connect(self.accept)
self.CancelPushButton.clicked.connect(self.reject)
self.PasswordLineEdit.returnPressed.connect(self.accept)
def setDefaultUsername(self, defUser, allowUsernameEdit=True):
self.UsernameLineEdit.setText(defUser)
if not allowUsernameEdit:
self.UsernameLineEdit.setReadOnly(True)
self.UsernameLineEdit.setStyleSheet(
"QLineEdit {background-color: lightgray}")
def getUsername(self):
return to_unicode(self.UsernameLineEdit.text())
def getPassword(self):
return to_unicode(self.PasswordLineEdit.text())
def languageChange(self):
self.setWindowTitle(
self.__tr("HP Device Manager - Enter Username/Password"))
self.PromptTextLabel.setText(self.__tr(self.prompt))
self.UsernameTextLabel.setText(self.__tr("Username:"))
self.PasswordTextLabel.setText(self.__tr("Password:"))
self.OkPushButton.setText(self.__tr("OK"))
self.CancelPushButton.setText(self.__tr("Cancel"))
def __tr(self, s, c=None):
return qApp.translate("SetupDialog", s, c)
def FailureMessageUI(prompt):
try:
dlg = PasswordDialog(prompt, None)
FailureUI(dlg, prompt)
finally:
pass
def showPasswordUI(prompt, userName=None, allowUsernameEdit=True):
try:
dlg = PasswordDialog(prompt, None)
if userName != None:
dlg.setDefaultUsername(userName, allowUsernameEdit)
if dlg.exec_() == QDialog.Accepted:
return (dlg.getUsername(), dlg.getPassword())
finally:
pass
return ("", "")
class FaxSetupDialog(QDialog, Ui_Dialog):
def __init__(self, parent, device_uri):
QDialog.__init__(self, parent)
self.setupUi(self)
self.device_uri = device_uri
self.initUi()
self.dev = None
self.fax_number = ''
self.fax_company_name = ''
self.call_password_ui = True
self.user_settings = UserSettings()
self.user_settings.load()
self.user_settings.debug()
QTimer.singleShot(0, self.updateUi)
def initUi(self):
# connect signals/slots
self.CancelButton.clicked.connect(self.CancelButton_clicked)
self.SaveBtn.clicked.connect(self.SaveBtn_Clicked)
self.FaxComboBox.DeviceUriComboBox_noDevices.connect(
self.FaxComboBox_noDevices)
self.FaxComboBox.DeviceUriComboBox_currentChanged.connect(
self.FaxComboBox_currentChanged)
self.FaxComboBox.setType(DEVICEURICOMBOBOX_TYPE_FAX_ONLY)
signal.signal(signal.SIGINT, signal.SIG_DFL)
# Application icon
self.setWindowIcon(QIcon(load_pixmap('hp_logo', '128x128')))
if self.device_uri:
self.FaxComboBox.setInitialDevice(self.device_uri)
self.NameCompanyLineEdit.setMaxLength(50)
self.FaxNumberLineEdit.setMaxLength(50)
self.FaxNumberLineEdit.setValidator(
PhoneNumValidator(self.FaxNumberLineEdit))
self.VoiceNumberLineEdit.setMaxLength(50)
self.VoiceNumberLineEdit.setValidator(
PhoneNumValidator(self.VoiceNumberLineEdit))
self.EmailLineEdit.setMaxLength(50)
self.fax_number = to_unicode(self.FaxNumberLineEdit.text())
self.fax_company_name = to_unicode(self.NameCompanyLineEdit.text())
'''
self.NameCompanyLineEdit.editingFinished.connect(
self.NameCompanyLineEdit_editingFinished)
self.NameCompanyLineEdit.textChanged["const QString &"].connect(
self.NameCompanyLineEdit_textChanged)
self.FaxNumberLineEdit.editingFinished.connect(
self.FaxNumberLineEdit_editingFinished)
self.FaxNumberLineEdit.textChanged["const QString &"].connect(
self.FaxNumberLineEdit_textChanged)
'''
self.VoiceNumberLineEdit.editingFinished.connect(
self.VoiceNumberLineEdit_editingFinished)
self.VoiceNumberLineEdit.textChanged["const QString &"].connect(
self.VoiceNumberLineEdit_textChanged)
self.EmailLineEdit.editingFinished.connect(
self.EmailLineEdit_editingFinished)
self.EmailLineEdit.textChanged["const QString &"].connect(
self.EmailLineEdit_textChanged)
self.tabWidget.currentChanged[int].connect(self.Tabs_currentChanged)
self.name_company_dirty = False
self.fax_number_dirty = False
self.voice_number_dirty = False
self.email_dirty = False
def updateUi(self):
if not fax_enabled:
FailureUI(self, self.__tr(
"<b>PC send fax support is not enabled.</b><p>Re-install HPLIP with fax support or use the device front panel to send a fax.</p><p>Click <i>OK</i> to exit.</p>"))
self.close()
return
self.FaxComboBox.updateUi()
self.tabWidget.setCurrentIndex(0)
self.fax_number = to_unicode(self.FaxNumberLineEdit.text())
self.fax_company_name = to_unicode(self.NameCompanyLineEdit.text())
def FaxComboBox_currentChanged(self, device_uri):
self.device_uri = device_uri
self.updateCoverpageTab()
if self.dev is not None:
self.dev.close()
try:
self.dev = fax.getFaxDevice(self.device_uri)
except Error:
CheckDeviceUI(self)
return
self.updateHeaderTab()
def FaxComboBox_noDevices(self):
FailureUI(self, self.__tr(
"<b>No devices that require fax setup found.</b>"))
self.close()
#
# Name/Company (for TTI header) (stored in device)
#
def NameCompanyLineEdit_editingFinished(self):
self.saveNameCompany(to_unicode(self.NameCompanyLineEdit.text()))
def NameCompanyLineEdit_textChanged(self, s):
self.name_company_dirty = True
def saveNameCompany(self, s):
self.name_company_dirty = False
retn = False
beginWaitCursor()
try:
try:
log.debug("Saving station name %s to device" % s)
if self.dev.isAuthRequired() == True and self.call_password_ui == True:
promptText = "Enter the printer's username password password\n"
while(True):
username, password = showPasswordUI(promptText)
if username == '' or password == '':
return False
respCode = self.dev.getCDMToken(username, password)
if respCode != 200:
promptText = "Invalid Username or Password!.\nRernter the printer's username password password\n"
continue
break
self.dev.setStationName(s)
retn = True
except Error:
CheckDeviceUI(self)
finally:
endWaitCursor()
return retn
#
# Fax Number (for TTI header) (stored in device)
#
def FaxNumberLineEdit_editingFinished(self):
self.saveFaxNumber(to_unicode(self.FaxNumberLineEdit.text()))
def FaxNumberLineEdit_textChanged(self, s):
self.fax_number_dirty = True
def saveFaxNumber(self, s):
self.fax_number_dirty = False
retn = False
beginWaitCursor()
try:
try:
log.debug("Saving fax number %s to device" % s)
if self.dev.isAuthRequired() == True and self.call_password_ui == True:
promptText = "Enter the printer's username password password\n"
while(True):
username, password = showPasswordUI(promptText)
if username == '' or password == '':
return retn
respCode = self.dev.getCDMToken(username, password)
if respCode != 200:
promptText = "Invalid Username or Password!.\nRernter the printer's username password password\n"
continue
break
self.dev.setPhoneNum(s)
retn=True
except Error:
CheckDeviceUI(self)
finally:
endWaitCursor()
return retn
#
# Voice Number (for coverpage) (stored in ~/.hplip/hplip.conf)
#
def VoiceNumberLineEdit_editingFinished(self):
self.saveVoiceNumber(to_unicode(self.VoiceNumberLineEdit.text()))
def VoiceNumberLineEdit_textChanged(self, s):
self.voice_number_dirty = True
def saveVoiceNumber(self, s):
log.debug("Saving voice number (%s) to ~/.hplip/hplip.conf" % s)
self.voice_number_dirty = False
#user_conf.set('fax', 'voice_phone', s)
self.user_settings.voice_phone = s
self.user_settings.save()
#
# EMail (for coverpage) (stored in ~/.hplip/hplip.conf)
#
def EmailLineEdit_editingFinished(self):
self.saveEmail(to_unicode(self.EmailLineEdit.text()))
def EmailLineEdit_textChanged(self, s):
self.email_dirty = True
def saveEmail(self, s):
log.debug("Saving email address (%s) to ~/.hplip/hplip.conf" % s)
self.email_dirty = False
#user_conf.set('fax', 'email_address', s)
self.user_settings.email_address = s
self.user_settings.save()
#
#
#
def CancelButton_clicked(self):
self.close()
def SaveBtn_Clicked(self):
current_fax_num = self.fax_number = to_unicode(self.FaxNumberLineEdit.text())
current_fax_company = to_unicode(self.NameCompanyLineEdit.text())
if current_fax_num != self.fax_number:
if self.saveFaxNumber(self.fax_number) == False:
self.FaxNumberLineEdit.setText(current_fax_num)
else:
self.fax_number = to_unicode(self.FaxNumberLineEdit.text())
self.call_password_ui = False
if current_fax_company != self.fax_company_name:
if self.saveNameCompany(self.fax_company_name) == False:
self.NameCompanyLineEdit.setText(current_fax_company)
else:
self.fax_company_name = to_unicode(self.NameCompanyLineEdit.text())
self.call_password_ui = False
def Tabs_currentChanged(self, tab=0):
""" Called when the active tab changes.
Update newly displayed tab.
"""
if tab == 0:
self.updateHeaderTab()
elif tab == 1:
self.updateCoverpageTab()
def updateHeaderTab(self):
beginWaitCursor()
try:
try:
name_company = to_unicode(self.dev.getStationName())
log.debug("name_company = '%s'" % name_company)
self.NameCompanyLineEdit.setText(name_company)
fax_number = str(self.dev.getPhoneNum())
log.debug("fax_number = '%s'" % fax_number)
self.FaxNumberLineEdit.setText(fax_number)
except Error:
CheckDeviceUI(self)
finally:
endWaitCursor()
def updateCoverpageTab(self):
#voice_phone = user_conf.get('fax', 'voice_phone')
voice_phone = self.user_settings.voice_phone
log.debug("voice_phone = '%s'" % voice_phone)
self.VoiceNumberLineEdit.setText(voice_phone)
#email_address = user_conf.get('fax', 'email_address')
email_address = self.user_settings.email_address
log.debug("email_address = '%s'" % email_address)
self.EmailLineEdit.setText(email_address)
def closeEvent(self, e):
if self.voice_number_dirty:
self.VoiceNumberLineEdit.editingFinished.emit()
if self.name_company_dirty:
self.NameCompanyLineEdit.editingFinished.emit()
if self.email_dirty:
self.EmailLineEdit.editingFinished.emit()
if self.fax_number_dirty:
self.FaxNumberLineEdit.editingFinished.emit()
if self.dev is not None:
self.dev.close()
e.accept()
#
# Misc
#
def __tr(self, s, c=None):
return qApp.translate("FaxSetupDialog", s, c)
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 786 B | 0644 |
|
| aboutdialog.py | File | 1.71 KB | 0644 |
|
| aboutdialog_base.py | File | 8.27 KB | 0644 |
|
| aligndialog.py | File | 31.94 KB | 0644 |
|
| aligndialog_base.py | File | 24.45 KB | 0644 |
|
| cleandialog.py | File | 12.28 KB | 0644 |
|
| cleandialog_base.py | File | 11.46 KB | 0644 |
|
| colorcaldialog.py | File | 14.36 KB | 0644 |
|
| colorcaldialog_base.py | File | 23.27 KB | 0644 |
|
| devicesetupdialog.py | File | 8.57 KB | 0644 |
|
| devicesetupdialog_base.py | File | 4.58 KB | 0644 |
|
| deviceuricombobox.py | File | 5.4 KB | 0644 |
|
| devmgr5.py | File | 84.28 KB | 0644 |
|
| devmgr5_base.py | File | 23.31 KB | 0644 |
|
| devmgr_ext.py | File | 2.51 KB | 0644 |
|
| fabgrouptable.py | File | 2.26 KB | 0644 |
|
| fabnametable.py | File | 1.2 KB | 0644 |
|
| fabwindow.py | File | 23.63 KB | 0644 |
|
| fabwindow_base.py | File | 8.7 KB | 0644 |
|
| faxsetupdialog.py | File | 14.9 KB | 0644 |
|
| faxsetupdialog_base.py | File | 5.65 KB | 0644 |
|
| filetable.py | File | 15.45 KB | 0644 |
|
| firmwaredialog.py | File | 3 KB | 0644 |
|
| firmwaredialog_base.py | File | 3.59 KB | 0644 |
|
| infodialog.py | File | 10.22 KB | 0644 |
|
| infodialog_base.py | File | 5.76 KB | 0644 |
|
| linefeedcaldialog.py | File | 3.52 KB | 0644 |
|
| linefeedcaldialog_base.py | File | 2.7 KB | 0644 |
|
| loadpapergroupbox.py | File | 3.3 KB | 0644 |
|
| makecopiesdialog.py | File | 2.55 KB | 0644 |
|
| makecopiesdialog_base.py | File | 2.42 KB | 0644 |
|
| mimetypesdialog.py | File | 1.76 KB | 0644 |
|
| mimetypesdialog_base.py | File | 4.17 KB | 0644 |
|
| nodevicesdialog.py | File | 2.26 KB | 0644 |
|
| nodevicesdialog_base.py | File | 6.05 KB | 0644 |
|
| plugindiagnose.py | File | 3.03 KB | 0644 |
|
| plugindiagnose_base.py | File | 3.02 KB | 0644 |
|
| plugindialog.py | File | 12.2 KB | 0644 |
|
| plugindialog_base.py | File | 6.7 KB | 0644 |
|
| pluginlicensedialog.py | File | 1.34 KB | 0644 |
|
| pluginlicensedialog_base.py | File | 4.81 KB | 0644 |
|
| pqdiagdialog.py | File | 3.34 KB | 0644 |
|
| pqdiagdialog_base.py | File | 2.67 KB | 0644 |
|
| printdialog.py | File | 6 KB | 0644 |
|
| printdialog_base.py | File | 5.44 KB | 0644 |
|
| printernamecombobox.py | File | 5.46 KB | 0644 |
|
| printsettings_base.py | File | 210 B | 0644 |
|
| printsettingsdialog.py | File | 3.46 KB | 0644 |
|
| printsettingsdialog_base.py | File | 2.71 KB | 0644 |
|
| printsettingstoolbox.py | File | 79.17 KB | 0644 |
|
| printtestpagedialog.py | File | 4.78 KB | 0644 |
|
| printtestpagedialog_base.py | File | 4.22 KB | 0644 |
|
| queuesconf.py | File | 10.61 KB | 0644 |
|
| readonlyradiobutton.py | File | 1.63 KB | 0644 |
|
| scandialog.py | File | 89.66 KB | 0644 |
|
| sendfaxdialog.py | File | 37.13 KB | 0644 |
|
| sendfaxdialog_base.py | File | 23.96 KB | 0644 |
|
| settingsdialog.py | File | 4.15 KB | 0644 |
|
| settingsdialog_base.py | File | 16.93 KB | 0644 |
|
| setupdialog.py | File | 57.44 KB | 0644 |
|
| setupdialog_base.py | File | 23.38 KB | 0644 |
|
| setupdialog_base5.py | File | 23.17 KB | 0644 |
|
| systemtray.py | File | 32.35 KB | 0644 |
|
| systrayframe.py | File | 8.2 KB | 0644 |
|
| systrayframe_base.py | File | 5.96 KB | 0644 |
|
| ui_utils.py | File | 20.76 KB | 0644 |
|
| upgradedialog.py | File | 4.59 KB | 0644 |
|
| upgradedialog_base.py | File | 3.38 KB | 0644 |
|
| wifisetupdialog.py | File | 35.63 KB | 0644 |
|
| wifisetupdialog_base.py | File | 39.7 KB | 0644 |
|