081db3a240
* Update ember-cli to ~3.20 * Remove bad optional-feature * Remove ember-fetch dep * re-install ember-fetch * update model fragments pr * update ember model fragments correct package name * update ember composable helpers to solve array helper error * update ember-concurrency * add back engine dependencies, automatically removed during ember-cli-upgrade * make author-form-options component js file otherwise error * for now comment out withTestWaiter * add eslint-node and fix if not with unless in templates * fix linting for tab index of false is now -1 and add type button to all buttons without types * fix href errors for linting, likely have to come back and fix * using eslint fix flag to fix all this.gets * ember modules codemode removed files that had module twice, will fix in next commit * finish codemode ember-data-codemod needed to rename const model * more this.get removal codemode did not work * cont. removal of this.get * stop mixin rules until figure out how to reconfig them all * smaller eslint ignores * get codemode * testing app small fixes to bring it back after all the changes * small changes to eslint * test removal of getProperties * fix issue with baseKey because value could be unknown needed to add a question mark in nested get * smaller linting fixes * get nested fixes * small linting error fixes * small linting changes * working through more small linting changes * another round of linting modifications * liniting fixes * ember module codemod * quinit dom codemod * angle bracket codemod * discovered that components must have js files * ran all codemods this is all that's left * small changes to fix get needs two object, should not have been using get. * fix issue with one input in form field * fun times with set and onChange from oninput * fix issue with model not being passed through on secret-edit-display * fix issue with yarn run test not working, revert without npm run all * linting and small fix when loading without a selectAuthBackend * fix failing test with ui-wizard issue * fix test failure due to model not being asked for correctly with new changes, probably run into this more. * fix issue with component helper and at props specific to wizard * rename log to clilog due to conflict with new eslint rule * small changes for test failures * component helper at fixes * Revert to old component style something with new one broke this and can't figure it out for now * small fishy smelling test fixes will revisit * small test changes * more small test changes, appears upgrade treats spaces differently * comment out code and test that no longer seems relevant but confirm * clean run on component test though still some potential timing issues on ui-console test * fixing one auth test issue and timing issue on enable-test * small mods * fix this conditional check from upgrade * linting fixes after master merge * package updates using yarn upgrade-interactive * update libraries that did not effect any of the test failures. * update ember truth helpers library * settling tests * Fix ui-panel control group output * fix features selection test failures * Fix auth tests (x-vault-token) * fix shared test * fix issue with data null on backend * Revert "Fix auth tests (x-vault-token)" This reverts commit 89cb174b2f1998efa56d9604d14131415ae65d6f. * Fix auth tests (x-vault-token) without updating this.set * Update redirect-to tests * fix wrapped token test * skip some flaky test * fix issue with href and a tags vs buttons * fix linting * updates to get tests running (#10409) * yarn isntall * increasing resource_class * whoops * trying large * back to xlarge * Fix param issue on transform item routes * test fixes * settle on policies (old) test * fix browserstack test warning and skips of test confirmed worked * Fix redirect-to test * skips * fix transformation test and skip some kmip * Skip tests * Add meep marker to remaining failing tests * Skip test with failing component * rever skip on secret-create test * Skip piece of test that fails due to navigation-input * fix settings test where can and skip in others after confirming * fix circle ci test failures * ssh role settle * Fix navigate-input and add settled to test * Remove extra import * secret cubbyhole and alicloud * Add settled to gcpkms test * settles on redirect to test * Bump browserstack test resource to large * Update browserstack resource size to xlarge * update todos * add back in withTestWaiter * try and fix credentials conditional action added comment instead * Update volatile computed properies to get functions * this step was never reached and we never defined secretType anywhere so I removed * add settled to policy old test * Fix navigate-input on policies and leases * replace ssh test with no var hoping that helps and add settled to other failing tests, unskip console tests * kmip, transit, role test remove a skip and add in settled * fix hover copy button, had to remove some testing functionality * Remove private router service * remove skip on control ssh and ui panel, fix search select by restructuring how to read the error * final bit of working through skipped test * Replace clearNonGlobalModels by linking directly to namespace with href-to * Remove unused var * Fix role-ssh id bug by updating form-field-from-model to form-field-group-loop * Fix transit create id would not update * Update option toggle selector for ssh-role * Fix ssh selector * cleanup pt1 * small clean up * cleanup part2 * Fix computed on pricing-metrics-form * small cleanup based on chelseas comments. Co-authored-by: Chelsea Shaw <chelshaw.dev@gmail.com> Co-authored-by: Sarah Thompson <sthompson@hashicorp.com>
162 lines
6 KiB
Handlebars
162 lines
6 KiB
Handlebars
{{#if (or (eq policyType "acl") (has-feature "Sentinel"))}}
|
|
<PageHeader as |p|>
|
|
<p.levelLeft>
|
|
<h1 class="title is-3">
|
|
{{uppercase policyType}} Policies
|
|
{{#unless (eq policyType "acl")}}
|
|
<span class="tag" aria-label="Enforcement level: {{model.enforcementLevel}}">
|
|
Sentinel
|
|
</span>
|
|
{{/unless}}
|
|
</h1>
|
|
</p.levelLeft>
|
|
</PageHeader>
|
|
<Toolbar>
|
|
{{#if model.meta.total}}
|
|
<ToolbarFilters>
|
|
<NavigateInput
|
|
filterFocusDidChange={{action "setFilterFocus"}}
|
|
@filterDidChange={{action "setFilter"}}
|
|
@filter={{this.filter}}
|
|
@filterMatchesKey={{filterMatchesKey}}
|
|
@firstPartialMatch={{firstPartialMatch}}
|
|
@extraNavParams={{policyType}}
|
|
@placeholder="Filter policies"
|
|
@mode="policy"
|
|
/>
|
|
{{#if filterFocused}}
|
|
{{#if filterMatchesKey}}
|
|
<p class="input-hint">
|
|
<kbd>ENTER</kbd> to go to <code>{{or pageFilter filter}}</code>
|
|
</p>
|
|
{{/if}}
|
|
{{#if firstPartialMatch}}
|
|
<p class="input-hint">
|
|
<kbd>TAB</kbd> to complete <code>{{firstPartialMatch.id}}</code>
|
|
</p>
|
|
{{/if}}
|
|
{{/if}}
|
|
</ToolbarFilters>
|
|
{{/if}}
|
|
<ToolbarActions>
|
|
<ToolbarLink
|
|
@type="add"
|
|
@params={{array 'vault.cluster.policies.create'}}
|
|
@data-test-policy-create-link=true
|
|
>
|
|
Create {{uppercase policyType}} policy
|
|
</ToolbarLink>
|
|
</ToolbarActions>
|
|
</Toolbar>
|
|
{{#if model.meta.total}}
|
|
{{#each model as |item|}}
|
|
{{#if (eq item.id "root")}}
|
|
<div class="list-item-row is-flex" data-test-policy-item>
|
|
<Icon
|
|
aria-hidden="true"
|
|
class="has-text-grey-light"
|
|
@glyph="file-outline"
|
|
/>
|
|
<div>
|
|
<span class="has-text-weight-semibold has-text-grey" data-test-policy-name>
|
|
{{item.id}}
|
|
</span>
|
|
<p class="help has-text-grey">
|
|
The <code>root</code> policy does not contain any rules but can
|
|
do anything within Vault. It should be used with extreme care.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
{{else}}
|
|
{{#linked-block
|
|
"vault.cluster.policy.show"
|
|
policyType
|
|
item.id
|
|
class="list-item-row"
|
|
data-test-policy-link=item.id
|
|
}}
|
|
<div class="columns is-mobile">
|
|
<div class="column is-10">
|
|
<LinkTo @route="vault.cluster.policy.show" @models={{array policyType item.id}} class="has-text-black has-text-weight-semibold" data-test-policy-item={{true}}><Icon
|
|
aria-hidden="true"
|
|
class="has-text-grey-light"
|
|
@glyph="file-outline"
|
|
/><span class="is-underline" data-test-policy-name>{{item.id}}</span>
|
|
</LinkTo>
|
|
</div>
|
|
<div class="column has-text-right">
|
|
<PopupMenu name="policy-nav">
|
|
<Confirm as |c|>
|
|
<nav class="menu">
|
|
<ul class="menu-list">
|
|
{{#if item.updatePath.isPending}}
|
|
<li class="action">
|
|
<button disabled type="button" class="link button is-loading is-transparent">
|
|
loading
|
|
</button>
|
|
</li>
|
|
<li class="action">
|
|
<button disabled type="button" class="link button is-loading is-transparent">
|
|
loading
|
|
</button>
|
|
</li>
|
|
{{else}}
|
|
{{#if item.canRead}}
|
|
<li class="action">
|
|
<LinkTo @route="vault.cluster.policy.show" @models={{array policyType item.id}} data-test-policy-link="show">
|
|
Details
|
|
</LinkTo>
|
|
</li>
|
|
{{/if}}
|
|
{{#if item.canEdit}}
|
|
<li class="action">
|
|
<LinkTo @route="vault.cluster.policy.edit" @models={{array policyType item.id}} data-test-policy-link="edit">
|
|
Edit
|
|
</LinkTo>
|
|
</li>
|
|
{{/if}}
|
|
{{#if item.canDelete}}
|
|
<li class="action">
|
|
<c.Message
|
|
@id={{item.id}}
|
|
@confirmMessage="This will permanently delete this policy and may affect access to some data"
|
|
@onConfirm={{action "deletePolicy" item}}
|
|
data-test-policy-delete={{item.id}}/>
|
|
</li>
|
|
{{/if}}
|
|
{{/if}}
|
|
</ul>
|
|
</nav>
|
|
</Confirm>
|
|
</PopupMenu>
|
|
</div>
|
|
</div>
|
|
{{/linked-block}}
|
|
{{/if}}
|
|
{{else}}
|
|
<EmptyState
|
|
@title="No policies matching "{{pageFilter}}""
|
|
/>
|
|
{{/each}}
|
|
{{#if (gt model.meta.lastPage 1) }}
|
|
<ListPagination @page={{model.meta.currentPage}} @lastPage={{model.meta.lastPage}} @link="vault.cluster.policies.index" />
|
|
{{/if}}
|
|
{{else}}
|
|
<EmptyState
|
|
@title="No {{uppercase policyType}} policies yet"
|
|
@message="A list of policies will be listed here. Create your first {{uppercase policyType}} policy to get started."
|
|
>
|
|
<LinkTo @route="vault.cluster.policies.create" class="link">
|
|
Create {{uppercase policyType}} policy
|
|
<Chevron />
|
|
</LinkTo>
|
|
<LearnLink @path="/vault/getting-started/policies">
|
|
Learn more
|
|
<Chevron />
|
|
</LearnLink>
|
|
</EmptyState>
|
|
{{/if}}
|
|
{{else}}
|
|
<UpgradePage @title="Sentinel" @minimumEdition="Vault Enterprise Premium" />
|
|
{{/if}}
|