mini_datathon / users.py
jeremyadd's picture
Upload 11 files
b5f6a08 verified
raw
history blame
1.25 kB
from dataclasses import dataclass
import pandas as pd
import os
@dataclass
class Users:
db_file: str = 'users.csv'
current_path: str = os.path.abspath(os.path.dirname(__file__))
def get_db(self):
try:
db = pd.read_csv(os.path.join(self.current_path, self.db_file))
except FileNotFoundError:
db = self.create_db()
return db
def create_db(self):
db = pd.DataFrame(columns=['login', 'password'])
db = db.append({'login': 'admin', 'password': 'password'}, ignore_index=True)
db.to_csv(os.path.join(self.current_path, self.db_file), index=False)
return db
def exists(self, login: str, password: str) -> bool:
db = self.get_db()
if db.loc[db.login == login].shape[0] != 0:
if db.loc[db.login == login, 'password'].values[0] == password:
return True
return False
def is_admin(self, login: str, password: str) -> bool:
db = self.get_db()
if db.loc[db.login == login, 'login'].values[0] == 'admin' and \
db.loc[db.login == login, 'password'].values[0] == password:
return True
else:
return False