本文整理匯總了Python中radlibs.Client.query方法的典型用法代碼示例。如果您正苦於以下問題:Python Client.query方法的具體用法?Python Client.query怎麽用?Python Client.query使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類radlibs.Client
的用法示例。
在下文中一共展示了Client.query方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_create_new_association
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_create_new_association(self, user):
session = Client().session()
response = self.app.post('/association/new',
data={'name': 'codescouts'})
association = session.query(Association).one()
user_association = session.query(UserAssociation).one()
eq_(user_association.association_id, association.association_id)
eq_(user_association.user_id, user.user_id)
eq_(association.name, 'codescouts')
eq_(response.status_code, 302, response.data)
eq_(response.headers['Location'],
'http://localhost/association/{0}'.format(
association.association_id))
示例2: token_url
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def token_url():
token = request.form['token']
api_params = {
'token': token,
'apiKey': os.environ['ENGAGE_API_KEY'],
'format': 'json',
}
response = requests.get('https://rpxnow.com/api/v2/auth_info',
params=api_params)
auth_info = json.loads(response.text)
if 'profile' not in auth_info:
return make_response('An error occurred interacting with your '
'identity provider. Since that does not '
'usually happen unless you are a radlibs '
'developer, here is the error in all its '
'terrible beauty: ' + response.text)
identifier = auth_info['profile']['identifier']
email = auth_info['profile'].get('email')
redirect_uri = request.form.get('redirect_uri', '/')
db_session = Client().session()
try:
user = db_session.query(User).\
filter(User.identifier == identifier).\
one()
except NoResultFound:
if email:
existing_users = db_session.query(User).\
filter(User.email == email).\
all()
if existing_users:
provider = provider_for_identifier(
existing_users[0].identifier)
return render_template(
'identifier_mismatch.html.jinja',
existing_provider=provider)
user = User(email=email,
identifier=identifier,
email_verified_at=utcnow())
db_session.add(user)
else:
session['partial_user'] = {'identifier': identifier}
return redirect(url_for('show_registration',
redirect_uri=redirect_uri))
session['user'] = {'identifier': identifier, 'email': email}
return redirect(redirect_uri)
示例3: test_invite_new_user_to_association
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_invite_new_user_to_association(self, user, send_invitation_mail):
user.email = "[email protected]"
session = Client().session()
association = Association(name='prancing ponies')
session.add(association)
session.flush()
session.add(UserAssociation(user_id=user.user_id,
association_id=association.association_id))
session.flush()
response = self.app.post(
'/association/{0}/invite_user'.format(association.association_id),
data={'email': '[email protected]'})
eq_(response.status_code, 200, response.data)
body = json.loads(response.data)
eq_(body, {'status': 'ok', 'action': 'invited'})
invite = session.query(AssociationInvite).one()
eq_(invite.email, '[email protected]')
eq_(invite.association_id, association.association_id)
send_invitation_mail.assert_called_once_with(
'[email protected]',
'[email protected]',
'prancing ponies',
'http://localhost/accept_invitation/{0}/'.format(invite.token))
示例4: new_rad_by_name
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def new_rad_by_name():
if not g.user:
return error_response('login required')
try:
parse(request.form['rad'])
except ParseError as e:
return error_response('parse error: {0}'.format(e.message))
session = Client().session()
lib_name = request.form['lib']
association_id = request.form['association_id']
try:
find_association(association_id)
except NoResultFound:
return error_response('no such association')
try:
lib = session.query(Lib).\
filter(Lib.name == lib_name).\
filter(Lib.association_id == association_id).\
one()
except NoResultFound:
return error_response("no such lib '{0}'".format(lib_name))
rad = Rad(created_by=g.user.user_id,
lib_id=lib.lib_id,
rad=request.form['rad'])
session.add(rad)
radlibs.lib.decache_lib(lib.name, lib.association_id)
return {
'status': 'ok',
'rad_id': rad.rad_id,
}
示例5: test_add_existing_user_to_association
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_add_existing_user_to_association(self, user):
session = Client().session()
association = Association(name='prancing ponies')
session.add(association)
session.flush()
session.add(UserAssociation(user_id=user.user_id,
association_id=association.association_id))
other_user = User(email_verified_at=utcnow(), email='[email protected]')
session.add(other_user)
session.flush()
response = self.app.post(
'/association/{0}/invite_user'.format(association.association_id),
data={'email': '[email protected]'})
eq_(response.status_code, 200, response.data)
body = json.loads(response.data)
eq_(body, {'status': 'ok', 'action': 'added'})
user_associations = session.query(
UserAssociation.user_id, UserAssociation.association_id).\
all()
eq_(user_associations, [
(user.user_id, association.association_id),
(other_user.user_id, association.association_id),
])
示例6: edit_rad
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def edit_rad(rad_id):
if rad_id == 0:
abort(404)
if not g.user:
return error_response('login required')
try:
parse(request.form['rad'])
except ParseError as e:
return error_response('parse error: {0}'.format(e.message))
session = Client().session()
try:
(rad, lib) = session.query(Rad, Lib).\
join(Lib).\
join(Association).\
join(UserAssociation).\
filter(UserAssociation.user_id == g.user.user_id).\
filter(Rad.rad_id == rad_id).\
one()
except NoResultFound:
return error_response('no such rad')
rad.rad = request.form['rad']
session.add(rad)
radlibs.lib.decache_lib(lib.name, lib.association_id)
return {'status': 'ok'}
示例7: find_association
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def find_association(association_id):
session = Client().session()
return session.query(Association).\
join(UserAssociation,
UserAssociation.association_id == Association.association_id).\
filter(Association.association_id == association_id).\
filter(UserAssociation.user_id == g.user.user_id).\
one()
示例8: test_verify_email
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_verify_email(self):
session = Client().session()
user = User()
session.add(user)
session.flush()
token = EmailVerificationToken.generate(user)
response = self.app.get('/verify_email/{0}'.format(token.token))
eq_(response.status_code, 200, response.data)
assert 'Thanks!' in response.data, 'response was rude'
del(user)
user = session.query(User).one()
assert user.email_verified_at, "email wasn't verified!"
tokens = session.query(EmailVerificationToken).all()
eq_(tokens, [])
示例9: verify_email
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def verify_email(token):
db_session = Client().session()
try:
verification_token = db_session.query(EmailVerificationToken).\
filter(EmailVerificationToken.token == token).\
one()
user = db_session.query(User).\
filter(User.user_id == verification_token.user_id).\
one()
except NoResultFound:
abort(404)
user.email_verified_at = utcnow()
db_session.add(user)
db_session.delete(verification_token)
return render_template('verification_complete.html.jinja')
示例10: test_accept_invite_while_logged_in
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_accept_invite_while_logged_in(self, user):
user.email = '[email protected]'
session = Client().session()
association = Association(name="tower of power")
session.add(association)
session.flush()
invite = AssociationInvite.generate(association.association_id,
'[email protected]')
session.flush()
response = self.app.get('/accept_invitation/{0}/'.format(invite.token))
eq_(response.status_code, 302, response.data)
eq_(response.headers['Location'],
'http://localhost/association/{0}'.format(association.association_id))
user_association = session.query(UserAssociation).\
filter(UserAssociation.user_id == user.user_id).\
one()
eq_(user_association.association_id, association.association_id)
invites = session.query(AssociationInvite).all()
eq_(invites, [])
示例11: manage_association
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def manage_association(association_id):
if not g.user:
abort(401)
session = Client().session()
try:
association = session.query(Association).\
join(UserAssociation,
UserAssociation.association_id == Association.association_id).\
filter(Association.association_id == association_id).\
filter(UserAssociation.user_id == g.user.user_id).\
one()
except NoResultFound:
abort(404)
radlibs = session.query(Lib.name,
Lib.lib_id,
Rad.rad_id,
Rad.rad).\
select_from(Lib).\
outerjoin(Rad, Lib.lib_id == Rad.lib_id).\
filter(Lib.association_id == association.association_id).\
all()
member_emails = session.query(User.email).\
join(UserAssociation, UserAssociation.user_id == User.user_id).\
filter(UserAssociation.association_id == association_id).\
all()
libs = {}
for (lib_name, lib_id, rad_id, rad) in radlibs:
if lib_name not in libs:
libs[lib_name] = {'rads': []}
libs[lib_name]['lib_id'] = lib_id
if rad:
libs[lib_name]['rads'].append({'rad_id': rad_id, 'rad': rad})
return render_template('manage_association.html.jinja',
association=association,
libs=libs,
member_emails=[e[0] for e in member_emails],
breadcrumbs=breadcrumbs(association.name))
示例12: test_bypass_login__new_user
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_bypass_login__new_user(self):
session = Client().session()
response = self.app.post('/login_bypass', data={
'email': '[email protected]',
'identifier': 'http://www.facebook.com/itsme',
})
eq_(response.status_code, 302)
eq_(response.headers['Location'], 'http://localhost/')
user = session.query(User).one()
eq_(user.email, '[email protected]')
eq_(user.identifier, 'http://www.facebook.com/itsme')
示例13: test_accept_invite_while_unverified_verifies_email
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_accept_invite_while_unverified_verifies_email(self, user):
user.email = '[email protected]'
user.email_verified_at = None
session = Client().session()
association = Association(name="tower of power")
session.add(association)
session.flush()
invite = AssociationInvite.generate(association.association_id,
'[email protected]')
session.flush()
response = self.app.get('/accept_invitation/{0}/'.format(invite.token))
eq_(response.status_code, 302, response.data)
del(user)
user = session.query(User).one()
assert user.email_verified_at, "Email wasn't verified"
示例14: test_log_in_with_a_provider_that_does_not_supply_email
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def test_log_in_with_a_provider_that_does_not_supply_email(
self, requests, os, send_verification_mail):
session = Client().session()
os.environ = {'ENGAGE_API_KEY': 'aoeu'}
response = Mock()
requests.get.return_value = response
response.text = json.dumps({
'profile': {
'identifier': 'twitter.com/tpain',
}
})
response = self.app.post(
'/token_url',
data={'token': 'asdf', 'redirect_uri': '/language'})
eq_(response.status_code, 302)
eq_(response.headers['Location'],
'http://localhost/complete_registration?redirect_uri=%2Flanguage')
response = self.app.get('/complete_registration',
data={'redirect_uri': '/language'})
eq_(response.status_code, 200, response.data)
response = self.app.post('/complete_registration', data={
'redirect_uri': '/language',
'email': '[email protected]'})
eq_(response.status_code, 302, response.data)
eq_(response.headers['Location'], 'http://localhost/language')
user = session.query(User).one()
eq_(user.email, '[email protected]')
eq_(user.identifier, 'twitter.com/tpain')
eq_(user.email_verified_at, None)
token = session.query(EmailVerificationToken).one()
send_verification_mail.assert_called_once_with(
user,
'http://localhost/verify_email/{0}'.format(token.token))
示例15: load_lib
# 需要導入模塊: from radlibs import Client [as 別名]
# 或者: from radlibs.Client import query [as 別名]
def load_lib(lib_name):
lib_key = '{0}:{1}'.format(g.association_id, lib_name)
lib = app.cache.get(lib_key)
if not lib:
session = Client().session()
lib = session.query(Rad.rad).\
join(Lib, Lib.lib_id == Rad.lib_id).\
filter(Lib.name == lib_name).\
filter(Lib.association_id == g.association_id).\
all()
if not lib:
raise KeyError(lib_name)
lib = [rad[0] for rad in lib]
app.cache.set(lib_key, lib, timeout=60*60)
return lib