se-hub/SE_API/ProjectRoutes.py

183 lines
4.5 KiB
Python
Raw Normal View History

__author__ = 'Aran'
from flask import Blueprint
import json
from GithubAPI.GithubAPI import GitHubAPI_Keys
from google.appengine.ext import db
import requests
import datetime
from flask import Flask, request, render_template, redirect, abort, Response
from flask.ext.github import GitHub
from flask.ext.cors import CORS, cross_origin
from flask.ext.autodoc import Autodoc
# DB Models
from models.Project import Project
#Validation Utils Libs
from SE_API.Validation_Utils import *
from SE_API.Respones_Utils import *
project_routes = Blueprint("project_routes", __name__)
auto = Autodoc()
2015-06-15 15:37:08 +00:00
@project_routes.route('/api/projects/create/<string:token>', methods=['POST'])
@auto.doc()
2015-06-15 15:37:08 +00:00
def create_project(token):
"""
<span class="card-title">This call will create a new project in the DB</span>
<br>
<b>Route Parameters</b><br>
- seToken: 'seToken'
<br>
<br>
<b>Payload</b><br>
- JSON Object, Example: <br>
{<br>
2015-06-15 15:58:03 +00:00
'projectName': 'Advance Math',<br>
'courseName': 'JCE',<br>
2015-06-21 19:22:13 +00:00
'logo_url': 'http://location.domain.com/image.jpg',<br>
2015-06-15 15:58:03 +00:00
'gitRepository': 'http://location.git.com/somthing'<br>
}<br>
<br>
<br>
<b>Response</b>
<br>
201 - Created
<br>
2015-06-15 15:58:03 +00:00
400 - Bad Request
<br>
403 - Invalid token or not a lecturer
"""
if not request.data:
return bad_request()
payload = json.loads(request.data)
2015-06-21 19:22:13 +00:00
#if not is_lecturer(token): #todo: change to lecturer id
# return forbidden("Invalid token or not a lecturer!")
user = get_user_by_token(token)
2015-06-21 19:22:13 +00:00
if user is None:
return bad_request("Wrong user Token")
#todo: check legality
try:
2015-06-15 15:37:08 +00:00
project = Project(projectName=payload['projectName'], courseName=payload['courseName'], masterId=user.key().id(), gitRepository=payload['gitRepository'], membersId=[token])
except Exception as e:
print e
return bad_request()
db.put(project)
db.save
return Response(response=project.to_JSON(),
status=201,
mimetype="application/json")
2015-06-15 15:37:08 +00:00
@project_routes.route('/api/projects/getProjectsByCourseName/<string:name>', methods=["GET"])
@auto.doc()
2015-06-15 15:37:08 +00:00
def getProjectsByCourseName(name):
2015-06-15 15:58:03 +00:00
"""
<span class="card-title">>This Call will return an array of all projects in a given course</span>
<br>
<b>Route Parameters</b><br>
2015-06-15 15:58:03 +00:00
- name: 'course name'
<br>
<br>
<b>Payload</b><br>
2015-06-15 15:37:08 +00:00
- NONE
<br>
<br>
<b>Response</b>
<br>
2015-06-15 15:37:08 +00:00
200 - JSON Example:<br>
<code>
{<br>
2015-06-15 15:58:03 +00:00
'projectName': 'Advance Math',<br>
'courseName': 'JCE',<br>
'grade': 98,<br>
'logo_url': 'http://location.domain.com/image.jpg',<br>
'gitRepository': 'http://location.git.com/somthing',<br>
'membersId': ['bob', 'dylan', 'quentin', 'terentino']<br>
2015-06-15 15:37:08 +00:00
}
</code>
<br>
2015-06-15 15:58:03 +00:00
"""
2015-06-15 15:37:08 +00:00
arr = []
query = Project.all()
query.filter("courseName = ", name)
for p in query.run():
arr.append(dict(json.loads(p.to_JSON())))
print arr
if len(arr) != 0:
return Response(response=json.dumps(arr),
status=200,
mimetype="application/json")
else:
2015-06-15 15:37:08 +00:00
return Response(response=[],
status=200,
mimetype="application/json")
@project_routes.route('/api/projects/deleteProject/<string:token>/<string:projectid>', methods=['DELETE'])
@auto.doc()
def deleteProject(token,projectid):
"""
<span class="card-title">This Call will delete a specific Project</span>
<br>
<b>Route Parameters</b><br>
- seToken: 'seToken'
- courseid: 'projectid'
<br>
<br>
<b>Payload</b><br>
- NONE <br>
<br>
<br>
<b>Response</b>
<br>
202 - Deleted Project
<br>
....<br>
{<br>
...<br>
}req<br>
]<br>
400 - no such Project
<br>
403 - Invalid token or not the owner of Project!<br>
"""
# if not is_lecturer(token): #todo: change to lecturer id
# return forbidden("Invalid token or not a lecturer!")
user = get_user_by_token(token)
p = Project.get_by_id(int(projectid))
if p is None:
return bad_request("no such Project")
if p.master_id == user.key().id():
db.delete(p)
db.save
return accepted("Project deleted")
return forbidden("user is not owner of Project")
@project_routes.route('/api/projects/help')
def documentation():
return auto.html()