vault/ui/app/services/flags.ts
Vault Automation 5d869440c3
[UI] Ember Data Migration - Client Counts (#12026) (#12132)
* updates flags service to use api service

* converts clients index route to ts

* updates clients config workflows to use api service

* updates clients date-range component to handle Date objects rather than ISO strings

* updates clients page-header component to handle Date objects and use api and capabilities services

* updates clients route to use api and capabilities services

* updates types in client-counts helpers

* updates client counts route to use api service

* updates types for client-counts serializers

* updates date handling in client counts page component

* updates clients overview page component

* converts clients page-header component to ts

* fixes type errors in clients page-header component

* updates client counts tests

* updates client-count-card component to use api service

* converts client-count-card component to ts

* removes model-form-fields test that uses clients/config model

* removes clients/version-history model usage from client-counts helpers tests

* removes migrated models from adapter and model registries

* removes clients ember data models, adapters and serializers

* updates clients date-range component to format dates in time zone

* cleans up references to activityError in client counts route

* adds clients/activity mirage model

* updates activation flags assertions in sync overview tests

* fixes issue selecting current period in clients date-range component and adds test

* fixes issues with enabled state for client counts

* updates parseAPITimestamp to handle date object formatting

* removes unnecesarry type casting for format return in parseAPITimestamp util

* updates parseAPITimestamp to use formatInTimeZone for strings

* updates parseAPITimestamp comment

* updates enabled value in clients config component to boolean

* adds date-fns-tz to core addon

* removes parseISO from date-formatters util in favor of new Date

* updates comments for client counts

* updates retention months validation for client counts config

* updates comment and min retention months default for client counts config

Co-authored-by: Jordan Reimer <zofskeez@gmail.com>
2026-02-03 16:18:52 +00:00

92 lines
3.2 KiB
TypeScript

/**
* Copyright IBM Corp. 2016, 2025
* SPDX-License-Identifier: BUSL-1.1
*/
import Service, { inject as service } from '@ember/service';
import { tracked } from '@glimmer/tracking';
import { keepLatestTask } from 'ember-concurrency';
import { macroCondition, isDevelopingApp } from '@embroider/macros';
import { ADMINISTRATIVE_NAMESPACE } from 'vault/services/namespace';
import type VersionService from 'vault/services/version';
import type ApiService from 'vault/services/api';
const FLAGS = {
vaultCloudNamespace: 'VAULT_CLOUD_ADMIN_NAMESPACE',
};
export type ActivationFlags = {
activated: string[];
unactivated: string[];
};
/**
* This service returns information about cluster flags. For now, the two available flags are from sys/internal/ui/feature-flags and sys/activation-flags.
* The feature-flags endpoint returns VAULT_CLOUD_ADMIN_NAMESPACE which indicates that the Vault cluster is managed rather than self-managed.
* The activation-flags endpoint returns which features are enabled.
*/
export default class FlagsService extends Service {
@service declare readonly version: VersionService;
@service declare readonly api: ApiService;
@tracked activatedFlags: string[] = [];
@tracked featureFlags: string[] = [];
get isHvdManaged(): boolean {
return this.featureFlags?.includes(FLAGS.vaultCloudNamespace);
}
// for non-managed clusters the root namespace path is technically an empty string so we return null
get hvdManagedNamespaceRoot(): string | null {
return this.isHvdManaged ? ADMINISTRATIVE_NAMESPACE : null;
}
getFeatureFlags = keepLatestTask(async () => {
try {
// unable to use internalUiListEnabledFeatureFlags method since the response does not conform to expected format
// example -> { feature_flags: string[] } instead of the standard { data: { feature_flags: string[] } }
// since it is typed as JSONApiResponse and not VoidResponse the client attempts to parse the body at
const response = await this.api.request.get('/sys/internal/ui/feature-flags');
const { feature_flags } = await response.json();
this.featureFlags = feature_flags || [];
} catch (error) {
const { response } = await this.api.parseError(error);
if (macroCondition(isDevelopingApp())) {
console.error(response);
}
}
});
fetchFeatureFlags() {
return this.getFeatureFlags.perform();
}
get secretsSyncIsActivated(): boolean {
return this.activatedFlags.includes('secrets-sync');
}
getActivatedFlags = keepLatestTask(async () => {
// Response could change between user sessions.
// Fire off endpoint without checking if activated features are already set.
if (this.version.isCommunity) return;
try {
const { data } = await this.api.sys.readActivationFlags(
this.api.buildHeaders({ token: '', namespace: '' })
);
this.activatedFlags = (data as ActivationFlags)?.activated;
return;
} catch (error) {
const { response } = await this.api.parseError(error);
if (macroCondition(isDevelopingApp())) {
console.error(response);
}
}
});
fetchActivatedFlags() {
return this.getActivatedFlags.perform();
}
}