Files
notifications-admin/app/main/views/invites.py

140 lines
5.2 KiB
Python
Raw Normal View History

from flask import abort, flash, redirect, render_template, session, url_for
from flask_login import current_user
from markupsafe import Markup
from app.main import main
2023-07-12 12:09:44 -04:00
from app.models.organization import Organization
from app.models.service import Service
2023-08-25 08:57:24 -07:00
from app.models.user import InvitedOrgUser, InvitedUser, OrganizationUsers, User, Users
@main.route("/invitation/<token>")
def accept_invite(token):
invited_user = InvitedUser.from_token(token)
if (
not current_user.is_anonymous
and current_user.email_address.lower() != invited_user.email_address.lower()
):
message = Markup(
"""
Youre signed in as {}.
This invite is for another email address.
<a href={} class="usa-link">Sign out</a>
and click the link again to accept this invite.
2016-04-26 12:12:47 +01:00
""".format(
current_user.email_address, url_for("main.sign_out")
)
)
2016-04-26 12:12:47 +01:00
flash(message=message)
abort(403)
if invited_user.status == "cancelled":
service = Service.from_id(invited_user.service)
return render_template(
"views/cancelled-invitation.html",
from_user=invited_user.from_user.name,
service_name=service.name,
)
if invited_user.status == "accepted":
session.pop("invited_user_id", None)
service = Service.from_id(invited_user.service)
return redirect(
url_for("main.service_dashboard", service_id=invited_user.service)
)
session["invited_user_id"] = invited_user.id
existing_user = User.from_email_address_or_none(invited_user.email_address)
if existing_user:
existing_user.update_email_access_validated_at()
invited_user.accept_invite()
if existing_user in Users(invited_user.service):
return redirect(
url_for("main.service_dashboard", service_id=invited_user.service)
)
else:
service = Service.from_id(invited_user.service)
# if the service you're being added to can modify auth type, then check if we can do this;
# if the user is a Platform Admin, we silently leave this unchanged to prevent a security
# issue where someone could switch their auth type to something less secure
if (
service.has_permission("email_auth")
and not existing_user.platform_admin
):
if invited_user.auth_type == "email_auth" or (
# they have a phone number, we want them to start using it.
# if they dont have a mobile we just ignore that option of the invite
existing_user.mobile_number
and invited_user.auth_type == "sms_auth"
):
existing_user.update(auth_type=invited_user.auth_type)
existing_user.add_to_service(
service_id=invited_user.service,
permissions=invited_user.permissions,
folder_permissions=invited_user.folder_permissions,
invited_by_id=invited_user.from_user.id,
)
return redirect(url_for("main.service_dashboard", service_id=service.id))
else:
return redirect(url_for("main.register_from_invite"))
2018-02-19 16:53:29 +00:00
2023-07-12 12:09:44 -04:00
@main.route("/organization-invitation/<token>")
2018-02-19 16:53:29 +00:00
def accept_org_invite(token):
invited_org_user = InvitedOrgUser.from_token(token)
if (
not current_user.is_anonymous
and current_user.email_address.lower() != invited_org_user.email_address.lower()
):
message = Markup(
"""
2018-02-19 16:53:29 +00:00
Youre signed in as {}.
This invite is for another email address.
<a class="usa-link" href={}>Sign out</a>
and click the link again to accept this invite.
2018-02-19 16:53:29 +00:00
""".format(
current_user.email_address, url_for("main.sign_out")
)
)
2018-02-19 16:53:29 +00:00
flash(message=message)
abort(403)
if invited_org_user.status == "cancelled":
2023-07-12 12:09:44 -04:00
organization = Organization.from_id(invited_org_user.organization)
return render_template(
"views/cancelled-invitation.html",
from_user=invited_org_user.invited_by.name,
organization_name=organization.name,
)
2018-02-19 16:53:29 +00:00
if invited_org_user.status == "accepted":
session.pop("invited_org_user_id", None)
return redirect(
url_for("main.organization_dashboard", org_id=invited_org_user.organization)
)
2018-02-19 16:53:29 +00:00
session["invited_org_user_id"] = invited_org_user.id
2018-02-19 16:53:29 +00:00
existing_user = User.from_email_address_or_none(invited_org_user.email_address)
2023-07-12 12:09:44 -04:00
organization_users = OrganizationUsers(invited_org_user.organization)
2018-02-19 16:53:29 +00:00
if existing_user:
existing_user.update_email_access_validated_at()
invited_org_user.accept_invite()
2023-07-12 12:09:44 -04:00
if existing_user not in organization_users:
existing_user.add_to_organization(
organization_id=invited_org_user.organization
)
return redirect(
url_for("main.organization_dashboard", org_id=invited_org_user.organization)
)
2018-02-19 16:53:29 +00:00
else:
return redirect(url_for("main.register_from_org_invite"))