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">
|
2019-05-16 19:49:38 +00:00
|
|
|
<Icon @glyph="vault-logo" @size="l" />
|
2018-10-21 19:19:34 +00:00
|
|
|
</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}}
|
2019-03-26 16:24:29 +00:00
|
|
|
<li class="{{if (is-active-route 'vault.cluster.secrets') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.secrets"
|
|
|
|
current-when="vault.cluster.secrets vault.cluster.settings.mount-secret-backend vault.cluster.settings.configure-secret-backend"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
data-test-navbar-item='secrets'
|
|
|
|
}}
|
|
|
|
Secrets
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
2019-01-18 22:04:40 +00:00
|
|
|
{{#if (has-permission 'access')}}
|
|
|
|
<li class="{{if (is-active-route 'vault.cluster.access') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
params=(route-params-for 'access')
|
2018-10-21 19:19:34 +00:00
|
|
|
current-when="vault.cluster.access vault.cluster.settings.auth"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
2019-01-18 22:04:40 +00:00
|
|
|
data-test-navbar-item='access'
|
|
|
|
}}
|
|
|
|
Access
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
{{/if}}
|
|
|
|
{{#if (has-permission 'policies')}}
|
|
|
|
<li class="{{if (is-active-route (array 'vault.cluster.policies' 'vault.cluster.policy')) 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.policies"
|
|
|
|
(route-params-for 'policies')
|
|
|
|
current-when="vault.cluster.policies vault.cluster.policy"
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
data-test-navbar-item='policies'
|
2018-10-21 19:19:34 +00:00
|
|
|
}}
|
2019-01-18 22:04:40 +00:00
|
|
|
Policies
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
{{/if}}
|
|
|
|
{{#if (has-permission 'tools')}}
|
|
|
|
<li class="{{if (is-active-route 'vault.cluster.tools') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.tools.tool"
|
|
|
|
(route-params-for 'tools')
|
|
|
|
invokeAction=(action Nav.closeDrawer)
|
|
|
|
}}
|
|
|
|
Tools
|
|
|
|
{{/link-to}}
|
|
|
|
</li>
|
|
|
|
{{/if}}
|
2018-10-21 19:19:34 +00:00
|
|
|
</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>
|
2020-10-05 21:34:52 +00:00
|
|
|
{{else if (and (has-permission 'metrics' routeParams='activity') (not cluster.dr.isSecondary) auth.currentToken)}}
|
|
|
|
<div class="navbar-sections">
|
|
|
|
<div class="{{if (is-active-route 'vault.cluster.metrics') 'is-active'}}">
|
|
|
|
{{#link-to
|
|
|
|
"vault.cluster.metrics"
|
|
|
|
current-when="vault.cluster.metrics"
|
|
|
|
data-test-navbar-item='metrics'
|
|
|
|
}}
|
|
|
|
Metrics
|
|
|
|
{{/link-to}}
|
|
|
|
</div>
|
|
|
|
</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>
|
2019-05-16 19:49:38 +00:00
|
|
|
<Icon @glyph="console" @size="l" />
|
2018-10-21 19:19:34 +00:00
|
|
|
<div class="status-menu-label">
|
|
|
|
Console
|
|
|
|
</div>
|
2019-05-13 19:05:25 +00:00
|
|
|
<Chevron @direction="down" class="has-text-white is-status-chevron" />
|
2018-10-21 19:19:34 +00:00
|
|
|
</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}}
|
2021-06-10 22:49:49 +00:00
|
|
|
<LicenseBanners @expiry={{activeCluster.licenseExpiry}} @autoloaded={{eq activeCluster.licenseState 'autoloaded'}} />
|
2018-10-21 19:19:34 +00:00
|
|
|
<div class="global-flash">
|
|
|
|
{{#each flashMessages.queue as |flash|}}
|
Update ui dependencies (#7244)
* be more specific about node version, and specify a yarn version
* update ember, ember-cli, ember-data, ember-data-model-fragments
* use router handlers to access transition information
* fix shadowing of component helper
* update ivy-codemirror, ember-cli-inject-live-reload
* remove custom router service
* don't use transition.queryParams
* update ember-cli-deprecation-workflow
* refactor kv v1 to use 'path' instead of 'id' on creation
* fix auth-jwt-test and toolbar-link-test
* update ember composable helpers
* remove Ember.copy from test file
* no more deprecations in the workflow
* fix more secret tests
* fix remaining failed tests
* move select component to core because it's used by ttl-picker
* generate new model class for each test instead of reusing an existing one
* fix selectors on kmip tests
* refactor how control groups construct urls from the new transition objects
* add router service override back in, and have it be evented so that we can trigger router events on it
* move stories and markdown files to core if the component lives in core
* update ember-cli, ember-cli-babel, ember-auto-import
* update base64js, date-fns, deepmerge, codemirror, broccoli-asset-rev
* update linting rules
* fix test selectors
* update ember-api-actions, ember-concurrency, ember-load-initializers, escape-string-regexp, normalize.css, prettier-eslint-cli, jsdoc-to-markdown
* remove test-results dir
* update base64js, ember-cli-clipboard, ember-cli-sass, ember-cli-string-helpers, ember-cli-template-lint, ember-cli-uglify, ember-link-action
* fix linting
* run yarn install without restoring from cache
* refactor how tests are run and handle the vault server subprocess
* update makefile for new test task names
* update circle config to use the new yarn task
* fix writing the seal keys when starting the dev server
* remove optional deps from the lockfile
* don't ignore-optional on yarn install
* remove errant console.log
* update ember-basic-dropdown-hover, jsonlint, yargs-parser
* update ember-cli-flash
* add back optionalDeps
* update @babel/core@7.5.5, ember-basic-dropdown@1.1.3, eslint-plugin-ember@6.8.2
* update storybook to the latest release
* add a babel config with targets so that the ember babel plugin works properly
* update ember-resolver, move ember-cli-storybook to devDependencies
* revert normalize.css upgrade
* silence fetchadapter warning for now
* exclude 3rd party array helper now that ember includes one
* fix switch and entity lookup styling
* only add -root suffix if it's not in versions mode
* make sure drop always has an array on the aws role form
* fix labels like we did with the backport
* update eslintignore
* update the yarn version in the docker build file
* update eslint ignore
2019-08-19 20:45:39 +00:00
|
|
|
{{#flash-message data-test-flash-message=true flash=flash as |customComponent flash close|}}
|
2018-10-21 19:19:34 +00:00
|
|
|
{{#if flash.componentName}}
|
|
|
|
{{component flash.componentName content=flash.content}}
|
|
|
|
{{else}}
|
2019-07-02 22:41:23 +00:00
|
|
|
<AlertPopup @type={{message-types flash.type}} @message={{flash.message}} @close={{close}} @isPreformatted={{flash.preformatted}} />
|
2018-10-21 19:19:34 +00:00
|
|
|
{{/if}}
|
|
|
|
{{/flash-message}}
|
|
|
|
{{/each}}
|
|
|
|
</div>
|
2021-09-03 18:46:50 +00:00
|
|
|
{{#if currentlyLoading}}
|
|
|
|
<LogoSplash />
|
2018-10-21 19:19:34 +00:00
|
|
|
{{else}}
|
2021-09-03 18:46:50 +00:00
|
|
|
{{#if showNav}}
|
|
|
|
<UiWizard>
|
|
|
|
<section class="section">
|
|
|
|
<div class="container is-widescreen">
|
|
|
|
<TokenExpireWarning @expirationDate={{auth.tokenExpirationDate}}>
|
|
|
|
{{outlet}}
|
|
|
|
</TokenExpireWarning>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</UiWizard>
|
|
|
|
{{else}}
|
|
|
|
{{outlet}}
|
|
|
|
{{/if}}
|
|
|
|
{{/if}}
|