2018-08-28 05:03:55 +00:00
|
|
|
{{#if showNav}}
|
2018-12-07 20:00:52 +00:00
|
|
|
<NavHeader data-test-header-with-nav @class="{{if consoleOpen 'panel-open'}}"
|
2018-11-14 00:55:07 +00:00
|
|
|
as |Nav|>
|
2018-08-28 05:03:55 +00:00
|
|
|
<Nav.home>
|
2018-10-21 19:19:34 +00:00
|
|
|
<HomeLink @class="navbar-item has-text-white has-current-color-fill">
|
|
|
|
{{partial 'svg/vault-logo'}}
|
|
|
|
</HomeLink>
|
2018-08-28 05:03:55 +00:00
|
|
|
</Nav.home>
|
2018-10-21 19:19:34 +00:00
|
|
|
<Nav.main>
|
|
|
|
<ul class="navbar-sections {{if (has-feature "Namespaces") 'with-ns-picker'}}">
|
|
|
|
{{#if (has-feature "Namespaces")}}
|
|
|
|
<li>
|
|
|
|
<NamespacePicker
|
|
|
|
@class="navbar-item"
|
|
|
|
@namespace={{namespaceQueryParam}}
|
|
|
|
>
|
|
|
|
</NamespacePicker>
|
|
|
|
</li>
|
|
|
|
{{/if}}
|
2018-11-14 00:55:07 +00:00
|
|
|
<li class="{{if (is-active-route 'vault.cluster.secrets') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.secrets"
|
2018-10-21 19:19:34 +00:00
|
|
|
current-when="vault.cluster.secrets vault.cluster.settings.mount-secret-backend vault.cluster.settings.configure-secret-backend"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
}}
|
|
|
|
Secrets
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
<li class="{{if (is-active-route 'vault.cluster.access') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.access"
|
|
|
|
current-when="vault.cluster.access vault.cluster.settings.auth"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
}}
|
|
|
|
Access
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
<li class="{{if (is-active-route (array 'vault.cluster.policies' 'vault.cluster.policy')) 'is-active'}}">
|
2018-11-14 00:55:07 +00:00
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.policies"
|
|
|
|
"acl"
|
2018-10-21 19:19:34 +00:00
|
|
|
current-when="vault.cluster.policies vault.cluster.policy"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
}}
|
|
|
|
Policies
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
<li class="{{if (is-active-route 'vault.cluster.tools') 'is-active'}}">
|
2018-11-14 00:55:07 +00:00
|
|
|
{{#link-to
|
2018-10-21 19:19:34 +00:00
|
|
|
"vault.cluster.tools.tool"
|
|
|
|
"wrap"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
}}
|
|
|
|
Tools
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</Nav.main>
|
2018-08-28 05:03:55 +00:00
|
|
|
<Nav.items>
|
2018-10-21 19:19:34 +00:00
|
|
|
<div class="navbar-separator is-hidden-tablet"></div>
|
2018-08-28 05:03:55 +00:00
|
|
|
{{#if namespaceService.inRootNamespace}}
|
2018-10-21 19:19:34 +00:00
|
|
|
<div class="navbar-item status-indicator-button" data-status="{{if activeCluster.unsealed "good" "bad"}}">
|
|
|
|
<StatusMenu @label="Status" @onLinkClick={{action Nav.closeDrawer}} />
|
2018-08-16 17:48:24 +00:00
|
|
|
</div>
|
2018-10-21 19:19:34 +00:00
|
|
|
<div class="navbar-separator is-hidden-mobile"></div>
|
2018-08-28 05:03:55 +00:00
|
|
|
{{/if}}
|
|
|
|
<div class="navbar-item">
|
2018-11-14 00:55:07 +00:00
|
|
|
<button type="button" class="button is-transparent nav-console-button{{if consoleOpen " popup-open"}}"
|
|
|
|
{{action (queue (action 'toggleConsole') (action Nav.closeDrawer))}} data-test-console-toggle>
|
2018-10-21 19:19:34 +00:00
|
|
|
<ICon @glyph="console" @size=24 />
|
|
|
|
<div class="status-menu-label">
|
|
|
|
Console
|
|
|
|
</div>
|
|
|
|
<ICon @glyph="chevron-down" @aria-hidden="true" @size=8 @class="has-text-white is-status-chevron" />
|
|
|
|
</button>
|
|
|
|
</div>
|
2018-11-05 16:56:59 +00:00
|
|
|
<div class="navbar-item nav-user-button {{if auth.allowExpiration "may-expire"}}" data-test-allow-expiration="{{auth.allowExpiration}}">
|
2018-10-21 19:19:34 +00:00
|
|
|
<StatusMenu @type="user" @label="User" @onLinkClick={{action Nav.closeDrawer}} />
|
2018-08-28 05:03:55 +00:00
|
|
|
</div>
|
|
|
|
</Nav.items>
|
2018-10-21 19:19:34 +00:00
|
|
|
</NavHeader>
|
|
|
|
{{/if}}
|
|
|
|
<div class="global-flash">
|
|
|
|
{{#each flashMessages.queue as |flash|}}
|
|
|
|
{{#flash-message data-test-flash-message=true flash=flash as |component flash close|}}
|
|
|
|
{{#if flash.componentName}}
|
|
|
|
{{component flash.componentName content=flash.content}}
|
|
|
|
{{else}}
|
2018-11-05 16:56:59 +00:00
|
|
|
<div class="message {{get (message-types flash.type) "class"}}">
|
2018-11-02 05:27:39 +00:00
|
|
|
<div class="columns is-mobile is-variable is-1">
|
|
|
|
<div class="column is-narrow message-icon">
|
2018-11-05 16:56:59 +00:00
|
|
|
<ICon @glyph="{{get (message-types flash.type) "glyph"}}" @size="20" @excludeIconClass={{true}} />
|
2018-11-02 05:27:39 +00:00
|
|
|
</div>
|
|
|
|
<div class="column">
|
|
|
|
<button type="button" class="close-button" {{action close}}>
|
|
|
|
{{i-con excludeIconClass=true glyph="close" aria-label="Close"}}
|
|
|
|
</button>
|
|
|
|
<div class="message-title">
|
|
|
|
{{get (message-types flash.type) "text"}}
|
|
|
|
</div>
|
|
|
|
{{#if flash.message}}
|
2018-11-05 16:56:59 +00:00
|
|
|
<p class="message-body" data-test-flash-message-body="true">
|
2018-11-02 05:27:39 +00:00
|
|
|
{{flash.message}}
|
|
|
|
</p>
|
|
|
|
{{/if}}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2018-10-21 19:19:34 +00:00
|
|
|
{{/if}}
|
|
|
|
{{/flash-message}}
|
|
|
|
{{/each}}
|
|
|
|
</div>
|
|
|
|
{{#if showNav}}
|
|
|
|
<UiWizard>
|
|
|
|
<section class="section">
|
|
|
|
<div class="container is-widescreen">
|
2018-11-14 00:55:07 +00:00
|
|
|
<TokenExpireWarning @expirationDate={{auth.tokenExpirationDate}}>
|
2018-10-21 19:19:34 +00:00
|
|
|
{{outlet}}
|
2018-11-14 00:55:07 +00:00
|
|
|
</TokenExpireWarning>
|
2018-10-21 19:19:34 +00:00
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</UiWizard>
|
|
|
|
{{else}}
|
|
|
|
{{outlet}}
|
|
|
|
{{/if}}
|