Merge remote-tracking branch 'origin/email-confirm' into main

This commit is contained in:
2022-10-22 15:42:25 +03:00
3 changed files with 9 additions and 6 deletions

View File

@@ -7,6 +7,7 @@ from graphql.type import GraphQLResolveInfo
from transliterate import translit
from starlette.responses import RedirectResponse
from auth.jwtcodec import JWTCodec
from auth.tokenstorage import TokenStorage
from auth.authenticate import login_required
from auth.email import send_auth_email
@@ -41,10 +42,12 @@ async def get_current_user(_, info):
@mutation.field("confirmEmail")
async def confirm_email(_, _info, confirm_token):
async def confirm_email(_, _info, code):
"""confirm owning email address"""
try:
user_id = await TokenStorage.get(confirm_token)
payload = JWTCodec.decode(code)
user_id = payload.user_id
await TokenStorage.get(f"{user_id}-{code}")
with local_session() as session:
user = session.query(User).where(User.id == user_id).first()
session_token = await TokenStorage.create_session(user)

View File

@@ -21,9 +21,9 @@ from services.zine.shoutauthor import ShoutAuthorStorage
async def get_user_subscriptions(slug):
return {
"unread": await get_unread_counter(slug), # unread inbox messages counter
"topics": [t.slug for t in get_followed_topics(0, slug)], # followed topics slugs
"authors": [a.slug for a in get_followed_authors(0, slug)], # followed authors slugs
"reactions": [r.shout for r in get_reactions_for_shouts(0, [slug, ])], # followed reacted shout
"topics": [t.slug for t in await get_followed_topics(0, slug)], # followed topics slugs
"authors": [a.slug for a in await get_followed_authors(0, slug)], # followed authors slugs
"reactions": [r.shout for r in await get_reactions_for_shouts(0, [slug, ])], # followed reacted shout
"communities": [c.slug for c in get_followed_communities(0, slug)], # followed communities slugs
}