87 lines
3.5 KiB
Python
87 lines
3.5 KiB
Python
#/usr/bin/env python3
|
|
|
|
from modules.pastafari2.libraries.task import Task
|
|
#from modules.pastafari.models.tasks import TaskModel
|
|
from paramecio2.libraries.db import coreforms
|
|
from paramecio2.libraries.db.extrafields.ipfield import IpField
|
|
from paramecio2.libraries.formsutils import show_form
|
|
from paramecio2.libraries.urls import make_url
|
|
from collections import OrderedDict
|
|
from modules.pastafari2.models.pastafari2 import ServerDbTask
|
|
from paramecio2.libraries.i18n import I18n
|
|
try:
|
|
from modules.mariadb.models.mariadb import DbServerMariaDb
|
|
server_db=True
|
|
except:
|
|
server_db=False
|
|
|
|
|
|
class ServerTask(Task):
|
|
|
|
def __init__(self, server, conn, remote_user='root', remote_password='', private_key='./ssh/id_rsa', password_key='', remote_path='pastafari2', task_id=0, data={}, port=22):
|
|
|
|
super().__init__(server, conn, remote_user, remote_password, private_key, password_key, remote_path, task_id, data, port)
|
|
|
|
self.name_task='MariaDB installation'
|
|
|
|
self.description_task='Update of a standalone mysql server'
|
|
|
|
self.codename_task='update_mysql'
|
|
|
|
self.files=[['modules/mariadb/scripts/update_mariadb.py', 0o700]]
|
|
|
|
# Format first array element is command with the interpreter, the task is agnostic, the files in os directory. The commands are setted with 750 permission.
|
|
# First element is the file, next elements are the arguments
|
|
|
|
#self.commands_to_execute=[['modules/pastafari/scripts/servers/databases/mysql/install_mariadb.py', '']];
|
|
|
|
#THe files to delete
|
|
|
|
self.delete_files=[]
|
|
|
|
self.delete_directories=['modules/mariadb/scripts']
|
|
|
|
#self.task=Task(conn)
|
|
|
|
self.one_time=False
|
|
|
|
self.version='1.0'
|
|
|
|
self.arr_form=OrderedDict()
|
|
|
|
self.links='<p><a href="{}">{}</a></p>'.format(make_url('mariadbservers/servers'), I18n.lang('mariadbservers', 'mariadbservers_list', 'MariaDB servers list'))
|
|
|
|
#self.commands_to_execute=[['modules/pastafari/scripts/servers/databases/mariadb/install_mariadb.py', '--password=%s' % self.data['mysql_password']]]
|
|
|
|
def post_task(self):
|
|
|
|
if server_db:
|
|
dbserver=DbServerMariaDb(self.connection)
|
|
|
|
dbserver.safe_query()
|
|
|
|
serverdb=ServerDbTask(self.connection)
|
|
|
|
#arr_server=serverdb.set_conditions('WHERE ip=%s', [self.server]).select_a_row_where()
|
|
arr_mariadb=dbserver.set_conditions('WHERE id=%s', [self.data['mariadb_id']]).select_a_row_where([], True)
|
|
|
|
if arr_mariadb:
|
|
dbserver.set_conditions('WHERE id=%s', [self.data['mariadb_id']]).update({'access_ip': self.data['ip']})
|
|
|
|
return True
|
|
|
|
|
|
def pre_task(self):
|
|
|
|
ip_option=''
|
|
|
|
if 'ip' in self.data:
|
|
ip_option='--ip='+self.data['ip']
|
|
|
|
self.commands_to_execute=[['modules/mariadb/scripts/update_mariadb.py', '%s' % (ip_option)]]
|
|
|
|
#self.links='<p><a href="{}">{}</a> >> <a href="{}">{}</a> >> <a href="{}">{}</a>'.format(make_url('webservers/servers'), I18n.lang('webservers', 'webservers_list', 'Webservers list'), make_url('webservers/virtualhost/'+str(self.webserver_id)), I18n.lang('webservers', 'websites', 'Websites'), make_url('webapps/'+str(self.data['virtualhost_id'])), I18n.lang('webservers', 'webapps', 'Webapps'))
|
|
|
|
|
|
return True
|
|
|