diff options
author | Nino van Hooff <ninovanhooff@gmail.com> | 2020-02-28 16:01:11 +0300 |
---|---|---|
committer | Nino van Hooff <ninovanhooff@gmail.com> | 2020-02-28 16:03:41 +0300 |
commit | 86fb0383decb1469c44004d5e1a3c5c1ea2d55ef (patch) | |
tree | 7de629060b353d5b2a43ea39d44e4b825353d190 /plugins/CuraDrive | |
parent | 77590ad0e25b900756322a536420faf7f95741cf (diff) |
Refactor refresh backups call to use HttpRequestManager
Diffstat (limited to 'plugins/CuraDrive')
-rw-r--r-- | plugins/CuraDrive/src/DriveApiService.py | 50 | ||||
-rw-r--r-- | plugins/CuraDrive/src/DrivePluginExtension.py | 5 |
2 files changed, 27 insertions, 28 deletions
diff --git a/plugins/CuraDrive/src/DriveApiService.py b/plugins/CuraDrive/src/DriveApiService.py index d8349ccc29..35f8d95ca6 100644 --- a/plugins/CuraDrive/src/DriveApiService.py +++ b/plugins/CuraDrive/src/DriveApiService.py @@ -5,14 +5,19 @@ import base64 import hashlib from datetime import datetime from tempfile import NamedTemporaryFile -from typing import Any, Optional, List, Dict +from typing import Any, Optional, List, Dict, Callable import requests from UM.Logger import Logger from UM.Message import Message from UM.Signal import Signal, signalemitter +from UM.TaskManagement.HttpRequestManager import HttpRequestManager +from UM.TaskManagement.HttpRequestScope import JsonDecoratorScope from cura.CuraApplication import CuraApplication +from plugins.Toolbox.src.UltimakerCloudScope import UltimakerCloudScope + +from PyQt5.QtNetwork import QNetworkReply from .UploadBackupJob import UploadBackupJob from .Settings import Settings @@ -34,33 +39,24 @@ class DriveApiService: def __init__(self) -> None: self._cura_api = CuraApplication.getInstance().getCuraAPI() + self._scope = JsonDecoratorScope(UltimakerCloudScope(CuraApplication.getInstance())) + + def getBackups(self, changed: Callable): + def callback(reply: QNetworkReply): + backup_list_response = HttpRequestManager.readJSON(reply) + if "data" not in backup_list_response: + Logger.log("w", "Could not get backups from remote, actual response body was: %s", + str(backup_list_response)) + changed([]) # empty list of backups + + changed(backup_list_response["data"]) + + HttpRequestManager.getInstance().get( + self.BACKUP_URL, + callback=callback, + scope=self._scope + ) - def getBackups(self) -> List[Dict[str, Any]]: - access_token = self._cura_api.account.accessToken - if not access_token: - Logger.log("w", "Could not get access token.") - return [] - try: - backup_list_request = requests.get(self.BACKUP_URL, headers = { - "Authorization": "Bearer {}".format(access_token) - }) - except requests.exceptions.ConnectionError: - Logger.logException("w", "Unable to connect with the server.") - return [] - - # HTTP status 300s mean redirection. 400s and 500s are errors. - # Technically 300s are not errors, but the use case here relies on "requests" to handle redirects automatically. - if backup_list_request.status_code >= 300: - Logger.log("w", "Could not get backups list from remote: %s", backup_list_request.text) - Message(catalog.i18nc("@info:backup_status", "There was an error listing your backups."), title = catalog.i18nc("@info:title", "Backup")).show() - return [] - - backup_list_response = backup_list_request.json() - if "data" not in backup_list_response: - Logger.log("w", "Could not get backups from remote, actual response body was: %s", str(backup_list_response)) - return [] - - return backup_list_response["data"] def createBackup(self) -> None: self.creatingStateChanged.emit(is_creating = True) diff --git a/plugins/CuraDrive/src/DrivePluginExtension.py b/plugins/CuraDrive/src/DrivePluginExtension.py index bcc326a133..31bf0bc933 100644 --- a/plugins/CuraDrive/src/DrivePluginExtension.py +++ b/plugins/CuraDrive/src/DrivePluginExtension.py @@ -133,7 +133,10 @@ class DrivePluginExtension(QObject, Extension): @pyqtSlot(name = "refreshBackups") def refreshBackups(self) -> None: - self._backups = self._drive_api_service.getBackups() + self._drive_api_service.getBackups(self._backupsChangedCallback) + + def _backupsChangedCallback(self, backups): + self.backups = backups self.backupsChanged.emit() @pyqtProperty(bool, notify = restoringStateChanged) |