#!/usr/bin/env python2
# -*- coding: utf-8 -*-

import sys
from os.path import join

def register_ead():
    """
        Enregistrement de l'EAD local
    """
    from creole.client import CreoleClient
    sys.path.insert(1, '/usr/share')
    from ead2.frontend.web.lib.servers import servers
    from ead2.lib.libead import EadKeyParser
    from ead2.lib.crypto import create_key as create_magicnb
    from ead2.backend.config.config import CONFIG_DIR, FRONTEND_KEYS_FILE
    from ead2.config.config import BACKEND_LISTEN_PORT
    nom_machine = CreoleClient().get_creole('nom_machine')
    nom_domaine = CreoleClient().get_creole('ssl_server_name')
    ead = EadKeyParser()
    ead.parse_file(join(CONFIG_DIR, FRONTEND_KEYS_FILE))
    ead_keys = ead.get_key_dict()
    if ead_keys != {}:
        # des frontend sont déjà enregistrés
        # Remplacement de 127.0.0.1 avec le nom complet DNS (valide dans le certif SSL)
        if "127.0.0.1" in ead_keys:
            toRm = ''
            srvLst = servers().get_server()
            for key,value in srvLst.items():
                if value[0] == 'https://127.0.0.1':
                    servers().del_server(key)
        else:
            return
    key = create_magicnb('admin', 'admin')
    dic = { nom_domaine: key }
    # ecriture clé ead-serveur
    ead.write_file(join(CONFIG_DIR, FRONTEND_KEYS_FILE), dic)
    # ecriture clé ead-web
    servers().add_server('https://{0}'.format(nom_domaine),
                         str(BACKEND_LISTEN_PORT),
                         nom_machine,
                         str(key))

register_ead()
