8e1a3c8c73
* Properly find row to insert sid_edit into * Use lazy evaluation for logging * Clean the login forms by using separate layouts for the interactive fields
91 lines
3.5 KiB
Python
91 lines
3.5 KiB
Python
import json
|
|
from logging import getLogger
|
|
from typing import Tuple
|
|
|
|
from PyQt5.QtCore import pyqtSignal, QUrl
|
|
from PyQt5.QtGui import QDesktopServices
|
|
from PyQt5.QtWidgets import QFrame, qApp, QFormLayout, QLineEdit
|
|
from legendary.core import LegendaryCore
|
|
from legendary.utils import webview_login
|
|
|
|
from rare.ui.components.dialogs.login.browser_login import Ui_BrowserLogin
|
|
from rare.utils.misc import icon
|
|
from rare.widgets.indicator_edit import IndicatorLineEdit, IndicatorReasonsCommon
|
|
|
|
logger = getLogger("BrowserLogin")
|
|
|
|
|
|
class BrowserLogin(QFrame):
|
|
success = pyqtSignal()
|
|
changed = pyqtSignal()
|
|
|
|
def __init__(self, core: LegendaryCore, parent=None):
|
|
super(BrowserLogin, self).__init__(parent=parent)
|
|
self.setFrameStyle(self.StyledPanel)
|
|
self.ui = Ui_BrowserLogin()
|
|
self.ui.setupUi(self)
|
|
|
|
self.core = core
|
|
self.login_url = self.core.egs.get_auth_url()
|
|
|
|
self.sid_edit = IndicatorLineEdit(
|
|
placeholder=self.tr("Insert authorizationCode here"), edit_func=self.text_changed, parent=self
|
|
)
|
|
self.sid_edit.line_edit.setEchoMode(QLineEdit.Password)
|
|
self.ui.link_text.setText(self.login_url)
|
|
self.ui.copy_button.setIcon(icon("mdi.content-copy", "fa.copy"))
|
|
self.ui.copy_button.clicked.connect(self.copy_link)
|
|
self.ui.form_layout.setWidget(
|
|
self.ui.form_layout.getWidgetPosition(self.ui.sid_label)[0],
|
|
QFormLayout.FieldRole, self.sid_edit
|
|
)
|
|
|
|
self.ui.open_button.clicked.connect(self.open_browser)
|
|
self.sid_edit.textChanged.connect(self.changed.emit)
|
|
|
|
def copy_link(self):
|
|
clipboard = qApp.clipboard()
|
|
clipboard.setText(self.login_url)
|
|
self.ui.status_label.setText(self.tr("Copied to clipboard"))
|
|
|
|
def is_valid(self):
|
|
return self.sid_edit.is_valid
|
|
|
|
@staticmethod
|
|
def text_changed(text) -> Tuple[bool, str, int]:
|
|
if text:
|
|
text = text.strip()
|
|
if text.startswith("{") and text.endswith("}"):
|
|
try:
|
|
text = json.loads(text).get("authorizationCode")
|
|
except json.JSONDecodeError:
|
|
return False, text, IndicatorReasonsCommon.WRONG_FORMAT
|
|
elif '"' in text:
|
|
text = text.strip('"')
|
|
return len(text) == 32, text, IndicatorReasonsCommon.WRONG_FORMAT
|
|
else:
|
|
return False, text, IndicatorReasonsCommon.VALID
|
|
|
|
def do_login(self):
|
|
self.ui.status_label.setText(self.tr("Logging in..."))
|
|
auth_code = self.sid_edit.text()
|
|
try:
|
|
if self.core.auth_code(auth_code):
|
|
logger.info("Successfully logged in as %s", self.core.lgd.userdata['displayName'])
|
|
self.success.emit()
|
|
else:
|
|
self.ui.status_label.setText(self.tr("Login failed."))
|
|
logger.warning("Failed to login through browser")
|
|
except Exception as e:
|
|
logger.warning(e)
|
|
|
|
def open_browser(self):
|
|
if not webview_login.webview_available:
|
|
logger.warning("You don't have webengine installed, you will need to manually copy the authorizationCode.")
|
|
QDesktopServices.openUrl(QUrl(self.login_url))
|
|
else:
|
|
if webview_login.do_webview_login(callback_code=self.core.auth_ex_token):
|
|
logger.info("Successfully logged in as %s", {self.core.lgd.userdata['displayName']})
|
|
self.success.emit()
|
|
else:
|
|
logger.warning("Failed to login through browser.")
|