5c2a08de6d
* Update browserslist * Add browserslistrc * ember-cli-update --to 3.26, fix conflicts * Run codemodes that start with ember-* * More codemods - before cp* * More codemods (curly data-test-*) * WIP ember-basic-dropdown template errors * updates ember-basic-dropdown and related deps to fix build issues * updates basic dropdown instances to new version API * updates more deps -- ember-template-lint is working again * runs no-implicit-this codemod * creates and runs no-quoteless-attributes codemod * runs angle brackets codemod * updates lint:hbs globs to only touch hbs files * removes yield only templates * creates and runs deprecated args transform * supresses lint error for invokeAction on LinkTo component * resolves remaining ambiguous path lint errors * resolves simple-unless lint errors * adds warnings for deprecated tagName arg on LinkTo components * adds warnings for remaining curly component invocation * updates global template lint rules * resolves remaining template lint errors * disables some ember specfic lint rules that target pre octane patterns * js lint fix run * resolves remaining js lint errors * fixes test run * adds npm-run-all dep * fixes test attribute issues * fixes console acceptance tests * fixes tests * adds yield only wizard/tutorial-active template * fixes more tests * attempts to fix more flaky tests * removes commented out settled in transit test * updates deprecations workflow and adds initializer to filter by version * updates flaky policies acl old test * updates to flaky transit test * bumps ember deps down to LTS version * runs linters after main merge * fixes client count tests after bad merge conflict fixes * fixes client count history test * more updates to lint config * another round of hbs lint fixes after extending stylistic rule * updates lint-staged commands * removes indent eslint rule since it seems to break things * fixes bad attribute in transform-edit-form template * test fixes * fixes enterprise tests * adds changelog * removes deprecated ember-concurrency-test-waiters dep and adds @ember/test-waiters * flaky test fix Co-authored-by: hashishaw <cshaw@hashicorp.com>
177 lines
6.1 KiB
Handlebars
177 lines
6.1 KiB
Handlebars
<div class="auth-form">
|
|
{{#if this.hasMethodsWithPath}}
|
|
<nav class="tabs is-marginless">
|
|
<ul>
|
|
{{#each this.methodsToShow as |method|}}
|
|
{{#with (or method.path method.type) as |methodKey|}}
|
|
<li
|
|
class={{if
|
|
(and this.selectedAuthIsPath (eq (or this.selectedAuthBackend.path this.selectedAuthBackend.type) methodKey))
|
|
"is-active"
|
|
""
|
|
}}
|
|
data-test-auth-method
|
|
>
|
|
<LinkTo
|
|
@route="vault.cluster.auth"
|
|
@model={{this.cluster.name}}
|
|
@query={{hash with=methodKey}}
|
|
data-test-auth-method-link={{method.type}}
|
|
>
|
|
{{or method.id (capitalize method.type)}}
|
|
</LinkTo>
|
|
</li>
|
|
{{/with}}
|
|
{{/each}}
|
|
{{#if this.hasMethodsWithPath}}
|
|
<li class={{unless this.selectedAuthIsPath "is-active" ""}} data-test-auth-method>
|
|
<LinkTo
|
|
@route="vault.cluster.auth"
|
|
@model={{this.cluster.name}}
|
|
@query={{hash with="token"}}
|
|
data-test-auth-method-link="other"
|
|
>
|
|
Other
|
|
</LinkTo>
|
|
</li>
|
|
{{/if}}
|
|
</ul>
|
|
</nav>
|
|
{{/if}}
|
|
<div class="box is-marginless is-shadowless">
|
|
<MessageError
|
|
@errorMessage={{if (and this.cluster.standby this.hasCSPError) this.cspErrorText this.error}}
|
|
data-test-auth-error
|
|
/>
|
|
<div class="has-bottom-margin-s">
|
|
<p class="is-label">{{this.selectedAuthBackend.path}}</p>
|
|
<span class="description has-text-grey" data-test-description={{true}}>
|
|
{{this.selectedAuthBackend.mountDescription}}
|
|
</span>
|
|
</div>
|
|
{{#if (or (not this.hasMethodsWithPath) (not this.selectedAuthIsPath))}}
|
|
<Select
|
|
@label="Method"
|
|
@name="auth-method"
|
|
@options={{supported-auth-backends}}
|
|
@valueAttribute={{"type"}}
|
|
@labelAttribute={{"typeDisplay"}}
|
|
@isFullwidth={{true}}
|
|
@selectedValue={{this.selectedAuth}}
|
|
@onChange={{action (mut this.selectedAuth)}}
|
|
/>
|
|
{{/if}}
|
|
{{#if (or (eq this.selectedAuthBackend.type "jwt") (eq this.selectedAuthBackend.type "oidc"))}}
|
|
<AuthJwt
|
|
@onError={{action "handleError"}}
|
|
@onLoading={{action (mut this.isLoading)}}
|
|
@onToken={{action (mut this.token)}}
|
|
@namespace={{this.namespace}}
|
|
@onNamespace={{action (mut this.namespace)}}
|
|
@onSelectedAuth={{action (mut this.selectedAuth)}}
|
|
@onSubmit={{action "doSubmit"}}
|
|
@onRoleName={{action (mut this.roleName)}}
|
|
@roleName={{this.roleName}}
|
|
@selectedAuthType={{this.selectedAuthBackend.type}}
|
|
@selectedAuthPath={{or this.customPath this.selectedAuthBackend.id}}
|
|
@disabled={{or this.authenticate.isRunning this.isLoading}}
|
|
>
|
|
<AuthFormOptions
|
|
@customPath={{this.customPath}}
|
|
@onPathChange={{action (mut this.customPath)}}
|
|
@selectedAuthIsPath={{this.selectedAuthIsPath}}
|
|
/>
|
|
</AuthJwt>
|
|
{{else}}
|
|
<form id="auth-form" onsubmit={{action "doSubmit"}}>
|
|
{{#if (eq this.providerName "github")}}
|
|
<div class="field">
|
|
<label for="token" class="is-label">GitHub token</label>
|
|
<div class="control">
|
|
<Input
|
|
@type="password"
|
|
@value={{this.token}}
|
|
name="token"
|
|
id="token"
|
|
class="input"
|
|
data-test-token={{true}}
|
|
autocomplete="off"
|
|
spellcheck="false"
|
|
/>
|
|
</div>
|
|
</div>
|
|
{{else if (eq this.providerName "token")}}
|
|
<div class="field">
|
|
<label for="token" class="is-label">Token</label>
|
|
<div class="control">
|
|
<Input
|
|
@type="password"
|
|
@value={{this.token}}
|
|
name="token"
|
|
class="input"
|
|
autocomplete="off"
|
|
spellcheck="false"
|
|
data-test-token={{true}}
|
|
/>
|
|
</div>
|
|
</div>
|
|
{{else}}
|
|
<div class="field">
|
|
<label for="username" class="is-label">Username</label>
|
|
<div class="control">
|
|
<Input
|
|
@value={{this.username}}
|
|
name="username"
|
|
id="username"
|
|
class="input"
|
|
autocomplete="off"
|
|
spellcheck="false"
|
|
data-test-username={{true}}
|
|
/>
|
|
</div>
|
|
</div>
|
|
<div class="field">
|
|
<label for="password" class="is-label">Password</label>
|
|
<div class="control">
|
|
<Input
|
|
@value={{this.password}}
|
|
name="password"
|
|
id="password"
|
|
@type="password"
|
|
class="input"
|
|
autocomplete="off"
|
|
spellcheck="false"
|
|
data-test-password={{true}}
|
|
/>
|
|
</div>
|
|
</div>
|
|
{{/if}}
|
|
{{#if (not-eq this.selectedAuthBackend.type "token")}}
|
|
<AuthFormOptions
|
|
@customPath={{this.customPath}}
|
|
@onPathChange={{action (mut this.customPath)}}
|
|
@selectedAuthIsPath={{this.selectedAuthIsPath}}
|
|
/>
|
|
{{/if}}
|
|
<button
|
|
data-test-auth-submit={{true}}
|
|
type="submit"
|
|
disabled={{this.authenticate.isRunning}}
|
|
class="button is-primary {{if this.authenticate.isRunning "is-loading"}}"
|
|
id="auth-submit"
|
|
>
|
|
Sign In
|
|
</button>
|
|
{{#if (and this.delayAuthMessageReminder.isIdle this.showLoading)}}
|
|
<AlertInline
|
|
@paddingTop={{true}}
|
|
@sizeSmall={{true}}
|
|
@type="info"
|
|
@message="If login takes longer than usual, you may need to check your device for an MFA notification, or contact your administrator if login times out."
|
|
data-test-auth-message="push"
|
|
/>
|
|
{{/if}}
|
|
</form>
|
|
{{/if}}
|
|
</div>
|
|
</div> |