mirror of
https://github.com/lensapp/lens.git
synced 2024-11-10 10:36:25 +03:00
Helper to resolve proxy from URL in any environment, or using extension-API (#5690)
* Permit modular directory structures for behaviours in spirit of "Screaming Architecture" Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Implement env-agnostic helper to resolve proxy from URL Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Implement way to resolve a proxy, that is not reliant on existing windows Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Restore reliancy on existing windows for resolving proxy for fears of Electron events misbehaving because of a temp-window used in case no windows are open Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Make resolving a proxy throw if no browser window is available Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Extract minimal abstraction for specifically logging error instead of also warn, info, etc. Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Make decorator for error logging not create orphan promise for easier controllability Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Add error logging to resolving of proxy Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Expose resolving of proxy in extension-API Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Add missing general override Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Add test to add documentation Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Disperse implementation of resolve-proxy back to conventional directory structure instead of an experimental one Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Revert "Permit modular directory structures for behaviours in spirit of "Screaming Architecture"" This reverts commit 75e1231b0e61b74d030d12365352226e7f1ce500. Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Rename a helper for less ambiguity Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com> * Add tsdoc for "resolveSystemProxy" exposed in Extension-API Co-authored-by: Janne Savolainen <janne.savolainen@live.fi> Signed-off-by: Iku-turso <mikko.aspiala@gmail.com>
This commit is contained in:
parent
fa23b5cd3f
commit
71427da02d
@ -0,0 +1,85 @@
|
||||
/**
|
||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
import type { AsyncFnMock } from "@async-fn/jest";
|
||||
import asyncFn from "@async-fn/jest";
|
||||
import type { ApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
|
||||
import { getApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder";
|
||||
import type { ResolveSystemProxy } from "../../common/utils/resolve-system-proxy/resolve-system-proxy-injection-token";
|
||||
import { resolveSystemProxyInjectionToken } from "../../common/utils/resolve-system-proxy/resolve-system-proxy-injection-token";
|
||||
import resolveSystemProxyFromElectronInjectable from "../../main/utils/resolve-system-proxy/resolve-system-proxy-from-electron.injectable";
|
||||
import { getPromiseStatus } from "../../common/test-utils/get-promise-status";
|
||||
|
||||
describe("resolve-system-proxy", () => {
|
||||
let applicationBuilder: ApplicationBuilder;
|
||||
let actualPromise: Promise<string>;
|
||||
let resolveSystemProxyFromElectronMock: AsyncFnMock<ResolveSystemProxy>;
|
||||
|
||||
beforeEach(async () => {
|
||||
applicationBuilder = getApplicationBuilder();
|
||||
|
||||
resolveSystemProxyFromElectronMock = asyncFn();
|
||||
|
||||
applicationBuilder.beforeApplicationStart(({ mainDi }) => {
|
||||
mainDi.override(
|
||||
resolveSystemProxyFromElectronInjectable,
|
||||
() => resolveSystemProxyFromElectronMock,
|
||||
);
|
||||
});
|
||||
|
||||
await applicationBuilder.render();
|
||||
});
|
||||
|
||||
describe("given in main, when called with URL", () => {
|
||||
beforeEach(async () => {
|
||||
const resolveSystemProxyInMain = applicationBuilder.dis.mainDi.inject(
|
||||
resolveSystemProxyInjectionToken,
|
||||
);
|
||||
|
||||
actualPromise = resolveSystemProxyInMain("some-url");
|
||||
});
|
||||
|
||||
it("calls for proxy of the URL from Electron", () => {
|
||||
expect(resolveSystemProxyFromElectronMock).toHaveBeenCalledWith("some-url");
|
||||
});
|
||||
|
||||
it("does not resolve yet", async () => {
|
||||
const promiseStatus = await getPromiseStatus(actualPromise);
|
||||
|
||||
expect(promiseStatus.fulfilled).toBe(false);
|
||||
});
|
||||
|
||||
it("when the call for proxy resolves, resolves with the proxy", async () => {
|
||||
resolveSystemProxyFromElectronMock.resolve("some-proxy");
|
||||
|
||||
expect(await actualPromise).toBe("some-proxy");
|
||||
});
|
||||
});
|
||||
|
||||
describe("given in renderer, when called with URL", () => {
|
||||
beforeEach(async () => {
|
||||
const resolveSystemProxyInRenderer = applicationBuilder.dis.rendererDi.inject(
|
||||
resolveSystemProxyInjectionToken,
|
||||
);
|
||||
|
||||
actualPromise = resolveSystemProxyInRenderer("some-url");
|
||||
});
|
||||
|
||||
it("calls for proxy of the URL from Electron", () => {
|
||||
expect(resolveSystemProxyFromElectronMock).toHaveBeenCalledWith("some-url");
|
||||
});
|
||||
|
||||
it("does not resolve yet", async () => {
|
||||
const promiseStatus = await getPromiseStatus(actualPromise);
|
||||
|
||||
expect(promiseStatus.fulfilled).toBe(false);
|
||||
});
|
||||
|
||||
it("when the call for proxy resolves, resolves with the proxy", async () => {
|
||||
resolveSystemProxyFromElectronMock.resolve("some-proxy");
|
||||
|
||||
expect(await actualPromise).toBe("some-proxy");
|
||||
});
|
||||
});
|
||||
});
|
13
src/common/log-error.injectable.ts
Normal file
13
src/common/log-error.injectable.ts
Normal file
@ -0,0 +1,13 @@
|
||||
/**
|
||||
* 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 loggerInjectable from "./logger.injectable";
|
||||
|
||||
const logErrorInjectable = getInjectable({
|
||||
id: "log-error",
|
||||
instantiate: (di) => di.inject(loggerInjectable).error,
|
||||
});
|
||||
|
||||
export default logErrorInjectable;
|
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* 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 type { RequestChannel } from "../channel/request-channel-injection-token";
|
||||
import { requestChannelInjectionToken } from "../channel/request-channel-injection-token";
|
||||
|
||||
export type ResolveSystemProxyChannel = RequestChannel<string, string>;
|
||||
|
||||
const resolveSystemProxyChannelInjectable = getInjectable({
|
||||
id: "resolve-system-proxy-channel",
|
||||
|
||||
instantiate: (): ResolveSystemProxyChannel => ({
|
||||
id: "resolve-system-proxy-channel",
|
||||
}),
|
||||
|
||||
injectionToken: requestChannelInjectionToken,
|
||||
});
|
||||
|
||||
export default resolveSystemProxyChannelInjectable;
|
@ -0,0 +1,12 @@
|
||||
/**
|
||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
|
||||
import { getInjectionToken } from "@ogre-tools/injectable";
|
||||
|
||||
export type ResolveSystemProxy = (url: string) => Promise<string>;
|
||||
|
||||
export const resolveSystemProxyInjectionToken = getInjectionToken<ResolveSystemProxy>({
|
||||
id: "resolve-system-proxy",
|
||||
});
|
@ -3,7 +3,7 @@
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
import { getInjectable } from "@ogre-tools/injectable";
|
||||
import loggerInjectable from "../../logger.injectable";
|
||||
import logErrorInjectable from "../../log-error.injectable";
|
||||
import { isPromise } from "../is-promise/is-promise";
|
||||
|
||||
export type WithErrorLoggingFor = (
|
||||
@ -16,30 +16,34 @@ const withErrorLoggingInjectable = getInjectable({
|
||||
id: "with-error-logging",
|
||||
|
||||
instantiate: (di): WithErrorLoggingFor => {
|
||||
const logger = di.inject(loggerInjectable);
|
||||
const logError = di.inject(logErrorInjectable);
|
||||
|
||||
return (getErrorMessage) =>
|
||||
(toBeDecorated) =>
|
||||
(...args) => {
|
||||
let returnValue: ReturnType<typeof toBeDecorated>;
|
||||
|
||||
try {
|
||||
const returnValue = toBeDecorated(...args);
|
||||
|
||||
if (isPromise(returnValue)) {
|
||||
returnValue.catch((e) => {
|
||||
const errorMessage = getErrorMessage(e);
|
||||
|
||||
logger.error(errorMessage, e);
|
||||
});
|
||||
}
|
||||
|
||||
return returnValue;
|
||||
returnValue = toBeDecorated(...args);
|
||||
} catch (e) {
|
||||
const errorMessage = getErrorMessage(e);
|
||||
|
||||
logger.error(errorMessage, e);
|
||||
logError(errorMessage, e);
|
||||
|
||||
throw e;
|
||||
}
|
||||
|
||||
if (isPromise(returnValue)) {
|
||||
return returnValue.catch((e: unknown) => {
|
||||
const errorMessage = getErrorMessage(e);
|
||||
|
||||
logError(errorMessage, e);
|
||||
|
||||
throw e;
|
||||
});
|
||||
}
|
||||
|
||||
return returnValue;
|
||||
};
|
||||
},
|
||||
});
|
||||
|
@ -163,23 +163,24 @@ describe("with-error-logging", () => {
|
||||
});
|
||||
|
||||
describe("when call rejects with error instance", () => {
|
||||
let error: Error;
|
||||
|
||||
beforeEach(async () => {
|
||||
try {
|
||||
await toBeDecorated.reject(new Error("some-error"));
|
||||
await returnValuePromise;
|
||||
} catch (e) {
|
||||
error = e as Error;
|
||||
}
|
||||
beforeEach(() => {
|
||||
toBeDecorated.reject(new Error("some-error"));
|
||||
});
|
||||
|
||||
it("logs the error", () => {
|
||||
it("logs the error", async () => {
|
||||
let error: unknown;
|
||||
|
||||
try {
|
||||
await returnValuePromise;
|
||||
} catch (e) {
|
||||
error = e;
|
||||
}
|
||||
|
||||
expect(loggerStub.error).toHaveBeenCalledWith("some-error-message-for-some-error", error);
|
||||
});
|
||||
|
||||
it("rejects", () => {
|
||||
return expect(() => returnValuePromise).rejects.toThrow("some-error");
|
||||
return expect(returnValuePromise).rejects.toThrow("some-error");
|
||||
});
|
||||
});
|
||||
|
||||
@ -187,8 +188,9 @@ describe("with-error-logging", () => {
|
||||
let error: unknown;
|
||||
|
||||
beforeEach(async () => {
|
||||
toBeDecorated.reject({ someProperty: "some-rejection" });
|
||||
|
||||
try {
|
||||
await toBeDecorated.reject({ someProperty: "some-rejection" });
|
||||
await returnValuePromise;
|
||||
} catch (e) {
|
||||
error = e;
|
||||
@ -203,7 +205,7 @@ describe("with-error-logging", () => {
|
||||
});
|
||||
|
||||
it("rejects", () => {
|
||||
return expect(() => returnValuePromise).rejects.toEqual({ someProperty: "some-rejection" });
|
||||
return expect(returnValuePromise).rejects.toEqual({ someProperty: "some-rejection" });
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -10,6 +10,8 @@ import * as Store from "./stores";
|
||||
import * as Util from "./utils";
|
||||
import * as Catalog from "./catalog";
|
||||
import * as Types from "./types";
|
||||
import * as Proxy from "./proxy";
|
||||
|
||||
import logger from "../../common/logger";
|
||||
|
||||
export {
|
||||
@ -20,4 +22,5 @@ export {
|
||||
Types,
|
||||
Util,
|
||||
logger,
|
||||
Proxy,
|
||||
};
|
||||
|
14
src/extensions/common-api/proxy.ts
Normal file
14
src/extensions/common-api/proxy.ts
Normal file
@ -0,0 +1,14 @@
|
||||
/**
|
||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
|
||||
import { asLegacyGlobalFunctionForExtensionApi } from "../as-legacy-globals-for-extension-api/as-legacy-global-function-for-extension-api";
|
||||
import { resolveSystemProxyInjectionToken } from "../../common/utils/resolve-system-proxy/resolve-system-proxy-injection-token";
|
||||
|
||||
/**
|
||||
* Resolves URL-specific proxy information from system. See more here: https://www.electronjs.org/docs/latest/api/session#sesresolveproxyurl
|
||||
* @param url - The URL for proxy information
|
||||
* @returns Promise for proxy information as string
|
||||
*/
|
||||
export const resolveSystemProxy = asLegacyGlobalFunctionForExtensionApi(resolveSystemProxyInjectionToken);
|
@ -99,6 +99,7 @@ import rollbackHelmReleaseInjectable from "./helm/helm-service/rollback-helm-rel
|
||||
import updateHelmReleaseInjectable from "./helm/helm-service/update-helm-release.injectable";
|
||||
import waitUntilBundledExtensionsAreLoadedInjectable from "./start-main-application/lens-window/application-window/wait-until-bundled-extensions-are-loaded.injectable";
|
||||
import { registerMobX } from "@ogre-tools/injectable-extension-for-mobx";
|
||||
import electronInjectable from "./utils/resolve-system-proxy/electron.injectable";
|
||||
|
||||
export function getDiForUnitTesting(opts: { doGeneralOverrides?: boolean } = {}) {
|
||||
const {
|
||||
@ -124,6 +125,7 @@ export function getDiForUnitTesting(opts: { doGeneralOverrides?: boolean } = {})
|
||||
di.preventSideEffects();
|
||||
|
||||
if (doGeneralOverrides) {
|
||||
di.override(electronInjectable, () => ({}));
|
||||
di.override(waitUntilBundledExtensionsAreLoadedInjectable, () => async () => {});
|
||||
di.override(getRandomIdInjectable, () => () => "some-irrelevant-random-id");
|
||||
di.override(hotbarStoreInjectable, () => ({ load: () => {} }));
|
||||
|
14
src/main/utils/resolve-system-proxy/electron.injectable.ts
Normal file
14
src/main/utils/resolve-system-proxy/electron.injectable.ts
Normal file
@ -0,0 +1,14 @@
|
||||
/**
|
||||
* 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 electron from "electron";
|
||||
|
||||
const electronInjectable = getInjectable({
|
||||
id: "electron",
|
||||
instantiate: () => electron,
|
||||
causesSideEffects: true,
|
||||
});
|
||||
|
||||
export default electronInjectable;
|
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* 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 resolveSystemProxyChannelInjectable from "../../../common/utils/resolve-system-proxy/resolve-system-proxy-channel.injectable";
|
||||
import resolveSystemProxyInjectable from "./resolve-system-proxy.injectable";
|
||||
import { requestChannelListenerInjectionToken } from "../../../common/utils/channel/request-channel-listener-injection-token";
|
||||
|
||||
const resolveSystemProxyChannelResponderInjectable = getInjectable({
|
||||
id: "resolve-system-proxy-channel-responder",
|
||||
|
||||
instantiate: (di) => ({
|
||||
channel: di.inject(resolveSystemProxyChannelInjectable),
|
||||
handler: di.inject(resolveSystemProxyInjectable),
|
||||
}),
|
||||
|
||||
injectionToken: requestChannelListenerInjectionToken,
|
||||
});
|
||||
|
||||
export default resolveSystemProxyChannelResponderInjectable;
|
@ -0,0 +1,32 @@
|
||||
/**
|
||||
* 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 electronInjectable from "./electron.injectable";
|
||||
import withErrorLoggingInjectable from "../../../common/utils/with-error-logging/with-error-logging.injectable";
|
||||
|
||||
const resolveSystemProxyFromElectronInjectable = getInjectable({
|
||||
id: "resolve-system-proxy-from-electron",
|
||||
|
||||
instantiate: (di) => {
|
||||
const electron = di.inject(electronInjectable);
|
||||
const withErrorLoggingFor = di.inject(withErrorLoggingInjectable);
|
||||
|
||||
const withErrorLogging = withErrorLoggingFor(() => "Error resolving proxy");
|
||||
|
||||
return withErrorLogging(async (url: string) => {
|
||||
const webContent = electron.webContents
|
||||
.getAllWebContents()
|
||||
.find((x) => !x.isDestroyed());
|
||||
|
||||
if (!webContent) {
|
||||
throw new Error(`Tried to resolve proxy for "${url}", but no browser window was available`);
|
||||
}
|
||||
|
||||
return await webContent.session.resolveProxy(url);
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
export default resolveSystemProxyFromElectronInjectable;
|
@ -0,0 +1,138 @@
|
||||
/**
|
||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||
*/
|
||||
|
||||
import { getDiForUnitTesting } from "../../getDiForUnitTesting";
|
||||
import resolveSystemProxyFromElectronInjectable from "./resolve-system-proxy-from-electron.injectable";
|
||||
import electronInjectable from "./electron.injectable";
|
||||
import type { AsyncFnMock } from "@async-fn/jest";
|
||||
import asyncFn from "@async-fn/jest";
|
||||
import type electron from "electron";
|
||||
import { getPromiseStatus } from "../../../common/test-utils/get-promise-status";
|
||||
import logErrorInjectable from "../../../common/log-error.injectable";
|
||||
import type { DiContainer } from "@ogre-tools/injectable";
|
||||
|
||||
describe("technical: resolve-system-proxy-from-electron", () => {
|
||||
let resolveSystemProxyMock: AsyncFnMock<(url: string) => Promise<string>>;
|
||||
let logErrorMock: jest.Mock;
|
||||
let di: DiContainer;
|
||||
let actualPromise: Promise<string>;
|
||||
|
||||
beforeEach(() => {
|
||||
di = getDiForUnitTesting();
|
||||
|
||||
logErrorMock = jest.fn();
|
||||
di.override(logErrorInjectable, () => logErrorMock);
|
||||
});
|
||||
|
||||
describe("given there are non-destroyed Lens windows, when called with URL", () => {
|
||||
beforeEach(() => {
|
||||
resolveSystemProxyMock = asyncFn();
|
||||
|
||||
di.override(
|
||||
electronInjectable,
|
||||
|
||||
() =>
|
||||
({
|
||||
webContents: {
|
||||
getAllWebContents: () => [
|
||||
{
|
||||
isDestroyed: () => true,
|
||||
|
||||
session: {
|
||||
resolveProxy: () => {
|
||||
throw new Error("should never come here");
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
isDestroyed: () => false,
|
||||
session: { resolveProxy: resolveSystemProxyMock },
|
||||
},
|
||||
|
||||
{
|
||||
isDestroyed: () => false,
|
||||
|
||||
session: {
|
||||
resolveProxy: () => {
|
||||
throw new Error("should never come here");
|
||||
},
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
} as unknown as typeof electron),
|
||||
);
|
||||
|
||||
const resolveSystemProxyFromElectron = di.inject(
|
||||
resolveSystemProxyFromElectronInjectable,
|
||||
);
|
||||
|
||||
actualPromise = resolveSystemProxyFromElectron("some-url");
|
||||
});
|
||||
|
||||
it("calls to resolve proxy from the first window", () => {
|
||||
expect(resolveSystemProxyMock).toHaveBeenCalledWith("some-url");
|
||||
});
|
||||
|
||||
it("does not resolve yet", async () => {
|
||||
const promiseStatus = await getPromiseStatus(actualPromise);
|
||||
|
||||
expect(promiseStatus.fulfilled).toBe(false);
|
||||
});
|
||||
|
||||
it("when call for proxy, resolves with the proxy", async () => {
|
||||
resolveSystemProxyMock.resolve("some-proxy");
|
||||
|
||||
expect(await actualPromise).toBe("some-proxy");
|
||||
});
|
||||
});
|
||||
|
||||
describe("given there are only destroyed Lens windows, when called with URL", () => {
|
||||
let error: any;
|
||||
|
||||
beforeEach(async () => {
|
||||
di.override(
|
||||
electronInjectable,
|
||||
() =>
|
||||
({
|
||||
webContents: {
|
||||
getAllWebContents: () => [
|
||||
{
|
||||
isDestroyed: () => true,
|
||||
|
||||
session: {
|
||||
resolveProxy: () => {
|
||||
throw new Error("should never come here");
|
||||
},
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
} as unknown as typeof electron),
|
||||
);
|
||||
|
||||
resolveSystemProxyMock = asyncFn();
|
||||
|
||||
const resolveSystemProxyFromElectron = di.inject(
|
||||
resolveSystemProxyFromElectronInjectable,
|
||||
);
|
||||
|
||||
try {
|
||||
await resolveSystemProxyFromElectron("some-url");
|
||||
} catch (e) {
|
||||
error = e;
|
||||
}
|
||||
});
|
||||
|
||||
it("throws error", () => {
|
||||
expect(error.message).toBe('Tried to resolve proxy for "some-url", but no browser window was available');
|
||||
});
|
||||
|
||||
it("logs error", () => {
|
||||
expect(logErrorMock).toHaveBeenCalledWith("Error resolving proxy", error);
|
||||
});
|
||||
});
|
||||
});
|
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* 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 { resolveSystemProxyInjectionToken } from "../../../common/utils/resolve-system-proxy/resolve-system-proxy-injection-token";
|
||||
import resolveSystemProxyFromElectronInjectable from "./resolve-system-proxy-from-electron.injectable";
|
||||
|
||||
const resolveSystemProxyInjectable = getInjectable({
|
||||
id: "resolve-system-proxy-for-main",
|
||||
|
||||
instantiate: (di) => {
|
||||
const resolveSystemProxyFromElectron = di.inject(resolveSystemProxyFromElectronInjectable);
|
||||
|
||||
return (url) => resolveSystemProxyFromElectron(url);
|
||||
},
|
||||
|
||||
injectionToken: resolveSystemProxyInjectionToken,
|
||||
});
|
||||
|
||||
export default resolveSystemProxyInjectable;
|
@ -0,0 +1,23 @@
|
||||
/**
|
||||
* 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 { resolveSystemProxyInjectionToken } from "../../../common/utils/resolve-system-proxy/resolve-system-proxy-injection-token";
|
||||
import requestFromChannelInjectable from "../channel/request-from-channel.injectable";
|
||||
import resolveSystemProxyChannelInjectable from "../../../common/utils/resolve-system-proxy/resolve-system-proxy-channel.injectable";
|
||||
|
||||
const resolveSystemProxyInjectable = getInjectable({
|
||||
id: "resolve-system-proxy-for-renderer",
|
||||
|
||||
instantiate: (di) => {
|
||||
const requestFromChannel = di.inject(requestFromChannelInjectable);
|
||||
const resolveSystemProxyChannel = di.inject(resolveSystemProxyChannelInjectable);
|
||||
|
||||
return async (url) => requestFromChannel(resolveSystemProxyChannel, url);
|
||||
},
|
||||
|
||||
injectionToken: resolveSystemProxyInjectionToken,
|
||||
});
|
||||
|
||||
export default resolveSystemProxyInjectable;
|
Loading…
Reference in New Issue
Block a user