mirror of
https://github.com/robweber/xbmcbackup.git
synced 2024-12-22 14:05:23 +01:00
865416977d
* updated addon.xml for Krypton * default log level is always debug now * added screenshots per krypton format * started new way of defining backup directories * reconfigured simple backup process * added an advanced backup editor and combined settings.xml scripts into a launcher * added strings for advanced editor * there was a function to do this * match excluded with regex * updated def for the addons set * directory has to end in slash to use exists() * added a backup set chooser on restore * added string for restore browser * utilize details to show root folder and icons * save non translated paths, better cross platform support * revert dropbox python 2.6 changes * start of #132 * can't have duplicate ids * updated strings * closes #132 * added a disclaimer for breaking changes * split backup and restore into separate functions * updated scripting to pass in list of sets to restore * beta version * added 2 min delay in startup - part of #147 * forgot to remove debug message * change to wait for abort in case someone tries to close Kodi * add retroplayer game saves to default file list * display restore points with most recent on top * remove length check, breaking change with this version means old archives are no longer compatible * format restore list according to regional settings * this function isn't used anymore, legacy of old file manager * use images folder as default * added note about compatibility * added utils function for regional date, use for scheduler notifications as well * add/remove include and exclude directories to a set * paths should have / at the end * show path relative to root * if in advanced mode allow jumping to editor from launch screen * check that path is within root folder of set * cannot have duplicate set names or rules regarding folders within a set * put strings in correct lang file * beta version bump * accidentally deleted string id * change exclude criteria. Regex was not matching in complex cases * make sure the dest folder (backup set root) exists before writing to it * modify select display to show recursive value for included folders * use a context menu here * added ability to toggle recursion of sub folders * beta 3 * added support doc * wrong branch * don't need this import anymore * don't need these imports * part of #133
65 lines
2.2 KiB
Python
65 lines
2.2 KiB
Python
import sys
|
|
import urlparse
|
|
import xbmc
|
|
import xbmcgui
|
|
import xbmcvfs
|
|
import resources.lib.utils as utils
|
|
from resources.lib.authorizers import DropboxAuthorizer,GoogleDriveAuthorizer
|
|
from resources.lib.advanced_editor import AdvancedBackupEditor
|
|
|
|
|
|
#launcher for various helpful functions found in the settings.xml area
|
|
|
|
def authorize_cloud(cloudProvider):
|
|
#drobpox
|
|
if(cloudProvider == 'dropbox'):
|
|
authorizer = DropboxAuthorizer()
|
|
|
|
if(authorizer.authorize()):
|
|
xbmcgui.Dialog().ok(utils.getString(30010),utils.getString(30027) + ' ' + utils.getString(30106))
|
|
else:
|
|
xbmcgui.Dialog().ok(utils.getString(30010),utils.getString(30107) + ' ' + utils.getString(30027))
|
|
|
|
#google drive
|
|
elif(cloudProvider == 'google_drive'):
|
|
authorizer = GoogleDriveAuthorizer()
|
|
|
|
if(authorizer.authorize()):
|
|
xbmcgui.Dialog().ok("Backup",utils.getString(30098) + ' ' + utils.getString(30106))
|
|
else:
|
|
xbmcgui.Dialog().ok("Backup",utils.getString(30107) + ' ' + utils.getString(30098))
|
|
|
|
def remove_auth():
|
|
#triggered from settings.xml - asks if user wants to delete OAuth token information
|
|
shouldDelete = xbmcgui.Dialog().yesno(utils.getString(30093),utils.getString(30094),utils.getString(30095),autoclose=7000)
|
|
|
|
if(shouldDelete):
|
|
#delete any of the known token file types
|
|
xbmcvfs.delete(xbmc.translatePath(utils.data_dir() + "tokens.txt")) #dropbox
|
|
xbmcvfs.delete(xbmc.translatePath(utils.data_dir() + "google_drive.dat")) #google drive
|
|
|
|
def get_params():
|
|
param = {}
|
|
try:
|
|
for i in sys.argv:
|
|
args = i
|
|
if(args.startswith('?')):
|
|
args = args[1:]
|
|
param.update(dict(urlparse.parse_qsl(args)))
|
|
except:
|
|
pass
|
|
return param
|
|
|
|
params = get_params()
|
|
|
|
if(params['action'] == 'authorize_cloud'):
|
|
authorize_cloud(params['provider'])
|
|
elif(params['action'] == 'remove_auth'):
|
|
remove_auth()
|
|
elif(params['action'] == 'advanced_editor'):
|
|
editor = AdvancedBackupEditor()
|
|
editor.showMainScreen()
|
|
elif(params['action'] == 'advanced_copy_config'):
|
|
editor = AdvancedBackupEditor()
|
|
editor.copySimpleConfig()
|