mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Switch KubeJsonApi.forCluster to be injectable but do not use
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
1809f98046
commit
558dbddeb8
@ -0,0 +1,33 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { apiKubePrefix, isDebugging } from "../vars";
|
||||||
|
import { apiBaseInjectionToken } from "./api-base";
|
||||||
|
import { KubeJsonApi } from "./kube-json-api";
|
||||||
|
|
||||||
|
export type CreateKubeJsonApiForCluster = (clusterId: string) => KubeJsonApi;
|
||||||
|
|
||||||
|
const createKubeJsonApiForClusterInjectable = getInjectable({
|
||||||
|
id: "create-kube-json-api-for-cluster",
|
||||||
|
instantiate: (di): CreateKubeJsonApiForCluster => {
|
||||||
|
const apiBase = di.inject(apiBaseInjectionToken);
|
||||||
|
|
||||||
|
return (clusterId) => {
|
||||||
|
const url = new URL(apiBase.config.serverAddress);
|
||||||
|
|
||||||
|
return new KubeJsonApi({
|
||||||
|
serverAddress: apiBase.config.serverAddress,
|
||||||
|
apiBase: apiKubePrefix,
|
||||||
|
debug: isDebugging,
|
||||||
|
}, {
|
||||||
|
headers: {
|
||||||
|
"Host": `${clusterId}.localhost:${url.port}`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
};
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
export default createKubeJsonApiForClusterInjectable;
|
||||||
@ -6,8 +6,6 @@
|
|||||||
import type { JsonApiData, JsonApiError } from "./json-api";
|
import type { JsonApiData, JsonApiError } from "./json-api";
|
||||||
import { JsonApi } from "./json-api";
|
import { JsonApi } from "./json-api";
|
||||||
import type { Response } from "node-fetch";
|
import type { Response } from "node-fetch";
|
||||||
import { apiKubePrefix, isDebugging } from "../vars";
|
|
||||||
import { apiBase } from "./api-base";
|
|
||||||
import type { KubeJsonApiObjectMetadata } from "./kube-object";
|
import type { KubeJsonApiObjectMetadata } from "./kube-object";
|
||||||
|
|
||||||
export interface KubeJsonApiListMetadata {
|
export interface KubeJsonApiListMetadata {
|
||||||
@ -47,20 +45,6 @@ export interface KubeJsonApiError extends JsonApiError {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export class KubeJsonApi extends JsonApi<KubeJsonApiData> {
|
export class KubeJsonApi extends JsonApi<KubeJsonApiData> {
|
||||||
static forCluster(clusterId: string): KubeJsonApi {
|
|
||||||
const url = new URL(apiBase.config.serverAddress);
|
|
||||||
|
|
||||||
return new this({
|
|
||||||
serverAddress: apiBase.config.serverAddress,
|
|
||||||
apiBase: apiKubePrefix,
|
|
||||||
debug: isDebugging,
|
|
||||||
}, {
|
|
||||||
headers: {
|
|
||||||
"Host": `${clusterId}.localhost:${url.port}`,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected parseError(error: KubeJsonApiError | string, res: Response): string[] {
|
protected parseError(error: KubeJsonApiError | string, res: Response): string[] {
|
||||||
if (typeof error === "string") {
|
if (typeof error === "string") {
|
||||||
return [error];
|
return [error];
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user