vault/ui/lib/sync/addon/utils/api-transforms.ts
Jordan Reimer 8700becc45
[UI] Ember Data Migration - API Property Casing (#31325)
* updates api client vars to snake_case for custom messages

* updates api client vars to snake_case for tools

* updates api client vars to snake_case for sync

* updates api client vars to snake_case for secrets engine

* updates api client vars to snake_case for auth

* updates api client vars to snake_case for usage

* updates api client dep to point to gh repo

* fixes custom-messages service unit tests

* fixes configure-ssh test

* fixes configure-ssh test...again
2025-07-18 09:32:01 -06:00

54 lines
1.9 KiB
TypeScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import { findDestination } from 'core/helpers/sync-destinations';
import type { DestinationType, ListDestination } from 'vault/sync';
import type { SystemListSyncDestinationsResponse } from '@hashicorp/vault-client-typescript';
// transforms the systemListSyncDestinations response to a flat array
// destination name and type are the only properties returned from the request
// to satisfy the list views, combine this data with static properties icon and typeDisplayName
// the flat array is then filtered by name and type if filter values are provided
export const listDestinationsTransform = (
response: SystemListSyncDestinationsResponse,
nameFilter?: string,
typeFilter?: string
) => {
const { key_info } = response;
const destinations: ListDestination[] = [];
// build ListDestination objects from keyInfo
for (const key in key_info) {
// iterate through each type's destination names
const names = (key_info as Record<string, string[]>)[key];
// remove trailing slash from key
const type = key.replace(/\/$/, '') as DestinationType;
names?.forEach((name: string) => {
const id = `${type}/${name}`;
const { icon, name: type_display_name } = findDestination(type);
// create object with destination's id and attributes
destinations.push({ id, name, type, icon, type_display_name });
});
}
// optionally filter by name and type
let filteredDestinations = [...destinations];
const filter = (key: 'type' | 'name', value: string) => {
return filteredDestinations.filter((destination: ListDestination) => {
return destination[key].toLowerCase().includes(value.toLowerCase());
});
};
if (typeFilter) {
filteredDestinations = filter('type', typeFilter);
}
if (nameFilter) {
filteredDestinations = filter('name', nameFilter);
}
return filteredDestinations;
};