Edit user permissions page shows redacted phone number and Change link

Also make plan for story development
This commit is contained in:
Pea Tyczynska
2019-02-21 13:03:06 +00:00
parent 882fc7ebab
commit 94c4151640
6 changed files with 82 additions and 8 deletions

View File

@@ -24,7 +24,7 @@ from app.main.forms import (
SearchUsersForm,
)
from app.models.user import permissions
from app.utils import user_has_permissions
from app.utils import redact_mobile_number, user_has_permissions
@main.route("/services/<service_id>/users")
@@ -78,7 +78,10 @@ def invite_user(service_id):
def edit_user_permissions(service_id, user_id):
service_has_email_auth = current_service.has_permission('email_auth')
user = current_service.get_team_member(user_id)
user_has_no_mobile_number = user.mobile_number is None
mobile_number = None
if user.mobile_number:
mobile_number = redact_mobile_number(user.mobile_number)
form = PermissionsForm.from_user(user, service_id)
@@ -96,7 +99,7 @@ def edit_user_permissions(service_id, user_id):
user=user,
form=form,
service_has_email_auth=service_has_email_auth,
user_has_no_mobile_number=user_has_no_mobile_number
mobile_number=mobile_number
)
@@ -200,6 +203,13 @@ def confirm_edit_user_email(service_id, user_id):
)
@main.route("/services/<service_id>/users/<user_id>/edit-phone-number", methods=['GET', 'POST'])
@login_required
@user_has_permissions('manage_service')
def edit_user_phone_number(service_id, user_id):
return True
@main.route("/services/<service_id>/cancel-invited-user/<uuid:invited_user_id>", methods=['GET'])
@user_has_permissions('manage_service')
def cancel_invited_user(service_id, invited_user_id):

View File

@@ -159,6 +159,7 @@ class HeaderNavigation(Navigation):
'edit_template_postage',
'edit_user_org_permissions',
'edit_user_email',
'edit_user_phone_number',
'edit_user_permissions',
'email_not_received',
'email_template',
@@ -328,6 +329,7 @@ class MainNavigation(Navigation):
'team-members': {
'confirm_edit_user_email',
'edit_user_email',
'edit_user_phone_number',
'edit_user_permissions',
'invite_user',
'manage_users',
@@ -609,6 +611,7 @@ class CaseworkNavigation(Navigation):
'edit_service_template',
'edit_template_postage',
'edit_user_email',
'edit_user_phone_number',
'edit_user_org_permissions',
'edit_user_permissions',
'email_branding',
@@ -847,6 +850,7 @@ class OrgNavigation(Navigation):
'edit_service_template',
'edit_template_postage',
'edit_user_email',
'edit_user_phone_number',
'edit_user_permissions',
'email_branding',
'email_not_received',

View File

@@ -16,7 +16,11 @@
<p>
{{ user.email_address }}&emsp;<a href="{{ url_for('.edit_user_email', service_id=current_service.id, user_id=user.id)}}">Change</a>
</p>
{% if mobile_number %}
<p id="user_phone_number">
{{ mobile_number }}&emsp;<a href="{{ url_for('.edit_user_phone_number', service_id=current_service.id, user_id=user.id)}}">Change</a>
</p>
{% endif %}
<div class="grid-row">
{% call form_wrapper(class="column-three-quarters") %}

View File

@@ -15,7 +15,7 @@
</p>
{% if service_has_email_auth %}
{% if user_has_no_mobile_number %}
{% if not mobile_number %}
{{ radios(
form.login_authentication,
disable=['sms_auth'],

View File

@@ -650,9 +650,9 @@ def guess_name_from_email_address(email_address):
def should_skip_template_page(template_type):
return (
current_user.has_permissions('send_messages') and
not current_user.has_permissions('manage_templates', 'manage_api_keys') and
template_type != 'letter'
current_user.has_permissions('send_messages')
and not current_user.has_permissions('manage_templates', 'manage_api_keys')
and template_type != 'letter'
)
@@ -671,3 +671,11 @@ def printing_today_or_tomorrow():
return 'today'
else:
return 'tomorrow'
def redact_mobile_number(mobile_number):
indices = [-4, -5, -6, -7]
mobile_number_list = list(mobile_number.replace(" ", ""))
for i in indices:
mobile_number_list[i] = "*"
return "".join(mobile_number_list)

View File

@@ -1005,3 +1005,51 @@ def test_confirm_edit_user_email_doesnt_change_user_email_for_non_team_member(
user_id=USER_ONE_ID,
_expected_status=404,
)
def test_confirm_edit_user_email_with_no_permission_aborts():
pass
def test_edit_user_permissions_page_displays_redacted_phone_number_and_change_link(
client_request,
active_user_with_permissions,
service_one,
mocker
):
user = active_user_with_permissions
mocker.patch('app.user_api_client.get_user', return_value=user)
page = client_request.get(
'main.edit_user_permissions',
service_id=service_one['id'],
user_id=user.id
)
assert user.name in page.find('h1').text
phone_number_paragraph = page.select('p[id=user_phone_number]')[0]
assert '0770****762' in phone_number_paragraph.text
change_link = phone_number_paragraph.findChild()
assert change_link.attrs['href'] == '/services/{}/users/{}/edit-phone-number'.format(
service_one['id'], user.id
)
def test_edit_user_phone_number_page():
pass
def test_edit_user_phone_number_redirects_to_confirmation():
pass
def test_confirm_edit_user_phone_number_page():
pass
def test_confirm_edit_user_phone_number_changes_user_mobile_number():
pass
def test_confirm_edit_user_phone_number_with_no_permission_aborts():
pass