discourse/app/assets/javascripts/admin/addon/templates/user-index.hbs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

624 lines
24 KiB
Handlebars
Raw Normal View History

<section class="details {{unless this.model.active "not-activated"}}">
<div class="user-controls">
{{#if this.model.canViewProfile}}
<LinkTo @route="user" @model={{this.model}} class="btn btn-default">
{{d-icon "user"}}
{{i18n "admin.user.show_public_profile"}}
</LinkTo>
{{/if}}
{{#if this.model.can_view_action_logs}}
<DButton @action={{action "viewActionLogs"}} @class="btn-default" @actionParam={{this.model.username}} @icon="far-list-alt" @label="admin.user.action_logs" />
{{/if}}
{{#if this.model.active}}
{{#if this.currentUser.admin}}
<DButton @class="btn-default" @action={{action "logOut"}} @icon="power-off" @label="admin.user.log_out" />
{{/if}}
{{/if}}
<PluginOutlet @name="admin-user-controls-after" @args={{hash model=this.model}} />
</div>
<div class="display-row username">
<AdminEditableField @name="user.username.title" @value={{this.model.username}} @action={{action "saveUsername"}} @editing={{this.editingUsername}} />
2013-02-06 03:16:51 +08:00
</div>
2013-04-20 13:34:11 +08:00
2019-05-25 01:39:16 +08:00
<div class="display-row name">
<AdminEditableField @name="user.name.title" @value={{this.model.name}} @action={{action "saveName"}} @editing={{this.editingName}} />
</div>
<PluginOutlet @name="admin-user-below-names" @args={{hash user=this.model}} />
{{#if this.canCheckEmails}}
<div class="display-row email">
<div class="field">{{i18n "user.email.primary"}}</div>
<div class="value">
{{#unless this.model.active}}
<div class="controls">{{i18n "admin.users.not_verified"}}</div>
{{/unless}}
{{#if this.model.email}}
<a href="mailto:{{this.model.email}}">{{this.model.email}}</a>
{{else}}
<DButton @class="btn-default" @action={{route-action "checkEmail"}} @actionParam={{this.model}} @icon="envelope" @label="admin.users.check_email.text" @title="admin.users.check_email.title" />
{{/if}}
</div>
<div class="controls">
{{#if this.siteSettings.auth_overrides_email}}
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
{{i18n "user.email.auth_override_instructions"}}
{{else if this.model.email}}
{{html-safe (i18n "admin.user.visit_profile" url=this.preferencesPath)}}
{{/if}}
</div>
</div>
2013-04-20 13:34:11 +08:00
<div class="display-row secondary-emails">
<div class="field">{{i18n "user.email.secondary"}}</div>
2018-07-03 19:51:22 +08:00
<div class="value">
{{#if this.model.email}}
{{#if this.model.secondary_emails}}
2018-07-03 19:51:22 +08:00
<ul>
{{#each this.model.secondary_emails as |email| }}
<li><a href="mailto:{{email}}">{{email}}</a></li>
2018-07-03 19:51:22 +08:00
{{/each}}
</ul>
{{else}}
{{i18n "user.email.no_secondary"}}
2018-07-03 19:51:22 +08:00
{{/if}}
{{else}}
<DButton @action={{route-action "checkEmail"}} @class="btn-default" @actionParam={{this.model}} @icon="envelope" @label="admin.users.check_email.text" @title="admin.users.check_email.title" />
2018-07-03 19:51:22 +08:00
{{/if}}
</div>
<div class="controls">
{{#if this.model.email}}
{{#if this.model.secondary_emails}}
{{#if this.siteSettings.auth_overrides_email}}
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
{{i18n "user.email.auth_override_instructions"}}
{{else}}
{{html-safe (i18n "admin.user.visit_profile" url=this.preferencesPath)}}
{{/if}}
{{/if}}
{{/if}}
</div>
2018-07-03 19:51:22 +08:00
</div>
<div class="display-row bounce-score">
<div class="field"><a href={{this.model.bounceLink}}>{{i18n "admin.user.bounce_score"}}</a></div>
<div class="value">{{this.model.bounceScore}}</div>
<div class="controls">
{{#if this.model.canResetBounceScore}}
<DButton @class="btn-default" @action={{action "resetBounceScore"}} @label="admin.user.reset_bounce_score.label" @title="admin.user.reset_bounce_score.title" />
{{/if}}
{{this.model.bounceScoreExplanation}}
</div>
</div>
<div class="display-row associations">
<div class="field">{{i18n "user.associated_accounts.title"}}</div>
<div class="value">
{{#if this.associatedAccountsLoaded}}
{{this.associatedAccounts}}
{{else}}
<DButton @class="btn-default" @action={{route-action "checkEmail"}} @actionParam={{this.model}} @icon="envelope" @label="admin.users.check_email.text" @title="admin.users.check_email.title" />
{{/if}}
</div>
</div>
{{/if}}
<div class="display-row">
<div class="field">{{i18n "user.avatar.title"}}</div>
<div class="value">{{avatar this.model imageSize="large"}}</div>
<div class="controls">
{{html-safe (i18n "admin.user.visit_profile" url=this.preferencesPath)}}
</div>
2013-02-06 03:16:51 +08:00
</div>
2013-04-20 13:34:11 +08:00
<div class="display-row">
<AdminEditableField @name="user.title.title" @value={{this.model.title}} @action={{action "saveTitle"}} @editing={{this.editingTitle}} />
</div>
<div class="display-row last-ip">
<div class="field">{{i18n "user.ip_address.title"}}</div>
<div class="value">{{this.model.ip_address}}</div>
<div class="controls">
{{#if this.currentUser.staff}}
<IpLookup @ip={{this.model.ip_address}} @userId={{this.model.id}} />
{{/if}}
2013-02-06 03:16:51 +08:00
</div>
</div>
2013-04-20 13:34:11 +08:00
<div class="display-row registration-ip">
<div class="field">{{i18n "user.registration_ip_address.title"}}</div>
<div class="value">{{this.model.registration_ip_address}}</div>
<div class="controls">
{{#if this.currentUser.staff}}
<IpLookup @ip={{this.model.registration_ip_address}} @userId={{this.model.id}} />
{{/if}}
</div>
</div>
{{#if this.showBadges}}
<div class="display-row">
<div class="field">{{i18n "admin.badges.title"}}</div>
<div class="value">
{{i18n "badges.badge_count" count=this.model.badge_count}}
</div>
<div class="controls">
<LinkTo @route="adminUser.badges" @model={{this.model}} class="btn btn-default">
{{d-icon "certificate"}}
{{i18n "admin.badges.edit_badges"}}
</LinkTo>
</div>
</div>
{{/if}}
<div class="display-row">
<div class="field">{{i18n "user.second_factor.title"}}</div>
<div class="value">
{{#if this.model.second_factor_enabled}}
{{i18n "yes_value"}}
{{else}}
{{i18n "no_value"}}
{{/if}}
</div>
<div class="controls">
{{#if this.canDisableSecondFactor}}
<DButton @class="btn-default" @action={{action "disableSecondFactor"}} @icon="unlock-alt" @label="user.second_factor.disable" />
{{/if}}
</div>
</div>
2013-02-06 03:16:51 +08:00
</section>
{{#if this.userFields}}
<section class="details">
{{#each this.userFields as |uf|}}
<div class="display-row">
<div class="field">{{uf.name}}</div>
<div class="value">
2014-12-13 02:28:20 +08:00
{{#if uf.value}}
{{uf.value}}
{{else}}
&mdash;
{{/if}}
</div>
</div>
{{/each}}
</section>
{{/if}}
<PluginOutlet @name="admin-user-details" @tagName="span" @connectorTagName="div" @args={{hash model=this.model}} />
<section class="details">
<h1>{{i18n "admin.user.permissions"}}</h1>
2013-02-06 03:16:51 +08:00
{{#if this.siteSettings.must_approve_users}}
<div class="display-row">
<div class="field">{{i18n "admin.users.approved"}}</div>
<div class="value">
{{#if this.model.approved}}
{{i18n "admin.user.approved_by"}}
<LinkTo @route="adminUser" @model={{this.model.approvedBy}}>
{{avatar this.model.approvedBy imageSize="small"}}
</LinkTo>
<LinkTo @route="adminUser" @model={{this.model.approvedBy}}>
{{this.model.approvedBy.username}}
</LinkTo>
{{else}}
{{i18n "no_value"}}
{{/if}}
</div>
<div class="controls">
{{#if this.model.approved}}
{{i18n "admin.user.approve_success"}}
{{else}}
{{#if this.model.can_approve}}
<DButton @class="btn-default" @action={{action "approve"}} @icon="check" @label="admin.user.approve" />
{{/if}}
{{/if}}
</div>
2013-02-06 03:16:51 +08:00
</div>
{{/if}}
2013-02-06 03:16:51 +08:00
<div class="display-row">
<div class="field">{{i18n "admin.users.active"}}</div>
<div class="value">{{i18n-yes-no this.model.active}}</div>
<div class="controls">
{{#if this.model.active}}
{{#if this.model.can_deactivate}}
<DButton @class="btn-default" @action={{action "deactivate"}} @label="admin.user.deactivate_account" />
{{i18n "admin.user.deactivate_explanation"}}
{{/if}}
{{else}}
{{#if this.model.can_send_activation_email}}
<DButton @class="btn-default" @action={{action "sendActivationEmail"}} @icon="envelope" @label="admin.user.send_activation_email" />
{{/if}}
{{#if this.model.can_activate}}
<DButton @class="btn-default" @action={{action "activate"}} @icon="check" @label="admin.user.activate" />
{{/if}}
{{/if}}
</div>
</div>
2017-09-27 04:46:37 +08:00
<div class="display-row">
<div class="field">{{i18n "admin.user.staged"}}</div>
<div class="value">{{i18n-yes-no this.model.staged}}</div>
<div class="controls">{{i18n "admin.user.staged_explanation"}}</div>
2017-09-27 04:46:37 +08:00
</div>
{{#if this.currentUser.admin}}
<div class="display-row">
<div class="field">{{i18n "admin.api.active_keys"}}</div>
<div class="value">
{{this.model.api_key_count}}
</div>
<div class="controls">
<DButton @class="btn-default" @href="/admin/api/keys" @label="admin.api.manage_keys" />
</div>
</div>
{{/if}}
2013-10-23 03:53:08 +08:00
<div class="display-row">
<div class="field">{{i18n "admin.user.admin"}}</div>
<div class="value">{{i18n-yes-no this.model.admin}}</div>
<div class="controls">
{{#if this.model.can_revoke_admin}}
<DButton @class="btn-default" @action={{action "revokeAdmin"}} @icon="shield-alt" @label="admin.user.revoke_admin" />
2013-02-06 03:16:51 +08:00
{{/if}}
{{#if this.model.can_grant_admin}}
<DButton @class="btn-default grant-admin" @action={{action "grantAdmin"}} @icon="shield-alt" @label="admin.user.grant_admin" />
{{/if}}
2013-02-06 03:16:51 +08:00
</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.moderator"}}</div>
<div class="value">{{i18n-yes-no this.model.moderator}}</div>
<div class="controls">
{{#if this.model.can_revoke_moderation}}
<DButton @class="btn-default" @action={{action "revokeModeration"}} @icon="shield-alt" @label="admin.user.revoke_moderation" />
{{/if}}
{{#if this.model.can_grant_moderation}}
<DButton @class="btn-default" @action={{action "grantModeration"}} @icon="shield-alt" @label="admin.user.grant_moderation" />
{{/if}}
</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "trust_level"}}</div>
<div class="value">
<ComboBox @content={{this.site.trustLevels}} @nameProperty="detailedName" @value={{this.model.trustLevel.id}} @onChange={{action (mut this.model.trust_level)}} />
{{#if this.model.dirty}}
<div>
<DButton @class="ok no-text" @action={{action "saveTrustLevel"}} @icon="check" />
<DButton @class="cancel no-text" @action={{action "restoreTrustLevel"}} @icon="times" />
</div>
{{/if}}
</div>
<div class="controls">
{{#if this.model.canLockTrustLevel}}
{{#if this.hasLockedTrustLevel}}
{{d-icon "lock" title="admin.user.trust_level_locked_tip"}}
<DButton @class="btn-default" @action={{action "lockTrustLevel"}} @actionParam={{false}} @label="admin.user.unlock_trust_level" />
{{else}}
{{d-icon "unlock" title="admin.user.trust_level_unlocked_tip"}}
<DButton @class="btn-default" @action={{action "lockTrustLevel"}} @actionParam={{true}} @label="admin.user.lock_trust_level" />
{{/if}}
{{/if}}
{{#if this.model.tl3Requirements}}
<LinkTo @route="adminUser.tl3Requirements" @model={{this.model}} class="btn btn-default">
{{i18n "admin.user.trust_level_3_requirements"}}
</LinkTo>
{{/if}}
</div>
</div>
<div class="user-suspended display-row {{if this.model.suspended "highlight-danger"}}">
<div class="field">{{i18n "admin.user.suspended"}}</div>
<div class="value">
{{i18n-yes-no this.model.suspended}}
{{#if this.model.suspended}}
{{#unless this.model.suspendedForever}}
{{i18n "admin.user.suspended_until" until=this.model.suspendedTillDate}}
{{/unless}}
{{/if}}
</div>
<div class="controls">
{{#if this.model.suspended}}
<DButton @class="btn-danger unsuspend-user" @action={{action "unsuspend"}} @icon="ban" @label="admin.user.unsuspend" />
{{i18n "admin.user.suspended_explanation"}}
{{else}}
{{#if this.model.canSuspend}}
<DButton @class="btn-danger suspend-user" @action={{action "showSuspendModal"}} @icon="ban" @label="admin.user.suspend" />
{{i18n "admin.user.suspended_explanation"}}
{{/if}}
2013-02-06 03:16:51 +08:00
{{/if}}
</div>
</div>
{{#if this.model.suspended}}
<div class="display-row highlight-danger suspension-info">
<div class="field">{{i18n "admin.user.suspended_by"}}</div>
<div class="value">
<LinkTo @route="adminUser" @model={{this.model.suspendedBy}}>
{{avatar this.model.suspendedBy imageSize="tiny"}}
</LinkTo>
<LinkTo @route="adminUser" @model={{this.model.suspendedBy}}>
{{this.model.suspendedBy.username}}
</LinkTo>
</div>
<div class="controls">
<b>{{i18n "admin.user.suspend_reason"}}</b>:
<div class="full-reason">{{this.model.full_suspend_reason}}</div>
</div>
</div>
{{/if}}
<div class="display-row {{if this.model.silenced "highlight-danger"}}">
<div class="field">{{i18n "admin.user.silenced"}}</div>
<div class="value">
{{i18n-yes-no this.model.silenced}}
{{#if this.model.silenced}}
{{#unless this.model.silencedForever}}
{{i18n "admin.user.suspended_until" until=this.model.silencedTillDate}}
{{/unless}}
{{/if}}
</div>
<div class="controls">
<ConditionalLoadingSpinner @size="small" @condition={{this.model.silencingUser}}>
{{#if this.model.silenced}}
<DButton @class="btn-danger unsilence-user" @action={{action "unsilence"}} @icon="microphone-slash" @label="admin.user.unsilence" />
{{i18n "admin.user.silence_explanation"}}
{{else}}
<DButton @class="btn-danger silence-user" @action={{action "showSilenceModal"}} @icon="microphone-slash" @label="admin.user.silence" />
{{i18n "admin.user.silence_explanation"}}
{{/if}}
</ConditionalLoadingSpinner>
</div>
</div>
{{#if this.model.silenced}}
<div class="display-row highlight-danger silence-info">
<div class="field">{{i18n "admin.user.silenced_by"}}</div>
<div class="value">
<LinkTo @route="adminUser" @model={{this.model.silencedBy}}>
{{avatar this.model.silencedBy imageSize="tiny"}}
</LinkTo>
<LinkTo @route="adminUser" @model={{this.model.silencedBy}}>
{{this.model.silencedBy.username}}
</LinkTo>
</div>
<div class="controls">
<b>{{i18n "admin.user.silence_reason"}}</b>:
<div class="full-reason">{{this.model.silence_reason}}</div>
</div>
</div>
{{/if}}
{{#if this.model.tl3_requirements.penalty_counts.total}}
<div class="display-row clear-penalty-history">
<div class="field">{{i18n "admin.user.penalty_count"}}</div>
<div class="value">{{this.model.tl3_requirements.penalty_counts.total}}</div>
{{#if this.currentUser.admin}}
<div class="controls">
<DButton @label="admin.user.clear_penalty_history.title" @class="btn-default" @icon="times" @action={{action "clearPenaltyHistory"}} />
{{i18n "admin.user.clear_penalty_history.description"}}
</div>
{{/if}}
</div>
{{/if}}
2013-02-06 03:16:51 +08:00
</section>
{{#if this.currentUser.admin}}
<section class="details">
<h1>{{i18n "admin.groups.title"}}</h1>
<div class="display-row">
<div class="field">{{i18n "admin.groups.automatic"}}</div>
<div class="value">{{html-safe this.automaticGroups}}</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.groups.custom"}}</div>
<div class="value">
<GroupChooser @content={{this.availableGroups}} @value={{this.customGroupIdsBuffer}} @labelProperty="name" @onChange={{action (mut this.customGroupIdsBuffer)}} />
</div>
{{#if this.customGroupsDirty}}
<div class="controls">
<DButton @icon="check" @class="ok" @action={{action "saveCustomGroups"}} />
<DButton @icon="times" @class="cancel" @action={{action "resetCustomGroups"}} />
</div>
{{/if}}
</div>
{{#if this.model.customGroups}}
<div class="display-row">
<div class="field">{{i18n "admin.groups.primary"}}</div>
<div class="value">
<ComboBox @content={{this.model.customGroups}} @value={{this.model.primary_group_id}} @onChange={{action (mut this.model.primary_group_id)}} @options={{hash
none="admin.groups.no_primary"
}} />
</div>
{{#if this.primaryGroupDirty}}
<div class="controls">
<DButton @icon="check" @class="ok" @action={{action "savePrimaryGroup"}} />
<DButton @icon="times" @class="cancel" @action={{action "resetPrimaryGroup"}} />
</div>
{{/if}}
</div>
{{/if}}
</section>
{{/if}}
<section class="details">
<h1>{{i18n "admin.user.activity"}}</h1>
2013-02-06 03:16:51 +08:00
<div class="display-row">
<div class="field">{{i18n "created"}}</div>
<div class="value">{{format-date this.model.created_at leaveAgo="true"}}</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "admin.users.last_emailed"}}</div>
<div class="value">{{format-date this.model.last_emailed_at}}</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "last_seen"}}</div>
<div class="value">{{format-date this.model.last_seen_at leaveAgo="true"}}</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.like_count"}}</div>
<div class="value">{{this.model.like_given_count}} / {{this.model.like_count}}</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.topics_entered"}}</div>
<div class="value">{{this.model.topics_entered}}</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.post_count"}}</div>
<div class="value">{{this.model.post_count}}</div>
<div class="controls">
{{#if this.model.can_delete_all_posts}}
{{#if this.model.post_count}}
<DButton @class="btn-danger" @action={{action "showDeletePostsConfirmation"}} @icon="far-trash-alt" @label="admin.user.delete_posts.button" />
{{/if}}
{{else}}
{{this.deleteAllPostsExplanation}}
{{/if}}
</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.posts_read_count"}}</div>
<div class="value">{{this.model.posts_read_count}}</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.warnings_received_count"}}</div>
<div class="value">{{this.model.warnings_received_count}}</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.flags_given_received_count"}}</div>
<div class="value">
{{this.model.flags_given_count}} / {{this.model.flags_received_count}}
</div>
<div class="controls">
{{#if this.model.flags_received_count}}
<LinkTo @route="review" @query={{hash username=this.model.username type="ReviewableFlaggedPost" status="all"}} class="btn">
{{i18n "admin.user.show_flags_received"}}
</LinkTo>
{{/if}}
</div>
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.private_topics_count"}}</div>
<div class="value">{{this.model.private_topics_count}}</div>
2013-02-06 03:16:51 +08:00
</div>
<div class="display-row">
<div class="field">{{i18n "admin.user.time_read"}}</div>
<div class="value">{{format-duration this.model.time_read}}</div>
</div>
<div class="display-row">
<div class="field">{{i18n "user.invited.days_visited"}}</div>
<div class="value">{{html-safe this.model.days_visited}}</div>
</div>
<div class="display-row post-edits-count">
<div class="field">{{i18n "admin.user.post_edits_count" }}</div>
<div class="value">
{{if (gt this.model.post_edits_count 0) this.model.post_edits_count "0"}}
</div>
<div class="controls">
{{#if (gt this.model.post_edits_count 0) }}
<LinkTo @route="adminReports.show" @model="post_edits" @query={{hash filters=this.postEditsByEditorFilter}} class="btn btn-icon">
{{d-icon "far-eye"}}
{{i18n "admin.user.view_edits"}}
</LinkTo>
{{/if}}
</div>
</div>
2013-02-06 03:16:51 +08:00
</section>
{{#if this.model.single_sign_on_record}}
<section class="details">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<h1>{{i18n "admin.user.discourse_connect.title"}}</h1>
2014-08-23 08:34:48 +08:00
{{#let this.model.single_sign_on_record as |sso|}}
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.external_id"}}</div>
<div class="value">{{sso.external_id}}</div>
{{#if this.model.can_delete_sso_record}}
<div class="controls">
<DButton @class="btn-danger" @action={{action "deleteSSORecord"}} @icon="far-trash-alt" @label="admin.user.discourse_connect.delete_sso_record" />
</div>
{{/if}}
</div>
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.external_username"}}</div>
<div class="value">{{sso.external_username}}</div>
</div>
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.external_name"}}</div>
<div class="value">{{sso.external_name}}</div>
</div>
{{#if this.canAdminCheckEmails}}
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.external_email"}}</div>
{{#if this.ssoExternalEmail}}
<div class="value">{{this.ssoExternalEmail}}</div>
{{else}}
<DButton @class="btn-default" @action={{action "checkSsoEmail"}} @actionParam={{this.model}} @icon="envelope" @label="admin.users.check_email.text" @title="admin.users.check_email.title" />
{{/if}}
</div>
{{/if}}
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.external_avatar_url"}}</div>
<div class="value">{{sso.external_avatar_url}}</div>
2014-08-23 08:34:48 +08:00
</div>
{{#if this.canAdminCheckEmails}}
<div class="display-row">
FEATURE: Rename 'Discourse SSO' to DiscourseConnect (#11978) The 'Discourse SSO' protocol is being rebranded to DiscourseConnect. This should help to reduce confusion when 'SSO' is used in the generic sense. This commit aims to: - Rename `sso_` site settings. DiscourseConnect specific ones are prefixed `discourse_connect_`. Generic settings are prefixed `auth_` - Add (server-side-only) backwards compatibility for the old setting names, with deprecation notices - Copy `site_settings` database records to the new names - Rename relevant translation keys - Update relevant translations This commit does **not** aim to: - Rename any Ruby classes or methods. This might be done in a future commit - Change any URLs. This would break existing integrations - Make any changes to the protocol. This would break existing integrations - Change any functionality. Further normalization across DiscourseConnect and other auth methods will be done separately The risks are: - There is no backwards compatibility for site settings on the client-side. Accessing auth-related site settings in Javascript is fairly rare, and an error on the client side would not be security-critical. - If a plugin is monkey-patching parts of the auth process, changes to locale keys could cause broken error messages. This should also be unlikely. The old site setting names remain functional, so security-related overrides will remain working. A follow-up commit will be made with a post-deploy migration to delete the old `site_settings` rows.
2021-02-08 18:04:33 +08:00
<div class="field">{{i18n "admin.user.discourse_connect.last_payload"}}</div>
{{#if this.ssoLastPayload}}
<div class="value">
{{#each this.ssoPayload as |line|}}
{{line}}<br>
{{/each}}
</div>
{{else}}
<DButton @class="btn-default" @action={{action "checkSsoPayload"}} @actionParam={{this.model}} @icon="far-list-alt" @label="admin.users.check_sso.text" @title="admin.users.check_sso.title" />
{{/if}}
</div>
{{/if}}
{{/let}}
2014-08-23 08:34:48 +08:00
</section>
{{/if}}
<PluginOutlet @name="after-user-details" @tagName="span" @connectorTagName="div" @args={{hash model=this.model}} />
2018-04-17 02:41:03 +08:00
<section>
<hr>
2015-03-11 01:06:08 +08:00
<div class="pull-right">
{{#if this.model.active}}
{{#if this.model.can_impersonate}}
<DButton @class="btn-danger btn-impersonate" @action={{action "impersonate"}} @icon="crosshairs" @label="admin.impersonate.title" @title="admin.impersonate.help" />
{{/if}}
{{/if}}
{{#if this.model.can_be_anonymized}}
<DButton @label="admin.user.anonymize" @icon="exclamation-triangle" @class="btn-danger btn-anonymize" @action={{action "anonymize"}} />
{{/if}}
2015-03-11 01:06:08 +08:00
{{#if this.model.canBeDeleted}}
<DButton @label="admin.user.delete" @icon="trash-alt" @class="btn-danger btn-user-delete" @action={{action "destroy"}} />
{{/if}}
{{#if this.model.can_be_merged}}
<DButton @label="admin.user.merge.button" @icon="arrows-alt-h" @class="btn-danger btn-user-merge" @action={{action "promptTargetUser"}} />
{{/if}}
2015-03-11 01:06:08 +08:00
</div>
{{#if this.deleteExplanation}}
<div class="clearfix"></div>
<br>
<div class="pull-right">
{{d-icon "exclamation-triangle"}} {{this.deleteExplanation}}
</div>
{{/if}}
</section>
<div class="clearfix"></div>