本文整理匯總了Python中web.seeother方法的典型用法代碼示例。如果您正苦於以下問題:Python web.seeother方法的具體用法?Python web.seeother怎麽用?Python web.seeother使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類web
的用法示例。
在下文中一共展示了web.seeother方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: oidc_auth
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def oidc_auth(account, issuer):
"""
Open ID Connect Login
:param account: Rucio account string
:param issuer: issuer key (e.g. xdc, wlcg) as in the idpsecrets.json file
:returns: rendered final page or a page with error message
"""
if not account:
account = 'webui'
if not issuer:
return RENDERER.problem("Please provide IdP issuer.")
kwargs = {'audience': None,
'auth_scope': None,
'issuer': issuer.lower(),
'auto': True,
'polling': False,
'refresh_lifetime': None,
'ip': None,
'webhome': ctx.realhome + '/oidc_final'}
auth_url = auth.get_auth_oidc(account, **kwargs)
if not auth_url:
return RENDERER.problem("It was not possible to get the OIDC authentication url from the Rucio auth server. "
+ "In case you provided your account name, make sure it is known to Rucio.") # NOQA: W503
return seeother(auth_url)
示例2: process_callback
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [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", "/"))
示例3: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def GET(self, *args, **kwargs):
"""
Checks if user is authenticated and calls GET_AUTH or performs logout.
Otherwise, returns the login template.
"""
if self.user_manager.session_logged_in():
if not self.user_manager.session_username() and not self.__class__.__name__ == "ProfilePage":
raise web.seeother("/preferences/profile")
if not self.is_lti_page and self.user_manager.session_lti_info() is not None: #lti session
self.user_manager.disconnect_user()
return self.template_helper.get_renderer().auth(self.user_manager.get_auth_methods())
return self.GET_AUTH(*args, **kwargs)
elif self.preview_allowed(*args, **kwargs):
return self.GET_AUTH(*args, **kwargs)
else:
error = ''
if "binderror" in web.input():
error = _("An account using this email already exists and is not bound with this service. "
"For security reasons, please log in via another method and bind your account in your profile.")
if "callbackerror" in web.input():
error = _("Couldn't fetch the required information from the service. Please check the provided "
"permissions (name, email) and contact your INGInious administrator if the error persists.")
return self.template_helper.get_renderer().auth(self.user_manager.get_auth_methods(), error)
示例4: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [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)
示例5: POST
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def POST(self):
login_form = self.get_login_form()
if not login_form.validates():
flash('error', 'form validation failed')
return render.login(login_form)
username = login_form['username'].value
password = login_form['password'].value
user = validate_user(username,password)
if user:
session.user = user
web.debug(web.config.session_parameters)
flash('success', """you are now logged in, "Add" to authorize %s""" % get_client_public_ip())
raise web.seeother('/')
else:
session.user = None
flash('error', 'login failed for user %s' % username)
raise web.seeother('/login')
return render.login(login_form)
示例6: authentication
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def authentication(uid=None):
def has_permission():
cookies = web.cookies()
token, user_id = cookies.get('token'), cookies.get('user_id')
if uid and not uid == user_id:
return False
if not token or not user_id:
return False
if not auth_check(user_id, token):
return False
return True
def decorator(func):
def _decorator():
if has_permission():
return func
else:
def return_a_error():
return web.seeother('/login')
return return_a_error
return _decorator()
return decorator
示例7: has_obj_permission
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def has_obj_permission(obj, obj_id, url="/login", exception=False):
def has_permission(_obj=obj, _obj_id=obj_id):
user_id = web.cookies().get('user_id')
if not user_id:
return False
if exception:
#Exception only for view public modules.
if int(get_detail(XSS_CORE, obj_id, 'owner')) == 0:
return True
if not is_owner(user_id=user_id, obj_id=_obj_id, obj_type=_obj):
return False
return True
def decorator(func):
def _decorator():
if has_permission(obj, obj_id):
return func
else:
def return_a_error():
return web.seeother(url)
return return_a_error
return _decorator()
return decorator
示例8: POST
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def POST(self):
if not 'user' in session or session.user is None:
f = register_form()
return render.login(f)
i = web.input(id=None, description=None)
cluster_id = i.id
if cluster_id is None:
return render.error("No cluster id specified.")
if not cluster_id.isdigit():
return render.error("Invalid number.")
cluster_id = int(cluster_id)
desc = i.description
vars = {"id":cluster_id}
db = open_db()
db.update('clusters', vars=vars, where="id = $id", description=desc)
raise web.seeother("/view_cluster?id=%d" % cluster_id)
#-----------------------------------------------------------------------
示例9: POST
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def POST(self):
input = web.input()
raise web.seeother('/?query=%s&tagrel=1' % input.tags)
示例10: redirect_to_last_known_url
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def redirect_to_last_known_url():
"""
Checks if there is preferred path in cookie and redirects to it.
:returns: redirect to last known path
"""
path = cookies().get('rucio-requested-path')
if not path:
path = '/'
return seeother(path)
示例11: authenticate
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def authenticate(rendered_tpl):
"""
Authentication management method.
:param rendered_tpl: rendered page template
:returns: rendered final page or a page with error message
"""
global AUTH_ISSUERS, SAML_SUPPORT, AUTH_TYPE, RENDERER
valid_token_dict = validate_webui_token()
if not valid_token_dict:
# remember fullpath in cookie to return to after login
setcookie('rucio-requested-path', value=unicode(ctx.fullpath), expires=120, path='/')
else:
return access_granted(valid_token_dict, rendered_tpl)
# login without any known server config
if not AUTH_TYPE:
return RENDERER.select_login_method(AUTH_ISSUERS, SAML_SUPPORT)
# for AUTH_TYPE predefined by the server continue
else:
if AUTH_TYPE == 'userpass':
return seeother('/login')
elif AUTH_TYPE == 'x509':
return x509token_auth(None)
elif AUTH_TYPE == 'x509_userpass':
if ctx.env.get('SSL_CLIENT_VERIFY') == 'SUCCESS':
return x509token_auth(None)
return RENDERER.no_certificate()
elif AUTH_TYPE == 'oidc':
return oidc_auth(None, AUTH_ISSUER_WEBUI)
elif AUTH_TYPE == 'saml':
return saml_auth("GET", rendered_tpl)
return RENDERER.problem('Invalid auth type')
示例12: POST
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def POST(self):
i = web.input(username="", password="")
if i.username == "" or i.password == "":
return render.error("Invalid username or password")
elif i.username != NFP_USER or sha1(i.password).hexdigest() != NFP_PASS:
return render.error("Invalid username or password")
session.user = i.username
return web.seeother("/")
#-----------------------------------------------------------------------
示例13: GET
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def GET(self):
session.user = None
del session.user
return web.seeother("/")
#-----------------------------------------------------------------------
示例14: basic_checks
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [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
示例15: POST_AUTH
# 需要導入模塊: import web [as 別名]
# 或者: from web import seeother [as 別名]
def POST_AUTH(self, courseid):
course, username = self.basic_checks(courseid)
user_input = web.input()
success = self.user_manager.course_register_user(course, username, user_input.get("register_password", None))
if success:
raise web.seeother(self.app.get_homepath() + "/course/" + course.get_id())
else:
return self.template_helper.get_renderer(use_jinja=True).course_register(course=course, error=True)