mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-22 07:01:09 +02:00
* Allow Managed clusters to see Secrets Sync Overview and Sidebar nav (#26649) * update badge text and allow hvd on secrets sync views * update logic in Secrets Sync overview and cta for hvd. * spacing * rearrange based on pr feedback * fix return on badgeText and cluster nav test * fix landing cta tests * update test to reflect new changes * moved call to feature-flags from application route to the service to match patterns * add managed test coverage on overview component test and remove premium feature so cta message appplies to both managed and non-managed clusters * missed service name and unskip admin test * clean up * fix tests * flags test fix * Rename isManaged and managedNamespaceRoot (#26697) * renames * lowercase HVD to match * missed some * test failure * [Secrets Sync] enable access to Sync clients page for HVD clusters (#26713) * feat: split client counts navbar into separate component * acceptance/clients/counts/overview-test: remove tests now covered by int tests * clients counts route: rename isSecretsSyncActivated to showSecretsSync * sync clients page: show unactivated state unless sync client history or feature is activated * client counts navbar: show sync tab only if client history or is /able to be/ activated * clients overview page: only show sync charts if activated * fix: rename isManaged to isHvd * acceptance/counts/overview-test: add HVD tests * acceptance/counts/overview-test: clean up unused cruft * aceptance/clients/counts/overview-test: ensure we dont get false negatives * chore: move Clients::Error to Clients::Counts::Error * chore: calculate showSecretSync in page component instead of route * chore: add copyright headers * acceptance/clients/counts/overview-test: stub activated flags to fix test * [Secrets sync] update sync test selectors (#26824) * acceptance/clients/counts/overview-test: use imported test selectors * general-selectors: add missing emptyStateSubtitle property * acceptance/clients/counts/sync: nest tests in top level module for easier test runs * Add permissions check to show/hide activate button (#26840) * add permissions check to flags service and consume in overview template * add back missing refresh * fix test failures * add test coverage * clean up * address flaky test * grr * address test failures * add changelog * try to fix test failure only on gh * fix fetch to match previous implementation of feature-flags * fix failing test * update comment --------- Co-authored-by: Noelle Daley <noelledaley@users.noreply.github.com> Co-authored-by: clairebontempo@gmail.com <clairebontempo@gmail.com>
95 lines
3.3 KiB
TypeScript
95 lines
3.3 KiB
TypeScript
/**
|
|
* Copyright (c) HashiCorp, Inc.
|
|
* SPDX-License-Identifier: BUSL-1.1
|
|
*/
|
|
|
|
import Component from '@glimmer/component';
|
|
import { tracked } from '@glimmer/tracking';
|
|
import { service } from '@ember/service';
|
|
import { task } from 'ember-concurrency';
|
|
import { waitFor } from '@ember/test-waiters';
|
|
import { action } from '@ember/object';
|
|
import errorMessage from 'vault/utils/error-message';
|
|
import Ember from 'ember';
|
|
|
|
import type FlashMessageService from 'vault/services/flash-messages';
|
|
import type StoreService from 'vault/services/store';
|
|
import type RouterService from '@ember/routing/router-service';
|
|
import type VersionService from 'vault/services/version';
|
|
import type FlagsService from 'vault/services/flags';
|
|
import type { SyncDestinationAssociationMetrics } from 'vault/vault/adapters/sync/association';
|
|
import type SyncDestinationModel from 'vault/vault/models/sync/destination';
|
|
|
|
interface Args {
|
|
destinations: Array<SyncDestinationModel>;
|
|
totalVaultSecrets: number;
|
|
isActivated: boolean;
|
|
licenseHasSecretsSync: boolean;
|
|
isHvdManaged: boolean;
|
|
}
|
|
|
|
export default class SyncSecretsDestinationsPageComponent extends Component<Args> {
|
|
@service declare readonly flashMessages: FlashMessageService;
|
|
@service declare readonly store: StoreService;
|
|
@service declare readonly router: RouterService;
|
|
@service declare readonly version: VersionService;
|
|
@service declare readonly flags: FlagsService;
|
|
|
|
@tracked destinationMetrics: SyncDestinationAssociationMetrics[] = [];
|
|
@tracked page = 1;
|
|
@tracked showActivateSecretsSyncModal = false;
|
|
@tracked hasConfirmedDocs = false;
|
|
@tracked error = null;
|
|
// eventually remove when we deal with permissions on activation-features
|
|
@tracked hideOptIn = false;
|
|
@tracked hideError = false;
|
|
|
|
pageSize = Ember.testing ? 3 : 5; // lower in tests to test pagination without seeding more data
|
|
|
|
constructor(owner: unknown, args: Args) {
|
|
super(owner, args);
|
|
if (this.args.destinations.length) {
|
|
this.fetchAssociationsForDestinations.perform();
|
|
}
|
|
}
|
|
|
|
fetchAssociationsForDestinations = task(this, {}, async (page = 1) => {
|
|
try {
|
|
const total = page * this.pageSize;
|
|
const paginatedDestinations = this.args.destinations.slice(total - this.pageSize, total);
|
|
this.destinationMetrics = await this.store
|
|
.adapterFor('sync/association')
|
|
.fetchByDestinations(paginatedDestinations);
|
|
this.page = page;
|
|
} catch (error) {
|
|
this.destinationMetrics = [];
|
|
}
|
|
});
|
|
|
|
@action
|
|
resetOptInModal() {
|
|
this.showActivateSecretsSyncModal = false;
|
|
this.hasConfirmedDocs = false;
|
|
}
|
|
|
|
@task
|
|
@waitFor
|
|
*onFeatureConfirm() {
|
|
// must return null instead of root for non managed cluster.
|
|
// child namespaces are not sent.
|
|
const namespace = this.args.isHvdManaged ? 'admin' : null;
|
|
try {
|
|
yield this.store
|
|
.adapterFor('application')
|
|
.ajax('/v1/sys/activation-flags/secrets-sync/activate', 'POST', { namespace });
|
|
// must refresh and not transition because transition does not refresh the model from within a namespace
|
|
yield this.router.refresh();
|
|
} catch (error) {
|
|
this.error = errorMessage(error);
|
|
this.flashMessages.danger(`Error enabling feature \n ${errorMessage(error)}`);
|
|
} finally {
|
|
this.resetOptInModal();
|
|
}
|
|
}
|
|
}
|