alphabet autorisé
- abcdefghijklmnopqrstuvwxyz
- minuscule*
Nous allons suivre le standard REST (c'est le plus simple des standards matechkiwch)
Le format utilisé est json, exemple de requête:
{
"sender": "adel",
"algorithm": "ceasar",
"message": "Hello World",
"key": 6,
"type": "encrypt"
}
- sender: représente le nom de l'expéditeur (utilisez vôtre prénom)
- algorithm: le nom de l'algorithme utilisé (où à utiliser) la liste standard des noms d'algorithms se trouve ici
- message: tout simplement le message à envoyer
- key: la clé, elle est dynamique et dépend de l'algo
- type (encrypt|decrypt): peut prendre deux valeurs 'encrypt' ou 'decrypt'
- encrypt: signifie que le message envoyé doit être crypté par le recipient (message doit être en clair)
- decrypt: signifie que le message envoyé doit être décrypté par le recipient (message doit être crypté)
- ceasar: 'ceasar'
- vigenere: 'vigenere'
- substitution: 'substitution'
- transposition: 'transposition'
- ceasar: nombre (type: number)
key: 6
- vigenere: string
key: 'grou'
- substitution: String
- alphabet de chiffrement:
- taille 26
- sans duplication
key: 'zyxwvutsrqponmlkjihgfedcba'
- alphabet de chiffrement:
- transposition: nombre (type: number)
key: 6
- clonez ce projet
git clone git@github.com:Quickinline/tp_m2_bsd.git
- Copiez le dossier "serveur" qui se trouve dans le dossier package dans votre projet
- lancez docker
docker-compose up -d && docker-compose logs -f
- et le serveur fonctionne au port 80 !!!
-
- testez le serveur en entrant ce lien sur votre navigateur http://localhost vous verrez un "hello world"
- Installez les dépendances
export PYTHONDONTWRITEBYTECODE=1 # (optional but its cleaner)
export FLASK_ENV=development # to enable development
export FLASK_APP=app # this is the file's name, if you happen to change it, change this env as well
# replace 'export' by 'set' for windows cmd)
pip install flask # installs flask (duh ...)
- lancez le serveur
flask run
# ajoutez "--port {numéro du port}" pour changer le port par défaut (3000)
- testez le serveur en entrant ce lien sur votre navigateur http://localhost:3000 vous trouverez un "hello world"
une fois le fichier app.py ouvert vous trouverez ceci
Vous devez ajouter votre code avant le return pour traiter la requête et actionner des modification dans vôtre application desktop (affichage, etc...)
from flask import Flask, request
from handler import validate_encrypt_request
app = Flask(__name__)
@app.route("/")
def hello_world():
return "<p>Hello, World!</p>"
@app.route('/encrypt', methods=['POST'])
def encrypt():
requestJson = request.get_json()
validate_encrypt_request(requestJson)
sender = requestJson['sender']
algorithm = requestJson['algorithm']
message = requestJson['message']
key = requestJson['key']
typed = requestJson['type']
# build response
# //insèrez votre code qui traite le message là
#
#
#
return 'response'
Tous les fichiers nécessaires se trouvent dans tp_m2_bsd\package\server\pyqt_integration
Pour démarrer importer ou copier la classe Server_Worker dans le même fichier où votre classe QMainWindow est définie. ce serveur est le même adel a écrite mais il est fait de manière à fonctionner avec pyqt5
# add this at the beging of your main file code
from flask import Flask, request,current_app
from handler import validate_encrypt_request
from PyQt5 import QtCore
class Server_Worker(QtCore.QObject):
res = QtCore.pyqtSignal(dict)
app = Flask(__name__)
def __init__(self):
super().__init__()
@app.route("/")
def hello_world():
return "<p>Hello, World!</p>"
@app.route('/encrypt', methods=['POST'])
def encrypt():
requestJson = request.get_json()
validate_encrypt_request(requestJson)
sender = requestJson['sender']
algorithm = requestJson['algorithm']
message = requestJson['message']
key = requestJson['key']
typed = requestJson['type']
current_app.config['obj'].res.emit(requestJson)
return requestJson
def run(self):
self.app.config['obj'] = self
self.app.run(host='0.0.0.0',port=3000)
Ensuite, dans votre fonction __init__ dans la classe QMainWindow, ajoutez ceci
self.server_worker = Server_Worker()
self.thread = QtCore.QThread()
self.server_worker.moveToThread(self.thread)
self.thread.started.connect(self.server_worker.run)
self.server_worker.res.connect(self.p)
self.thread.start()
ajoutez cette fonction à votre classe QMainWindow redéfinissez la selon vos besoins, elle devrait mettre à jour l'interface,(n'oubliez pas de déchiffrer le texte).
def p(self,val):
# add this in your QMainWindow class and write UI changes here the val varible is what result of the post request
print(val)
la variable val est un dictionnaire python avec une structure similaire à celle-ci
{'sender': 'yacine', 'algorithm': 'ceasar', 'message': 'Hello World', 'key': 6, 'type': 'encrypt'}
Toutes les fonctions peuvent être trouvées dans le fichier tp_m2_bsd/package/server/peer_discovery.py
dans ce fichier, vous trouverez les fonctions nécessaires à votre identification ainsi qu'à l'identification d'autres personnes en plus de la fonction d'envoi des données à votre destination.
cette fonction permet d'obtenir l'adresse IP de la passerelle par défaut (gatway)
def get_gatway_ip():
try:
gateways = netifaces.gateways()
defaults = gateways.get("default")
return defaults[2][0]
except:
raise Exception('make sure you are online...')
cette fonction est utilisée à la fois pour vous identifier ainsi que pour obtenir des informations sur d'autres peer
def request(name):
data = {'name':name,'active':True}
try:
x = requests.post(f"http://{get_gatway_ip()}:3000/get-peers",json=data)
if x.status_code == 200:
return x.json()
else:
return []
except Exception as e:
print(e)
return []
pour l'utiliser il suffit de spécifier votre nom dans le réseau.
lorsque vous envoyez la demande, une réponse sera renvoyée par le serveur si le code de réponse est 200 cela signifie que la demande a réussi et la fonction renverra une chaîne json similaire à cette structure
[{"ip":"10.42.0.12","name":"Yacine","active":True}]
sinon la fonction retournera une List vide
cette fonction est utilisée pour envoyer des données à d'autres peer (vous n'êtes pas obligé de l'utiliser, vous pouvez écrire la votre).
assurez-vous simplement d'appeler cette fonction avec tous les bons arguments et vérifiez si le code de retour est 200, si c'est le cas, cela signifie que vous êtes bon, les informations que vous avez envoyées ont été reçues et le serveur de destination a répondu. tout autre code signifie que la demande n'a pas été faite correctement.
def send_data(ip,sender,algo,msg,key):
data = {"sender": sender ,"algorithm": algo ,"message": msg ,"key": key ,"type": "encrypt"}
url = f'http://{ip}:3000/encrypt'
try:
x = requests.post(url, json=data)
return x.status_code
except Exception as e:
print(e)
return -1