Commit c502748d authored by Paul Slaughter's avatar Paul Slaughter

Merge branch 'docs-aqualls-fix-token-language' into 'master'

Tidy up language on access tokens UI page

See merge request gitlab-org/gitlab!62939
parents b01c63af a192f5d2
...@@ -145,17 +145,23 @@ export default { ...@@ -145,17 +145,23 @@ export default {
<gl-sprintf <gl-sprintf
:message=" :message="
__( __(
'This is a private email address %{helpIcon} generated just for you. Anyone who gets ahold of it can create issues or merge requests as if they were you. You should %{resetLinkStart}reset it%{resetLinkEnd} if that ever happens.', 'This is a private email address %{helpIcon} generated just for you. Anyone who has it can create issues or merge requests as if they were you. If that happens, %{resetLinkStart}reset this token%{resetLinkEnd}.',
) )
" "
> >
<template #helpIcon> <template #helpIcon>
<gl-link :href="emailsHelpPagePath" target="_blank" <gl-link :href="emailsHelpPagePath" target="_blank">
><gl-icon class="gl-text-blue-600" name="question-o" <gl-icon class="gl-text-blue-600" name="question-o" />
/></gl-link> </gl-link>
</template> </template>
<template #resetLink="{ content }"> <template #resetLink="{ content }">
<gl-button variant="link" @click="resetIncomingEmailToken">{{ content }}</gl-button> <gl-button
variant="link"
data-testid="reset_email_token_link"
@click="resetIncomingEmailToken"
>
{{ content }}
</gl-button>
</template> </template>
</gl-sprintf> </gl-sprintf>
</p> </p>
......
...@@ -40,15 +40,15 @@ ...@@ -40,15 +40,15 @@
%h4.gl-mt-0 %h4.gl-mt-0
= s_('AccessTokens|Feed token') = s_('AccessTokens|Feed token')
%p %p
= s_('AccessTokens|Your feed token is used to authenticate you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar, and is included in those feed URLs.') = s_('AccessTokens|Your feed token authenticates you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar. It is visible in those feed URLs.')
%p %p
= s_('AccessTokens|It cannot be used to access any other data.') = s_('AccessTokens|It cannot be used to access any other data.')
.col-lg-8.feed-token-reset .col-lg-8.feed-token-reset
= label_tag :feed_token, s_('AccessTokens|Feed token'), class: 'label-bold' = label_tag :feed_token, s_('AccessTokens|Feed token'), class: 'label-bold'
= text_field_tag :feed_token, current_user.feed_token, class: 'form-control gl-form-input js-select-on-focus', readonly: true = text_field_tag :feed_token, current_user.feed_token, class: 'form-control gl-form-input js-select-on-focus', readonly: true
%p.form-text.text-muted %p.form-text.text-muted
- reset_link = link_to s_('AccessTokens|reset it'), [:reset, :feed_token, :profile], method: :put, data: { confirm: s_('AccessTokens|Are you sure? Any RSS or calendar URLs currently in use will stop working.') } - reset_link = link_to s_('AccessTokens|reset this token'), [:reset, :feed_token, :profile], method: :put, data: { confirm: s_('AccessTokens|Are you sure? Any RSS or calendar URLs currently in use will stop working.'), testid: :reset_feed_token_link }
- reset_message = s_('AccessTokens|Keep this token secret. Anyone who gets ahold of it can read activity and issue RSS feeds or your calendar feed as if they were you. You should %{link_reset_it} if that ever happens.') % { link_reset_it: reset_link } - reset_message = s_('AccessTokens|Keep this token secret. Anyone who has it can read activity and issue RSS feeds or your calendar feed as if they were you. If that happens, %{link_reset_it}.') % { link_reset_it: reset_link }
= reset_message.html_safe = reset_message.html_safe
- if incoming_email_token_enabled? - if incoming_email_token_enabled?
...@@ -59,15 +59,15 @@ ...@@ -59,15 +59,15 @@
%h4.gl-mt-0 %h4.gl-mt-0
= s_('AccessTokens|Incoming email token') = s_('AccessTokens|Incoming email token')
%p %p
= s_('AccessTokens|Your incoming email token is used to authenticate you when you create a new issue by email, and is included in your personal project-specific email addresses.') = s_('AccessTokens|Your incoming email token authenticates you when you create a new issue by email, and is included in your personal project-specific email addresses.')
%p %p
= s_('AccessTokens|It cannot be used to access any other data.') = s_('AccessTokens|It cannot be used to access any other data.')
.col-lg-8.incoming-email-token-reset .col-lg-8.incoming-email-token-reset
= label_tag :incoming_email_token, s_('AccessTokens|Incoming email token'), class: 'label-bold' = label_tag :incoming_email_token, s_('AccessTokens|Incoming email token'), class: 'label-bold'
= text_field_tag :incoming_email_token, current_user.incoming_email_token, class: 'form-control gl-form-input js-select-on-focus', readonly: true = text_field_tag :incoming_email_token, current_user.incoming_email_token, class: 'form-control gl-form-input js-select-on-focus', readonly: true
%p.form-text.text-muted %p.form-text.text-muted
- reset_link = link_to s_('AccessTokens|reset it'), [:reset, :incoming_email_token, :profile], method: :put, data: { confirm: s_('AccessTokens|Are you sure? Any issue email addresses currently in use will stop working.') } - reset_link = link_to s_('AccessTokens|reset this token'), [:reset, :incoming_email_token, :profile], method: :put, data: { confirm: s_('AccessTokens|Are you sure? Any issue email addresses currently in use will stop working.'), testid: :reset_email_token_link }
- reset_message = s_('AccessTokens|Keep this token secret. Anyone who gets ahold of it can create issues as if they were you. You should %{link_reset_it} if that ever happens.') % { link_reset_it: reset_link } - reset_message = s_('AccessTokens|Keep this token secret. Anyone who has it can create issues as if they were you. If that happens, %{link_reset_it}.') % { link_reset_it: reset_link }
= reset_message.html_safe = reset_message.html_safe
- if static_objects_external_storage_enabled? - if static_objects_external_storage_enabled?
...@@ -78,7 +78,7 @@ ...@@ -78,7 +78,7 @@
%h4.gl-mt-0 %h4.gl-mt-0
= s_('AccessTokens|Static object token') = s_('AccessTokens|Static object token')
%p %p
= s_('AccessTokens|Your static object token is used to authenticate you when repository static objects (e.g. archives, blobs, ...) are being served from an external storage.') = s_('AccessTokens|Your static object token authenticates you when repository static objects (such as archives or blobs) are served from an external storage.')
%p %p
= s_('AccessTokens|It cannot be used to access any other data.') = s_('AccessTokens|It cannot be used to access any other data.')
.col-lg-8 .col-lg-8
...@@ -88,5 +88,5 @@ ...@@ -88,5 +88,5 @@
- reset_link = url_for [:reset, :static_object_token, :profile] - reset_link = url_for [:reset, :static_object_token, :profile]
- reset_link_start = '<a data-confirm="%{confirm}" rel="nofollow" data-method="put" href="%{url}">'.html_safe % { confirm: s_('AccessTokens|Are you sure?'), url: reset_link } - reset_link_start = '<a data-confirm="%{confirm}" rel="nofollow" data-method="put" href="%{url}">'.html_safe % { confirm: s_('AccessTokens|Are you sure?'), url: reset_link }
- reset_link_end = '</a>'.html_safe - reset_link_end = '</a>'.html_safe
- reset_message = s_('AccessTokens|Keep this token secret. Anyone who gets ahold of it can access repository static objects as if they were you. You should %{reset_link_start}reset it%{reset_link_end} if that ever happens.') % { reset_link_start: reset_link_start, reset_link_end: reset_link_end } - reset_message = s_('AccessTokens|Keep this token secret. Anyone who has it can access repository static objects as if they were you. If that ever happens, %{reset_link_start}reset this token%{reset_link_end}.') % { reset_link_start: reset_link_start, reset_link_end: reset_link_end }
= reset_message.html_safe = reset_message.html_safe
...@@ -1744,13 +1744,13 @@ msgstr "" ...@@ -1744,13 +1744,13 @@ msgstr ""
msgid "AccessTokens|It cannot be used to access any other data." msgid "AccessTokens|It cannot be used to access any other data."
msgstr "" msgstr ""
msgid "AccessTokens|Keep this token secret. Anyone who gets ahold of it can access repository static objects as if they were you. You should %{reset_link_start}reset it%{reset_link_end} if that ever happens." msgid "AccessTokens|Keep this token secret. Anyone who has it can access repository static objects as if they were you. If that ever happens, %{reset_link_start}reset this token%{reset_link_end}."
msgstr "" msgstr ""
msgid "AccessTokens|Keep this token secret. Anyone who gets ahold of it can create issues as if they were you. You should %{link_reset_it} if that ever happens." msgid "AccessTokens|Keep this token secret. Anyone who has it can create issues as if they were you. If that happens, %{link_reset_it}."
msgstr "" msgstr ""
msgid "AccessTokens|Keep this token secret. Anyone who gets ahold of it can read activity and issue RSS feeds or your calendar feed as if they were you. You should %{link_reset_it} if that ever happens." msgid "AccessTokens|Keep this token secret. Anyone who has it can read activity and issue RSS feeds or your calendar feed as if they were you. If that happens, %{link_reset_it}."
msgstr "" msgstr ""
msgid "AccessTokens|Personal Access Tokens" msgid "AccessTokens|Personal Access Tokens"
...@@ -1768,16 +1768,16 @@ msgstr "" ...@@ -1768,16 +1768,16 @@ msgstr ""
msgid "AccessTokens|You can generate a personal access token for each application you use that needs access to the GitLab API." msgid "AccessTokens|You can generate a personal access token for each application you use that needs access to the GitLab API."
msgstr "" msgstr ""
msgid "AccessTokens|Your feed token is used to authenticate you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar, and is included in those feed URLs." msgid "AccessTokens|Your feed token authenticates you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar. It is visible in those feed URLs."
msgstr "" msgstr ""
msgid "AccessTokens|Your incoming email token is used to authenticate you when you create a new issue by email, and is included in your personal project-specific email addresses." msgid "AccessTokens|Your incoming email token authenticates you when you create a new issue by email, and is included in your personal project-specific email addresses."
msgstr "" msgstr ""
msgid "AccessTokens|Your static object token is used to authenticate you when repository static objects (e.g. archives, blobs, ...) are being served from an external storage." msgid "AccessTokens|Your static object token authenticates you when repository static objects (such as archives or blobs) are served from an external storage."
msgstr "" msgstr ""
msgid "AccessTokens|reset it" msgid "AccessTokens|reset this token"
msgstr "" msgstr ""
msgid "AccessibilityReport|Learn more" msgid "AccessibilityReport|Learn more"
...@@ -33255,7 +33255,7 @@ msgstr "" ...@@ -33255,7 +33255,7 @@ msgstr ""
msgid "This is a merge train pipeline" msgid "This is a merge train pipeline"
msgstr "" msgstr ""
msgid "This is a private email address %{helpIcon} generated just for you. Anyone who gets ahold of it can create issues or merge requests as if they were you. You should %{resetLinkStart}reset it%{resetLinkEnd} if that ever happens." msgid "This is a private email address %{helpIcon} generated just for you. Anyone who has it can create issues or merge requests as if they were you. If that happens, %{resetLinkStart}reset this token%{resetLinkEnd}."
msgstr "" msgstr ""
msgid "This is a security log of important events involving your account." msgid "This is a security log of important events involving your account."
......
...@@ -20,7 +20,7 @@ RSpec.describe 'Issues > User resets their incoming email token' do ...@@ -20,7 +20,7 @@ RSpec.describe 'Issues > User resets their incoming email token' do
page.within '#issuable-email-modal' do page.within '#issuable-email-modal' do
previous_token = page.find('input[type="text"]').value previous_token = page.find('input[type="text"]').value
click_button 'reset it' find('[data-testid="reset_email_token_link"]').click
wait_for_requests wait_for_requests
......
...@@ -70,7 +70,7 @@ RSpec.describe 'Profile account page', :js do ...@@ -70,7 +70,7 @@ RSpec.describe 'Profile account page', :js do
within('.feed-token-reset') do within('.feed-token-reset') do
previous_token = find("#feed_token").value previous_token = find("#feed_token").value
accept_confirm { click_link('reset it') } accept_confirm { find('[data-testid="reset_feed_token_link"]').click }
expect(find('#feed_token').value).not_to eq(previous_token) expect(find('#feed_token').value).not_to eq(previous_token)
end end
...@@ -89,7 +89,7 @@ RSpec.describe 'Profile account page', :js do ...@@ -89,7 +89,7 @@ RSpec.describe 'Profile account page', :js do
within('.incoming-email-token-reset') do within('.incoming-email-token-reset') do
previous_token = find('#incoming_email_token').value previous_token = find('#incoming_email_token').value
accept_confirm { click_link('reset it') } accept_confirm { find('[data-testid="reset_email_token_link"]').click }
expect(find('#incoming_email_token').value).not_to eq(previous_token) expect(find('#incoming_email_token').value).not_to eq(previous_token)
end end
......
...@@ -22,6 +22,10 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do ...@@ -22,6 +22,10 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do
find("#feed_token").value find("#feed_token").value
end end
def feed_token_description
"Your feed token authenticates you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar. It is visible in those feed URLs."
end
def disallow_personal_access_token_saves! def disallow_personal_access_token_saves!
allow(PersonalAccessTokens::CreateService).to receive(:new).and_return(pat_create_service) allow(PersonalAccessTokens::CreateService).to receive(:new).and_return(pat_create_service)
...@@ -123,8 +127,9 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do ...@@ -123,8 +127,9 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do
allow(Gitlab::CurrentSettings).to receive(:disable_feed_token).and_return(false) allow(Gitlab::CurrentSettings).to receive(:disable_feed_token).and_return(false)
visit profile_personal_access_tokens_path visit profile_personal_access_tokens_path
expect(page).to have_content("Your feed token is used to authenticate you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar, and is included in those feed URLs.")
expect(feed_token).to eq(user.feed_token) expect(feed_token).to eq(user.feed_token)
expect(page).to have_content(feed_token_description)
end end
end end
...@@ -133,8 +138,8 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do ...@@ -133,8 +138,8 @@ RSpec.describe 'Profile > Personal Access Tokens', :js do
allow(Gitlab::CurrentSettings).to receive(:disable_feed_token).and_return(true) allow(Gitlab::CurrentSettings).to receive(:disable_feed_token).and_return(true)
visit profile_personal_access_tokens_path visit profile_personal_access_tokens_path
expect(page).not_to have_content("Your feed token is used to authenticate you when your RSS reader loads a personalized RSS feed or when your calendar application loads a personalized calendar, and is included in those feed URLs.") expect(page).to have_no_content(feed_token_description)
expect(page).not_to have_css("#feed_token") expect(page).to have_no_css("#feed_token")
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment