@alauda-fe/common
Version:
Alauda frontend team common codes.
73 lines • 12.4 kB
JavaScript
/**
* @packageDocumentation
* @module api
*/
import { HttpClient } from '@angular/common/http';
import { Inject, Injectable, isDevMode } from '@angular/core';
import { map } from 'rxjs';
import { TOKEN_RESOURCE_DEFINITIONS } from '../core/constants/tokens';
import { API_GATEWAY, ifExist, publishRef, } from '../core/public-api';
import { EMPTY_API_PREFIX_PARTS, getApiPrefixParts, normalizeApiGroup, normalizeDefinition, } from './helpers';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common/http";
export class K8sApiResourceService {
constructor(http, resourceDefinitions) {
this.http = http;
this.resourceDefinitions = resourceDefinitions;
// @internal
this._listCaches = {};
// @internal
this._typeCaches = {};
}
getDefinition(typeOrDefinition) {
if (isDevMode() && !typeOrDefinition) {
throw new TypeError(`resource type or definition is required, but received: '${String(typeOrDefinition)}'`);
}
const definition = typeof typeOrDefinition === 'string'
? this.resourceDefinitions[typeOrDefinition]
: typeOrDefinition;
if (definition) {
return normalizeDefinition(definition);
}
const type = typeOrDefinition;
if (isDevMode()) {
console.warn(`"${type}" could not be found in \`TOKEN_RESOURCE_DEFINITIONS\`, have you provided it correctly?`);
}
return { type, ...EMPTY_API_PREFIX_PARTS };
}
getApiPath({ cluster, namespace, name, type, apiGroup, apiVersion, }) {
apiGroup = normalizeApiGroup(apiGroup);
/* eslint-disable sonarjs/no-nested-template-literals */
return `${API_GATEWAY}${ifExist(cluster, `/kubernetes/${cluster}`)}/api${apiGroup && 's'}${ifExist(apiGroup, `/${apiGroup}`)}/${apiVersion || 'v1'}${ifExist(namespace, `/namespaces/${namespace}`)}${ifExist(type, `/${type}`)}${ifExist(name, `/${name}`)}`;
/* eslint-enable sonarjs/no-nested-template-literals */
}
getResourceList(resource, cluster) {
const { apiVersion } = resource;
const cached = this._listCaches[cluster] || (this._listCaches[cluster] = {});
return (cached[apiVersion] ||
(cached[apiVersion] = this.http
.get(this.getApiPath({
cluster,
...getApiPrefixParts(apiVersion),
}))
.pipe(map(({ resources }) => resources), publishRef())));
}
getResourceType(resource, cluster) {
const { apiVersion, kind } = resource;
const cached = this._typeCaches[cluster] || (this._typeCaches[cluster] = {});
return (cached[apiVersion] ||
(cached[apiVersion] = this.getResourceList(resource, cluster).pipe(map(resources => resources.find(item => item.kind === kind).name), publishRef())));
}
static { this.ɵfac = function K8sApiResourceService_Factory(t) { return new (t || K8sApiResourceService)(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(TOKEN_RESOURCE_DEFINITIONS)); }; }
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: K8sApiResourceService, factory: K8sApiResourceService.ɵfac, providedIn: 'root' }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(K8sApiResourceService, [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}], () => [{ type: i1.HttpClient }, { type: undefined, decorators: [{
type: Inject,
args: [TOKEN_RESOURCE_DEFINITIONS]
}] }], null); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"k8s-api-resource.service.js","sourceRoot":"","sources":["../../../../../libs/common/src/api/k8s-api-resource.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module api\n */\n\nimport { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, isDevMode } from '@angular/core';\nimport { Observable, map } from 'rxjs';\n\nimport { TOKEN_RESOURCE_DEFINITIONS } from '../core/constants/tokens';\nimport {\n  APIResourceItem,\n  APIResourceList,\n  KubernetesResource,\n  API_GATEWAY,\n  ifExist,\n  publishRef,\n} from '../core/public-api';\n\nimport {\n  EMPTY_API_PREFIX_PARTS,\n  getApiPrefixParts,\n  normalizeApiGroup,\n  normalizeDefinition,\n} from './helpers';\nimport { K8sResourceDefinition, K8sResourceDefinitions } from './types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class K8sApiResourceService {\n  constructor(\n    private readonly http: HttpClient,\n    @Inject(TOKEN_RESOURCE_DEFINITIONS)\n    private readonly resourceDefinitions: K8sResourceDefinitions,\n  ) {}\n\n  // @internal\n  private _listCaches: Record<\n    string,\n    Record<string, Observable<APIResourceItem[]>>\n  > = {};\n\n  // @internal\n  private _typeCaches: Record<string, Record<string, Observable<string>>> = {};\n\n  getDefinition(\n    typeOrDefinition: string | K8sResourceDefinition,\n  ): Required<K8sResourceDefinition> {\n    if (isDevMode() && !typeOrDefinition) {\n      throw new TypeError(\n        `resource type or definition is required, but received: '${String(\n          typeOrDefinition,\n        )}'`,\n      );\n    }\n\n    const definition =\n      typeof typeOrDefinition === 'string'\n        ? this.resourceDefinitions[typeOrDefinition]\n        : typeOrDefinition;\n\n    if (definition) {\n      return normalizeDefinition(definition);\n    }\n\n    const type = typeOrDefinition as string;\n    if (isDevMode()) {\n      console.warn(\n        `\"${type}\" could not be found in \\`TOKEN_RESOURCE_DEFINITIONS\\`, have you provided it correctly?`,\n      );\n    }\n    return { type, ...EMPTY_API_PREFIX_PARTS };\n  }\n\n  getApiPath({\n    cluster,\n    namespace,\n    name,\n    type,\n    apiGroup,\n    apiVersion,\n  }: {\n    cluster?: string;\n    namespace?: string;\n    name?: string;\n    type?: string;\n    apiGroup?: string;\n    apiVersion?: string;\n  }): string {\n    apiGroup = normalizeApiGroup(apiGroup);\n    /* eslint-disable sonarjs/no-nested-template-literals */\n    return `${API_GATEWAY}${ifExist(cluster, `/kubernetes/${cluster}`)}/api${\n      apiGroup && 's'\n    }${ifExist(apiGroup, `/${apiGroup}`)}/${apiVersion || 'v1'}${ifExist(\n      namespace,\n      `/namespaces/${namespace}`,\n    )}${ifExist(type, `/${type}`)}${ifExist(name, `/${name}`)}`;\n    /* eslint-enable sonarjs/no-nested-template-literals */\n  }\n\n  getResourceList<T extends KubernetesResource>(resource: T, cluster: string) {\n    const { apiVersion } = resource;\n\n    const cached =\n      this._listCaches[cluster] || (this._listCaches[cluster] = {});\n\n    return (\n      cached[apiVersion] ||\n      (cached[apiVersion] = this.http\n        .get<APIResourceList>(\n          this.getApiPath({\n            cluster,\n            ...getApiPrefixParts(apiVersion),\n          }),\n        )\n        .pipe(\n          map(({ resources }) => resources),\n          publishRef(),\n        ))\n    );\n  }\n\n  getResourceType<T extends KubernetesResource>(resource: T, cluster: string) {\n    const { apiVersion, kind } = resource;\n\n    const cached =\n      this._typeCaches[cluster] || (this._typeCaches[cluster] = {});\n\n    return (\n      cached[apiVersion] ||\n      (cached[apiVersion] = this.getResourceList(resource, cluster).pipe(\n        map(resources => resources.find(item => item.kind === kind).name),\n        publishRef(),\n      ))\n    );\n  }\n}\n"]}