本文整理汇总了Python中websauna.utils.slug.uuid_to_slug函数的典型用法代码示例。如果您正苦于以下问题:Python uuid_to_slug函数的具体用法?Python uuid_to_slug怎么用?Python uuid_to_slug使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了uuid_to_slug函数的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Python代码示例。
示例1: test_edit_choice_question
def test_edit_choice_question(browser: DriverAPI, tutorial_req, web_server, dbsession):
"""Change choice's assigned question in edit."""
from .tutorial import Question
from .tutorial import Choice
with transaction.manager:
q = Question(question_text="What is love")
dbsession.add(q)
dbsession.flush()
q2 = Question(question_text="Who shot JFK")
dbsession.add(q2)
dbsession.flush()
q2_slug = uuid_to_slug(q2.uuid)
c = Choice(choice_text="Foobar", question=q)
dbsession.add(c)
dbsession.flush()
c_slug = uuid_to_slug(c.uuid)
b = browser
create_logged_in_user(dbsession, tutorial_req.registry, web_server, browser, admin=True)
b.visit("{}/admin/models/choice/{}/edit".format(web_server, c_slug))
b.select("question", q2_slug)
b.find_by_name("save").click()
assert b.is_element_present_by_css("#msg-changes-saved")
with transaction.manager:
c = dbsession.query(Choice).get(1)
assert c.question.uuid == slug_to_uuid(q2_slug)
开发者ID:rmoorman,项目名称:websauna,代码行数:33,代码来源:test_autoform.py
示例2: wallet_root
def wallet_root(wallet_root, request):
"""Root of all hosted wallet resources.
When wallet folder is accessed without path key, redirect to the users own wallet."""
url = request.resource_url(wallet_root[uuid_to_slug(request.user.uuid)])
return httpexceptions.HTTPFound(url)
开发者ID:websauna,项目名称:websauna.wallet,代码行数:7,代码来源:wallet.py
示例3: create_activation
def create_activation(request, user):
"""Create through-the-web user sign up with his/her email.
We don't want to force the users to pick up an usernames, so we just generate an username.
The user is free to change their username later.
"""
assert user.id
user.username = user.generate_username()
user.registration_source = "email"
db = get_session(request)
Activation = request.registry.getUtility(IActivationClass)
activation = Activation()
db.add(activation)
user.activation = activation
db.flush()
# TODO Create a hook for this, don't assume create_activation() call
# TODO We don't need pystache just for this!
context = {
'link': request.route_url('activate', user_id=uuid_to_slug(user.uuid), code=user.activation.code)
}
send_templated_mail(request, [user.email], "login/email/activate", context)
site_creator = get_site_creator(request.registry)
site_creator.check_empty_site_init(request.dbsession, user)
开发者ID:rmoorman,项目名称:websauna,代码行数:30,代码来源:views.py
示例4: detail
def detail(request: Request):
# Convert base64 encoded UUID string from request path to Python UUID object
question_uuid = slug_to_uuid(request.matchdict["question_uuid"])
question = request.dbsession.query(Question).filter_by(uuid=question_uuid).first()
if not question:
raise HTTPNotFound()
if request.method == "POST":
# Check that CSRF token was good
check_csrf_token(request)
question = request.dbsession.query(Question).filter_by(uuid=question_uuid).first()
if not question:
raise HTTPNotFound()
if "choice" in request.POST:
# Extracts the form choice and turn it to UUID object
chosen_uuid = slug_to_uuid(request.POST["choice"])
selected_choice = question.choices.filter_by(uuid=chosen_uuid).first()
selected_choice.votes += 1
messages.add(request, msg="Thank you for your vote", kind="success")
return HTTPFound(request.route_url("results", question_uuid=uuid_to_slug(question.uuid)))
else:
error_message = "You did not select any choice."
return locals()
开发者ID:websauna,项目名称:myapp,代码行数:29,代码来源:views.py
示例5: test_remove_user_from_group
def test_remove_user_from_group(web_server, init, browser, dbsession):
"""Remove users from assigned groups in admin."""
b = browser
from websauna.system.user.models import Group
create_logged_in_user(dbsession, init.config.registry, web_server, browser, admin=True)
# Create a group where we
with transaction.manager:
g = Group(name=GROUP_NAME)
dbsession.add(g)
u = get_user(dbsession)
u.groups.append(g)
dbsession.flush()
group_uuid = uuid_to_slug(g.uuid)
b.find_by_css("#nav-admin").click()
b.find_by_css("#btn-panel-list-user").click()
b.find_by_css(".crud-row-1 .btn-crud-listing-edit").click()
# Check the group checkbox. We could put some more specific classes for controls here.
b.find_by_css("input[type='checkbox'][value='{}']".format(group_uuid)).click()
b.find_by_name("save").click()
assert b.is_text_present("Changes saved")
# After removing we should no longer see the removed group name on user show page
assert not b.is_text_present(GROUP_NAME)
开发者ID:frispete,项目名称:websauna,代码行数:30,代码来源:test_groups.py
示例6: test_put_user_to_group
def test_put_user_to_group(web_server, browser, dbsession, init):
"""Check that we can assign users to groups in admin interface."""
b = browser
from websauna.system.user.models import Group
create_logged_in_user(dbsession, init.config.registry, web_server, browser, admin=True)
# Create a group where we
with transaction.manager:
g = Group(name=GROUP_NAME)
dbsession.add(g)
dbsession.flush()
group_uuid = uuid_to_slug(g.uuid)
b.find_by_css("#nav-admin").click()
b.find_by_css("#btn-panel-list-user").click()
b.find_by_css(".crud-row-1 .btn-crud-listing-edit").click()
# Check the group checkbox. We could put some more specific classes for controls here.
b.find_by_css("input[type='checkbox'][value='{}']".format(group_uuid)).click()
b.find_by_name("save").click()
assert b.is_text_present("Changes saved")
# Now we are on Show page of the user, having the new group name visible
assert b.is_text_present(GROUP_NAME)
开发者ID:frispete,项目名称:websauna,代码行数:28,代码来源:test_groups.py
示例7: test_edit_choice_remove_question
def test_edit_choice_remove_question(browser: DriverAPI, tutorial_req, web_server, dbsession):
"""Editing choice allows us to reset question value back to null."""
from .tutorial import Question
from .tutorial import Choice
with transaction.manager:
q = Question(question_text="What is love")
dbsession.add(q)
dbsession.flush()
c = Choice(choice_text="Foobar", question=q)
dbsession.add(c)
dbsession.flush()
c_slug = uuid_to_slug(c.uuid)
b = browser
create_logged_in_user(dbsession, tutorial_req.registry, web_server, browser, admin=True)
b.visit("{}/admin/models/choice/{}/edit".format(web_server, c_slug))
b.select("question", "")
b.find_by_name("save").click()
assert b.is_element_present_by_css("#msg-changes-saved")
with transaction.manager:
c = dbsession.query(Choice).get(1)
assert c.question == None
开发者ID:rmoorman,项目名称:websauna,代码行数:28,代码来源:test_autoform.py
示例8: test_question_delete
def test_question_delete(browser: DriverAPI, tutorial_req, web_server, dbsession):
"""Delete question and make sure it deletes related choices.."""
from .tutorial import Question
from .tutorial import Choice
with transaction.manager:
q = Question(question_text="What is love")
dbsession.add(q)
dbsession.flush()
c = Choice(choice_text="Baby don't hurt me", question=q)
dbsession.add(c)
dbsession.flush()
q_slug = uuid_to_slug(q.uuid)
b = browser
create_logged_in_user(dbsession, tutorial_req.registry, web_server, browser, admin=True)
b.visit("{}/admin/models/question/{}".format(web_server, q_slug))
b.find_by_css("#btn-crud-delete").click()
b.find_by_css("#btn-delete-yes").click()
with transaction.manager:
assert dbsession.query(Question).count() == 0
assert dbsession.query(Choice).count() == 0
开发者ID:agronholm,项目名称:websauna,代码行数:26,代码来源:test_autoform.py
示例9: test_add_choice_question
def test_add_choice_question(browser: DriverAPI, tutorial_req, web_server, dbsession):
from .tutorial import Question
from .tutorial import Choice
with transaction.manager:
q = Question(question_text="What is love")
dbsession.add(q)
dbsession.flush()
question_uuid = uuid_to_slug(q.uuid)
b = browser
create_logged_in_user(dbsession, tutorial_req.registry, web_server, browser, admin=True)
b.visit(web_server)
b.find_by_css("#nav-admin").click()
b.find_by_css("#btn-panel-add-choice").click()
b.fill("choice_text", "Baby don't hurt me")
b.select("question", question_uuid)
b.find_by_name("add").click()
assert b.is_element_present_by_css("#msg-item-added")
with transaction.manager:
assert dbsession.query(Choice).first().question is not None
开发者ID:rmoorman,项目名称:websauna,代码行数:26,代码来源:test_autoform.py
示例10: network_choice_widget
def network_choice_widget(node: colander.SchemaNode, kw: dict):
request = kw["request"]
dbsession = request.dbsession
query = dbsession.query(AssetNetwork)
vocab = convert_query_to_tuples(
query,
first_column=lambda o: uuid_to_slug(o.id),
second_column=lambda o: o.human_friendly_name)
return deform.widget.SelectWidget(values=vocab)
开发者ID:websauna,项目名称:websauna.wallet,代码行数:9,代码来源:schemas.py
示例11: get_operations
def get_operations(self, state: Iterable):
ops = (
self.wallet.user.owned_crypto_operations.join(CryptoOperation)
.filter(CryptoOperation.state.in_(state))
.order_by(CryptoOperation.created_at.desc())
)
for op in ops:
uo = UserOperation(self.request, op)
yield Resource.make_lineage(self, uo, uuid_to_slug(op.id))
开发者ID:websauna,项目名称:websauna.wallet,代码行数:10,代码来源:wallet.py
示例12: __getitem__
def __getitem__(self, item):
uuid = slug_to_uuid(item)
uop = self.request.dbsession.query(UserCryptoOperation).get(uuid)
if not uop:
raise KeyError()
if uop.user != self.wallet.user:
raise httpexceptions.HTTPForbidden()
return Resource.make_lineage(self, UserOperation(self.request, uop), uuid_to_slug(uop.id))
开发者ID:websauna,项目名称:websauna.wallet,代码行数:11,代码来源:wallet.py
示例13: uuid_to_slug
def uuid_to_slug(jinja_ctx, context, **kw):
"""Convert UUID object to a base64 encoded slug.
Example::
{% for question in latest_question_list %}
<li>
<a href="{{ route_url('details', question.uuid|uuid_to_slug) }}">
{{ question.question_text }}
</a>
</li>
{% endfor %}
"""
return slug.uuid_to_slug(context)
开发者ID:rmoorman,项目名称:websauna,代码行数:15,代码来源:templatecontext.py
示例14: test_view_user_details
def test_view_user_details(browser, web_server, init, dbsession):
"""See that we can view the details of the user in a browser."""
b = browser
create_logged_in_user(dbsession, init.config.registry, web_server, browser, admin=True)
b.find_by_css("#nav-admin").click()
b.find_by_css("#latest-user-shortcut").click()
# TODO: Use CSS selector
assert b.is_text_present("[email protected]")
with transaction.manager:
# Check that we show the user uuid slug on the page correctly
u = dbsession.query(User).first()
assert b.is_text_present(uuid_to_slug(u.uuid))
开发者ID:frispete,项目名称:websauna,代码行数:18,代码来源:test_user_admin.py
示例15: test_question_shows_choices
def test_question_shows_choices(browser: DriverAPI, tutorial_req, web_server, dbsession):
"""If question has active choices they are shown on Show screen, albeit not editable."""
from .tutorial import Question
from .tutorial import Choice
with transaction.manager:
q = Question(question_text="What is love")
dbsession.add(q)
dbsession.flush()
q_slug = uuid_to_slug(q.uuid)
c = Choice(choice_text="Baby don't hurt me", question=q)
dbsession.add(c)
dbsession.flush()
b = browser
create_logged_in_user(dbsession, tutorial_req.registry, web_server, browser, admin=True)
b.visit("{}/admin/models/question/{}/show".format(web_server, q_slug))
assert b.is_text_present("Baby don't hurt me")
开发者ID:rmoorman,项目名称:websauna,代码行数:21,代码来源:test_autoform.py
示例16: test_register_email
def test_register_email(web_server, browser, dbsession):
"""Register on the site and login after activation."""
# Load user model
# registry = get_current_registry()
# User = registry.queryUtility(IUserClass)
# assert User
b = browser
b.visit(web_server)
b.click_link_by_text("Sign up")
assert b.is_element_visible_by_css("#sign-up-form")
b.fill("email", EMAIL)
b.fill("password", PASSWORD)
b.fill("password-confirm", PASSWORD)
b.find_by_name("sign_up").click()
assert b.is_element_visible_by_css("#waiting-for-activation")
# Now peek the Activation link from the database
user = get_user(dbsession)
assert user.activation.code
activation_link = "{}/activate/{}/{}".format(web_server, uuid_to_slug(user.uuid), user.activation.code)
b.visit(activation_link)
assert b.is_element_visible_by_css("#sign-up-complete")
b.fill("username", EMAIL)
b.fill("password", PASSWORD)
b.find_by_name("login_email").click()
# After login we see a profile link to our profile
assert b.is_element_visible_by_css("#nav-logout")
开发者ID:rmoorman,项目名称:websauna,代码行数:39,代码来源:test_register.py
示例17: test_user_group_choices_preserved_on_validation_error
def test_user_group_choices_preserved_on_validation_error(web_server, init, browser, dbsession):
"""When user edit form validation fails, we should preserve the existing group choices.
This stresses out hacky implementation of websauna.system.form.colander and deserialization.
"""
b = browser
from websauna.system.user.models import Group
create_logged_in_user(dbsession, init.config.registry, web_server, browser, admin=True)
# Create a group where we
with transaction.manager:
g = Group(name=GROUP_NAME)
dbsession.add(g)
u = get_user(dbsession)
u.groups.append(g)
dbsession.flush()
group_uuid = uuid_to_slug(g.uuid)
b.find_by_css("#nav-admin").click()
b.find_by_css("#btn-panel-list-user").click()
b.find_by_css(".crud-row-1 .btn-crud-listing-edit").click()
# We are in group 2 initially, assert checkbox is checked
assert b.find_by_css("input[type='checkbox'][value='{}'][checked='True']".format(group_uuid))
# Do validation error by leaving username empty
b.fill("username", "")
b.find_by_name("save").click()
assert b.is_text_present("There was a problem")
# Both group checkboxes should be still selected
with transaction.manager:
for g in dbsession.query(Group).all():
assert b.find_by_css("input[type='checkbox'][value='{}'][checked='True']".format(uuid_to_slug(g.uuid)))
开发者ID:frispete,项目名称:websauna,代码行数:37,代码来源:test_groups.py
示例18: get_user_wallet
def get_user_wallet(request) -> UserWallet:
wallet_root = route_factory(request)
return wallet_root[uuid_to_slug(request.user.uuid)]
开发者ID:websauna,项目名称:websauna.wallet,代码行数:3,代码来源:wallet.py
示例19: get_user_crypto_operation_resource
def get_user_crypto_operation_resource(request, uop: UserCryptoOperation) -> UserOperation:
assert isinstance(uop, UserCryptoOperation)
wallet_root = route_factory(request)
wallet = wallet_root[uuid_to_slug(uop.user.uuid)]
return wallet.get_uop_resource(uop)
开发者ID:websauna,项目名称:websauna.wallet,代码行数:5,代码来源:wallet.py
示例20: get_addresses
def get_addresses(self):
addresses = self.user.owned_crypto_addresses
for addr in addresses:
ua = UserAddress(self.request, addr)
yield Resource.make_lineage(self, ua, uuid_to_slug(addr.id))
开发者ID:websauna,项目名称:websauna.wallet,代码行数:5,代码来源:wallet.py
注:本文中的websauna.utils.slug.uuid_to_slug函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论