PEP formating
This commit is contained in:
@@ -25,11 +25,12 @@ def install(appname, config, upgrade, restore):
|
|||||||
utils.printcolor(u"{}".format(inst), utils.RED)
|
utils.printcolor(u"{}".format(inst), utils.RED)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
def backup(config, bashArg, nomail):
|
def backup(config, bashArg, nomail):
|
||||||
"""Backup instance"""
|
"""Backup instance"""
|
||||||
try:
|
try:
|
||||||
script = importlib.import_module(
|
script = importlib.import_module(
|
||||||
"modoboa_installer.scripts.backup")
|
"modoboa_installer.scripts.backup")
|
||||||
except ImportError:
|
except ImportError:
|
||||||
print("Error importing backup")
|
print("Error importing backup")
|
||||||
try:
|
try:
|
||||||
@@ -38,6 +39,7 @@ def backup(config, bashArg, nomail):
|
|||||||
utils.printcolor(u"{}".format(inst), utils.RED)
|
utils.printcolor(u"{}".format(inst), utils.RED)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
def restore(restore):
|
def restore(restore):
|
||||||
"""Restore instance"""
|
"""Restore instance"""
|
||||||
try:
|
try:
|
||||||
|
|||||||
@@ -44,8 +44,10 @@ class Amavis(base.Installer):
|
|||||||
if package.backend.FORMAT == "deb":
|
if package.backend.FORMAT == "deb":
|
||||||
amavisCustomConf = os.path.join(self.restore, "custom/99-custom")
|
amavisCustomConf = os.path.join(self.restore, "custom/99-custom")
|
||||||
if self.restore and os.path.isfile(amavisCustomConf):
|
if self.restore and os.path.isfile(amavisCustomConf):
|
||||||
utils.copy_file(amavisCustomConf, os.path.join(self.config_dir, "/conf.d"))
|
utils.copy_file(amavisCustomConf, os.path.join(
|
||||||
utils.printcolor("Custom amavis configuration restored", utils.GREEN)
|
self.config_dir, "/conf.d"))
|
||||||
|
utils.printcolor(
|
||||||
|
"Custom amavis configuration restored", utils.GREEN)
|
||||||
return [
|
return [
|
||||||
"conf.d/05-node_id", "conf.d/15-content_filter_mode",
|
"conf.d/05-node_id", "conf.d/15-content_filter_mode",
|
||||||
"conf.d/50-user"]
|
"conf.d/50-user"]
|
||||||
@@ -74,12 +76,16 @@ class Amavis(base.Installer):
|
|||||||
def get_sql_schema_path(self):
|
def get_sql_schema_path(self):
|
||||||
"""Return schema path."""
|
"""Return schema path."""
|
||||||
if self.restore:
|
if self.restore:
|
||||||
utils.printcolor("Trying to restore amavis database from backup", utils.MAGENTA)
|
utils.printcolor(
|
||||||
amavisDbBackupPath = os.path.join(self.restore, "databases/amavis.sql")
|
"Trying to restore amavis database from backup", utils.MAGENTA)
|
||||||
|
amavisDbBackupPath = os.path.join(
|
||||||
|
self.restore, "databases/amavis.sql")
|
||||||
if os.path.isfile(amavisDbBackupPath):
|
if os.path.isfile(amavisDbBackupPath):
|
||||||
utils.printcolor("Amavis database backup found ! Restoring...", utils.GREEN)
|
utils.printcolor(
|
||||||
|
"Amavis database backup found ! Restoring...", utils.GREEN)
|
||||||
return amavisDbBackupPath
|
return amavisDbBackupPath
|
||||||
utils.printcolor("Amavis database backup not found, creating empty database", utils.RED)
|
utils.printcolor(
|
||||||
|
"Amavis database backup not found, creating empty database", utils.RED)
|
||||||
|
|
||||||
version = package.backend.get_installed_version("amavisd-new")
|
version = package.backend.get_installed_version("amavisd-new")
|
||||||
if version is None:
|
if version is None:
|
||||||
@@ -94,7 +100,7 @@ class Amavis(base.Installer):
|
|||||||
path = self.get_file_path(
|
path = self.get_file_path(
|
||||||
"amavis_{}_{}.sql".format(self.dbengine, version))
|
"amavis_{}_{}.sql".format(self.dbengine, version))
|
||||||
if not os.path.exists(path):
|
if not os.path.exists(path):
|
||||||
raise utils.FatalError("Failed to find amavis database schema")
|
raise utils.FatalError("Failed to find amavis database schema")
|
||||||
return path
|
return path
|
||||||
|
|
||||||
def pre_run(self):
|
def pre_run(self):
|
||||||
|
|||||||
@@ -10,23 +10,24 @@ import sys
|
|||||||
from .. import database
|
from .. import database
|
||||||
from .. import utils
|
from .. import utils
|
||||||
|
|
||||||
#TODO: have version of each modoboa componenents saved into the config file to restore the same version
|
# TODO: have version of each modoboa componenents saved into the config file to restore the same version
|
||||||
|
|
||||||
|
|
||||||
class Backup():
|
class Backup():
|
||||||
|
|
||||||
#Backup structure ( {optional} ):
|
# Backup structure ( {optional} ):
|
||||||
#{{backup_folder}}
|
# {{backup_folder}}
|
||||||
#||
|
# ||
|
||||||
#||--> installer.cfg
|
# ||--> installer.cfg
|
||||||
#||--> custom
|
# ||--> custom
|
||||||
# |--> { (copy of) /etc/amavis/conf.d/99-custom }
|
# |--> { (copy of) /etc/amavis/conf.d/99-custom }
|
||||||
# |--> { (copy of) /etc/postfix/custom_whitelist.cidr }
|
# |--> { (copy of) /etc/postfix/custom_whitelist.cidr }
|
||||||
#||--> databases
|
# ||--> databases
|
||||||
# |--> modoboa.sql
|
# |--> modoboa.sql
|
||||||
# |--> { amavis.sql }
|
# |--> { amavis.sql }
|
||||||
# |--> { spamassassin.sql }
|
# |--> { spamassassin.sql }
|
||||||
#||--> mails
|
# ||--> mails
|
||||||
# |--> vmails
|
# |--> vmails
|
||||||
|
|
||||||
def __init__(self, config, bashArg, nomail):
|
def __init__(self, config, bashArg, nomail):
|
||||||
self.config = config
|
self.config = config
|
||||||
@@ -39,39 +40,40 @@ class Backup():
|
|||||||
self.isBash = True
|
self.isBash = True
|
||||||
self.bash = bashArg
|
self.bash = bashArg
|
||||||
|
|
||||||
|
|
||||||
def preparePath(self):
|
def preparePath(self):
|
||||||
pw = pwd.getpwnam("root")
|
pw = pwd.getpwnam("root")
|
||||||
for dir in self.BACKUPDIRECTORY:
|
for dir in self.BACKUPDIRECTORY:
|
||||||
utils.mkdir_safe(os.path.join(self.destinationPath,dir),
|
utils.mkdir_safe(os.path.join(self.destinationPath, dir),
|
||||||
stat.S_IRWXU | stat.S_IRWXG, pw[2], pw[3])
|
stat.S_IRWXU | stat.S_IRWXG, pw[2], pw[3])
|
||||||
|
|
||||||
|
|
||||||
def validatePath(self, path):
|
def validatePath(self, path):
|
||||||
"""Check basic condition for backup directory"""
|
"""Check basic condition for backup directory"""
|
||||||
try :
|
try:
|
||||||
pathExists = os.path.exists(path)
|
pathExists = os.path.exists(path)
|
||||||
except:
|
except:
|
||||||
print("Provided path is not recognized...")
|
print("Provided path is not recognized...")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if pathExists and os.path.isfile(path):
|
if pathExists and os.path.isfile(path):
|
||||||
print("Error, you provided a file instead of a directory!")
|
print("Error, you provided a file instead of a directory!")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if not pathExists:
|
if not pathExists:
|
||||||
if not self.isBash:
|
if not self.isBash:
|
||||||
createDir = input(f"\"{path}\" doesn't exists, would you like to create it ? [Y/n]\n").lower()
|
createDir = input(
|
||||||
|
f"\"{path}\" doesn't exists, would you like to create it ? [Y/n]\n").lower()
|
||||||
|
|
||||||
if self.isBash or (not self.isBash and (createDir == "y" or createDir == "yes")):
|
if self.isBash or (not self.isBash and (createDir == "y" or createDir == "yes")):
|
||||||
pw = pwd.getpwnam("root")
|
pw = pwd.getpwnam("root")
|
||||||
utils.mkdir_safe(path, stat.S_IRWXU | stat.S_IRWXG, pw[2], pw[3])
|
utils.mkdir_safe(path, stat.S_IRWXU |
|
||||||
|
stat.S_IRWXG, pw[2], pw[3])
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if len(os.listdir(path)) != 0:
|
if len(os.listdir(path)) != 0:
|
||||||
if not self.isBash:
|
if not self.isBash:
|
||||||
delDir = input("Warning : backup folder is not empty, it will be purged if you continue... [Y/n]\n").lower()
|
delDir = input(
|
||||||
|
"Warning : backup folder is not empty, it will be purged if you continue... [Y/n]\n").lower()
|
||||||
if self.isBash or (not self.isBash and (delDir == "y" or delDir == "yes")):
|
if self.isBash or (not self.isBash and (delDir == "y" or delDir == "yes")):
|
||||||
shutil.rmtree(path)
|
shutil.rmtree(path)
|
||||||
else:
|
else:
|
||||||
@@ -82,7 +84,6 @@ class Backup():
|
|||||||
self.preparePath()
|
self.preparePath()
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
def setPath(self):
|
def setPath(self):
|
||||||
"""Setup backup directory"""
|
"""Setup backup directory"""
|
||||||
if self.isBash:
|
if self.isBash:
|
||||||
@@ -90,7 +91,7 @@ class Backup():
|
|||||||
date = datetime.datetime.now().strftime("%m_%d_%Y_%H_%M")
|
date = datetime.datetime.now().strftime("%m_%d_%Y_%H_%M")
|
||||||
path = f"/modoboa_backup/backup_{date}/"
|
path = f"/modoboa_backup/backup_{date}/"
|
||||||
self.validatePath(path)
|
self.validatePath(path)
|
||||||
else :
|
else:
|
||||||
validate = self.validatePath(self.bash)
|
validate = self.validatePath(self.bash)
|
||||||
if not validate:
|
if not validate:
|
||||||
print("provided bash is not right, exiting...")
|
print("provided bash is not right, exiting...")
|
||||||
@@ -103,15 +104,14 @@ class Backup():
|
|||||||
print("CTRL+C to cancel")
|
print("CTRL+C to cancel")
|
||||||
user_value = utils.user_input("-> ")
|
user_value = utils.user_input("-> ")
|
||||||
|
|
||||||
|
|
||||||
def backupConfigFile(self):
|
def backupConfigFile(self):
|
||||||
utils.copy_file("installer.cfg", self.destinationPath)
|
utils.copy_file("installer.cfg", self.destinationPath)
|
||||||
|
|
||||||
|
|
||||||
def backupMails(self):
|
def backupMails(self):
|
||||||
|
|
||||||
if self.nomail:
|
if self.nomail:
|
||||||
utils.printcolor("Skipping mail backup, no-mail argument provided", utils.MAGENTA)
|
utils.printcolor(
|
||||||
|
"Skipping mail backup, no-mail argument provided", utils.MAGENTA)
|
||||||
return
|
return
|
||||||
|
|
||||||
utils.printcolor("Backing up mails", utils.MAGENTA)
|
utils.printcolor("Backing up mails", utils.MAGENTA)
|
||||||
@@ -120,7 +120,7 @@ class Backup():
|
|||||||
|
|
||||||
if not os.path.exists(home_path) or os.path.isfile(home_path):
|
if not os.path.exists(home_path) or os.path.isfile(home_path):
|
||||||
utils.printcolor("Error backing up Email, provided path "
|
utils.printcolor("Error backing up Email, provided path "
|
||||||
f" ({home_path}) seems not right...", utils.RED)
|
f" ({home_path}) seems not right...", utils.RED)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
dst = os.path.join(self.destinationPath, "mails/")
|
dst = os.path.join(self.destinationPath, "mails/")
|
||||||
@@ -131,15 +131,16 @@ class Backup():
|
|||||||
shutil.copytree(home_path, dst)
|
shutil.copytree(home_path, dst)
|
||||||
utils.printcolor("Mail backup complete!", utils.GREEN)
|
utils.printcolor("Mail backup complete!", utils.GREEN)
|
||||||
|
|
||||||
|
|
||||||
def backupCustomConfig(self):
|
def backupCustomConfig(self):
|
||||||
"""Custom config :
|
"""Custom config :
|
||||||
- Amavis : /etc/amavis/conf.d/99-custom
|
- Amavis : /etc/amavis/conf.d/99-custom
|
||||||
- Postwhite : /etc/postwhite.conf
|
- Postwhite : /etc/postwhite.conf
|
||||||
Feel free to suggest to add others!"""
|
Feel free to suggest to add others!"""
|
||||||
utils.printcolor("Backing up some custom configuration...", utils.MAGENTA)
|
utils.printcolor(
|
||||||
|
"Backing up some custom configuration...", utils.MAGENTA)
|
||||||
|
|
||||||
custom_path = os.path.join(self.destinationPath, self.BACKUPDIRECTORY[0])
|
custom_path = os.path.join(
|
||||||
|
self.destinationPath, self.BACKUPDIRECTORY[0])
|
||||||
|
|
||||||
"""AMAVIS"""
|
"""AMAVIS"""
|
||||||
amavis_custom = "/etc/amavis/conf.d/99-custom"
|
amavis_custom = "/etc/amavis/conf.d/99-custom"
|
||||||
@@ -153,7 +154,6 @@ class Backup():
|
|||||||
utils.copy_file(postswhite_custom, custom_path)
|
utils.copy_file(postswhite_custom, custom_path)
|
||||||
utils.printcolor("Postwhite configuration saved!", utils.GREEN)
|
utils.printcolor("Postwhite configuration saved!", utils.GREEN)
|
||||||
|
|
||||||
|
|
||||||
def backupDBs(self):
|
def backupDBs(self):
|
||||||
"""Backing up databases"""
|
"""Backing up databases"""
|
||||||
|
|
||||||
@@ -166,27 +166,30 @@ class Backup():
|
|||||||
dbname = self.config.get("modoboa", "dbname")
|
dbname = self.config.get("modoboa", "dbname")
|
||||||
dbuser = self.config.get("modoboa", "dbuser")
|
dbuser = self.config.get("modoboa", "dbuser")
|
||||||
dbpasswd = self.config.get("modoboa", "dbpassword")
|
dbpasswd = self.config.get("modoboa", "dbpassword")
|
||||||
backend.dumpDatabase(dbname, dbuser, dbpasswd, os.path.join(dump_path,"modoboa.sql"))
|
backend.dumpDatabase(dbname, dbuser, dbpasswd,
|
||||||
|
os.path.join(dump_path, "modoboa.sql"))
|
||||||
|
|
||||||
"""Amavis"""
|
"""Amavis"""
|
||||||
if (self.config.has_option("amavis", "enabled") and
|
if (self.config.has_option("amavis", "enabled") and
|
||||||
self.config.getboolean("amavis", "enabled")):
|
self.config.getboolean("amavis", "enabled")):
|
||||||
dbname = self.config.get("amavis", "dbname")
|
dbname = self.config.get("amavis", "dbname")
|
||||||
dbuser = self.config.get("amavis", "dbuser")
|
dbuser = self.config.get("amavis", "dbuser")
|
||||||
dbpasswd = self.config.get("amavis", "dbpassword")
|
dbpasswd = self.config.get("amavis", "dbpassword")
|
||||||
backend.dumpDatabase(dbname, dbuser, dbpasswd, os.path.join(dump_path,"amavis.sql"))
|
backend.dumpDatabase(dbname, dbuser, dbpasswd,
|
||||||
|
os.path.join(dump_path, "amavis.sql"))
|
||||||
|
|
||||||
"""SpamAssassin"""
|
"""SpamAssassin"""
|
||||||
if (self.config.has_option("spamassassin", "enabled") and
|
if (self.config.has_option("spamassassin", "enabled") and
|
||||||
self.config.getboolean("spamassassin", "enabled")):
|
self.config.getboolean("spamassassin", "enabled")):
|
||||||
dbname = self.config.get("spamassassin", "dbname")
|
dbname = self.config.get("spamassassin", "dbname")
|
||||||
dbuser = self.config.get("spamassassin", "dbuser")
|
dbuser = self.config.get("spamassassin", "dbuser")
|
||||||
dbpasswd = self.config.get("spamassassin", "dbpassword")
|
dbpasswd = self.config.get("spamassassin", "dbpassword")
|
||||||
backend.dumpDatabase(dbname, dbuser, dbpasswd, os.path.join(dump_path,"spamassassin.sql"))
|
backend.dumpDatabase(dbname, dbuser, dbpasswd,
|
||||||
|
os.path.join(dump_path, "spamassassin.sql"))
|
||||||
|
|
||||||
def backupCompletion(self):
|
def backupCompletion(self):
|
||||||
utils.printcolor("Backup process done, your backup is availible here:"
|
utils.printcolor("Backup process done, your backup is availible here:"
|
||||||
f"--> {self.destinationPath}", utils.GREEN)
|
f"--> {self.destinationPath}", utils.GREEN)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
self.setPath()
|
self.setPath()
|
||||||
@@ -195,5 +198,3 @@ class Backup():
|
|||||||
self.backupCustomConfig()
|
self.backupCustomConfig()
|
||||||
self.backupDBs()
|
self.backupDBs()
|
||||||
self.backupCompletion()
|
self.backupCompletion()
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -90,19 +90,22 @@ class Dovecot(base.Installer):
|
|||||||
"""Additional tasks."""
|
"""Additional tasks."""
|
||||||
mail_dir = os.path.join(self.restore, "mails/")
|
mail_dir = os.path.join(self.restore, "mails/")
|
||||||
if self.restore and len(os.listdir(mail_dir)) > 0:
|
if self.restore and len(os.listdir(mail_dir)) > 0:
|
||||||
utils.printcolor("Copying mail backup over dovecot directory", utils.GREEN)
|
utils.printcolor(
|
||||||
|
"Copying mail backup over dovecot directory", utils.GREEN)
|
||||||
|
|
||||||
if os.path.exists(self.home_dir):
|
if os.path.exists(self.home_dir):
|
||||||
shutil.rmtree(self.home_dir)
|
shutil.rmtree(self.home_dir)
|
||||||
|
|
||||||
shutil.copytree(mail_dir, self.home_dir)
|
shutil.copytree(mail_dir, self.home_dir)
|
||||||
#Resetting permission for vmail
|
# Resetting permission for vmail
|
||||||
for dirpath, dirnames, filenames in os.walk(self.home_dir):
|
for dirpath, dirnames, filenames in os.walk(self.home_dir):
|
||||||
shutil.chown(dirpath, self.user, self.user)
|
shutil.chown(dirpath, self.user, self.user)
|
||||||
for filename in filenames:
|
for filename in filenames:
|
||||||
shutil.chown(os.path.join(dirpath, filename), self.user, self.user)
|
shutil.chown(os.path.join(dirpath, filename),
|
||||||
|
self.user, self.user)
|
||||||
elif self.restore:
|
elif self.restore:
|
||||||
utils.printcolor("It seems that mails were not backed up, skipping mail restoration.", utils.MAGENTA)
|
utils.printcolor(
|
||||||
|
"It seems that mails were not backed up, skipping mail restoration.", utils.MAGENTA)
|
||||||
|
|
||||||
if self.dbengine == "postgres":
|
if self.dbengine == "postgres":
|
||||||
dbname = self.config.get("modoboa", "dbname")
|
dbname = self.config.get("modoboa", "dbname")
|
||||||
|
|||||||
@@ -176,15 +176,18 @@ class Modoboa(base.Installer):
|
|||||||
self.backend.grant_access(
|
self.backend.grant_access(
|
||||||
self.config.get("amavis", "dbname"), self.dbuser)
|
self.config.get("amavis", "dbname"), self.dbuser)
|
||||||
|
|
||||||
|
|
||||||
def get_sql_schema_path(self):
|
def get_sql_schema_path(self):
|
||||||
if self.restore:
|
if self.restore:
|
||||||
utils.printcolor("Trying to restore modoboa database from backup", utils.MAGENTA)
|
utils.printcolor(
|
||||||
modoboaDbBackupPath = os.path.join(self.restore, "databases/modoboa.sql")
|
"Trying to restore modoboa database from backup", utils.MAGENTA)
|
||||||
|
modoboaDbBackupPath = os.path.join(
|
||||||
|
self.restore, "databases/modoboa.sql")
|
||||||
if os.path.isfile(modoboaDbBackupPath):
|
if os.path.isfile(modoboaDbBackupPath):
|
||||||
utils.printcolor("Modoboa database backup found ! Restoring...", utils.GREEN)
|
utils.printcolor(
|
||||||
|
"Modoboa database backup found ! Restoring...", utils.GREEN)
|
||||||
return modoboaDbBackupPath
|
return modoboaDbBackupPath
|
||||||
utils.printcolor("Modoboa database backup not found, creating empty database", utils.RED)
|
utils.printcolor(
|
||||||
|
"Modoboa database backup not found, creating empty database", utils.RED)
|
||||||
|
|
||||||
return super().get_sql_schema_path()()
|
return super().get_sql_schema_path()()
|
||||||
|
|
||||||
|
|||||||
@@ -46,10 +46,12 @@ class Postwhite(base.Installer):
|
|||||||
self.install_from_archive(SPF_TOOLS_REPOSITORY, install_dir)
|
self.install_from_archive(SPF_TOOLS_REPOSITORY, install_dir)
|
||||||
postw_dir = self.install_from_archive(
|
postw_dir = self.install_from_archive(
|
||||||
POSTWHITE_REPOSITORY, install_dir)
|
POSTWHITE_REPOSITORY, install_dir)
|
||||||
postwhiteBackupConf = os.path.join(self.restore, "custom/postwhite.conf")
|
postwhiteBackupConf = os.path.join(
|
||||||
|
self.restore, "custom/postwhite.conf")
|
||||||
if self.restore and os.path.isfile(postwhiteBackupConf):
|
if self.restore and os.path.isfile(postwhiteBackupConf):
|
||||||
utils.copy_file(postwhiteBackupConf, "/etc")
|
utils.copy_file(postwhiteBackupConf, "/etc")
|
||||||
utils.printcolor("postwhite.conf restored from backup", utils.GREEN)
|
utils.printcolor(
|
||||||
|
"postwhite.conf restored from backup", utils.GREEN)
|
||||||
else:
|
else:
|
||||||
utils.copy_file(os.path.join(postw_dir, "postwhite.conf"), "/etc")
|
utils.copy_file(os.path.join(postw_dir, "postwhite.conf"), "/etc")
|
||||||
postw_bin = os.path.join(postw_dir, "postwhite")
|
postw_bin = os.path.join(postw_dir, "postwhite")
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import os
|
|||||||
import sys
|
import sys
|
||||||
from .. import utils
|
from .. import utils
|
||||||
|
|
||||||
|
|
||||||
class Restore:
|
class Restore:
|
||||||
def __init__(self, restore):
|
def __init__(self, restore):
|
||||||
"""Restoring pre-check (backup integriety)"""
|
"""Restoring pre-check (backup integriety)"""
|
||||||
@@ -11,7 +12,8 @@ class Restore:
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
if not os.path.isdir(restore):
|
if not os.path.isdir(restore):
|
||||||
utils.printcolor("Provided path is not a directory !", utils.RED)
|
utils.printcolor(
|
||||||
|
"Provided path is not a directory !", utils.RED)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
except:
|
except:
|
||||||
utils.printcolor("Provided path is not right...", utils.RED)
|
utils.printcolor("Provided path is not right...", utils.RED)
|
||||||
@@ -20,10 +22,12 @@ class Restore:
|
|||||||
try:
|
try:
|
||||||
modobasql_file = os.path.join(restore, "databases/modoboa.sql")
|
modobasql_file = os.path.join(restore, "databases/modoboa.sql")
|
||||||
if not os.path.isfile(modobasql_file):
|
if not os.path.isfile(modobasql_file):
|
||||||
utils.printcolor(modobasql_file +" not found, please check your backup", utils.RED)
|
utils.printcolor(
|
||||||
|
modobasql_file + " not found, please check your backup", utils.RED)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
except:
|
except:
|
||||||
utils.printcolor(modobasql_file + " not found, please check your backup", utils.RED)
|
utils.printcolor(modobasql_file +
|
||||||
|
" not found, please check your backup", utils.RED)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
#Everything seems allright here, proceding...
|
# Everything seems allright here, proceding...
|
||||||
|
|||||||
@@ -26,12 +26,16 @@ class Spamassassin(base.Installer):
|
|||||||
def get_sql_schema_path(self):
|
def get_sql_schema_path(self):
|
||||||
"""Return SQL schema."""
|
"""Return SQL schema."""
|
||||||
if self.restore:
|
if self.restore:
|
||||||
utils.printcolor("Trying to restore spamassassin database from backup", utils.MAGENTA)
|
utils.printcolor(
|
||||||
amavisDbBackupPath = os.path.join(self.restore, "databases/spamassassin.sql")
|
"Trying to restore spamassassin database from backup", utils.MAGENTA)
|
||||||
|
amavisDbBackupPath = os.path.join(
|
||||||
|
self.restore, "databases/spamassassin.sql")
|
||||||
if os.path.isfile(amavisDbBackupPath):
|
if os.path.isfile(amavisDbBackupPath):
|
||||||
utils.printcolor("Spamassassin database backup found ! Restoring...", utils.GREEN)
|
utils.printcolor(
|
||||||
|
"Spamassassin database backup found ! Restoring...", utils.GREEN)
|
||||||
return amavisDbBackupPath
|
return amavisDbBackupPath
|
||||||
utils.printcolor("Spamassassin database backup not found, creating empty database", utils.RED)
|
utils.printcolor(
|
||||||
|
"Spamassassin database backup not found, creating empty database", utils.RED)
|
||||||
|
|
||||||
if self.dbengine == "postgres":
|
if self.dbengine == "postgres":
|
||||||
fname = "bayes_pg.sql"
|
fname = "bayes_pg.sql"
|
||||||
|
|||||||
@@ -106,12 +106,14 @@ def mkdir(path, mode, uid, gid):
|
|||||||
os.chmod(path, mode)
|
os.chmod(path, mode)
|
||||||
os.chown(path, uid, gid)
|
os.chown(path, uid, gid)
|
||||||
|
|
||||||
|
|
||||||
def mkdir_safe(path, mode, uid, gid):
|
def mkdir_safe(path, mode, uid, gid):
|
||||||
"""Create a directory. Safe way (-p)"""
|
"""Create a directory. Safe way (-p)"""
|
||||||
if not os.path.exists(path):
|
if not os.path.exists(path):
|
||||||
os.makedirs(os.path.abspath(path), mode)
|
os.makedirs(os.path.abspath(path), mode)
|
||||||
mkdir(path, mode, uid, gid)
|
mkdir(path, mode, uid, gid)
|
||||||
|
|
||||||
|
|
||||||
def make_password(length=16):
|
def make_password(length=16):
|
||||||
"""Create a random password."""
|
"""Create a random password."""
|
||||||
return "".join(
|
return "".join(
|
||||||
|
|||||||
19
run.py
19
run.py
@@ -17,6 +17,7 @@ from modoboa_installer import ssl
|
|||||||
from modoboa_installer import system
|
from modoboa_installer import system
|
||||||
from modoboa_installer import utils
|
from modoboa_installer import utils
|
||||||
|
|
||||||
|
|
||||||
def installation_disclaimer(args, config):
|
def installation_disclaimer(args, config):
|
||||||
"""Display installation disclaimer."""
|
"""Display installation disclaimer."""
|
||||||
hostname = config.get("general", "hostname")
|
hostname = config.get("general", "hostname")
|
||||||
@@ -44,6 +45,7 @@ def upgrade_disclaimer(config):
|
|||||||
" will be impacted:", utils.BLUE
|
" will be impacted:", utils.BLUE
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def backup_disclamer():
|
def backup_disclamer():
|
||||||
"""Display backup disclamer. """
|
"""Display backup disclamer. """
|
||||||
utils.printcolor(
|
utils.printcolor(
|
||||||
@@ -51,6 +53,7 @@ def backup_disclamer():
|
|||||||
" !! You should really transfer the backup somewhere else..."
|
" !! You should really transfer the backup somewhere else..."
|
||||||
" Custom configuration (like to postfix) won't be saved.", utils.BLUE)
|
" Custom configuration (like to postfix) won't be saved.", utils.BLUE)
|
||||||
|
|
||||||
|
|
||||||
def restore_disclamer():
|
def restore_disclamer():
|
||||||
"""Display restore disclamer. """
|
"""Display restore disclamer. """
|
||||||
utils.printcolor(
|
utils.printcolor(
|
||||||
@@ -58,6 +61,7 @@ def restore_disclamer():
|
|||||||
"If a new version has been released in between, please update your database !",
|
"If a new version has been released in between, please update your database !",
|
||||||
utils.BLUE)
|
utils.BLUE)
|
||||||
|
|
||||||
|
|
||||||
def main(input_args):
|
def main(input_args):
|
||||||
"""Install process."""
|
"""Install process."""
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
@@ -109,16 +113,17 @@ def main(input_args):
|
|||||||
|
|
||||||
if not args.backup and (args.bash != None or args.sbash or args.no_mail):
|
if not args.backup and (args.bash != None or args.sbash or args.no_mail):
|
||||||
utils.printcolor("You provided --bash or --sbash without --backup, "
|
utils.printcolor("You provided --bash or --sbash without --backup, "
|
||||||
"if you want to do a backup, please provide --backup!", utils.RED)
|
"if you want to do a backup, please provide --backup!", utils.RED)
|
||||||
return
|
return
|
||||||
elif args.bash != None and args.sbash :
|
elif args.bash != None and args.sbash:
|
||||||
utils.printcolor("You provided --bash PATH and --sbash at the same time. "
|
utils.printcolor("You provided --bash PATH and --sbash at the same time. "
|
||||||
"Please provided only one!", utils.RED)
|
"Please provided only one!", utils.RED)
|
||||||
return
|
return
|
||||||
elif args.bash == "TRUE":
|
elif args.bash == "TRUE":
|
||||||
utils.printcolor("You can't pick *TRUE* as backup directory !", utils.RED)
|
utils.printcolor(
|
||||||
|
"You can't pick *TRUE* as backup directory !", utils.RED)
|
||||||
|
|
||||||
#Restore prep
|
# Restore prep
|
||||||
isRestoring = False
|
isRestoring = False
|
||||||
if args.restore != None:
|
if args.restore != None:
|
||||||
isRestoring = True
|
isRestoring = True
|
||||||
@@ -128,7 +133,8 @@ def main(input_args):
|
|||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
utils.printcolor("Welcome to Modoboa installer!\n", utils.GREEN)
|
utils.printcolor("Welcome to Modoboa installer!\n", utils.GREEN)
|
||||||
wasConfigFileAlreadyThere = utils.check_config_file(args.configfile, args.interactive, args.upgrade, args.backup, isRestoring)
|
wasConfigFileAlreadyThere = utils.check_config_file(
|
||||||
|
args.configfile, args.interactive, args.upgrade, args.backup, isRestoring)
|
||||||
|
|
||||||
if args.stop_after_configfile_check or (not wasConfigFileAlreadyThere and args.backup):
|
if args.stop_after_configfile_check or (not wasConfigFileAlreadyThere and args.backup):
|
||||||
return
|
return
|
||||||
@@ -207,5 +213,6 @@ def main(input_args):
|
|||||||
.format(config.get("general", "hostname")),
|
.format(config.get("general", "hostname")),
|
||||||
utils.GREEN)
|
utils.GREEN)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main(sys.argv[1:])
|
main(sys.argv[1:])
|
||||||
|
|||||||
Reference in New Issue
Block a user