__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() #---------------------------------------------------------- # POST #---------------------------------------------------------- @project_routes.route('/api/projects/create/', methods=['POST']) @auto.doc() def create_project(token): """ This call will create a new project in the DB
Route Parameters
- seToken: 'seToken'

Payload
- JSON Object, Example:
{
'projectName': 'Advance Math',
'courseName': 'JCE',
'logo_url': 'http://location.domain.com/image.jpg',
'gitRepository': 'http://location.git.com/somthing'
}


Response
201 - Created
400 - Bad Request
403 - Invalid token or not a lecturer """ if not request.data: return bad_request() payload = json.loads(request.data) #if not is_lecturer(token): #todo: change to lecturer id # return forbidden("Invalid token or not a lecturer!") user = get_user_by_token(token) if user is None: return bad_request("Wrong user Token") #todo: check legality try: 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") #---------------------------------------------------------- # PUT #---------------------------------------------------------- #---------------------------------------------------------- # GET #---------------------------------------------------------- @project_routes.route('/api/projects/getProjectsByCourseName/', methods=["GET"]) @auto.doc() def getProjectsByCourseName(name): """ >This Call will return an array of all projects in a given course
Route Parameters
- name: 'course name'

Payload
- NONE

Response
200 - JSON Example:
{
'projectName': 'Advance Math',
'courseName': 'JCE',
'grade': 98,
'logo_url': 'http://location.domain.com/image.jpg',
'gitRepository': 'http://location.git.com/somthing',
'membersId': ['bob', 'dylan', 'quentin', 'terentino'],
'id' : 1234567890
}

""" 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: return Response(response=[], status=200, mimetype="application/json") #---------------------------------------------------------- # DELETE #---------------------------------------------------------- @project_routes.route('/api/projects/deleteProject//', methods=['DELETE']) @auto.doc() def deleteProject(token,projectid): """ This Call will delete a specific Project
Route Parameters
- seToken: 'seToken' - courseid: 'projectid'

Payload
- NONE


Response
202 - Deleted Project
....
{
...
}req
]
400 - no such Project
403 - Invalid token or not the owner of Project!
""" # 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") #---------------------------------------------------------- # DOCUMENTATION #---------------------------------------------------------- @project_routes.route('/api/projects/help') def documentation(): return auto.html()