mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Release v5.2.5 (#3926)
Co-authored-by: Jim Ehrismann <40840436+jim-docker@users.noreply.github.com> Co-authored-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
f54fc628cf
commit
bc36d48677
@ -3,7 +3,7 @@
|
|||||||
"productName": "OpenLens",
|
"productName": "OpenLens",
|
||||||
"description": "OpenLens - Open Source IDE for Kubernetes",
|
"description": "OpenLens - Open Source IDE for Kubernetes",
|
||||||
"homepage": "https://github.com/lensapp/lens",
|
"homepage": "https://github.com/lensapp/lens",
|
||||||
"version": "5.2.4",
|
"version": "5.2.5",
|
||||||
"main": "static/build/main.js",
|
"main": "static/build/main.js",
|
||||||
"copyright": "© 2021 OpenLens Authors",
|
"copyright": "© 2021 OpenLens Authors",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
|||||||
@ -69,7 +69,7 @@ export const apiKubePrefix = "/api-kube" as string; // k8s cluster apis
|
|||||||
|
|
||||||
// Links
|
// Links
|
||||||
export const issuesTrackerUrl = "https://github.com/lensapp/lens/issues" as string;
|
export const issuesTrackerUrl = "https://github.com/lensapp/lens/issues" as string;
|
||||||
export const slackUrl = "https://join.slack.com/t/k8slens/shared_invite/enQtOTc5NjAyNjYyOTk4LWU1NDQ0ZGFkOWJkNTRhYTc2YjVmZDdkM2FkNGM5MjhiYTRhMDU2NDQ1MzIyMDA4ZGZlNmExOTc0N2JmY2M3ZGI" as string;
|
export const slackUrl = "https://join.slack.com/t/k8slens/shared_invite/zt-wcl8jq3k-68R5Wcmk1o95MLBE5igUDQ" as string;
|
||||||
export const supportUrl = "https://docs.k8slens.dev/latest/support/" as string;
|
export const supportUrl = "https://docs.k8slens.dev/latest/support/" as string;
|
||||||
|
|
||||||
export const appSemVer = new SemVer(packageInfo.version);
|
export const appSemVer = new SemVer(packageInfo.version);
|
||||||
|
|||||||
@ -16,9 +16,9 @@
|
|||||||
"name": "OpenLens Authors"
|
"name": "OpenLens Authors"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/node": "*",
|
"@types/node": "14.17.14",
|
||||||
"@types/react-select": "*",
|
"@types/react-select": "3.1.2",
|
||||||
"@material-ui/core": "*",
|
"@material-ui/core": "4.12.3",
|
||||||
"conf": "^7.0.1",
|
"conf": "^7.0.1",
|
||||||
"typed-emitter": "^1.3.1"
|
"typed-emitter": "^1.3.1"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -18,4 +18,39 @@
|
|||||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
export * from "./parse-query";
|
|
||||||
|
import { isLongRunningRequest } from "../lens-proxy";
|
||||||
|
|
||||||
|
describe("isLongRunningRequest", () => {
|
||||||
|
it("returns true on watches", () => {
|
||||||
|
["watch=true", "watch=1", "watch"].forEach((param) => {
|
||||||
|
expect(
|
||||||
|
isLongRunningRequest(`/api/v1/namespaces/default/pods?${param}`)
|
||||||
|
).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns false on disabled watches", () => {
|
||||||
|
["watch=false", "watch=0", ""].forEach((param) => {
|
||||||
|
expect(
|
||||||
|
isLongRunningRequest(`/api/v1/namespaces/default/pods?${param}`)
|
||||||
|
).toBeFalsy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns true on follows", () => {
|
||||||
|
["follow=true", "follow=1", "follow"].forEach((param) => {
|
||||||
|
expect(
|
||||||
|
isLongRunningRequest(`/api/v1/namespaces/default/pods/foo/log?${param}`)
|
||||||
|
).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("returns false on disabled follows", () => {
|
||||||
|
["follow=false", "follow=0", ""].forEach((param) => {
|
||||||
|
expect(
|
||||||
|
isLongRunningRequest(`/api/v1/namespaces/default/pods/foo/log?${param}`)
|
||||||
|
).toBeFalsy();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -117,10 +117,10 @@ export class ContextHandler {
|
|||||||
return `http://127.0.0.1:${this.kubeAuthProxy.port}${path}`;
|
return `http://127.0.0.1:${this.kubeAuthProxy.port}${path}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
async getApiTarget(isWatchRequest = false): Promise<httpProxy.ServerOptions> {
|
async getApiTarget(isLongRunningRequest = false): Promise<httpProxy.ServerOptions> {
|
||||||
const timeout = isWatchRequest ? 4 * 60 * 60 * 1000 : 30000; // 4 hours for watch request, 30 seconds for the rest
|
const timeout = isLongRunningRequest ? 4 * 60 * 60_000 : 30_000; // 4 hours for long running request, 30 seconds for the rest
|
||||||
|
|
||||||
if (isWatchRequest) {
|
if (isLongRunningRequest) {
|
||||||
return this.newApiTarget(timeout);
|
return this.newApiTarget(timeout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -31,6 +31,7 @@ import { Singleton } from "../common/utils";
|
|||||||
import type { Cluster } from "./cluster";
|
import type { Cluster } from "./cluster";
|
||||||
import type { ProxyApiRequestArgs } from "./proxy-functions";
|
import type { ProxyApiRequestArgs } from "./proxy-functions";
|
||||||
import { appEventBus } from "../common/event-bus";
|
import { appEventBus } from "../common/event-bus";
|
||||||
|
import { getBoolean } from "./utils/parse-query";
|
||||||
|
|
||||||
type GetClusterForRequest = (req: http.IncomingMessage) => Cluster | null;
|
type GetClusterForRequest = (req: http.IncomingMessage) => Cluster | null;
|
||||||
|
|
||||||
@ -40,6 +41,15 @@ export interface LensProxyFunctions {
|
|||||||
kubeApiRequest: (args: ProxyApiRequestArgs) => void | Promise<void>;
|
kubeApiRequest: (args: ProxyApiRequestArgs) => void | Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const watchParam = "watch";
|
||||||
|
const followParam = "follow";
|
||||||
|
|
||||||
|
export function isLongRunningRequest(reqUrl: string) {
|
||||||
|
const url = new URL(reqUrl, "http://localhost");
|
||||||
|
|
||||||
|
return getBoolean(url.searchParams, watchParam) || getBoolean(url.searchParams, followParam);
|
||||||
|
}
|
||||||
|
|
||||||
export class LensProxy extends Singleton {
|
export class LensProxy extends Singleton {
|
||||||
protected origin: string;
|
protected origin: string;
|
||||||
protected proxyServer: http.Server;
|
protected proxyServer: http.Server;
|
||||||
@ -174,9 +184,8 @@ export class LensProxy extends Singleton {
|
|||||||
if (req.url.startsWith(apiKubePrefix)) {
|
if (req.url.startsWith(apiKubePrefix)) {
|
||||||
delete req.headers.authorization;
|
delete req.headers.authorization;
|
||||||
req.url = req.url.replace(apiKubePrefix, "");
|
req.url = req.url.replace(apiKubePrefix, "");
|
||||||
const isWatchRequest = req.url.includes("watch=");
|
|
||||||
|
|
||||||
return contextHandler.getApiTarget(isWatchRequest);
|
return contextHandler.getApiTarget(isLongRunningRequest(req.url));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -23,7 +23,7 @@ import type { LensApiRequest } from "../router";
|
|||||||
import { helmService } from "../helm/helm-service";
|
import { helmService } from "../helm/helm-service";
|
||||||
import logger from "../logger";
|
import logger from "../logger";
|
||||||
import { respondJson, respondText } from "../utils/http-responses";
|
import { respondJson, respondText } from "../utils/http-responses";
|
||||||
import { getBoolean } from "./utils/parse-query";
|
import { getBoolean } from "../utils/parse-query";
|
||||||
|
|
||||||
export class HelmApiRoute {
|
export class HelmApiRoute {
|
||||||
static async listCharts(request: LensApiRequest) {
|
static async listCharts(request: LensApiRequest) {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user