2017-03-29 16:43:37 +02:00
|
|
|
import os
|
2017-05-06 18:03:15 +02:00
|
|
|
from datetime import datetime, timedelta
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
from flask import session
|
2017-03-29 16:43:37 +02:00
|
|
|
from flask_restful import Resource, request
|
|
|
|
|
|
|
|
from app.api import mailsModels
|
2017-03-31 00:19:02 +02:00
|
|
|
from app.api.LoginAPI import login_required
|
2017-05-06 18:03:15 +02:00
|
|
|
from app.model import Roles, getParam, getGroup, getUser, USER, LIVRET, getLivret, getTutorship
|
2017-03-31 12:35:29 +02:00
|
|
|
from app.utils import send_mail, checkParams
|
|
|
|
|
2017-03-29 16:43:37 +02:00
|
|
|
|
|
|
|
class LivretAPI(Resource):
|
|
|
|
"""
|
|
|
|
Livret Api Resource
|
|
|
|
"""
|
2017-03-31 12:35:29 +02:00
|
|
|
|
2017-03-31 00:19:02 +02:00
|
|
|
@login_required(roles=[Roles.etudiant])
|
2017-03-29 16:43:37 +02:00
|
|
|
def post(self):
|
|
|
|
args = request.get_json(cache=False, force=True)
|
2017-05-06 18:03:15 +02:00
|
|
|
if not checkParams(['group_id', 'etutor_id', 'company_name', 'company_address', 'contract_type',
|
2017-03-31 12:35:29 +02:00
|
|
|
'contract_start', 'contract_end', 'description'], args):
|
2017-03-29 16:43:37 +02:00
|
|
|
return {"ERROR": "One or more parameters are missing !"}, 400
|
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
user = session.get("user")
|
|
|
|
group_id = args['group_id']
|
|
|
|
etutor_id = args['etutor_id']
|
|
|
|
company_name = args['company_name']
|
|
|
|
company_address = args['company_address']
|
|
|
|
contract_type = int(args['contract_type'])
|
|
|
|
contract_start = datetime.strptime(args['contract_start'], "%d-%m-%Y")
|
|
|
|
contract_end = datetime.strptime(args['contract_end'], "%d-%m-%Y")
|
|
|
|
description = args['description']
|
2017-03-29 16:43:37 +02:00
|
|
|
mails = []
|
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
group = getGroup(gid=group_id)
|
|
|
|
if group is None:
|
2017-05-08 15:48:12 +02:00
|
|
|
return {"ERROR": "This group with id " + str(group_id) + "does not exists !"}, 405
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
tutorship = getTutorship(gid=group_id, student=user["id"])
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
if tutorship is None:
|
2017-05-08 15:48:12 +02:00
|
|
|
return {"ERROR": "The current student is not registered in the group" + str(group_id) + " !"}, 405
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
tutorship_id = tutorship["id"]
|
|
|
|
|
|
|
|
livret = getLivret(group_id=group_id, student_id=user["id"])
|
|
|
|
if livret is not None:
|
2017-05-08 15:48:12 +02:00
|
|
|
return {"LID": livret["id"]}, 200
|
2017-03-31 12:35:29 +02:00
|
|
|
|
2017-05-08 19:51:28 +02:00
|
|
|
# On vérifie que l'utilisateur actuel a le droit de modifier ce livret
|
|
|
|
if user["id"] != livret["tutorship_id"]["student_id"]:
|
|
|
|
return {"ERROR": "UNAUTHORIZED"}, 401
|
|
|
|
|
|
|
|
user2 = getUser(uid=etutor_id)
|
|
|
|
if user2 is None:
|
2017-03-31 12:35:29 +02:00
|
|
|
return {"ERROR": "The user with id " + str(etutor_id) + " does not exists !"}, 400
|
2017-03-29 16:43:37 +02:00
|
|
|
else:
|
2017-05-08 19:51:28 +02:00
|
|
|
query = USER.select(USER.c.id == user2["id"])
|
2017-03-29 16:43:37 +02:00
|
|
|
rows = query.execute()
|
|
|
|
res = rows.first()
|
|
|
|
if res.hash is not None and len(res.hash) > 0:
|
2017-05-06 18:03:15 +02:00
|
|
|
mail = mailsModels.getMailContent("NEW_ETUTOR_ADDED", {"GROUPE": group["name"],
|
2017-03-29 16:43:37 +02:00
|
|
|
"URL": getParam('OLA_URL') + "registration/"
|
|
|
|
+ res.hash})
|
|
|
|
else:
|
2017-05-06 18:03:15 +02:00
|
|
|
mail = mailsModels.getMailContent("ETUTOR_ADDED", {"GROUPE": group["name"],
|
2017-03-29 16:43:37 +02:00
|
|
|
"URL": getParam('OLA_URL')})
|
|
|
|
|
2017-05-08 19:51:28 +02:00
|
|
|
mails.append((user2["email"], mail))
|
|
|
|
if str(Roles.tuteur_entreprise) not in user2['role'].split('-'):
|
2017-03-31 12:35:29 +02:00
|
|
|
return {"ERROR": "The user with id " + str(etutor_id) +
|
|
|
|
" doesn't have the 'etutor' role (" + str(Roles.tuteur_entreprise) + ") !"}, 400
|
|
|
|
|
|
|
|
if contract_start > contract_end:
|
|
|
|
return {"ERROR": "The contract start can't be after its end !"}, 400
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
res_dir = group["ressources_dir"] + "/" + str(user['id']) + "/"
|
|
|
|
expire = datetime.now() + timedelta(days=365)
|
2017-03-31 12:35:29 +02:00
|
|
|
|
|
|
|
query = LIVRET.insert().values(tutorship_id=tutorship_id, etutor_id=etutor_id, company_name=company_name,
|
|
|
|
company_address=company_address, contract_type=contract_type,
|
|
|
|
contract_start=contract_start, contract_end=contract_end,
|
|
|
|
description=description, ressources_dir=res_dir, opened='1', expire=expire)
|
2017-03-29 16:43:37 +02:00
|
|
|
res = query.execute()
|
|
|
|
os.mkdir(res_dir)
|
|
|
|
|
|
|
|
for m in mails:
|
|
|
|
addr = m[0]
|
|
|
|
mail = m[1]
|
|
|
|
send_mail(mail[0], addr, mail[1])
|
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
return {"LID": res.lastrowid}, 201
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
@login_required(roles=[Roles.etudiant])
|
2017-05-06 18:03:15 +02:00
|
|
|
def put(self, lid):
|
2017-03-29 16:43:37 +02:00
|
|
|
args = request.get_json(cache=False, force=True)
|
2017-05-06 18:03:15 +02:00
|
|
|
if not checkParams(['etutor_id', 'company_name', 'company_address', 'contract_type',
|
|
|
|
'contract_start', 'contract_end', 'description'], args):
|
2017-03-29 16:43:37 +02:00
|
|
|
return {"ERROR": "One or more parameters are missing !"}, 400
|
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
etutor_id = args['etutor_id']
|
|
|
|
company_name = args['company_name']
|
|
|
|
company_address = args['company_address']
|
|
|
|
contract_type = int(args['contract_type'])
|
|
|
|
contract_start = datetime.strptime(args['contract_start'], "%d-%m-%Y")
|
|
|
|
contract_end = datetime.strptime(args['contract_end'], "%d-%m-%Y")
|
|
|
|
description = args['description']
|
2017-03-29 16:43:37 +02:00
|
|
|
mails = []
|
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
livret = getLivret(lid=lid)
|
|
|
|
if livret is None:
|
|
|
|
return {"ERROR": "This livret does not exists !"}, 405
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-08 19:51:28 +02:00
|
|
|
# On vérifie que l'utilisateur actuel a le droit de modifier ce livret
|
|
|
|
user = session.get("user")
|
|
|
|
if user["id"] != livret["tutorship_id"]["student_id"]:
|
|
|
|
return {"ERROR": "UNAUTHORIZED"}, 401
|
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
user = getUser(uid=etutor_id)
|
2017-03-29 16:43:37 +02:00
|
|
|
if user is None:
|
2017-05-06 18:03:15 +02:00
|
|
|
return {"ERROR": "The user with id " + str(etutor_id) + " does not exists !"}, 400
|
2017-03-29 16:43:37 +02:00
|
|
|
else:
|
|
|
|
query = USER.select(USER.c.id == user["id"])
|
|
|
|
rows = query.execute()
|
|
|
|
res = rows.first()
|
|
|
|
if res.hash is not None and len(res.hash) > 0:
|
2017-05-06 18:03:15 +02:00
|
|
|
mail = mailsModels.getMailContent("NEW_ETUTOR_ADDED",
|
|
|
|
{"GROUPE": livret["tutorship_id"]["group_id"]["name"],
|
|
|
|
"URL": getParam('OLA_URL') + "registration/"
|
|
|
|
+ res.hash})
|
2017-03-29 16:43:37 +02:00
|
|
|
else:
|
2017-05-06 18:03:15 +02:00
|
|
|
mail = mailsModels.getMailContent("ETUTOR_ADDED", {"GROUPE": livret["tutorship_id"]["group_id"]["name"],
|
|
|
|
"URL": getParam('OLA_URL')})
|
2017-03-29 16:43:37 +02:00
|
|
|
|
|
|
|
mails.append((user["email"], mail))
|
2017-05-06 18:03:15 +02:00
|
|
|
if str(Roles.tuteur_entreprise) not in user['role'].split('-'):
|
|
|
|
return {"ERROR": "The user with id " + str(etutor_id) +
|
|
|
|
" doesn't have the 'etutor' role (" + str(Roles.tuteur_entreprise) + ") !"}, 400
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
if contract_start > contract_end:
|
|
|
|
return {"ERROR": "The contract start can't be after its end !"}, 400
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
query = LIVRET.update().values(etutor_id=etutor_id, company_name=company_name,
|
|
|
|
company_address=company_address, contract_type=contract_type,
|
|
|
|
contract_start=contract_start, contract_end=contract_end,
|
|
|
|
description=description) \
|
|
|
|
.where(LIVRET.c.id == lid)
|
2017-03-29 16:43:37 +02:00
|
|
|
query.execute()
|
|
|
|
|
|
|
|
for m in mails:
|
|
|
|
addr = m[0]
|
|
|
|
mail = m[1]
|
|
|
|
send_mail(mail[0], addr, mail[1])
|
|
|
|
|
2017-05-06 18:03:15 +02:00
|
|
|
return {"LID": lid}, 200
|
2017-03-29 16:43:37 +02:00
|
|
|
|
2017-03-31 12:35:29 +02:00
|
|
|
@login_required()
|
2017-05-06 18:03:15 +02:00
|
|
|
def get(self, lid=0, group_id=0, student_id=0):
|
|
|
|
if lid > 0:
|
|
|
|
return {'LIVRET': getLivret(lid=lid)}, 200
|
|
|
|
elif group_id > 0 and student_id > 0:
|
|
|
|
return {'LIVRET': getLivret(group_id=group_id, student_id=student_id)}, 200
|