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.

926 lines
27 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={{fn this.viewActionLogs this.model.username}}
@icon="far-rectangle-list"
@label="admin.user.action_logs"
class="btn-default"
/>
{{/if}}
{{#if this.model.active}}
{{#if this.currentUser.admin}}
<DButton
@action={{this.logOut}}
@icon="power-off"
@label="admin.user.log_out"
class="btn-default"
/>
{{/if}}
{{/if}}
<PluginOutlet
@name="admin-user-controls-after"
@outletArgs={{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"
@outletArgs={{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
@action={{fn (route-action "checkEmail") this.model}}
@icon="envelope"
@label="admin.users.check_email.text"
@title="admin.users.check_email.title"
class="btn-default"
/>
{{/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={{fn (route-action "checkEmail") this.model}}
@icon="envelope"
@label="admin.users.check_email.text"
@title="admin.users.check_email.title"
class="btn-default"
/>
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
@action={{this.resetBounceScore}}
@label="admin.user.reset_bounce_score.label"
@title="admin.user.reset_bounce_score.title"
class="btn-default"
/>
{{/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
@action={{fn (route-action "checkEmail") this.model}}
@icon="envelope"
@label="admin.users.check_email.text"
@title="admin.users.check_email.title"
class="btn-default"
/>
{{/if}}
</div>
{{#if (and this.currentUser.admin this.associatedAccounts)}}
<div class="controls">
<DButton
@action={{this.deleteAssociatedAccounts}}
@icon="trash-can"
@label="admin.users.delete_associated_accounts.text"
@title="admin.users.delete_associated_accounts.title"
class="btn-danger"
/>
</div>
{{/if}}
</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 second-factor">
<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
@action={{this.disableSecondFactor}}
@icon="unlock-keyhole"
@label="user.second_factor.disable"
class="btn-default disable-second-factor"
/>
{{/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}}
<span>
<PluginOutlet
@name="admin-user-details"
@connectorTagName="div"
@outletArgs={{hash model=this.model}}
/>
</span>
<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
@action={{this.approve}}
@icon="check"
@label="admin.user.approve"
class="btn-default"
/>
{{/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
@action={{this.deactivate}}
@label="admin.user.deactivate_account"
class="btn-default"
/>
{{i18n "admin.user.deactivate_explanation"}}
{{/if}}
{{else}}
{{#if this.model.can_send_activation_email}}
<DButton
@action={{this.sendActivationEmail}}
@icon="envelope"
@label="admin.user.send_activation_email"
class="btn-default"
/>
{{/if}}
{{#if this.model.can_activate}}
<DButton
@action={{this.activate}}
@icon="check"
@label="admin.user.activate"
class="btn-default"
/>
{{/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
@href="/admin/api/keys"
@label="admin.api.manage_keys"
class="btn-default"
/>
</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
@action={{this.revokeAdmin}}
@icon="shield-halved"
@label="admin.user.revoke_admin"
class="btn-default"
/>
2013-02-06 03:16:51 +08:00
{{/if}}
{{#if this.model.can_grant_admin}}
<DButton
@action={{this.grantAdmin}}
@icon="shield-halved"
@label="admin.user.grant_admin"
class="btn-default 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
@action={{this.revokeModeration}}
@icon="shield-halved"
@label="admin.user.revoke_moderation"
class="btn-default"
/>
{{/if}}
{{#if this.model.can_grant_moderation}}
<DButton
@action={{this.grantModeration}}
@icon="shield-halved"
@label="admin.user.grant_moderation"
class="btn-default"
/>
{{/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={{fn (mut this.model.trust_level)}}
/>
{{#if this.model.dirty}}
<div>
<DButton
@action={{this.saveTrustLevel}}
@icon="check"
class="ok no-text"
/>
<DButton
@action={{this.restoreTrustLevel}}
@icon="xmark"
class="cancel no-text"
/>
</div>
{{/if}}
</div>
<div class="controls">
{{#if this.model.canLockTrustLevel}}
{{#if this.hasLockedTrustLevel}}
{{d-icon "lock" title="admin.user.trust_level_locked_tip"}}
<DButton
@action={{fn this.lockTrustLevel false}}
@label="admin.user.unlock_trust_level"
class="btn-default"
/>
{{else}}
{{d-icon "unlock" title="admin.user.trust_level_unlocked_tip"}}
<DButton
@action={{fn this.lockTrustLevel true}}
@label="admin.user.lock_trust_level"
class="btn-default"
/>
{{/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
@action={{this.unsuspend}}
@icon="ban"
@label="admin.user.unsuspend"
class="btn-danger unsuspend-user"
/>
{{i18n "admin.user.suspended_explanation"}}
{{else}}
{{#if this.model.canSuspend}}
<DButton
@action={{this.showSuspendModal}}
@icon="ban"
@label="admin.user.suspend"
class="btn-danger suspend-user"
/>
{{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
@action={{this.unsilence}}
@icon="microphone-slash"
@label="admin.user.unsilence"
class="btn-danger unsilence-user"
/>
{{i18n "admin.user.silence_explanation"}}
{{else}}
{{#if this.model.canSilence}}
<DButton
@action={{this.showSilenceModal}}
@icon="microphone-slash"
@label="admin.user.silence"
class="btn-danger silence-user"
/>
{{i18n "admin.user.silence_explanation"}}
{{/if}}
{{/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"
@icon="xmark"
@action={{this.clearPenaltyHistory}}
class="btn-default"
/>
{{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={{fn (mut this.customGroupIdsBuffer)}}
/>
</div>
{{#if this.customGroupsDirty}}
<div class="controls">
<DButton @icon="check" @action={{this.saveCustomGroups}} class="ok" />
<DButton
@icon="xmark"
@action={{this.resetCustomGroups}}
class="cancel"
/>
</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={{fn (mut this.model.primary_group_id)}}
@options={{hash none="admin.groups.no_primary"}}
/>
</div>
{{#if this.primaryGroupDirty}}
<div class="controls">
<DButton
@icon="check"
@action={{this.savePrimaryGroup}}
class="ok"
/>
<DButton
@icon="xmark"
@action={{this.resetPrimaryGroup}}
class="cancel"
/>
</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
@action={{this.showDeletePostsConfirmation}}
@icon="trash-can"
@label="admin.user.delete_posts.button"
class="btn-danger"
/>
{{/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
@action={{this.deleteSSORecord}}
@icon="trash-can"
@label="admin.user.discourse_connect.delete_sso_record"
class="btn-danger"
/>
</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
@action={{fn this.checkSsoEmail this.model}}
@icon="envelope"
@label="admin.users.check_email.text"
@title="admin.users.check_email.title"
class="btn-default"
/>
{{/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
@action={{fn this.checkSsoPayload this.model}}
@icon="far-rectangle-list"
@label="admin.users.check_sso.text"
@title="admin.users.check_sso.title"
class="btn-default"
/>
{{/if}}
</div>
{{/if}}
{{/let}}
2014-08-23 08:34:48 +08:00
</section>
{{/if}}
<span>
<PluginOutlet
@name="after-user-details"
@connectorTagName="div"
@outletArgs={{hash model=this.model}}
/>
</span>
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
@action={{this.impersonate}}
@icon="crosshairs"
@label="admin.impersonate.title"
@title="admin.impersonate.help"
class="btn-danger btn-impersonate"
/>
{{/if}}
{{/if}}
{{#if this.model.can_be_anonymized}}
<DButton
@label="admin.user.anonymize"
@icon="triangle-exclamation"
@action={{this.anonymize}}
class="btn-danger btn-anonymize"
/>
{{/if}}
2015-03-11 01:06:08 +08:00
{{#if this.model.canBeDeleted}}
<DButton
@label="admin.user.delete"
@icon="trash-can"
@action={{this.destroyUser}}
class="btn-danger btn-user-delete"
/>
{{/if}}
{{#if this.model.can_be_merged}}
<DButton
@label="admin.user.merge.button"
@icon="left-right"
@action={{this.promptTargetUser}}
class="btn-danger btn-user-merge"
/>
{{/if}}
2015-03-11 01:06:08 +08:00
</div>
{{#if this.deleteExplanation}}
<div class="clearfix"></div>
<br />
<div class="pull-right">
{{d-icon "triangle-exclamation"}}
{{this.deleteExplanation}}
</div>
{{/if}}
</section>
<div class="clearfix"></div>