Skip to content

Commit

Permalink
Bug: Fix issue with double encoding on space in secret history route (#…
Browse files Browse the repository at this point in the history
…10596)

* setup for concept it works, but probably not the best solution

* add comment and remove console and test var

* use normalize path higher up to fix issu

* add test for bug that fixing

* forgot a couple of changes

* changelog
  • Loading branch information
Monkeychip authored Jan 4, 2021
1 parent 90377ad commit 702929e
Show file tree
Hide file tree
Showing 6 changed files with 42 additions and 4 deletions.
4 changes: 4 additions & 0 deletions changelog/10596.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
```release-note:bug
ui: Fix bug that double encodes secret route when there are spaces in the path and makes you unable to view the version history.
```

4 changes: 3 additions & 1 deletion ui/app/routes/vault/cluster/secrets/backend/versions.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import Route from '@ember/routing/route';
import utils from 'vault/lib/key-utils';
import UnloadModelRoute from 'vault/mixins/unload-model-route';
import { normalizePath } from 'vault/utils/path-encoding-helpers';

export default Route.extend(UnloadModelRoute, {
templateName: 'vault/cluster/secrets/backend/versions',
Expand All @@ -22,6 +23,7 @@ export default Route.extend(UnloadModelRoute, {
model(params) {
let { secret } = params;
const { backend } = this.paramsFor('vault.cluster.secrets.backend');
return this.store.queryRecord('secret-v2', { id: secret, backend });
let id = normalizePath(secret);
return this.store.queryRecord('secret-v2', { id, backend });
},
});
3 changes: 2 additions & 1 deletion ui/app/templates/components/secret-edit.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@
as |D|
>
<D.trigger
data-test-popup-menu-trigger="true"
data-test-popup-menu-trigger="history"
@class={{concat "popup-menu-trigger toolbar-link" (if D.isOpen " is-active")}}
@tagName="button"
>
Expand All @@ -56,6 +56,7 @@
<ul class="menu-list">
<li class="action">
<SecretLink
@data-test-version-history
@mode="versions"
@secret={{this.model.id}}
@class="has-text-black has-text-weight-semibold has-bottom-shadow"
Expand Down
2 changes: 2 additions & 0 deletions ui/app/templates/components/secret-link.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
data-test-transit-link=data-test-transit-link
data-test-transit-key-actions-link=data-test-transit-key-actions-link
data-test-transit-action-link=data-test-transit-action-link
data-test-version-history=data-test-version-history
data-test-version=data-test-version
invokeAction=(action onLinkClick)
}}
{{yield}}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@
<SecretVersionMenu @version={{list.item}} @useDefaultTrigger={{true}}>
<li class="action">
<SecretLink
@data-test-version
@mode="show"
@secret={{model.id}}
@class="has-text-black has-text-weight-semibold"
Expand Down
32 changes: 30 additions & 2 deletions ui/tests/acceptance/secrets/backend/kv/secret-test.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { visit, settled, currentURL, currentRouteName } from '@ember/test-helpers';
import { click, visit, settled, currentURL, currentRouteName } from '@ember/test-helpers';
import { create } from 'ember-cli-page-object';
import { module, test } from 'qunit';
import { setupApplicationTest } from 'ember-qunit';
Expand All @@ -20,7 +20,7 @@ let writeSecret = async function(backend, path, key, val) {
return editPage.createSecret(path, key, val);
};

module('Acceptance | secrets/secret/create meep', function(hooks) {
module('Acceptance | secrets/secret/create', function(hooks) {
setupApplicationTest(hooks);

hooks.beforeEach(async function() {
Expand Down Expand Up @@ -288,6 +288,34 @@ module('Acceptance | secrets/secret/create meep', function(hooks) {
}
});

test('create secret with space shows version data', async function(assert) {
let enginePath = `kv-${new Date().getTime()}`;
let secretPath = 'space space';
// mount version 2
await mountSecrets.visit();
await mountSecrets.selectType('kv');
await mountSecrets
.next()
.path(enginePath)
.submit();
await settled();
await listPage.create();
await editPage.createSecret(secretPath, 'foo', 'bar');
await settled();
await click('[data-test-popup-menu-trigger="history"]');
await settled();
await click('[data-test-version-history]');
await settled();
assert.dom('[data-test-list-item-content]').exists('renders the version and not an error state');
// click on version
await click('[data-test-popup-menu-trigger="true"]');
await click('[data-test-version]');
await settled();
// perform encode function that should be done by the encodePath
let encodedSecretPath = secretPath.replace(/ /g, '%20');
assert.equal(currentURL(), `/vault/secrets/${enginePath}/show/${encodedSecretPath}?version=1`);
});

// the web cli does not handle a quote as part of a path, so we test it here via the UI
test('creating a secret with a single or double quote works properly', async function(assert) {
await consoleComponent.runCommands('write sys/mounts/kv type=kv');
Expand Down

0 comments on commit 702929e

Please sign in to comment.