# -*-coding:utf8 -*
"""
Module permettant d'authentifier un utilisateur
Permet son accès au logiciel ou non
"""

import DB.dbLink as dbo
from getpass import getpass
import hashlib
import mysql.connector as mariadb

class Auth():
    """Classe permettant l'authentification des utilisateurs"""
    access = False

    def __init__(self, inputid,inputmdp):

        self.input_id = inputid
        self.input_psswd = inputmdp
        self.input_psswd = hashlib.md5(self.input_psswd.encode())
        self.grantAccess()

    def grantAccess(self):
        """Authentification de l'utilisateur """
        #On définit les champs à récupérer en BDD comme vides
        user_id = None
        user_psswd = None

        #On va récupérer les infos en BDD
        link = dbo.DBLink()
        result = link.query("SELECT IDUtil, Nom, MdP FROM utilisateur WHERE Identifiant = %s", [self.input_id, ])

        for id_user, nom, mdp in result:
            user_id = id_user
            user_id = nom
            user_psswd = mdp

        #Si l'user ID a été trouvé
        #On compare le mot de passe entré à celui récupéré en BDD, si ça matche, on renvoie True
        if user_id != None:
            if self.input_psswd.hexdigest() == user_psswd:
                Auth.access = True
                Auth.current_user_id = id_user
                print("Accès autorisé")
            else:
                print("Accès refusé : Le mot de passe est incorrect")
        else:
            print("Accès refusé : cet utilisateur n'existe pas")

        return Auth.access