diff --git a/service/src/auth.py b/service/src/auth.py index 894e531..e4c7cee 100644 --- a/service/src/auth.py +++ b/service/src/auth.py @@ -72,8 +72,14 @@ async def sign_up(): final_text = "" for j in text: final_text += j + + private_key_text = private_key.split('\n') + text = private_key_text[1:-2] + final_private_key_text = "" + for j in text: + final_private_key_text += j - new_user = User(email=email, first_name=first_name, private_key=private_key, public_key=public_key, public_key_name = final_text, password= password1, time = datetime.datetime.now()) + new_user = User(email=email, first_name=first_name, private_key=private_key, public_key=public_key, public_key_name = final_text, private_key_name = final_private_key_text ,password= password1, time = datetime.datetime.now()) db.session.add(new_user) db.session.commit() login_user(new_user, remember=True) # missing await? diff --git a/service/src/models.py b/service/src/models.py index ffa70d4..4115c71 100644 --- a/service/src/models.py +++ b/service/src/models.py @@ -8,6 +8,11 @@ db.Column('group_id', db.Integer, db.ForeignKey('NoteGroup.id')) ) +user_friends_association = db.Table('user_friends_association', + db.Column('user_id', db.Integer, db.ForeignKey('User.id')), + db.Column('friend_id', db.Integer, db.ForeignKey('User.id')) +) + class NoteGroup(db.Model): __tablename__ = 'NoteGroup' id = db.Column(db.Integer, primary_key=True) @@ -51,6 +56,7 @@ class User(db.Model, UserMixin): private_key = db.Column(db.String(255), unique=True) public_key = db.Column(db.String(255), unique=True) public_key_name = db.Column(db.String(255), unique=True) + private_key_name = db.Column(db.String(255), unique=True) status = db.Column(db.String(255)) time = db.Column(db.DateTime(timezone=True), default=func.now()) diff --git a/service/src/views.py b/service/src/views.py index f660e1d..0bd516b 100644 --- a/service/src/views.py +++ b/service/src/views.py @@ -5,6 +5,7 @@ from .models import User from .models import user_group_association from .models import NoteOfGroup +from .models import user_friends_association from . import db import json import datetime as dt @@ -230,4 +231,42 @@ async def profil(): current_user.status = status db.session.commit() flash('Profile updated!', category='success') - return render_template("profil.html", user=current_user, groups=Note_groups) \ No newline at end of file + return render_template("profil.html", user=current_user, groups=Note_groups) + + +# @views.route('/add_friend', methods=['GET', 'POST']) +# @login_required +# async def add_friend_headfunction(): +# if request.method == 'POST': +# if 'accept_friend' in request.form: +# user_email = request.form.get('user.email') +# print(user_email) + +# elif 'reject_friend' in request.form: +# user_email = request.form.get('user.email') +# print(user_email) + +# elif 'add_friend' in request.form: +# friend_email = request.form.get('friend_email') +# print(friend_email) +# add_friend(friend_email) +# #return add_friend(friend_email) +# else: +# users = User.query.all() +# user_list = [] +# for user in users: +# if user.email != current_user.email: +# user_list.append(user) +# return render_template("add_friend.html", users=user_list) + +# # def accept_friend(): + +# # def reject_friend(): + +# def add_friend(friend_email): +# if len(friend_email) < 1: +# flash('Friend email is too short!', category='error') +# elif db.session.query(User).filter_by(email=friend_email).first(): + + + diff --git a/service/src_old/__init__.py b/service/src_old/__init__.py deleted file mode 100644 index 371b855..0000000 --- a/service/src_old/__init__.py +++ /dev/null @@ -1,60 +0,0 @@ -from flask import Flask -from flask_sqlalchemy import SQLAlchemy -from os import path -from flask_login import LoginManager -import logging -import os -import random -import base64 - -log_directory = os.path.join("..", "instance") -if not os.path.exists(log_directory): - os.makedirs(log_directory) - -fh = logging.FileHandler(os.path.join(log_directory, "service.log")) -logger = logging.getLogger("ENOWARS_LOGER") -logger.setLevel(logging.DEBUG) -fh = logging.FileHandler("../instance/service.log") -fh.setLevel(logging.DEBUG) -formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s") -fh.setFormatter(formatter) -logger.addHandler(fh) - -db = SQLAlchemy() -DB_NAME = "database.db" -def generate_secret_key(): - return base64.b64encode(random.SystemRandom().getrandbits(256).to_bytes(32, 'little')).decode('utf-8') - - -def create_app(): - app = Flask(__name__) - app.config['SECRET_KEY'] = os.environ.get('SECRET_KEY', generate_secret_key()) - app.config['SQLALCHEMY_DATABASE_URI'] = f'sqlite:///{DB_NAME}' - db.init_app(app) - - from .views import views - from .auth import auth - - app.register_blueprint(views, url_prefix='/') - app.register_blueprint(auth, url_prefix='/') - - from .models import User, Note - - with app.app_context(): - db.create_all() - - login_manager = LoginManager() - login_manager.login_view = 'auth.login' - login_manager.init_app(app) - - @login_manager.user_loader - def load_user(id): - return User.query.get(int(id)) - - return app - - -def create_database(app): - if not path.exists('website/' + DB_NAME): - db.create_all(app=app) - logger.info('Created Database!') diff --git a/service/src_old/aes_encryption.py b/service/src_old/aes_encryption.py deleted file mode 100644 index 2e95dc5..0000000 --- a/service/src_old/aes_encryption.py +++ /dev/null @@ -1,42 +0,0 @@ -from Crypto.Cipher import AES -from Crypto.Random import get_random_bytes -from Crypto.Util.Padding import pad, unpad -import random -import time -import datetime -import base64 - -def random_number(): - random_number = random.randint(0, 2**128 - 1) - return random_number.to_bytes(16, byteorder='big') - -def aes_encrypt(plaintext): - current_time = datetime.datetime.now().time() - time_str = str(current_time) - time = time_str.split(':') - seed = time[0] + time[1] - random.seed(seed) - - key = random_number() - nonce = random_number() - - cipher = AES.new(key, AES.MODE_GCM, nonce=nonce) - plaintext_bytes = plaintext.encode() - padded_plaintext = pad(plaintext_bytes, AES.block_size) - ciphertext = cipher.encrypt(padded_plaintext) - return base64.b64encode(ciphertext).decode(), key, nonce - - - - - - - - - - - - - - - diff --git a/service/src_old/auth.py b/service/src_old/auth.py deleted file mode 100644 index e4c7cee..0000000 --- a/service/src_old/auth.py +++ /dev/null @@ -1,98 +0,0 @@ -from flask import Blueprint, render_template, request, flash, redirect, url_for -from .models import User -from werkzeug.security import generate_password_hash, check_password_hash -from . import db, logger ##means from __init__.py import db -from flask_login import login_user, login_required, logout_user, current_user -from . import rsa_encryption -import datetime - - -auth = Blueprint('auth', __name__) - - -@auth.route('/login', methods=['GET', 'POST']) -async def login(): - if request.method == 'POST': - email = request.form.get('email') - password = request.form.get('password') - user = User.query.filter_by(email=email).first() - if user: - if(user.password == password): - flash('Logged in successfully!', category='success') - login_user(user, remember=True) - return redirect(url_for('views.home')) - else: - flash('Incorrect password, try again.', category='error') - else: - flash('Email does not exist.', category='error') - return render_template("login.html", user=current_user) - - -@auth.route('/logout') -@login_required -async def logout(): - logout_user() - return redirect(url_for('auth.login')) - - -@auth.route('/sign-up', methods=['GET', 'POST']) -async def sign_up(): - if request.method == 'POST': - email = request.form.get('email') - first_name = request.form.get('firstName') - password1 = request.form.get('password1') - password2 = request.form.get('password2') - #to be changed - public_key = request.form.get('public_key') - - - user = User.query.filter_by(email=email).first() - if user: - flash('Email already exists.', category='error') - elif len(email) < 4: - flash('Email must be greater than 3 characters.', category='error') - elif len(first_name) < 2: - flash('First name must be greater than 1 character.', category='error') - elif password1 != password2: - flash('Passwords don\'t match.', category='error') - elif len(password1) < 7: - flash('Password must be at least 7 characters.', category='error') - else: - if public_key == "on": - #check if public key is already in use - while True: - private_key, public_key = rsa_encryption.get_keys() - all_public_keys = [user_public.public_key for user_public in User.query.all()] - if public_key not in all_public_keys: - break - - #saving the public key in a format that can be used as later - text = public_key.split('\n') - text = text[1:-2] - final_text = "" - for j in text: - final_text += j - - private_key_text = private_key.split('\n') - text = private_key_text[1:-2] - final_private_key_text = "" - for j in text: - final_private_key_text += j - - new_user = User(email=email, first_name=first_name, private_key=private_key, public_key=public_key, public_key_name = final_text, private_key_name = final_private_key_text ,password= password1, time = datetime.datetime.now()) - db.session.add(new_user) - db.session.commit() - login_user(new_user, remember=True) # missing await? - flash('Account created!', category='success') - return redirect(url_for('views.home')) - else: - private_key = None - public_key = None - new_user = User(email=email, first_name=first_name, private_key=private_key, public_key=public_key, password= password1, time = datetime.datetime.now()) - db.session.add(new_user) - db.session.commit() #await? - login_user(new_user, remember=True) # missing await? - flash('Account created!', category='success') - return redirect(url_for('views.home')) - - return render_template("sign_up.html", user=current_user) diff --git a/service/src_old/cleanup.py b/service/src_old/cleanup.py deleted file mode 100644 index d74a4ab..0000000 --- a/service/src_old/cleanup.py +++ /dev/null @@ -1,58 +0,0 @@ -import os -import sqlite3 -import datetime -import time - -Interval_for_cleanup = datetime.timedelta(minutes=15) - -db_path = os.path.dirname(__file__) -db_path = os.path.dirname(db_path) -db_path = os.path.join(db_path, 'instance') -db_path = os.path.join(db_path, 'database.db') - -def cleanup_header(): - time.sleep(120) - time_to_sleep = 60 - while True: - cleanup_Note() - cleanup_User() - cleanup_NoteGroup() - cleanup_NoteOfGroup() - time.sleep(time_to_sleep) - - -def cleanup_Note(): - db = sqlite3.connect(db_path) - cursor = db.cursor() - cursor.execute('DELETE FROM Note WHERE time < ?', (datetime.datetime.now() - Interval_for_cleanup,)) - db.commit() - db.close() - -def cleanup_User(): - db = sqlite3.connect(db_path) - cursor = db.cursor() - cursor.execute('SELECT id FROM User WHERE time < ?', (datetime.datetime.now() - Interval_for_cleanup,)) - users_to_delete = cursor.fetchall() - users_to_delete = [user[0] for user in users_to_delete] - cursor.execute('DELETE FROM user_group_association WHERE user_id IN ({})'.format(','.join('?' * len(users_to_delete))), users_to_delete) - cursor.execute('DELETE FROM User WHERE time < ?', (datetime.datetime.now() - Interval_for_cleanup,)) - db.commit() - db.close() - -def cleanup_NoteGroup(): - db = sqlite3.connect(db_path) - cursor = db.cursor() - cursor.execute('DELETE FROM NoteGroup WHERE time < ?', (datetime.datetime.now() - Interval_for_cleanup,)) - db.commit() - db.close() - -def cleanup_NoteOfGroup(): - db = sqlite3.connect(db_path) - cursor = db.cursor() - cursor.execute('DELETE FROM NoteOfGroup WHERE time < ?', (datetime.datetime.now() - Interval_for_cleanup,)) - db.commit() - db.close() - - -if __name__ == '__main__': - cleanup_header() \ No newline at end of file diff --git a/service/src_old/models.py b/service/src_old/models.py deleted file mode 100644 index 4115c71..0000000 --- a/service/src_old/models.py +++ /dev/null @@ -1,64 +0,0 @@ -from . import db -from flask_login import UserMixin -from sqlalchemy.sql import func - -# Association table for the many-to-many relationship between users and groups -user_group_association = db.Table('user_group_association', - db.Column('user_id', db.Integer, db.ForeignKey('User.id')), - db.Column('group_id', db.Integer, db.ForeignKey('NoteGroup.id')) -) - -user_friends_association = db.Table('user_friends_association', - db.Column('user_id', db.Integer, db.ForeignKey('User.id')), - db.Column('friend_id', db.Integer, db.ForeignKey('User.id')) -) - -class NoteGroup(db.Model): - __tablename__ = 'NoteGroup' - id = db.Column(db.Integer, primary_key=True) - name = db.Column(db.String(150)) - group_key = db.Column(db.String(255)) - time = db.Column(db.DateTime(timezone=True), default=func.now()) - # Define the relationship with User using the association table - users = db.relationship('User', secondary=user_group_association, backref=db.backref('groups', lazy='dynamic')) - notes = db.relationship('NoteOfGroup', backref='group', lazy=True) - -class NoteOfGroup(db.Model): - __tablename__ = 'NoteOfGroup' - id = db.Column(db.Integer, primary_key=True) - name = db.Column(db.String(255)) - data = db.Column(db.String(10000)) - encrypted_data = db.Column(db.String(10000)) - time = db.Column(db.DateTime(timezone=True), default=func.now()) - description = db.Column(db.Text) - group_id = db.Column(db.Integer, db.ForeignKey('NoteGroup.id')) - key = db.Column(db.String(255)) - nonce = db.Column(db.String(255)) - -class Note(db.Model): - __tablename__ = 'Note' - id = db.Column(db.Integer, primary_key=True) - name = db.Column(db.String(255)) - data = db.Column(db.String(10000)) - encrypted_data = db.Column(db.String(10000)) - description = db.Column(db.Text) - owner_id = db.Column(db.Integer, db.ForeignKey('User.id')) - destination_id = db.Column(db.Integer) - time = db.Column(db.DateTime(timezone=True), default=func.now()) - -class User(db.Model, UserMixin): - __tablename__ = 'User' - id = db.Column(db.Integer, primary_key=True) - email = db.Column(db.String(150), unique=True) - password = db.Column(db.String(150)) - first_name = db.Column(db.String(150)) - notes = db.relationship('Note', backref='owner', lazy=True) - private_key = db.Column(db.String(255), unique=True) - public_key = db.Column(db.String(255), unique=True) - public_key_name = db.Column(db.String(255), unique=True) - private_key_name = db.Column(db.String(255), unique=True) - status = db.Column(db.String(255)) - time = db.Column(db.DateTime(timezone=True), default=func.now()) - - - diff --git a/service/src_old/requirements.txt b/service/src_old/requirements.txt deleted file mode 100644 index 4a2b19e..0000000 Binary files a/service/src_old/requirements.txt and /dev/null differ diff --git a/service/src_old/rsa_encryption.py b/service/src_old/rsa_encryption.py deleted file mode 100644 index 1f4f14b..0000000 --- a/service/src_old/rsa_encryption.py +++ /dev/null @@ -1,98 +0,0 @@ -import rsa -from cryptography.hazmat.primitives.asymmetric import rsa as crsa -from cryptography.hazmat.primitives import serialization -from cryptography.hazmat.primitives.asymmetric import padding -from cryptography.hazmat.primitives import hashes -import random -import sympy -import time -import pickle -import base64 - -from gmpy2 import is_prime - -# the prime calculation is based on https://www.geeksforgeeks.org/how-to-generate-large-prime-numbers-for-rsa-algorithm/ -# First 10000 prime numbers - - -first_primes_list = list(sympy.primerange(2, 10000)) - -# Generate RSA key pair -def generate_key_pair(p,q): - n = p * q - e = 65537 # Commonly used public exponent - d = rsa.common.inverse(e, (p-1)*(q-1)) - # Generate RSA key object - private_key = rsa.PrivateKey(n, e, d, p, q) - public_key = rsa.PublicKey(n, e) - return private_key, public_key - -# Generate a random n-bit number -def nBitRandom(n): - random.seed(random.SystemRandom().random()) - return random.randrange(2**(n-1)+1, 2**n - 1) - - -def getLowLevelPrime(n): - while True: - # Obtain a random number - randomnumber = nBitRandom(n) - randomnumber2 = randomnumber + 4 - - # test if number is prime - for divisor in first_primes_list: - if randomnumber % divisor == 0 and divisor**2 <= randomnumber or randomnumber2 % divisor == 0 and divisor**2 <= randomnumber2: - break - else: - return randomnumber, randomnumber2 - - -def random_prime(): - def test(p,q): - for _ in first_primes_list: - if p % _ == 0 or q % _ == 0: return False - return True - while True: - p = nBitRandom(256) - p |= 1 - q = p + 6 - if test(p,q): - if is_prime(p) and is_prime(q): return p,q - - -def get_keys(): - p,q = random_prime() - private_key, public_key = generate_key_pair(p,q) - return private_key.save_pkcs1().decode(), public_key.save_pkcs1().decode() - - -async def encryption_of_message(message, public_key): - #make 52 byte/char long messages and add them together to make bigger - #byte_len = 20 - byte_len = 52 - public_key = rsa.PublicKey.load_pkcs1(public_key.encode()) - message = message.encode('utf-8') - message_chunks = [message[i:i+byte_len] for i in range(0, len(message), byte_len)] - cipher_string = b"" - for i in range(len(message_chunks)): - cipher = rsa.encrypt(message_chunks[i], public_key) - cipher_string += cipher - return base64.b64encode(cipher_string).decode() - -def decryption_of_message(cipher_string, private_key): - #byte_len = 32 #64 - byte_len = 64 - private_key = rsa.PrivateKey.load_pkcs1(private_key.encode()) - cipher_string = base64.b64decode(cipher_string) - cipher_array = [cipher_string[i:i+byte_len] for i in range(0, len(cipher_string), byte_len)] - plaintext = "" - for cipher in cipher_array: - plaintext += rsa.decrypt(cipher, private_key).decode() - return plaintext - -# if __name__ == '__main__': -# message = "ENOABCDEF1234567890+/=ABCDEFGHIJKLM1234567890+/=1234567890+/=" -# private_key, public_key = get_keys() -# cipher_string = encryption_of_message(message, public_key) -# plaintext = decryption_of_message(cipher_string, private_key) -# print("Plaintext: ", plaintext) diff --git a/service/src_old/static/index.js b/service/src_old/static/index.js deleted file mode 100644 index 7039e54..0000000 --- a/service/src_old/static/index.js +++ /dev/null @@ -1,16 +0,0 @@ -function deleteNote(noteId) { - fetch("/delete-note", { - method: "POST", - body: JSON.stringify({ noteId: noteId }), - }).then((_res) => { - window.location.href = "/"; - }); -} -function deleteNoteGroup(noteGroupId) { - fetch("/delete-note-group", { - method: "POST", - body: JSON.stringify({ noteGroupId: noteGroupId }), - }).then((_res) => { - window.location.href = window.location.pathname; - }); -} diff --git a/service/src_old/static/style.css b/service/src_old/static/style.css deleted file mode 100644 index 7d14101..0000000 --- a/service/src_old/static/style.css +++ /dev/null @@ -1,2 +0,0 @@ -/* here will be the css code for the whatsapp scam side */ - \ No newline at end of file diff --git a/service/src_old/templates/add_friend.html b/service/src_old/templates/add_friend.html deleted file mode 100644 index a838093..0000000 --- a/service/src_old/templates/add_friend.html +++ /dev/null @@ -1,21 +0,0 @@ -{% extends "base.html" %} {% block title %}ADD FRIENDS{% endblock %} {% block content - %} -
-{% endblock %} \ No newline at end of file diff --git a/service/src_old/templates/base.html b/service/src_old/templates/base.html deleted file mode 100644 index 9cfc60c..0000000 --- a/service/src_old/templates/base.html +++ /dev/null @@ -1,106 +0,0 @@ - - - - - - - - - -