parent
7b4f360a5e
commit
057d5eca8f
@ -0,0 +1,79 @@
|
|||||||
|
import useSWR from "swr";
|
||||||
|
|
||||||
|
import Widget from "../widget";
|
||||||
|
import Block from "../block";
|
||||||
|
import { useState } from "react";
|
||||||
|
|
||||||
|
export default function Npm({ service }) {
|
||||||
|
const config = service.widget;
|
||||||
|
const { url } = config;
|
||||||
|
|
||||||
|
const [token, setToken] = useState();
|
||||||
|
|
||||||
|
const fetcher = async (reqUrl) => {
|
||||||
|
const { url, email, password } = config;
|
||||||
|
const urlConstructed = `${url}/api/tokens`;
|
||||||
|
const body = { identity: email, secret: password };
|
||||||
|
|
||||||
|
if (!token) {
|
||||||
|
const res = await fetch(urlConstructed, {
|
||||||
|
method: "POST",
|
||||||
|
body: JSON.stringify(body),
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.then((response) => response.json())
|
||||||
|
.then(
|
||||||
|
async (data) =>
|
||||||
|
await fetch(reqUrl, {
|
||||||
|
method: "GET",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: "Bearer " + data.token,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
);
|
||||||
|
return res.json();
|
||||||
|
} else {
|
||||||
|
const resp = await fetch(reqUrl, {
|
||||||
|
method: "GET",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
Authorization: "Bearer " + token,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
return resp.json();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data: infoData, error: infoError } = useSWR(`${url}/api/nginx/proxy-hosts`, fetcher);
|
||||||
|
|
||||||
|
console.log(infoData);
|
||||||
|
|
||||||
|
if (infoError) {
|
||||||
|
return <Widget error="NGINX Proxy Manager API Error" />;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!infoData) {
|
||||||
|
return (
|
||||||
|
<Widget>
|
||||||
|
<Block label="Running" />
|
||||||
|
<Block label="Stopped" />
|
||||||
|
<Block label="Total" />
|
||||||
|
</Widget>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const enabled = infoData.filter((c) => c.enabled === 1).length;
|
||||||
|
const disabled = infoData.filter((c) => c.enabled === 0).length;
|
||||||
|
const total = infoData.length;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Widget>
|
||||||
|
<Block label="Enabled" value={enabled} />
|
||||||
|
<Block label="Disabled" value={disabled} />
|
||||||
|
<Block label="Total" value={total} />
|
||||||
|
</Widget>
|
||||||
|
);
|
||||||
|
}
|
Loading…
Reference in new issue