mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 06:44:41 +00:00
5fb9df1640
* Adding explicit MPL license for sub-package This directory and its subdirectories (packages) contain files licensed with the MPLv2 `LICENSE` file in this directory and are intentionally licensed separately from the BSL `LICENSE` file at the root of this repository. * Adding explicit MPL license for sub-package This directory and its subdirectories (packages) contain files licensed with the MPLv2 `LICENSE` file in this directory and are intentionally licensed separately from the BSL `LICENSE` file at the root of this repository. * Updating the license from MPL to Business Source License Going forward, this project will be licensed under the Business Source License v1.1. Please see our blog post for more details at <Blog URL>, FAQ at www.hashicorp.com/licensing-faq, and details of the license at www.hashicorp.com/bsl. * add missing license headers * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 * Update copyright file headers to BUSL-1.1 --------- Co-authored-by: hashicorp-copywrite[bot] <110428419+hashicorp-copywrite[bot]@users.noreply.github.com>
168 lines
4.8 KiB
JavaScript
168 lines
4.8 KiB
JavaScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import Mixin from '@ember/object/mixin';
|
|
import { inject as service } from '@ember/service';
|
|
import { set, get } from '@ember/object';
|
|
import { singularize } from 'ember-inflector';
|
|
|
|
/** With Blocking Actions
|
|
* This mixin contains common write actions (Create Update Delete) for routes.
|
|
* It could also be an Route to extend but decoration seems to be more sense right now.
|
|
*
|
|
* Each 'blocking action' (blocking in terms of showing some sort of blocking loader) is
|
|
* wrapped in the functionality to signal that the page should be blocked
|
|
* (currently via the 'feedback' service) as well as some reasonable default hooks for where the page
|
|
* should go when the action has finished.
|
|
*
|
|
* Hooks can and are being overwritten for custom redirects/error handling on a route by route basis.
|
|
*
|
|
* Notifications are part of the injectable 'feedback' service, meaning different ones
|
|
* could be easily swapped in an out as need be in the future.
|
|
*
|
|
*/
|
|
export default Mixin.create({
|
|
_feedback: service('feedback'),
|
|
settings: service('settings'),
|
|
init: function () {
|
|
this._super(...arguments);
|
|
const feedback = this._feedback;
|
|
const route = this;
|
|
set(this, 'feedback', {
|
|
execute: function (cb, type, error) {
|
|
const temp = route.routeName.split('.');
|
|
temp.pop();
|
|
const routeName = singularize(temp.pop());
|
|
|
|
return feedback.execute(cb, type, error, routeName);
|
|
},
|
|
});
|
|
},
|
|
afterCreate: function (item) {
|
|
// do the same as update
|
|
return this.afterUpdate(...arguments);
|
|
},
|
|
afterUpdate: function (item) {
|
|
// e.g. dc.intentions.index
|
|
const parts = this.routeName.split('.');
|
|
// e.g. index or edit
|
|
parts.pop();
|
|
// e.g. dc.intentions, essentially go to the listings page
|
|
return this.transitionTo(parts.join('.'));
|
|
},
|
|
afterDelete: function (item) {
|
|
// e.g. dc.intentions.index
|
|
const parts = this.routeName.split('.');
|
|
// e.g. index or edit
|
|
const page = parts.pop();
|
|
switch (page) {
|
|
case 'index':
|
|
// essentially if I'm on the index page, stay there
|
|
return this.refresh();
|
|
default:
|
|
// e.g. dc.intentions essentially do to the listings page
|
|
return this.transitionTo(parts.join('.'));
|
|
}
|
|
},
|
|
errorCreate: function (type, e) {
|
|
return type;
|
|
},
|
|
errorUpdate: function (type, e) {
|
|
return type;
|
|
},
|
|
errorDelete: function (type, e) {
|
|
return type;
|
|
},
|
|
actions: {
|
|
cancel: function () {
|
|
// do the same as an update, or override
|
|
return this.afterUpdate(...arguments);
|
|
},
|
|
create: function (item, event) {
|
|
event.preventDefault();
|
|
|
|
return this.feedback.execute(
|
|
() => {
|
|
return this.repo.persist(item).then((item) => {
|
|
return this.afterCreate(...arguments);
|
|
});
|
|
},
|
|
'create',
|
|
(type, e) => {
|
|
return this.errorCreate(type, e);
|
|
}
|
|
);
|
|
},
|
|
update: function (item, event) {
|
|
event.preventDefault();
|
|
|
|
return this.feedback.execute(
|
|
() => {
|
|
return this.repo.persist(item).then(() => {
|
|
return this.afterUpdate(...arguments);
|
|
});
|
|
},
|
|
'update',
|
|
(type, e) => {
|
|
return this.errorUpdate(type, e);
|
|
}
|
|
);
|
|
},
|
|
delete: function (item) {
|
|
return this.feedback.execute(
|
|
() => {
|
|
return this.repo.remove(item).then(() => {
|
|
return this.afterDelete(...arguments);
|
|
});
|
|
},
|
|
'delete',
|
|
(type, e) => {
|
|
return this.errorDelete(type, e);
|
|
}
|
|
);
|
|
},
|
|
use: function (item) {
|
|
return this.repo
|
|
.findBySlug({
|
|
dc: get(item, 'Datacenter'),
|
|
ns: get(item, 'Namespace'),
|
|
partition: get(item, 'Partition'),
|
|
id: get(item, 'AccessorID'),
|
|
})
|
|
.then((item) => {
|
|
return this.settings.persist({
|
|
token: {
|
|
AccessorID: get(item, 'AccessorID'),
|
|
SecretID: get(item, 'SecretID'),
|
|
Namespace: get(item, 'Namespace'),
|
|
Partition: get(item, 'Partition'),
|
|
},
|
|
});
|
|
});
|
|
},
|
|
logout: function (item) {
|
|
return this.settings.delete('token');
|
|
},
|
|
clone: function (item) {
|
|
let cloned;
|
|
return this.feedback.execute(() => {
|
|
return this.repo
|
|
.clone(item)
|
|
.then((item) => {
|
|
cloned = item;
|
|
// cloning is similar to delete in that
|
|
// if you clone from the listing page, stay on the listing page
|
|
// whereas if you clone from another token, take me back to the listing page
|
|
// so I can see it
|
|
return this.afterDelete(...arguments);
|
|
})
|
|
.then(function () {
|
|
return cloned;
|
|
});
|
|
}, 'clone');
|
|
},
|
|
},
|
|
});
|