From 236cf3537841b72d4369d193983fa7b8e5e934de Mon Sep 17 00:00:00 2001 From: Ludovic TOURMAN Date: Thu, 18 Jul 2024 16:57:36 +0200 Subject: [PATCH] Add authorization header only if token exists Signed-off-by: Ludovic TOURMAN --- frontend/src/lib/k8s/apiProxy.ts | 53 ++++++++++++++++++++++++-------- 1 file changed, 40 insertions(+), 13 deletions(-) diff --git a/frontend/src/lib/k8s/apiProxy.ts b/frontend/src/lib/k8s/apiProxy.ts index e4169fee6d..88afe02255 100644 --- a/frontend/src/lib/k8s/apiProxy.ts +++ b/frontend/src/lib/k8s/apiProxy.ts @@ -257,9 +257,18 @@ async function refreshToken(token: string | null): Promise { }; try { + const headers = new Headers({ + ...JSON_HEADERS, + }); + + const token = getToken(cluster); + if (!!token) { + headers.set('Authorization', `Bearer ${token}`); + } + const response = await fetch(tokenUrl, { method: 'POST', - headers: { Authorization: `Bearer ${token}`, ...JSON_HEADERS }, + headers, body: JSON.stringify(tokenData), }); @@ -1733,12 +1742,18 @@ export function startPortForward( address: string = '', id: string = '' ) { + const headers = new Headers({ + ...JSON_HEADERS, + }); + + const token = getToken(cluster); + if (!!token) { + headers.set('Authorization', `Bearer ${token}`); + } + return fetch(`${helpers.getAppUrl()}portforward`, { method: 'POST', - headers: new Headers({ - Authorization: `Bearer ${getToken(cluster)}`, - ...JSON_HEADERS, - }), + headers, body: JSON.stringify({ cluster, namespace, @@ -1823,12 +1838,18 @@ export function listPortForward(cluster: string) { * to get the status of the drain node process. */ export function drainNode(cluster: string, nodeName: string) { + const headers = new Headers({ + ...JSON_HEADERS, + }); + + const token = getToken(cluster); + if (!!token) { + headers.set('Authorization', `Bearer ${token}`); + } + return fetch(`${helpers.getAppUrl()}drain-node`, { method: 'POST', - headers: new Headers({ - Authorization: `Bearer ${getToken(cluster)}`, - ...JSON_HEADERS, - }), + headers, body: JSON.stringify({ cluster, nodeName, @@ -1865,12 +1886,18 @@ interface DrainNodeStatus { * @throws {Error} if the response is not ok */ export function drainNodeStatus(cluster: string, nodeName: string): Promise { + const headers = new Headers({ + ...JSON_HEADERS, + }); + + const token = getToken(cluster); + if (!!token) { + headers.set('Authorization', `Bearer ${token}`); + } + return fetch(`${helpers.getAppUrl()}drain-node-status?cluster=${cluster}&nodeName=${nodeName}`, { method: 'GET', - headers: new Headers({ - Authorization: `Bearer ${getToken(cluster)}`, - ...JSON_HEADERS, - }), + headers, }).then(response => { return response.json().then((data: DrainNodeStatus) => { if (!response.ok) {