Skip to content

Commit

Permalink
Merge pull request #360 from metrico/fix/init-ready
Browse files Browse the repository at this point in the history
fix: ready endpoint handling
  • Loading branch information
jacovinus authored Oct 31, 2023
2 parents aee608f + e0201fe commit 3343bbd
Showing 1 changed file with 42 additions and 34 deletions.
76 changes: 42 additions & 34 deletions src/views/Main/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { getDsHeaders } from "../../components/QueryBuilder/Operations/helpers";
import setDataSources from "../DataSources/store/setDataSources";
import { setShowDataSourceSetting } from "./setShowDataSourceSetting";


// updateDataSources:

export function updateDataSourcesWithUrl(
Expand Down Expand Up @@ -146,33 +147,35 @@ export async function checkLocalAPI(
datasource: any,
auth?: AuthParams,
isAuth?: boolean
) {
): Promise<boolean> {
let response: any = {};
let conf = getAxiosConf(datasource);
let isReady = false;
let opts: any = { ...conf };

if (auth?.username !== "" && isAuth) {
opts.auth = auth;
}

try {
let res = await getReadyResponse(url, opts, response);

response = res;
} catch (e: any) {
isReady = false;
} finally {
if (
response &&
response?.status === 200 &&
(response?.contentType === "application/json; charset=utf-8" ||
response?.contentLength === "0")
) {
isReady = true;
return new Promise(async (resolve, rej) => {
try {
let res = await getReadyResponse(url, opts, response);

response = res;
} catch (e: any) {
rej(false);
} finally {
if (
response &&
response?.status === 200 &&
(response?.contentType.includes("application/json") ||
response?.contentLength === "0")
) {
resolve(true);
} else {
rej(false);
}
}
}
return isReady;
});
}

export async function updateDataSourcesFromLocalUrl(
Expand All @@ -196,26 +199,31 @@ export async function updateDataSourcesFromLocalUrl(
}
}
}

let dsReady = false;

let isLocalReady = false;

if (logsDs?.url !== "") {

dsReady = await checkLocalAPI(logsDs.url, logsDs, auth, isBasicAuth); // add the auth in here
}
if (!dsReady) {
isLocalReady = await checkLocalAPI(location, logsDs);

if (isLocalReady && !dsReady) {
const dsCP = [...dataSources];
const prevDs = JSON.parse(JSON.stringify(dsCP));

const newDs = prevDs?.map((m: any) => ({
...m,
url: location,
}));
localStorage.setItem("dataSources", JSON.stringify(newDs));
dispatch(setDataSources(newDs));
} else if (!dsReady && !isLocalReady) {
navigate("datasources");

if (!dsReady) {
isLocalReady = await checkLocalAPI(location, logsDs);

if (isLocalReady && !dsReady) {
const dsCP = [...dataSources];
const prevDs = JSON.parse(JSON.stringify(dsCP));

const newDs = prevDs?.map((m: any) => ({
...m,
url: location,
}));
localStorage.setItem("dataSources", JSON.stringify(newDs));
dispatch(setDataSources(newDs));
} else if (!dsReady && !isLocalReady) {
navigate("datasources");
}
}
}
}

0 comments on commit 3343bbd

Please sign in to comment.