diff options
-rw-r--r-- | module/setup.py | 138 | ||||
-rw-r--r-- | module/utils.py | 14 |
2 files changed, 95 insertions, 57 deletions
diff --git a/module/setup.py b/module/setup.py index ffe2a01ef..7848359a6 100644 --- a/module/setup.py +++ b/module/setup.py @@ -10,7 +10,7 @@ from os import makedirs from os.path import abspath, dirname, exists, join from subprocess import PIPE, call -from module.utils import get_console_encoding +from module.utils import get_console_encoding, versiontuple class Setup: @@ -24,7 +24,7 @@ class Setup: def start(self): langs = self.config.getMetaData("general", "language")["type"].split(";") - lang = self.ask(u"Choose your Language", "en", langs) + lang = self.ask(u"Choose setup language", "en", langs) gettext.setpaths([join(os.sep, "usr", "share", "pyload", "locale"), None]) translation = gettext.translation("setup", join(self.path, "locale"), languages=[lang, "en"], fallback=True) translation.install(True) @@ -50,6 +50,7 @@ class Setup: # print "Falling back to commandline setup." print + print print _("Welcome to the pyLoad Configuration Assistant.") print _("It will check your system and make a basic setup in order to run pyLoad.") print @@ -60,18 +61,23 @@ class Setup: print _("If you have any problems with this assistant hit STRG-C,") print _("to abort and don't let him start with pyload.py automatically anymore.") print - print _("When you are ready for system check, hit enter.") - raw_input() + print + raw_input(_("When you are ready for system check, hit enter.")) + print print basic, ssl, captcha, web, js = self.system_check() print + print if not basic: print _("You need pycurl, sqlite and python 2.5, 2.6 or 2.7 to run pyLoad.") print _("Please correct this and re-run pyLoad.") + print print _("Setup will now close.") - raw_input() + print + print + raw_input(_("Press Enter to exit.")) return False raw_input(_("System check finished, hit enter to see your status report.")) @@ -88,7 +94,7 @@ class Setup: if captcha: avail.append(_("automatic captcha decryption")) if web: - avail.append(_("Webinterface")) + avail.append(_("webinterface")) if js: avail.append(_("extended Click'N'Load")) @@ -97,50 +103,50 @@ class Setup: for av in avail: string += ", " + av - print _("Features available:") - print - print string[1:] - print + print _("AVAILABLE FEATURES:") + string[1:] print if len(avail) < 5: - print _("Featues missing: ") - print + print _("MISSING FEATURES: ") if not self.check_module("Crypto"): - print _("no py-crypto available") + print _("- no py-crypto available") print _("You need this if you want to decrypt container files.") print if not ssl: - print _("no SSL available") + print _("- no SSL available") print _("This is needed if you want to establish a secure connection to core or webinterface.") print _("If you only want to access locally to pyLoad ssl is not usefull.") print if not captcha: - print _("no Captcha Recognition available") + print _("- no Captcha Recognition available") print _("Only needed for some hosters and as freeuser.") print if not js: - print _("no JavaScript engine found") + print _("- no JavaScript engine found") print _("You will need this for some Click'N'Load links. Install Spidermonkey, ossp-js, pyv8 or rhino") + print + print print _("You can abort the setup now and fix some dependicies if you want.") + print con = self.ask(_("Continue with setup?"), self.yes, bool=True) if not con: return False print - print _("Do you want to change the config path?") + print print _("CURRENT CONFIG PATH: %s") % abspath("") - print _( - "If you use pyLoad on a server or the home partition lives on an iternal flash it may be a good idea to change it.") - path = self.ask(_("Change config path?"), self.no, bool=True) + print + print _("NOTE: If you use pyLoad on a server or the home partition lives on an iternal flash it may be a good idea to change it.") + path = self.ask(_("Do you want to change the config path?"), self.no, bool=True) if path: + print self.conf_path() #calls exit when changed @@ -150,6 +156,8 @@ class Setup: con = self.ask(_("Make basic setup?"), self.yes, bool=True) if con: + print + print self.conf_basic() if ssl: @@ -158,6 +166,7 @@ class Setup: ssl = self.ask(_("Configure ssl?"), self.no, bool=True) if ssl: print + print self.conf_ssl() if web: @@ -165,17 +174,30 @@ class Setup: print _("Do you want to configure webinterface?") web = self.ask(_("Configure webinterface?"), self.yes, bool=True) if web: + print + print self.conf_web() print - print _("Setup finished successfully.") - print _("Hit enter to exit and restart pyLoad") - raw_input() + print + print _("Setup finished successfully!") + print + print + raw_input(_("Hit enter to exit and restart pyLoad.")) return True def system_check(self): """ make a systemcheck and return the results""" + + print _("## System Information ##") + print + print _("Platform: %s") % sys.platform + print _("Operating System: %s") % os.name + print _("Python: %s") % sys.version.replace("\n", "") + print + print + print _("## System Check ##") print @@ -221,49 +243,53 @@ class Setup: print - jinja = True - try: import jinja2 v = jinja2.__version__ - if v and "unknown" not in v: - if not v.startswith("2.5") and not v.startswith("2.6"): - print _("Your installed jinja2 version %s seems too old.") % jinja2.__version__ - print _("You can safely continue but if the webinterface is not working,") - print _("please upgrade or deinstall it, pyLoad includes a sufficient jinja2 libary.") - print - jinja = False + if v and versiontuple(v) < (2, 5, 0): + jinja = False + else: + jinja = True except: - pass + jinja = False + + jinja = self.print_dep("jinja2", jinja) - self.print_dep("jinja2", jinja) beaker = self.check_module("beaker") self.print_dep("beaker", beaker) + bjoern = self.check_module("bjoern") self.print_dep("bjoern", bjoern) web = sqlite and beaker from module.common import JsEngine - js = True if JsEngine.ENGINE else False self.print_dep(_("JS engine"), js) + if not jinja: + print + print + print _("WARNING: Your installed jinja2 version %s seems too old.") % jinja2.__version__ + print _("You can safely continue but if the webinterface is not working,") + print _("please upgrade or uninstall it, because pyLoad self-includes jinja2 libary.") + return basic, ssl, captcha, web, js def conf_basic(self): - print print _("## Basic Setup ##") print print _("The following logindata is valid for CLI and webinterface.") - + from module.database import DatabaseBackend db = DatabaseBackend(None) db.setup() + print _("NOTE: Consider a password of 10 or more symbols if you expect to access from outside your local network (ex. internet).") + print username = self.ask(_("Username"), "User") password = self.ask("", "", password=True) db.addUser(username, password) @@ -276,13 +302,13 @@ class Setup: print langs = self.config.getMetaData("general", "language") - self.config["general"]["language"] = self.ask(_("Language"), "en", langs["type"].split(";")) + self.config["general"]["language"] = self.ask(_("Choose pyLoad language"), "en", langs["type"].split(";")) - self.config["general"]["download_folder"] = self.ask(_("Downloadfolder"), "Downloads") + print + self.config["general"]["download_folder"] = self.ask(_("Download folder"), "Downloads") + print self.config["download"]["max_downloads"] = self.ask(_("Max parallel downloads"), "3") - #print _("You should disable checksum proofing, if you have low hardware requirements.") - #self.config["general"]["checksum"] = self.ask(_("Proof checksum?"), "y", bool=True) - + print reconnect = self.ask(_("Use Reconnect?"), self.no, bool=True) self.config["reconnect"]["activated"] = reconnect if reconnect: @@ -290,7 +316,6 @@ class Setup: def conf_web(self): - print print _("## Webinterface Setup ##") print @@ -301,16 +326,15 @@ class Setup: self.config["webinterface"]["port"] = self.ask(_("Port"), "8000") print print _("pyLoad offers several server backends, now following a short explanation.") - print "builtin:", _("Default server; best choice if you plan to use pyLoad just for you.") - print "threaded:", _("Support SSL connection and can serve simultaneously more client flawlessly.") - print "fastcgi:", _( + print "- builtin:", _("Default server; best choice if you plan to use pyLoad just for you.") + print "- threaded:", _("Support SSL connection and can serve simultaneously more client flawlessly.") + print "- fastcgi:", _( "Can be used by apache, lighttpd, etc.; needs to be properly configured before.") if os.name != "nt": - print "lightweight:", _("Very fast alternative to builtin; requires libev and bjoern packages.") + print "- lightweight:", _("Very fast alternative to builtin; requires libev and bjoern packages.") print - print _( - "Attention: In some rare cases the builtin server is not working, if you notice problems with the webinterface") + print _("NOTE: In some rare cases the builtin server is not working, if you notice problems with the webinterface") print _("come back here and change the builtin server to the threaded one here.") if os.name == "nt": @@ -395,8 +419,8 @@ class Setup: languages=[self.config["general"]["language"], "en"], fallback=True) translation.install(True) - print _("Setting new configpath, current configuration will not be transfered!") - path = self.ask(_("Configpath"), abspath("")) + print _("Setting new config path, current configuration will not be transfered!") + path = self.ask(_("CONFIG PATH"), abspath("")) try: path = join(pypath, path) if not exists(path): @@ -404,9 +428,12 @@ class Setup: f = open(join(pypath, "module", "config", "configdir"), "wb") f.write(path) f.close() - print _("Configpath changed, setup will now close, please restart to go on.") - print _("Press Enter to exit.") - raw_input() + print + print + print _("pyLoad config path changed, setup will now close!") + print + print + raw_input(_("Press Enter to exit.")) sys.exit() except Exception, e: print _("Setting config path failed: %s") % str(e) @@ -417,7 +444,7 @@ class Setup: if value: print _("%s: OK") % name else: - print _("%s: missing") % name + print _("%s: MISSING") % name def check_module(self, module): @@ -460,7 +487,6 @@ class Setup: pwlen = 8 while p1 != p2: # getpass(_("Password: ")) will crash on systems with broken locales (Win, NAS) - print _("Warning: Consider a password of 10 or more symbols if you expect to access from outside your local network (ex. internet).") sys.stdout.write(_("Password: ")) p1 = getpass("") diff --git a/module/utils.py b/module/utils.py index 93ff14a46..039f64c3a 100644 --- a/module/utils.py +++ b/module/utils.py @@ -40,7 +40,7 @@ def remove_chars(string, repl): def safe_path(name): - #remove some chars + """ remove bad chars """ name = name.encode('ascii', 'replace') # Non-ASCII chars usually breaks file saving. Replacing. if os.name == 'nt': return remove_chars(name, u'\00\01\02\03\04\05\06\07\10\11\12\13\14\15\16\17\20\21\22\23\24\25\26\27\30\31\32' @@ -48,11 +48,19 @@ def safe_path(name): else: return remove_chars(name, u'\0/\\"') +#: Deprecated method +def save_path(name): + return safe_path(name) + def safe_join(*args): """ joins a path, encoding aware """ return fs_encode(join(*[x if type(x) == unicode else decode(x) for x in args])) +#: Deprecated method +def save_join(*args): + return safe_join(*args) + # File System Encoding functions: # Use fs_encode before accesing files on disk, it will encode the string properly @@ -213,3 +221,7 @@ def fixup(m): def html_unescape(text): """Removes HTML or XML character references and entities from a text string""" return re.sub("&#?\w+;", fixup, text) + + +def versiontuple(v): #: By kindall (http://stackoverflow.com/a/11887825) + return tuple(map(int, (v.split(".")))) |