From a9bbb75c1fdd7a8a34fdc07c3dd84df4293255a9 Mon Sep 17 00:00:00 2001 From: Alexander Kantchev Date: Wed, 17 Jan 2024 16:43:15 +0200 Subject: [PATCH] [Task IAC-805] Added caching for workflows, action categories, resources, configurations Signed-off-by: Alexander Kantchev --- .../vrdt-common/src/rest/VroRestClient.ts | 89 ++++++++++++++----- .../node/vrdt-common/src/rest/vro-model.ts | 25 +++++- 2 files changed, 89 insertions(+), 25 deletions(-) diff --git a/packages/node/vrdt-common/src/rest/VroRestClient.ts b/packages/node/vrdt-common/src/rest/VroRestClient.ts index 25c89cf1..ece717d0 100644 --- a/packages/node/vrdt-common/src/rest/VroRestClient.ts +++ b/packages/node/vrdt-common/src/rest/VroRestClient.ts @@ -12,12 +12,16 @@ import { ApiCategoryType } from "../types" import { BaseConfiguration } from "../platform" import { Auth, BasicAuth, VraSsoAuth } from "./auth" import { + Action, ApiElement, + Configuration, ContentChildrenResponse, ContentLinksResponse, InventoryElement, LogMessage, + Resource, Version, + Workflow, WorkflowLogsResponse, WorkflowParam, WorkflowState @@ -28,9 +32,13 @@ import { HintAction, HintModule } from "../types/hint" export class VroRestClient { private readonly logger = Logger.get("VroRestClient") private auth: Record | PromiseLike> - private hintActions: HintAction[] - private hintElements: ApiElement[] - private actions: any[] + private hintActions: Map = new Map() + private rootElements: Map = new Map() + private childElements: Map = new Map() + private actions: Action[] = [] + private workflows: Workflow[] = [] + private configurations: Configuration[] = [] + private resources: Resource[] = [] constructor(private settings: BaseConfiguration) { this.auth = this.getInitialAuth() @@ -363,7 +371,7 @@ export class VroRestClient { return packages.sort((x, y) => x.localeCompare(y)) } - async getActions(): Promise<{ fqn: string; id: string; version: string }[]> { + async getActions(): Promise { // return the cached actions (if any) if (this.actions && Array.isArray(this.actions) && this.actions.length) { return this.actions @@ -396,7 +404,12 @@ export class VroRestClient { return this.actions } - async getWorkflows(): Promise<{ name: string; id: string; version: string }[]> { + async getWorkflows(): Promise { + // return the cached workflows (if any) + if (this.workflows && Array.isArray(this.workflows) && this.workflows.length) { + return this.workflows + } + const responseJson: ContentLinksResponse = await this.send("GET", "workflows") const workflows: { name: string; id: string; version: string }[] = responseJson.link .map(wf => { @@ -418,10 +431,19 @@ export class VroRestClient { return !!val && val.name !== undefined && val.id !== undefined }) as { name: string; id: string; version: string }[] - return workflows.sort((x, y) => x.name.localeCompare(y.name)) + workflows.sort((x, y) => x.name.localeCompare(y.name)) + // cache the workflows + this.workflows = workflows + + return workflows } - async getConfigurations(): Promise<{ name: string; id: string; version: string }[]> { + async getConfigurations(): Promise { + // return the cached configurations (if any) + if (this.configurations && Array.isArray(this.configurations) && this.configurations.length) { + return this.configurations + } + const responseJson: ContentLinksResponse = await this.send("GET", "configurations") const configs: { name: string; id: string; version: string }[] = responseJson.link .map(conf => { @@ -441,11 +463,20 @@ export class VroRestClient { .filter(val => { return !!val && val.name !== undefined && val.id !== undefined }) as { name: string; id: string; version: string }[] + configs.sort((x, y) => x.name.localeCompare(y.name)) + + // cache the configurations + this.configurations = configs - return configs.sort((x, y) => x.name.localeCompare(y.name)) + return configs } - async getResources(): Promise<{ name: string; id: string }[]> { + async getResources(): Promise { + // return the cached resources (if any) + if (this.resources && Array.isArray(this.resources) && this.resources.length) { + return this.resources + } + const responseJson: ContentLinksResponse = await this.send("GET", "resources") const resources: { name: string; id: string }[] = responseJson.link .map(res => { @@ -464,10 +495,20 @@ export class VroRestClient { return !!val && val.name !== undefined && val.id !== undefined }) as { name: string; id: string }[] - return resources.sort((x, y) => x.name.localeCompare(y.name)) + resources.sort((x, y) => x.name.localeCompare(y.name)) + + // cache the resources + this.resources = resources + + return resources } async getRootCategories(categoryType: ApiCategoryType): Promise { + // return cached hint root elements (if any) in order to not overload vRO + if (this.rootElements?.has(categoryType) && Array.isArray(this.rootElements?.get(categoryType))) { + return this.childElements?.get(categoryType) as ApiElement[] + } + const responseJson: ContentLinksResponse = await this.send( "GET", `categories?isRoot=true&categoryType=${categoryType}` @@ -487,13 +528,18 @@ export class VroRestClient { return val.name !== undefined && val.id !== undefined }) as ApiElement[] - return categories.sort((x, y) => x.name.localeCompare(y.name)) + categories.sort((x, y) => x.name.localeCompare(y.name)) + + // cache the hint root elements in order not to overload vRO REST API + this.childElements.set(categoryType, categories) + + return categories } async getChildrenOfCategory(categoryId: string): Promise { - // return cached hint elements (if any) in order to not overload vRO - if (this.hintElements && Array.isArray(this.hintElements) && this.hintElements.length) { - return this.hintElements + // return cached hint child elements (if any) in order to not overload vRO + if (this.childElements?.has(categoryId) && Array.isArray(this.childElements?.get(categoryId))) { + return this.childElements?.get(categoryId) as ApiElement[] } const responseJson: ContentChildrenResponse = await this.send("GET", `categories/${categoryId}`) @@ -518,16 +564,17 @@ export class VroRestClient { }) as ApiElement[] children.sort((x, y) => x.name.localeCompare(y.name)) - // cache the hint elements in order not to overload vRO REST API - this.hintElements = children - return this.hintElements + // cache the hint child elements in order not to overload vRO REST API + this.childElements.set(categoryId, children) + + return children } async getChildrenOfCategoryWithDetails(categoryId: string): Promise { // return cached hint actions (if any) in order to not overload vRO REST API - if (this.hintActions && Array.isArray(this.hintActions) && this.hintActions.length) { - return this.hintActions + if (this.hintActions?.has(categoryId) && Array.isArray(this.hintActions?.get(categoryId))) { + return this.hintActions?.get(categoryId) as HintAction[] } let responseJson: HintModule = { @@ -558,9 +605,9 @@ export class VroRestClient { }) children.sort((x, y) => x.name.localeCompare(y.name)) // cache the hint actions in order not to overload vRO REST API - this.hintActions = children + this.hintActions.set(categoryId, children) - return this.hintActions + return children } async getResource(id: string): Promise { diff --git a/packages/node/vrdt-common/src/rest/vro-model.ts b/packages/node/vrdt-common/src/rest/vro-model.ts index 7e6e96c5..d0e81b21 100644 --- a/packages/node/vrdt-common/src/rest/vro-model.ts +++ b/packages/node/vrdt-common/src/rest/vro-model.ts @@ -47,16 +47,33 @@ export interface WorkflowLogsResponse { }[] } -export interface ApiElement { +export interface Resource { + id: string name: string +} + +// For better readability a separate interface is created +export interface Configuration extends Resource { + version: string +} + +// For better readability a separate interface is created +export interface Workflow extends Resource { + version: string +} + +export interface Action { id: string + fqn: string + version: string +} + +export interface ApiElement extends Resource { type: ApiCategoryType | ApiElementType rel: string } -export interface InventoryElement { - name: string - id: string +export interface InventoryElement extends Resource { type: string rel: string href: string