mirror of https://github.com/hashicorp/consul
ui: Adds warning icon to side menu when ACLs are disabled (#9864)
* ui: Adds warning icon to side menu when ACLs are are disabledpull/9890/head
parent
f4a96768d1
commit
aca7976580
|
@ -0,0 +1,3 @@
|
||||||
|
```release-note:improvement
|
||||||
|
ui: add permanently visible indicator when ACLs are disabled
|
||||||
|
```
|
|
@ -10,10 +10,16 @@ export default class ACLAbility extends BaseAbility {
|
||||||
get canRead() {
|
get canRead() {
|
||||||
return this.env.var('CONSUL_ACLS_ENABLED') && super.canRead;
|
return this.env.var('CONSUL_ACLS_ENABLED') && super.canRead;
|
||||||
}
|
}
|
||||||
|
|
||||||
get canDuplicate() {
|
get canDuplicate() {
|
||||||
return this.env.var('CONSUL_ACLS_ENABLED') && super.canWrite;
|
return this.env.var('CONSUL_ACLS_ENABLED') && super.canWrite;
|
||||||
}
|
}
|
||||||
|
|
||||||
get canDelete() {
|
get canDelete() {
|
||||||
return this.env.var('CONSUL_ACLS_ENABLED') && this.item.ID !== 'anonymous' && super.canWrite;
|
return this.env.var('CONSUL_ACLS_ENABLED') && this.item.ID !== 'anonymous' && super.canWrite;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get canUse() {
|
||||||
|
return this.env.var('CONSUL_ACLS_ENABLED');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,11 +125,18 @@
|
||||||
<a href={{href-to 'dc.intentions' @dc.Name}}>Intentions</a>
|
<a href={{href-to 'dc.intentions' @dc.Name}}>Intentions</a>
|
||||||
</li>
|
</li>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{#if (can "read acls")}}
|
<li class="acls-separator" role="separator">
|
||||||
<li role="separator">Access Controls</li>
|
Access Controls
|
||||||
|
{{#if (not (can "use acls"))}}
|
||||||
|
<span
|
||||||
|
{{tooltip "ACLs are not currently enabled in this cluster"}}
|
||||||
|
></span>
|
||||||
|
{{/if}}
|
||||||
|
</li>
|
||||||
<li data-test-main-nav-tokens class={{if (is-href 'dc.acls.tokens' @dc.Name) 'is-active'}}>
|
<li data-test-main-nav-tokens class={{if (is-href 'dc.acls.tokens' @dc.Name) 'is-active'}}>
|
||||||
<a href={{href-to 'dc.acls.tokens' @dc.Name}}>Tokens</a>
|
<a href={{href-to 'dc.acls.tokens' @dc.Name}}>Tokens</a>
|
||||||
</li>
|
</li>
|
||||||
|
{{#if (can "read acls")}}
|
||||||
<li data-test-main-nav-policies class={{if (is-href 'dc.acls.policies' @dc.Name) 'is-active'}}>
|
<li data-test-main-nav-policies class={{if (is-href 'dc.acls.policies' @dc.Name) 'is-active'}}>
|
||||||
<a href={{href-to 'dc.acls.policies' @dc.Name}}>Policies</a>
|
<a href={{href-to 'dc.acls.policies' @dc.Name}}>Policies</a>
|
||||||
</li>
|
</li>
|
||||||
|
@ -139,6 +146,16 @@
|
||||||
<li data-test-main-nav-auth-methods class={{if (is-href 'dc.acls.auth-methods' @dc.Name) 'is-active'}}>
|
<li data-test-main-nav-auth-methods class={{if (is-href 'dc.acls.auth-methods' @dc.Name) 'is-active'}}>
|
||||||
<a href={{href-to 'dc.acls.auth-methods' @dc.Name}}>Auth Methods</a>
|
<a href={{href-to 'dc.acls.auth-methods' @dc.Name}}>Auth Methods</a>
|
||||||
</li>
|
</li>
|
||||||
|
{{else if (not (can "use acls"))}}
|
||||||
|
<li data-test-main-nav-policies class={{if (is-href 'dc.acls.policies' @dc.Name) 'is-active'}}>
|
||||||
|
<span>Policies</span>
|
||||||
|
</li>
|
||||||
|
<li data-test-main-nav-roles class={{if (is-href 'dc.acls.roles' @dc.Name) 'is-active'}}>
|
||||||
|
<span>Roles</span>
|
||||||
|
</li>
|
||||||
|
<li data-test-main-nav-auth-methods class={{if (is-href 'dc.acls.auth-methods' @dc.Name) 'is-active'}}>
|
||||||
|
<span>Auth Methods</span>
|
||||||
|
</li>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</ul>
|
</ul>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
|
@ -11,4 +11,12 @@
|
||||||
.feedback-link a::after {
|
.feedback-link a::after {
|
||||||
@extend %with-logo-github-monochrome-mask, %as-pseudo;
|
@extend %with-logo-github-monochrome-mask, %as-pseudo;
|
||||||
}
|
}
|
||||||
|
.acls-separator span {
|
||||||
|
@extend %led-icon;
|
||||||
|
color: $red-500;
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
top: 2px;
|
||||||
|
margin-left: 2px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
@import './skin';
|
@import './skin';
|
||||||
@import './layout';
|
@import './layout';
|
||||||
/* things that should look like nav buttons */
|
/* things that should look like nav buttons */
|
||||||
%main-nav-vertical > ul > li > a,
|
%main-nav-vertical > ul > li > a {
|
||||||
%main-nav-vertical > ul > li > span {
|
|
||||||
@extend %main-nav-vertical-action;
|
@extend %main-nav-vertical-action;
|
||||||
}
|
}
|
||||||
%main-nav-vertical > ul > li.is-active > a {
|
%main-nav-vertical > ul > li.is-active > a {
|
||||||
|
@ -14,10 +13,8 @@
|
||||||
@extend %main-nav-vertical-action-active-intent;
|
@extend %main-nav-vertical-action-active-intent;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Whilst we want spans to look the same as actions */
|
%main-nav-vertical-action:hover,
|
||||||
/* we don't want them to act the same */
|
%main-nav-vertical-action:focus {
|
||||||
%main-nav-vertical-action:not(span):hover,
|
|
||||||
%main-nav-vertical-action:not(span):focus {
|
|
||||||
@extend %main-nav-vertical-action-intent;
|
@extend %main-nav-vertical-action-intent;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
margin-left: .5rem;
|
margin-left: .5rem;
|
||||||
}
|
}
|
||||||
%main-nav-vertical-action,
|
%main-nav-vertical-action,
|
||||||
|
%main-nav-vertical li:not([role="separator"]) > span,
|
||||||
%main-nav-vertical [role="separator"] {
|
%main-nav-vertical [role="separator"] {
|
||||||
display: block;
|
display: block;
|
||||||
padding: 7px 25px;
|
padding: 7px 25px;
|
||||||
|
|
|
@ -23,6 +23,9 @@
|
||||||
background-color: var(--gray-050);
|
background-color: var(--gray-050);
|
||||||
color: var(--gray-700);
|
color: var(--gray-700);
|
||||||
}
|
}
|
||||||
|
%main-nav-vertical li:not([role="separator"]) > span {
|
||||||
|
color: var(--gray-300);
|
||||||
|
}
|
||||||
%main-nav-vertical [role="separator"] {
|
%main-nav-vertical [role="separator"] {
|
||||||
color: var(--gray-600);
|
color: var(--gray-600);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import { modifier } from 'ember-modifier';
|
import { modifier } from 'ember-modifier';
|
||||||
|
|
||||||
export default modifier(function enabled($element, [bool], hash) {
|
export default modifier(function enabled($element, [bool = true], hash) {
|
||||||
if (['input', 'textarea', 'select', 'button'].includes($element.nodeName.toLowerCase())) {
|
if (['input', 'textarea', 'select', 'button'].includes($element.nodeName.toLowerCase())) {
|
||||||
if (bool) {
|
if (bool) {
|
||||||
$element.disabled = bool;
|
$element.disabled = bool;
|
||||||
|
|
|
@ -22,3 +22,29 @@
|
||||||
height: 1.2em;
|
height: 1.2em;
|
||||||
vertical-align: text-top;
|
vertical-align: text-top;
|
||||||
}
|
}
|
||||||
|
%led-icon {
|
||||||
|
position: relative;
|
||||||
|
box-sizing: border-box;
|
||||||
|
width: 12px;
|
||||||
|
height: 12px;
|
||||||
|
}
|
||||||
|
%led-icon::after,
|
||||||
|
%led-icon::before {
|
||||||
|
content: '';
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 100%;
|
||||||
|
}
|
||||||
|
%led-icon::before {
|
||||||
|
border: 1px solid currentColor;
|
||||||
|
opacity: 0.5;
|
||||||
|
}
|
||||||
|
%led-icon::after {
|
||||||
|
position: absolute;
|
||||||
|
top: 2px;
|
||||||
|
left: 2px;
|
||||||
|
width: calc(100% - 4px);
|
||||||
|
height: calc(100% - 4px);
|
||||||
|
background-color: currentColor;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue