本文整理匯總了Python中web.notfound方法的典型用法代碼示例。如果您正苦於以下問題:Python web.notfound方法的具體用法?Python web.notfound怎麽用?Python web.notfound使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類web
的用法示例。
在下文中一共展示了web.notfound方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: process_callback
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def process_callback(self, auth_id):
auth_method = self.user_manager.get_auth_method(auth_id)
if not auth_method:
raise web.notfound()
auth_storage = self.user_manager.session_auth_storage().setdefault(auth_id, {})
user = auth_method.callback(auth_storage)
if user and auth_storage.get("method", "") == "signin":
if not self.user_manager.bind_user(auth_id, user):
raise web.seeother("/signin?binderror")
elif user and auth_storage.get("method", "") == "share":
submission = self.submission_manager.get_submission(auth_storage["submissionid"], True)
if submission:
course = self.course_factory.get_course(submission["courseid"])
task = course.get_task(submission["taskid"])
auth_method.share(auth_storage, course, task, submission, self.user_manager.session_language())
else:
raise web.notfound()
else:
raise web.seeother("/signin?callbackerror")
raise web.seeother(auth_storage.get("redir_url", "/"))
示例2: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def GET(self):
"""
Checks if user is authenticated and calls POST_AUTH or performs login and calls GET_AUTH.
Otherwise, returns the login template.
"""
data = self.user_manager.session_lti_info()
if data is None:
raise web.notfound()
try:
course = self.course_factory.get_course(data["task"][0])
if data["consumer_key"] not in course.lti_keys().keys():
raise Exception()
except:
return self.template_helper.get_renderer().lti_bind(False, "", None, "Invalid LTI data")
user_profile = self.database.users.find_one({"ltibindings." + data["task"][0] + "." + data["consumer_key"]: data["username"]})
if user_profile:
self.user_manager.connect_user(user_profile["username"], user_profile["realname"], user_profile["email"], user_profile["language"])
if self.user_manager.session_logged_in():
raise web.seeother(self.app.get_homepath() + "/lti/task")
return self.template_helper.get_renderer().lti_login(False)
示例3: GET_AUTH
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def GET_AUTH(self, courseid, groupid=''): # pylint: disable=arguments-differ
""" Edit a group """
course, __ = self.get_course_and_check_rights(courseid, allow_all_staff=True)
if course.is_lti():
raise web.notfound()
if "download" in web.input():
web.header('Content-Type', 'text/x-yaml', unique=True)
web.header('Content-Disposition', 'attachment; filename="groups.yaml"', unique=True)
groups = [{"description": group["description"],
"students": group["students"],
"size": group["size"],
"audiences": [str(c) for c in group["audiences"]]} for group in
self.user_manager.get_course_groups(course)]
return yaml.dump(groups)
return self.display_page(course)
示例4: GET_AUTH
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def GET_AUTH(self, courseid): # pylint: disable=arguments-differ
""" GET request """
course, __ = self.get_course_and_check_rights(courseid)
user_input = web.input(tasks=[], aggregations=[], users=[])
error = ""
# First, check for a particular submission
if "submission" in user_input:
submission = self.database.submissions.find_one({"_id": ObjectId(user_input.submission),
"courseid": course.get_id(),
"status": {"$in": ["done", "error"]}})
if submission is None:
raise web.notfound()
self._logger.info("Downloading submission %s - %s - %s - %s", submission['_id'], submission['courseid'],
submission['taskid'], submission['username'])
archive, error = self.submission_manager.get_submission_archive(course, [submission], [])
if not error:
web.header('Content-Type', 'application/x-gzip', unique=True)
web.header('Content-Disposition', 'attachment; filename="submissions.tgz"', unique=True)
return archive
# Else, display the complete page
return self.display_page(course, user_input, error)
示例5: get_course_and_check_rights
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def get_course_and_check_rights(self, courseid, taskid=None, allow_all_staff=True):
""" Returns the course with id ``courseid`` and the task with id ``taskid``, and verify the rights of the user.
Raise web.notfound() when there is no such course of if the users has not enough rights.
:param courseid: the course on which to check rights
:param taskid: If not None, returns also the task with id ``taskid``
:param allow_all_staff: allow admins AND tutors to see the page. If false, all only admins.
:returns (Course, Task)
"""
try:
course = self.course_factory.get_course(courseid)
if allow_all_staff:
if not self.user_manager.has_staff_rights_on_course(course):
raise web.notfound()
else:
if not self.user_manager.has_admin_rights_on_course(course):
raise web.notfound()
if taskid is None:
return course, None
else:
return course, course.get_task(taskid)
except:
raise web.notfound()
示例6: action_download
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def action_download(self, courseid, taskid, path):
""" Download a file or a directory """
wanted_path = self.verify_path(courseid, taskid, path)
if wanted_path is None:
raise web.notfound()
task_fs = self.task_factory.get_task_fs(courseid, taskid)
(method, mimetype_or_none, file_or_url) = task_fs.distribute(wanted_path)
if method == "local":
web.header('Content-Type', mimetype_or_none)
return file_or_url
elif method == "url":
raise web.redirect(file_or_url)
else:
raise web.notfound()
示例7: POST_AUTH
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def POST_AUTH(self, courseid): # pylint: disable=arguments-differ
""" POST request """
course, __ = self.get_course_and_check_rights(courseid)
msgs = []
if "replay" in web.input():
if not self.user_manager.has_admin_rights_on_course(course):
raise web.notfound()
input = self.get_input()
tasks = course.get_tasks()
data, __ = self.get_submissions(course, input)
for submission in data:
self.submission_manager.replay_job(tasks[submission["taskid"]], submission)
msgs.append(_("{0} selected submissions were set for replay.").format(str(len(data))))
return self.page(course, msgs)
示例8: POST
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def POST(self):
""" Handles POST request """
if self.user_manager.session_logged_in() or not self.app.allow_registration:
raise web.notfound()
reset = None
msg = ""
error = False
data = web.input()
if "register" in data:
msg, error = self.register_user(data)
elif "lostpasswd" in data:
msg, error = self.lost_passwd(data)
elif "resetpasswd" in data:
msg, error, reset = self.get_reset_data(data)
if reset:
msg, error = self.reset_passwd(data)
if not error:
reset = None
return self.template_helper.get_renderer().register(reset, msg, error)
示例9: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def GET(self,name):
ext = name.split(".")[-1] # Gather extension
if name.find('.')<0:
ext = 'jpg'
imfile = self.get_local( os.path.splitext(name)[0] )
#print imfile
try:
web.header("Content-Type", cType[ext]) # Set the Header
return open(imfile,"rb").read() # Notice 'rb' for reading images
except:
raise web.notfound()
示例10: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def GET(self, id=None):
global db, nextid
if(len(id) == 0):
return json.dumps(db)
elif(int(id) in db):
return json.dumps(db[int(id)])
else:
return web.notfound()
示例11: DELETE
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def DELETE(self, id):
global db, nextid
if(int(id) in db):
db.pop(int(id))
return json.dumps({'deleted': int(id)})
else:
return web.notfound()
示例12: PUT
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def PUT(self, id):
global db, nextid
if(int(id) in db):
db[int(id)] = json.loads(web.data())
return json.dumps({'updated': int(id)})
else:
return web.notfound()
示例13: basic_checks
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def basic_checks(self, courseid):
try:
course = self.course_factory.get_course(courseid)
except:
raise web.notfound()
username = self.user_manager.session_username()
user_info = self.user_manager.get_user_info(username)
if self.user_manager.course_is_user_registered(course, username) or not course.is_registration_possible(user_info):
raise web.seeother(self.app.get_homepath() + "/course/" + course.get_id())
return course, username
示例14: process_signin
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def process_signin(self,auth_id):
auth_method = self.user_manager.get_auth_method(auth_id)
if not auth_method:
raise web.notfound()
auth_storage = self.user_manager.session_auth_storage().setdefault(auth_id, {})
auth_storage["redir_url"] = web.ctx.env.get('HTTP_REFERER', '/')
auth_storage["method"] = "signin"
auth_link = auth_method.get_auth_link(auth_storage)
raise web.seeother(auth_link)
示例15: process_share
# 需要導入模塊: import web [as 別名]
# 或者: from web import notfound [as 別名]
def process_share(self, auth_id):
auth_method = self.user_manager.get_auth_method(auth_id)
if not auth_method:
raise web.notfound()
auth_storage = self.user_manager.session_auth_storage().setdefault(auth_id, {})
auth_storage["redir_url"] = web.ctx.env.get('HTTP_REFERER', '/')
auth_storage["method"] = "share"
auth_storage["submissionid"] = web.input().get("submissionid", "")
auth_link = auth_method.get_auth_link(auth_storage, True)
raise web.seeother(auth_link)