vault/ui/app/models/replication-attributes.js
hashicorp-copywrite[bot] 0b12cdcfd1
[COMPLIANCE] License changes (#22290)
* 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 https://hashi.co/bsl-blog, 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 BUS-1.1

* Fix test that expected exact offset on hcl file

---------

Co-authored-by: hashicorp-copywrite[bot] <110428419+hashicorp-copywrite[bot]@users.noreply.github.com>
Co-authored-by: Sarah Thompson <sthompson@hashicorp.com>
Co-authored-by: Brian Kassouf <bkassouf@hashicorp.com>
2023-08-10 18:14:03 -07:00

90 lines
2.6 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import Model, { attr } from '@ember-data/model';
import { match, not } from '@ember/object/computed';
import { computed } from '@ember/object';
export default Model.extend({
clusterId: attr('string'),
clusterIdDisplay: computed('clusterId', 'mode', function () {
const clusterId = this.clusterId;
return clusterId ? clusterId.split('-')[0] : null;
}),
mode: attr('string'),
replicationDisabled: match('mode', /disabled|unsupported/),
replicationUnsupported: match('mode', /unsupported/),
replicationEnabled: not('replicationDisabled'),
// primary attrs
isPrimary: match('mode', /primary/),
knownSecondaries: attr('array'),
secondaries: attr('array'),
// secondary attrs
isSecondary: match('mode', /secondary/),
connection_state: attr('string'),
modeForUrl: computed('isPrimary', 'isSecondary', 'mode', function () {
const mode = this.mode;
return mode === 'bootstrapping'
? 'bootstrapping'
: (this.isSecondary && 'secondary') || (this.isPrimary && 'primary');
}),
modeForHeader: computed('mode', function () {
const mode = this.mode;
if (!mode) {
// mode will be false or undefined if it calls the status endpoint while still setting up the cluster
return 'loading';
}
return mode;
}),
secondaryId: attr('string'),
primaryClusterAddr: attr('string'),
knownPrimaryClusterAddrs: attr('array'),
primaries: attr('array'),
state: attr('string'), //stream-wal, merkle-diff, merkle-sync, idle
lastRemoteWAL: attr('number'),
// attrs on primary and secondary
lastWAL: attr('number'),
merkleRoot: attr('string'),
merkleSyncProgress: attr('object'),
get syncProgress() {
const { state, merkleSyncProgress } = this;
if (state !== 'merkle-sync' || !merkleSyncProgress) {
return null;
}
const { sync_total_keys, sync_progress } = merkleSyncProgress;
return {
progress: sync_progress,
total: sync_total_keys,
};
},
syncProgressPercent: computed('syncProgress', function () {
const syncProgress = this.syncProgress;
if (!syncProgress) {
return null;
}
const { progress, total } = syncProgress;
return Math.floor(100 * (progress / total));
}),
modeDisplay: computed('mode', function () {
const displays = {
disabled: 'Disabled',
unknown: 'Unknown',
bootstrapping: 'Bootstrapping',
primary: 'Primary',
secondary: 'Secondary',
unsupported: 'Not supported',
};
return displays[this.mode] || 'Disabled';
}),
});