2018-09-25 16:28:26 +00:00
|
|
|
import { isBlank, isNone } from '@ember/utils';
|
|
|
|
import { inject as service } from '@ember/service';
|
|
|
|
import Component from '@ember/component';
|
2018-10-17 04:23:29 +00:00
|
|
|
import { computed, set } from '@ember/object';
|
2018-10-19 22:24:57 +00:00
|
|
|
import { alias, or } from '@ember/object/computed';
|
2018-10-06 03:05:53 +00:00
|
|
|
import { task, waitForEvent } from 'ember-concurrency';
|
2018-04-03 14:16:57 +00:00
|
|
|
import FocusOnInsertMixin from 'vault/mixins/focus-on-insert';
|
2018-12-20 19:46:37 +00:00
|
|
|
import WithNavToNearestAncestor from 'vault/mixins/with-nav-to-nearest-ancestor';
|
2018-04-03 14:16:57 +00:00
|
|
|
import keys from 'vault/lib/keycodes';
|
|
|
|
import KVObject from 'vault/lib/kv-object';
|
2018-10-16 21:08:31 +00:00
|
|
|
import { maybeQueryRecord } from 'vault/macros/maybe-query-record';
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
const LIST_ROUTE = 'vault.cluster.secrets.backend.list';
|
|
|
|
const LIST_ROOT_ROUTE = 'vault.cluster.secrets.backend.list-root';
|
|
|
|
const SHOW_ROUTE = 'vault.cluster.secrets.backend.show';
|
|
|
|
|
2018-12-20 19:46:37 +00:00
|
|
|
export default Component.extend(FocusOnInsertMixin, WithNavToNearestAncestor, {
|
2018-09-25 16:28:26 +00:00
|
|
|
wizard: service(),
|
|
|
|
router: service(),
|
2018-10-09 04:21:02 +00:00
|
|
|
store: service(),
|
2018-11-12 16:27:06 +00:00
|
|
|
flashMessages: service(),
|
2018-09-25 16:28:26 +00:00
|
|
|
|
2018-04-03 14:16:57 +00:00
|
|
|
// a key model
|
|
|
|
key: null,
|
2018-10-06 03:05:53 +00:00
|
|
|
model: null,
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
// a value to pre-fill the key input - this is populated by the corresponding
|
|
|
|
// 'initialKey' queryParam
|
|
|
|
initialKey: null,
|
|
|
|
|
|
|
|
// set in the route's setupController hook
|
|
|
|
mode: null,
|
|
|
|
|
|
|
|
secretData: null,
|
|
|
|
|
2018-11-12 16:27:06 +00:00
|
|
|
wrappedData: null,
|
|
|
|
isWrapping: false,
|
|
|
|
showWrapButton: computed.not('wrappedData'),
|
|
|
|
|
2018-04-03 14:16:57 +00:00
|
|
|
// called with a bool indicating if there's been a change in the secretData
|
2018-09-25 16:28:26 +00:00
|
|
|
onDataChange() {},
|
|
|
|
onRefresh() {},
|
|
|
|
onToggleAdvancedEdit() {},
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
// did user request advanced mode
|
|
|
|
preferAdvancedEdit: false,
|
|
|
|
|
|
|
|
// use a named action here so we don't have to pass one in
|
|
|
|
// this will bubble to the route
|
|
|
|
toggleAdvancedEdit: 'toggleAdvancedEdit',
|
2018-09-05 16:07:39 +00:00
|
|
|
error: null,
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
codemirrorString: null,
|
|
|
|
|
|
|
|
hasLintError: false,
|
2018-10-06 03:05:53 +00:00
|
|
|
isV2: false,
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
init() {
|
|
|
|
this._super(...arguments);
|
2018-10-06 03:05:53 +00:00
|
|
|
let secrets = this.model.secretData;
|
|
|
|
if (!secrets && this.model.selectedVersion) {
|
|
|
|
this.set('isV2', true);
|
|
|
|
secrets = this.model.belongsTo('selectedVersion').value().secretData;
|
|
|
|
}
|
2018-04-03 14:16:57 +00:00
|
|
|
const data = KVObject.create({ content: [] }).fromJSON(secrets);
|
|
|
|
this.set('secretData', data);
|
|
|
|
this.set('codemirrorString', data.toJSONString());
|
|
|
|
if (data.isAdvanced()) {
|
|
|
|
this.set('preferAdvancedEdit', true);
|
|
|
|
}
|
|
|
|
this.checkRows();
|
2018-10-08 18:20:55 +00:00
|
|
|
if (this.wizard.featureState === 'details' && this.mode === 'create') {
|
|
|
|
let engine = this.model.backend.includes('kv') ? 'kv' : this.model.backend;
|
|
|
|
this.wizard.transitionFeatureMachine('details', 'CONTINUE', engine);
|
2018-08-28 05:03:55 +00:00
|
|
|
}
|
|
|
|
|
2018-10-06 03:05:53 +00:00
|
|
|
if (this.mode === 'edit') {
|
2018-04-03 14:16:57 +00:00
|
|
|
this.send('addRow');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-10-06 03:05:53 +00:00
|
|
|
waitForKeyUp: task(function*() {
|
|
|
|
while (true) {
|
|
|
|
let event = yield waitForEvent(document.body, 'keyup');
|
|
|
|
this.onEscape(event);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.on('didInsertElement')
|
|
|
|
.cancelOn('willDestroyElement'),
|
|
|
|
|
2018-09-25 16:28:26 +00:00
|
|
|
partialName: computed('mode', function() {
|
2018-10-08 18:20:55 +00:00
|
|
|
return `partials/secret-form-${this.mode}`;
|
2018-04-03 14:16:57 +00:00
|
|
|
}),
|
|
|
|
|
2018-10-16 21:08:31 +00:00
|
|
|
updatePath: maybeQueryRecord(
|
2018-10-09 04:21:02 +00:00
|
|
|
'capabilities',
|
|
|
|
context => {
|
2019-06-20 13:37:27 +00:00
|
|
|
if (!context.model || context.mode === 'create') {
|
2018-10-16 21:08:31 +00:00
|
|
|
return;
|
2018-10-09 04:21:02 +00:00
|
|
|
}
|
2018-10-18 18:03:05 +00:00
|
|
|
let backend = context.isV2 ? context.get('model.engine.id') : context.model.backend;
|
2018-10-09 04:21:02 +00:00
|
|
|
let id = context.model.id;
|
|
|
|
let path = context.isV2 ? `${backend}/data/${id}` : `${backend}/${id}`;
|
|
|
|
return {
|
|
|
|
id: path,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'isV2',
|
|
|
|
'model',
|
|
|
|
'model.id',
|
|
|
|
'mode'
|
|
|
|
),
|
2018-12-03 14:22:13 +00:00
|
|
|
canDelete: alias('model.canDelete'),
|
2018-10-09 04:21:02 +00:00
|
|
|
canEdit: alias('updatePath.canUpdate'),
|
|
|
|
|
2018-10-16 21:08:31 +00:00
|
|
|
v2UpdatePath: maybeQueryRecord(
|
2018-10-15 14:38:05 +00:00
|
|
|
'capabilities',
|
|
|
|
context => {
|
2019-06-20 13:37:27 +00:00
|
|
|
if (!context.model || context.mode === 'create' || context.isV2 === false) {
|
2018-10-16 21:08:31 +00:00
|
|
|
return;
|
2018-10-15 14:38:05 +00:00
|
|
|
}
|
2018-10-18 18:03:05 +00:00
|
|
|
let backend = context.get('model.engine.id');
|
2018-10-15 14:38:05 +00:00
|
|
|
let id = context.model.id;
|
|
|
|
return {
|
|
|
|
id: `${backend}/metadata/${id}`,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
'isV2',
|
|
|
|
'model',
|
|
|
|
'model.id',
|
|
|
|
'mode'
|
|
|
|
),
|
2018-10-16 21:08:31 +00:00
|
|
|
canEditV2Secret: alias('v2UpdatePath.canUpdate'),
|
2018-10-15 14:38:05 +00:00
|
|
|
|
2018-10-06 03:05:53 +00:00
|
|
|
requestInFlight: or('model.isLoading', 'model.isReloading', 'model.isSaving'),
|
2018-04-03 14:16:57 +00:00
|
|
|
|
2019-01-10 16:37:25 +00:00
|
|
|
buttonDisabled: or('requestInFlight', 'model.isFolder', 'model.flagsIsInvalid', 'hasLintError', 'error'),
|
2018-04-03 14:16:57 +00:00
|
|
|
|
2018-10-06 03:05:53 +00:00
|
|
|
modelForData: computed('isV2', 'model', function() {
|
2019-06-20 13:37:27 +00:00
|
|
|
let { model } = this;
|
|
|
|
if (!model) return null;
|
|
|
|
return this.isV2 ? model.belongsTo('selectedVersion').value() : model;
|
2018-10-06 03:05:53 +00:00
|
|
|
}),
|
|
|
|
|
2018-04-03 14:16:57 +00:00
|
|
|
basicModeDisabled: computed('secretDataIsAdvanced', 'showAdvancedMode', function() {
|
2018-10-06 03:05:53 +00:00
|
|
|
return this.secretDataIsAdvanced || this.showAdvancedMode === false;
|
2018-04-03 14:16:57 +00:00
|
|
|
}),
|
|
|
|
|
|
|
|
secretDataAsJSON: computed('secretData', 'secretData.[]', function() {
|
2018-10-06 03:05:53 +00:00
|
|
|
return this.secretData.toJSON();
|
2018-04-03 14:16:57 +00:00
|
|
|
}),
|
|
|
|
|
|
|
|
secretDataIsAdvanced: computed('secretData', 'secretData.[]', function() {
|
2018-10-06 03:05:53 +00:00
|
|
|
return this.secretData.isAdvanced();
|
2018-04-03 14:16:57 +00:00
|
|
|
}),
|
|
|
|
|
|
|
|
showAdvancedMode: computed('preferAdvancedEdit', 'secretDataIsAdvanced', 'lastChange', function() {
|
2018-10-06 03:05:53 +00:00
|
|
|
return this.secretDataIsAdvanced || this.preferAdvancedEdit;
|
2018-04-03 14:16:57 +00:00
|
|
|
}),
|
|
|
|
|
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
|
|
|
isWriteWithoutRead: computed('model.failedServerRead', 'modelForData.failedServerRead', 'isV2', function() {
|
|
|
|
if (!this.model) return;
|
|
|
|
// if the version couldn't be read from the server
|
|
|
|
if (this.isV2 && this.modelForData.failedServerRead) {
|
|
|
|
return true;
|
2019-04-16 20:27:23 +00:00
|
|
|
}
|
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
|
|
|
// if the model couldn't be read from the server
|
|
|
|
if (!this.isV2 && this.model.failedServerRead) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}),
|
2019-04-16 20:27:23 +00:00
|
|
|
|
2018-04-03 14:16:57 +00:00
|
|
|
transitionToRoute() {
|
2018-12-20 19:46:37 +00:00
|
|
|
return this.router.transitionTo(...arguments);
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
onEscape(e) {
|
2018-10-06 03:05:53 +00:00
|
|
|
if (e.keyCode !== keys.ESC || this.mode !== 'show') {
|
2018-04-03 14:16:57 +00:00
|
|
|
return;
|
|
|
|
}
|
2018-10-06 03:05:53 +00:00
|
|
|
const parentKey = this.model.parentKey;
|
2018-04-03 14:16:57 +00:00
|
|
|
if (parentKey) {
|
|
|
|
this.transitionToRoute(LIST_ROUTE, parentKey);
|
|
|
|
} else {
|
|
|
|
this.transitionToRoute(LIST_ROOT_ROUTE);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// successCallback is called in the context of the component
|
2018-10-06 03:05:53 +00:00
|
|
|
persistKey(successCallback) {
|
2018-10-15 14:38:05 +00:00
|
|
|
let secret = this.model;
|
2018-12-03 14:22:13 +00:00
|
|
|
let secretData = this.modelForData;
|
2018-10-15 14:38:05 +00:00
|
|
|
let isV2 = this.isV2;
|
2018-12-03 14:22:13 +00:00
|
|
|
let key = secretData.get('path') || secret.id;
|
2018-05-29 19:48:55 +00:00
|
|
|
|
|
|
|
if (key.startsWith('/')) {
|
|
|
|
key = key.replace(/^\/+/g, '');
|
2018-12-03 14:22:13 +00:00
|
|
|
secretData.set(secretData.pathAttr, key);
|
2018-04-03 14:16:57 +00:00
|
|
|
}
|
|
|
|
|
2018-12-03 14:22:13 +00:00
|
|
|
return secretData.save().then(() => {
|
|
|
|
if (!secretData.isError) {
|
|
|
|
if (isV2) {
|
2018-10-17 02:42:29 +00:00
|
|
|
secret.set('id', key);
|
2018-12-03 14:22:13 +00:00
|
|
|
}
|
|
|
|
if (isV2 && Object.keys(secret.changedAttributes()).length) {
|
2018-10-15 14:38:05 +00:00
|
|
|
// save secret metadata
|
|
|
|
secret
|
|
|
|
.save()
|
|
|
|
.then(() => {
|
|
|
|
this.saveComplete(successCallback, key);
|
|
|
|
})
|
|
|
|
.catch(e => {
|
|
|
|
this.set(e, e.errors.join(' '));
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.saveComplete(successCallback, key);
|
2018-08-28 05:03:55 +00:00
|
|
|
}
|
2018-04-03 14:16:57 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2018-10-15 14:38:05 +00:00
|
|
|
saveComplete(callback, key) {
|
|
|
|
if (this.wizard.featureState === 'secret') {
|
|
|
|
this.wizard.transitionFeatureMachine('secret', 'CONTINUE');
|
|
|
|
}
|
|
|
|
callback(key);
|
|
|
|
},
|
2018-04-03 14:16:57 +00:00
|
|
|
|
|
|
|
checkRows() {
|
2018-10-06 03:05:53 +00:00
|
|
|
if (this.secretData.length === 0) {
|
2018-04-03 14:16:57 +00:00
|
|
|
this.send('addRow');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
actions: {
|
2018-10-06 03:05:53 +00:00
|
|
|
//submit on shift + enter
|
2018-06-14 18:52:00 +00:00
|
|
|
handleKeyDown(e) {
|
2018-04-03 14:16:57 +00:00
|
|
|
e.stopPropagation();
|
|
|
|
if (!(e.keyCode === keys.ENTER && e.metaKey)) {
|
|
|
|
return;
|
|
|
|
}
|
2018-10-06 03:05:53 +00:00
|
|
|
let $form = this.element.querySelector('form');
|
2018-04-03 14:16:57 +00:00
|
|
|
if ($form.length) {
|
|
|
|
$form.submit();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
handleChange() {
|
2018-10-06 03:05:53 +00:00
|
|
|
this.set('codemirrorString', this.secretData.toJSONString(true));
|
2018-10-17 04:23:29 +00:00
|
|
|
set(this.modelForData, 'secretData', this.secretData.toJSON());
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
2018-11-12 16:27:06 +00:00
|
|
|
handleWrapClick() {
|
|
|
|
this.set('isWrapping', true);
|
|
|
|
if (this.isV2) {
|
|
|
|
this.store
|
|
|
|
.adapterFor('secret-v2-version')
|
|
|
|
.queryRecord(this.modelForData.id, { wrapTTL: 1800 })
|
|
|
|
.then(resp => {
|
|
|
|
this.set('wrappedData', resp.wrap_info.token);
|
|
|
|
this.flashMessages.success('Secret Successfully Wrapped!');
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
this.flashMessages.error('Could Not Wrap Secret');
|
|
|
|
})
|
|
|
|
.finally(() => {
|
|
|
|
this.set('isWrapping', false);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.store
|
|
|
|
.adapterFor('secret')
|
|
|
|
.queryRecord(null, null, { backend: this.model.backend, id: this.modelForData.id, wrapTTL: 1800 })
|
|
|
|
.then(resp => {
|
|
|
|
this.set('wrappedData', resp.wrap_info.token);
|
|
|
|
this.flashMessages.success('Secret Successfully Wrapped!');
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
this.flashMessages.error('Could Not Wrap Secret');
|
|
|
|
})
|
|
|
|
.finally(() => {
|
|
|
|
this.set('isWrapping', false);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
clearWrappedData() {
|
|
|
|
this.set('wrappedData', null);
|
|
|
|
},
|
|
|
|
|
|
|
|
handleCopySuccess() {
|
|
|
|
this.flashMessages.success('Copied Wrapped Data!');
|
|
|
|
this.send('clearWrappedData');
|
|
|
|
},
|
|
|
|
|
|
|
|
handleCopyError() {
|
|
|
|
this.flashMessages.error('Could Not Copy Wrapped Data');
|
|
|
|
this.send('clearWrappedData');
|
|
|
|
},
|
|
|
|
|
2018-04-03 14:16:57 +00:00
|
|
|
createOrUpdateKey(type, event) {
|
|
|
|
event.preventDefault();
|
2018-10-16 21:08:31 +00:00
|
|
|
let model = this.modelForData;
|
2018-04-03 14:16:57 +00:00
|
|
|
// prevent from submitting if there's no key
|
|
|
|
// maybe do something fancier later
|
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
|
|
|
if (type === 'create' && isBlank(model.path || model.id)) {
|
2018-04-03 14:16:57 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-12-03 14:22:13 +00:00
|
|
|
this.persistKey(() => {
|
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
|
|
|
this.transitionToRoute(SHOW_ROUTE, this.model.path || this.model.id);
|
2018-10-06 03:05:53 +00:00
|
|
|
});
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
deleteKey() {
|
2018-12-20 19:46:37 +00:00
|
|
|
let { id } = this.model;
|
2018-10-06 03:05:53 +00:00
|
|
|
this.model.destroyRecord().then(() => {
|
2018-12-20 19:46:37 +00:00
|
|
|
this.navToNearestAncestor.perform(id);
|
2018-04-03 14:16:57 +00:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
refresh() {
|
2018-10-06 03:05:53 +00:00
|
|
|
this.onRefresh();
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
addRow() {
|
2018-10-06 03:05:53 +00:00
|
|
|
const data = this.secretData;
|
2018-09-25 16:28:26 +00:00
|
|
|
if (isNone(data.findBy('name', ''))) {
|
2018-04-03 14:16:57 +00:00
|
|
|
data.pushObject({ name: '', value: '' });
|
2018-10-15 14:38:05 +00:00
|
|
|
this.send('handleChange');
|
2018-04-03 14:16:57 +00:00
|
|
|
}
|
|
|
|
this.checkRows();
|
|
|
|
},
|
|
|
|
|
|
|
|
deleteRow(name) {
|
2018-10-06 03:05:53 +00:00
|
|
|
const data = this.secretData;
|
2018-04-03 14:16:57 +00:00
|
|
|
const item = data.findBy('name', name);
|
2018-09-25 16:28:26 +00:00
|
|
|
if (isBlank(item.name)) {
|
2018-04-03 14:16:57 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
data.removeObject(item);
|
|
|
|
this.checkRows();
|
2018-10-15 14:38:05 +00:00
|
|
|
this.send('handleChange');
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
toggleAdvanced(bool) {
|
2018-10-06 03:05:53 +00:00
|
|
|
this.onToggleAdvancedEdit(bool);
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
codemirrorUpdated(val, codemirror) {
|
2018-09-05 16:07:39 +00:00
|
|
|
this.set('error', null);
|
2018-04-03 14:16:57 +00:00
|
|
|
codemirror.performLint();
|
|
|
|
const noErrors = codemirror.state.lint.marked.length === 0;
|
|
|
|
if (noErrors) {
|
2018-09-05 16:07:39 +00:00
|
|
|
try {
|
2018-10-06 03:05:53 +00:00
|
|
|
this.secretData.fromJSONString(val);
|
2018-10-31 22:37:23 +00:00
|
|
|
set(this.modelForData, 'secretData', this.secretData.toJSON());
|
2018-09-05 16:07:39 +00:00
|
|
|
} catch (e) {
|
|
|
|
this.set('error', e.message);
|
|
|
|
}
|
2018-04-03 14:16:57 +00:00
|
|
|
}
|
|
|
|
this.set('hasLintError', !noErrors);
|
|
|
|
this.set('codemirrorString', val);
|
|
|
|
},
|
|
|
|
|
|
|
|
formatJSON() {
|
2018-10-06 03:05:53 +00:00
|
|
|
this.set('codemirrorString', this.secretData.toJSONString(true));
|
2018-04-03 14:16:57 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|