be632db682
* runs ember-cli-update to 4.4.0 * updates yarn.lock * updates dependencies causing runtime errors (#17135) * Inject Store Service When Accessed Implicitly (#17345) * adds codemod for injecting store service * adds custom babylon parser with decorators-legacy plugin for jscodeshift transforms * updates inject-store-service codemod to only look for .extend object expressions and adds recast options * runs inject-store-service codemod on js files * replace query-params helper with hash (#17404) * Updates/removes dependencies throwing errors in Ember 4.4 (#17396) * updates ember-responsive to latest * updates ember-composable-helpers to latest and uses includes helper since contains was removed * updates ember-concurrency to latest * updates ember-cli-clipboard to latest * temporary workaround for toolbar-link component throwing errors for using params arg with LinkTo * adds missing store injection to auth configure route * fixes issue with string-list component throwing error for accessing prop in same computation * fixes non-iterable query params issue in mfa methods controller * refactors field-to-attrs to handle belongsTo rather than fragments * converts mount-config fragment to belongsTo on auth-method model * removes ember-api-actions and adds tune method to auth-method adapter * converts cluster replication attributes from fragment to relationship * updates ember-data, removes ember-data-fragments and updates yarn to latest * removes fragments from secret-engine model * removes fragment from test-form-model * removes commented out code * minor change to inject-store-service codemod and runs again on js files * Remove LinkTo positional params (#17421) * updates ember-cli-page-object to latest version * update toolbar-link to support link-to args and not positional params * adds replace arg to toolbar-link component * Clean up js lint errors (#17426) * replaces assert.equal to assert.strictEqual * update eslint no-console to error and disables invididual intended uses of console * cleans up hbs lint warnings (#17432) * Upgrade bug and test fixes (#17500) * updates inject-service codemod to take arg for service name and runs for flashMessages service * fixes hbs lint error after merging main * fixes flash messages * updates more deps * bug fixes * test fixes * updates ember-cli-content-security-policy and prevents default form submission throwing errors * more bug and test fixes * removes commented out code * fixes issue with code-mirror modifier sending change event on setup causing same computation error * Upgrade Clean Up (#17543) * updates deprecation workflow and filter * cleans up build errors, removes unused ivy-codemirror and sass and updates ember-cli-sass and node-sass to latest * fixes control groups test that was skipped after upgrade * updates control group service tests * addresses review feedback * updates control group service handleError method to use router.currentURL rather that transition.intent.url * adds changelog entry
60 lines
1.9 KiB
JavaScript
60 lines
1.9 KiB
JavaScript
import AdapterError from '@ember-data/adapter/error';
|
|
import AuthConfigComponent from './config';
|
|
import { inject as service } from '@ember/service';
|
|
import { task } from 'ember-concurrency';
|
|
import { waitFor } from '@ember/test-waiters';
|
|
|
|
/**
|
|
* @module AuthConfigForm/Options
|
|
* The `AuthConfigForm/Options` is options portion of the auth config form.
|
|
*
|
|
* @example
|
|
* ```js
|
|
* {{auth-config-form/options model.model}}
|
|
* ```
|
|
*
|
|
* @property model=null {DS.Model} - The corresponding auth model that is being configured.
|
|
*
|
|
*/
|
|
|
|
export default AuthConfigComponent.extend({
|
|
flashMessages: service(),
|
|
router: service(),
|
|
wizard: service(),
|
|
|
|
saveModel: task(
|
|
waitFor(function* () {
|
|
let data = this.model.config.serialize();
|
|
data.description = this.model.description;
|
|
|
|
// token_type should not be tuneable for the token auth method, default is 'default-service'
|
|
if (this.model.type === 'token') {
|
|
delete data.token_type;
|
|
}
|
|
|
|
try {
|
|
yield this.model.tune(data);
|
|
} catch (err) {
|
|
// AdapterErrors are handled by the error-message component
|
|
// in the form
|
|
if (err instanceof AdapterError === false) {
|
|
throw err;
|
|
}
|
|
// because we're not calling model.save the model never updates with
|
|
// the error. Forcing the error message by manually setting the errorMessage
|
|
try {
|
|
this.model.set('errorMessage', err.errors.firstObject);
|
|
} catch {
|
|
// do nothing
|
|
}
|
|
return;
|
|
}
|
|
if (this.wizard.currentMachine === 'authentication' && this.wizard.featureState === 'config') {
|
|
this.wizard.transitionFeatureMachine(this.wizard.featureState, 'CONTINUE');
|
|
}
|
|
this.router.transitionTo('vault.cluster.access.methods').followRedirects();
|
|
this.flashMessages.success('The configuration was saved successfully.');
|
|
})
|
|
),
|
|
});
|