2019-11-25 15:48:42 -06:00
|
|
|
import xbmcgui
|
|
|
|
import xbmcvfs
|
2017-01-31 08:08:00 -06:00
|
|
|
import resources.lib.tinyurl as tinyurl
|
|
|
|
import resources.lib.utils as utils
|
2019-08-26 15:40:15 -05:00
|
|
|
|
2019-11-25 15:19:57 -06:00
|
|
|
# don't die on import error yet, these might not even get used
|
2019-08-26 15:40:15 -05:00
|
|
|
try:
|
2019-11-26 12:58:35 -06:00
|
|
|
from dropbox import dropbox
|
2020-12-18 09:31:52 -06:00
|
|
|
from dropbox import oauth
|
2019-08-26 15:40:15 -05:00
|
|
|
except ImportError:
|
|
|
|
pass
|
|
|
|
|
2019-11-26 10:43:38 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
class DropboxAuthorizer:
|
|
|
|
APP_KEY = ""
|
|
|
|
APP_SECRET = ""
|
2019-11-26 10:43:38 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
def __init__(self):
|
|
|
|
self.APP_KEY = utils.getSetting('dropbox_key')
|
|
|
|
self.APP_SECRET = utils.getSetting('dropbox_secret')
|
|
|
|
|
|
|
|
def setup(self):
|
2017-11-07 14:19:27 -06:00
|
|
|
result = True
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
if(self.APP_KEY == '' and self.APP_SECRET == ''):
|
2019-11-25 15:19:57 -06:00
|
|
|
# we can't go any farther, need these for sure
|
2020-12-18 09:28:17 -06:00
|
|
|
xbmcgui.Dialog().ok(utils.getString(30010), '%s %s\n%s' % (utils.getString(30027), utils.getString(30058), utils.getString(30059)))
|
2017-11-07 14:19:27 -06:00
|
|
|
|
|
|
|
result = False
|
2019-11-25 15:33:34 -06:00
|
|
|
|
|
|
|
return result
|
2017-01-31 08:08:00 -06:00
|
|
|
|
|
|
|
def isAuthorized(self):
|
2017-12-03 17:32:21 -06:00
|
|
|
user_token = self._getToken()
|
2017-01-31 08:08:00 -06:00
|
|
|
|
2019-11-26 10:49:17 -06:00
|
|
|
return user_token != ''
|
2017-01-31 08:08:00 -06:00
|
|
|
|
|
|
|
def authorize(self):
|
|
|
|
result = True
|
2017-11-07 14:19:27 -06:00
|
|
|
|
|
|
|
if(not self.setup()):
|
|
|
|
return False
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
if(self.isAuthorized()):
|
2019-11-25 15:19:57 -06:00
|
|
|
# delete the token to start over
|
2017-01-31 08:08:00 -06:00
|
|
|
self._deleteToken()
|
|
|
|
|
2019-11-25 15:19:57 -06:00
|
|
|
# copied flow from http://dropbox-sdk-python.readthedocs.io/en/latest/moduledoc.html#dropbox.oauth.DropboxOAuth2FlowNoRedirect
|
2020-12-18 09:31:52 -06:00
|
|
|
flow = oauth.DropboxOAuth2FlowNoRedirect(self.APP_KEY, self.APP_SECRET)
|
2017-01-31 08:08:00 -06:00
|
|
|
|
2017-12-03 17:32:21 -06:00
|
|
|
url = flow.start()
|
2017-01-31 08:08:00 -06:00
|
|
|
|
2019-11-25 15:19:57 -06:00
|
|
|
# print url in log
|
2017-01-31 08:08:00 -06:00
|
|
|
utils.log("Authorize URL: " + url)
|
2020-12-18 09:31:52 -06:00
|
|
|
xbmcgui.Dialog().ok(utils.getString(30010), '%s\n%s\n%s' % (utils.getString(30056), utils.getString(30057), str(tinyurl.shorten(url), 'utf-8')))
|
2017-12-03 17:32:21 -06:00
|
|
|
|
2019-11-25 15:19:57 -06:00
|
|
|
# get the auth code
|
2017-12-03 17:32:21 -06:00
|
|
|
code = xbmcgui.Dialog().input(utils.getString(30027) + ' ' + utils.getString(30103))
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2019-11-26 10:43:38 -06:00
|
|
|
# if user authorized this will work
|
2017-01-31 08:08:00 -06:00
|
|
|
|
2017-12-03 17:32:21 -06:00
|
|
|
try:
|
|
|
|
user_token = flow.finish(code)
|
|
|
|
self._setToken(user_token.access_token)
|
2019-08-19 15:23:48 -05:00
|
|
|
except Exception as e:
|
2017-12-03 17:32:21 -06:00
|
|
|
utils.log("Error: %s" % (e,))
|
|
|
|
result = False
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2019-11-26 10:49:17 -06:00
|
|
|
return result
|
2017-01-31 08:08:00 -06:00
|
|
|
|
2019-11-25 15:19:57 -06:00
|
|
|
# return the DropboxClient, or None if can't be created
|
2017-01-31 08:08:00 -06:00
|
|
|
def getClient(self):
|
|
|
|
result = None
|
|
|
|
|
2017-12-03 17:32:21 -06:00
|
|
|
user_token = self._getToken()
|
|
|
|
|
|
|
|
if(user_token != ''):
|
2019-11-26 10:43:38 -06:00
|
|
|
# create the client
|
2017-12-03 17:32:21 -06:00
|
|
|
result = dropbox.Dropbox(user_token)
|
2017-01-31 08:08:00 -06:00
|
|
|
|
|
|
|
try:
|
2017-12-03 17:32:21 -06:00
|
|
|
result.users_get_current_account()
|
2017-01-31 08:08:00 -06:00
|
|
|
except:
|
2019-11-26 10:43:38 -06:00
|
|
|
# this didn't work, delete the token file
|
2017-01-31 08:08:00 -06:00
|
|
|
self._deleteToken()
|
2017-12-03 17:32:21 -06:00
|
|
|
result = None
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
return result
|
|
|
|
|
2019-11-25 15:45:41 -06:00
|
|
|
def _setToken(self, token):
|
2019-11-25 15:19:57 -06:00
|
|
|
# write the token files
|
2020-11-18 14:07:06 -06:00
|
|
|
token_file = open(xbmcvfs.translatePath(utils.data_dir() + "tokens.txt"), 'w')
|
2017-12-03 17:32:21 -06:00
|
|
|
token_file.write(token)
|
2017-01-31 08:08:00 -06:00
|
|
|
token_file.close()
|
|
|
|
|
|
|
|
def _getToken(self):
|
2019-11-25 15:19:57 -06:00
|
|
|
# get token, if it exists
|
2020-11-18 14:07:06 -06:00
|
|
|
if(xbmcvfs.exists(xbmcvfs.translatePath(utils.data_dir() + "tokens.txt"))):
|
|
|
|
token_file = open(xbmcvfs.translatePath(utils.data_dir() + "tokens.txt"))
|
2017-12-03 17:32:21 -06:00
|
|
|
token = token_file.read()
|
2017-01-31 08:08:00 -06:00
|
|
|
token_file.close()
|
|
|
|
|
2017-12-03 17:32:21 -06:00
|
|
|
return token
|
2017-01-31 08:08:00 -06:00
|
|
|
else:
|
2017-12-03 17:32:21 -06:00
|
|
|
return ""
|
2019-11-25 15:33:34 -06:00
|
|
|
|
2017-01-31 08:08:00 -06:00
|
|
|
def _deleteToken(self):
|
2020-11-18 14:07:06 -06:00
|
|
|
if(xbmcvfs.exists(xbmcvfs.translatePath(utils.data_dir() + "tokens.txt"))):
|
|
|
|
xbmcvfs.delete(xbmcvfs.translatePath(utils.data_dir() + "tokens.txt"))
|