diff --git a/ltchat.py b/ltchat.py index 223a7cd..b434d29 100644 --- a/ltchat.py +++ b/ltchat.py @@ -1,403 +1,403 @@ #!/usr/bin/python2 """ Qt GUI front-end to the Lightron chat. Copyright (C) 2016-2017 Glen Harpring 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 3 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, see . """ import sys,os,httplib,urllib,urllib2,math,time,json,traceback print len(sys.argv) if len(sys.argv) < 2: gui = "-qt5" else: gui = sys.argv[1] try: if gui == "-qt4" or gui == "-qt3": raise ImportError from PyQt5 import QtCore, QtGui, QtWidgets guiused = "Qt5" except ImportError: #Fallback to PyQt4 print("Warning: Attempting to use Qt4") try: if gui == "-qt3": raise ImportError from PyQt4 import QtCore, QtGui from PyQt4 import QtGui as QtWidgets guiused = "Qt4" except ImportError: #Fallback to PySide is basically PyQt4 and is still included in the latest Ubuntu releases. try: if gui == "-qt3": raise ImportError from PySide import QtCore, QtGui from PySide import QtGui as QtWidgets guiused = "Qt4" except ImportError: print("Warning: Attempting to use Qt3") try: from qt import QtCore, QtGui guiused = "Qt3" except: print("PyQt4 or PyQt5 must be installed for this to work (properly)"); #from HTMLParser import HTMLParser global getChat,useragent getChat = httplib.HTTPSConnection('lightron.org') class ChatBrowser(QtWidgets.QTextBrowser): def loadResource(self,type,name): if type == 1: return urllib2.urlopen(str(name.toString())).read() if type == 2 or type == 3: if not str(name.toString()) in self.cache: try: flag = name.toString().split("https://lightron.org/inc/images/flags/")[1].split(".")[0]; except: flag = "tftde"; if 'https://lightron.org/inc/images/flags/' in name.toString() and flag is not "tftde" and os.path.isfile("/usr/share/locale/l10n/"+flag+"/flag.png"): self.cache[str(name.toString())] = QtGui.QImage("/usr/share/locale/l10n/"+flag+"/flag.png") else: print "Downloading "+name.toString()+" of type "+str(type)+" into memory..." try: self.cache[str(name.toString())] = QtGui.QImage.fromData(urllib2.urlopen(str(name.toString())).read(),os.path.splitext(name.toString())[1].upper()) print "[DONE]" except: print "[FAIL]" return False return self.cache[str(name.toString())] -useragent = "Mozilla/5.0 QTextBrowser/"+guiused+" LTChatGUI/3.0r10"; +useragent = "Mozilla/5.0 QTextBrowser/"+guiused+" LTChatGUI/3.0r12"; class main(object): def setup(self, MainWindow): global USERNAME,WHOSONLINE,curronline,PING,CHATS,wait,COOKIE,mself,FIRST mself=self COOKIE="";USERNAME = "Guest";WHOSONLINE = curronline = "";CHATS = "Loading...";PING = '?';wait=3;self.prevCHATS="";FIRST=True; self.thread = QtCore.QThread() #Create a generic thread for now self.chatstyle = """ html { width: 293px; font-size: 11px; font-family: verdana, sans-serif; line-height: 18px; } .send { width: 60px; padding: 0px; margin-top: 2px; } .message { position: relative; right: 3px; border-bottom: 1px solid #CCC; } .user { font-size: 12px; font-weight: bold; font-family: Arial; padding-right:3px; } .timestamp { color: #555; font-size: 10px; margin-left: 30px; } .delete { float: right; margin-right: 10px; }""" MainWindow.setObjectName("MainWindow") MainWindow.resize(335,400) MainWindow.setWindowTitle("Lightron Chat GUI") self.centralwidget = QtWidgets.QWidget(MainWindow) self.centralwidget.setObjectName("centralwidget") self.gridLayout = QtWidgets.QGridLayout(self.centralwidget) self.gridLayout.setObjectName("gridLayout") self.label = QtWidgets.QLabel(self.centralwidget) self.label.setObjectName("label") self.gridLayout.addWidget(self.label, 1, 0, 1, 1) self.label_3 = QtWidgets.QLabel(self.centralwidget) self.label_3.setObjectName("label_3") self.gridLayout.addWidget(self.label_3, 1, 1, 1, 2) self.pushButton_2 = QtWidgets.QPushButton(self.centralwidget) self.pushButton_2.setObjectName("pushButton_2") self.pushButton_2.setText("Options") self.pushButton_2.clicked.connect(self.showOptions) self.gridLayout.addWidget(self.pushButton_2, 1, 3, 1, 1) self.textBrowser = ChatBrowser(self.centralwidget) self.textBrowser.setObjectName("textBrowser") self.textBrowser.cache = {} self.textBrowser.setOpenExternalLinks(True) self.gridLayout.addWidget(self.textBrowser, 2, 0, 1, 4) self.pushButton = QtWidgets.QPushButton(self.centralwidget) self.pushButton.setObjectName("pushButton") self.pushButton.setText("Send") self.pushButton.clicked.connect(self.send) self.gridLayout.addWidget(self.pushButton, 3, 3, 1, 1) self.lineEdit = QtWidgets.QLineEdit(self.centralwidget) self.lineEdit.setObjectName("lineEdit") self.gridLayout.addWidget(self.lineEdit, 3, 0, 1, 3) self.label_2 = QtWidgets.QLabel(self.centralwidget) self.label_2.setObjectName("label_2") self.label_2.setOpenExternalLinks(True) self.gridLayout.addWidget(self.label_2, 5, 0, 1, 4) MainWindow.setCentralWidget(self.centralwidget) self.updateTimer = QtCore.QTimer(MainWindow) self.updateTimer.timeout.connect(self.update) self.updateTimer.start(4000) self.updated();self.update() QtCore.QMetaObject.connectSlotsByName(MainWindow) def update(self): if not self.thread.isRunning(): self.prevCHATS = CHATS self.thread = UpdatingChat() self.thread.finished.connect(self.updated) self.thread.start() def send(self): global COOKIE postdata = urllib.urlencode({'action':'submit','message':str(self.lineEdit.text())}) try: con = httplib.HTTPSConnection("lightron.org") con.request("POST","/Ajax/Chat",postdata,{"User-Agent":useragent,"Cookie":COOKIE,"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8"}) ChatsResponse = con.getresponse() except: pass; self.lineEdit.setText("") self.updated();self.update() def showOptions(self): self.options = QtWidgets.QMenu() if USERNAME == "Guest": self.optionsLogin = self.options.addAction("Login") self.optionsLogin.triggered.connect(self.login) else: self.optionsProfile = self.options.addAction("Profile") self.optionsProfile.triggered.connect(self.profile) self.optionsLogout = self.options.addAction("Logout") self.optionsLogout.triggered.connect(self.logout) self.options.addSeparator() self.optionsStats = self.options.addAction("Statitics") self.optionsStats.triggered.connect(self.stats) self.optionsAbout = self.options.addAction("About") self.optionsStats.triggered.connect(self.about) #self.optionsToC = self.options.addAction("License Agreement") #self.optionsToC.triggered.connect(self.gpl) self.options.exec_(QtGui.QCursor().pos()) def updated(self): global USERNAME,COOKIE if USERNAME == "Guest": self.label.setText("Please sign in to chat.") out=True else: self.label.setText("Hello, "+USERNAME+"!") out=False self.pushButton.setHidden(out) self.lineEdit.setHidden(out) self.label_3.setText(str(PING)+"ms") self.label_2.setText(WHOSONLINE) self.label_2.setToolTip(curronline) if CHATS == "": print "Returned chat appears to be blank." elif not self.prevCHATS == CHATS: self.textBrowser.setHtml('\n
'+str(CHATS)+"
") def login(self): login() def completeLogin(self): global USERNAME, COOKIE postdata = urllib.urlencode({'username':loginDia.lineEdit.text(),'password':loginDia.lineEdit_2.text()}) try: con = httplib.HTTPSConnection("lightron.org") con.request("POST","/Authentication",postdata,{"User-Agent":useragent,"Cookie":COOKIE,"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8"}) except: QtWidgets.QMessageBox.critical(MainWindow,'LTChat','Unable to login. Are you connected to the internet?',QtWidgets.QMessageBox.Ok) return; data = con.getresponse() datar = str(data.read()) datars = data.getheader('Location') if datars == "/?invalid": QtWidgets.QMessageBox.warning(MainWindow,'LTChat','Username and/or password invalid.',QtWidgets.QMessageBox.Ok) loginDia.lineEdit_2.selectAll() elif datars != "/": QtWidgets.QMessageBox.critical(MainWindow,'LTChat','Returned "'+datar.rstrip('\n')+'"',QtWidgets.QMessageBox.Ok) else: #self.lineEdit.setText(str(data)) #COOKIE = data.getheader('Cookie') USERNAME = loginDia.lineEdit.text() loginDia.hide() self.update() def logout(self): global USERNAME, COOKIE USERNAME = "Guest";COOKIE=""; self.updated() def profile(self): profile() def stats(self): return; def about(self): return; def changepass(self): return; class LoginDialog(QtWidgets.QDialog): def __init__(self): super(LoginDialog,self).__init__() self.setup() def setup(self): self.setWindowTitle("Login to LTChat") self.resize(335,80) self.gridLayout = QtWidgets.QGridLayout(self) self.gridLayout.setObjectName("gridLayout") spacerItem = QtWidgets.QSpacerItem(260, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum) self.gridLayout.addItem(spacerItem, 2, 0, 1, 1) self.pushButton = QtWidgets.QPushButton(self) self.pushButton.setObjectName("pushButton") self.pushButton.setText("Login!") self.pushButton.setShortcut("Enter, Return") self.pushButton.clicked.connect(mself.completeLogin) self.gridLayout.addWidget(self.pushButton, 2, 1, 1, 1) self.lineEdit = QtWidgets.QLineEdit(self) self.lineEdit.setObjectName("lineEdit") self.lineEdit.setPlaceholderText("Username") self.gridLayout.addWidget(self.lineEdit, 0, 0, 1, 2) self.lineEdit_2 = QtWidgets.QLineEdit(self) self.lineEdit_2.setEchoMode(QtWidgets.QLineEdit.Password) self.lineEdit_2.setObjectName("lineEdit_2") self.lineEdit_2.setPlaceholderText("Password") self.gridLayout.addWidget(self.lineEdit_2, 1, 0, 1, 2) QtCore.QMetaObject.connectSlotsByName(self) class profileDialog(QtWidgets.QDialog): def __init__(self): super(profileDialog,self).__init__() self.setup() def setup(self): self.setWindowTitle("My Profile - LTChat") self.resize(335,80) try: con = httplib.HTTPSConnection("lightron.org") con.request("POST","/Authentication",urllib.urlencode({'action':'userControlPanel'}),{"User-Agent":useragent,"Cookie":COOKIE,"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8"}) except: QtWidgets.QMessageBox.critical(MainWindow,'LTChat','Unable to login. Are you connected to the internet?',QtWidgets.QMessageBox.Ok) return; self.gridLayout = QtWidgets.QGridLayout(self) self.gridLayout.setObjectName("gridLayout") spacerItem = QtWidgets.QSpacerItem(260, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum) self.gridLayout.addItem(spacerItem, 2, 0, 1, 1) self.pushButton = QtWidgets.QPushButton(self) self.pushButton.setObjectName("pushButton") self.pushButton.setText("Close") self.pushButton.setShortcut("Enter, Return") self.pushButton.clicked.connect(self.close) self.gridLayout.addWidget(self.pushButton, 2, 1, 1, 1) self.profileImage = QtWidgets.QLabel() image = "https://lightron.org/inc/images/avatar/101.png" self.proImage = QtGui.QPixmap.fromImage(mself.textBrowser.loadResource(2,QtCore.QUrl(image))) self.profileImage.setPixmap(self.proImage) self.gridLayout.addWidget(self.profileImage, 0, 0, 1, 2) QtCore.QMetaObject.connectSlotsByName(self) class UpdatingChat(QtCore.QThread): def run(self): global USERNAME,WHOSONLINE,curronline,PING,CHATS,wait,getChat,FIRST,COOKIE if FIRST: try: con = httplib.HTTPSConnection("lightron.org") con.request("GET","/","",{"User-Agent":useragent}) data = con.getresponse() except httplib.ssl.SSLError: ex_type, ex, tb = sys.exc_info() CHATS = "

Error: SSL Certificate Error!

"+traceback.format_exc(tb)+"

" PING = "inf"; WHOSONLINE = ""; curronline = "can't tell" del tb; return; except: CHATS = "

Error: Loading failed, is your internet connected?

" PING = "inf"; WHOSONLINE = ""; curronline = "can't tell" return; FIRST = False; cookieheader = data.getheader('Set-Cookie'); if cookieheader is None: cookieheader = ""; COOKIE = cookieheader.split(" ")[0] wait=wait+1 defheader = {"User-Agent":useragent,"Cookie":COOKIE,"Content-Type":"application/x-www-form-urlencoded; charset=UTF-8","X-Requested-With":"XMLHttpRequest"} getChat = httplib.HTTPSConnection('lightron.org') pullr = urllib.urlencode({"action":"pull","max-id":"0"}) try: timebefore=time.time(); getChat.request("POST","/Ajax/Chat",pullr,defheader); timeafter=time.time() PING = int((float(timeafter)-float(timebefore))*1000) except: return; try: ChatsRespons = getChat.getresponse().read() #print ChatsRespons; except: if CHATS is "": CHATS = "

Error: Unable to receive chats. Is your internet connection working?

" PING = "inf"; WHOSONLINE = ""; curronline = "can't tell" try: ChatsResponse = json.loads(ChatsRespons) #print ChatsResponse; except: return thechatshtm = ChatsResponse["output"].replace("margin: 0px 4px -1px 0px;","margin-right:4px;margin-bottom:-1px;") #WHOSONLINE = ChatsResponse["chatters"].replace("padding: 0px 4px;\">","\"> ") WHOSONLINE = ChatsResponse["online"] if len(ChatsResponse["online"].split(":")) > 1: curronline = ChatsResponse["online"].split(":")[1].replace("padding: 0px 4px;\">","\"> ") else: curronline = "nobody" CHATS = str(thechatshtm.replace("