mirror of
				https://github.com/gethomepage/homepage.git
				synced 2025-11-03 19:17:03 -05:00 
			
		
		
		
	added tdarr widget
This commit is contained in:
		
							parent
							
								
									e7b0fc1419
								
							
						
					
					
						commit
						aaa1f76176
					
				@ -192,6 +192,12 @@
 | 
				
			|||||||
        "stopped": "Stopped",
 | 
					        "stopped": "Stopped",
 | 
				
			||||||
        "total": "Total"
 | 
					        "total": "Total"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "tdarr": {
 | 
				
			||||||
 | 
					        "queue": "Queue",
 | 
				
			||||||
 | 
					        "processed": "Processed",
 | 
				
			||||||
 | 
					        "errored": "Errored",
 | 
				
			||||||
 | 
					        "saved": "Saved"
 | 
				
			||||||
 | 
					    },     
 | 
				
			||||||
    "traefik": {
 | 
					    "traefik": {
 | 
				
			||||||
        "routers": "Routers",
 | 
					        "routers": "Routers",
 | 
				
			||||||
        "services": "Services",
 | 
					        "services": "Services",
 | 
				
			||||||
 | 
				
			|||||||
@ -43,6 +43,7 @@ const components = {
 | 
				
			|||||||
  speedtest: dynamic(() => import("./speedtest/component")),
 | 
					  speedtest: dynamic(() => import("./speedtest/component")),
 | 
				
			||||||
  strelaysrv: dynamic(() => import("./strelaysrv/component")),
 | 
					  strelaysrv: dynamic(() => import("./strelaysrv/component")),
 | 
				
			||||||
  tautulli: dynamic(() => import("./tautulli/component")),
 | 
					  tautulli: dynamic(() => import("./tautulli/component")),
 | 
				
			||||||
 | 
					  tdarr: dynamic(() => import("./tdarr/component")),
 | 
				
			||||||
  traefik: dynamic(() => import("./traefik/component")),
 | 
					  traefik: dynamic(() => import("./traefik/component")),
 | 
				
			||||||
  transmission: dynamic(() => import("./transmission/component")),
 | 
					  transmission: dynamic(() => import("./transmission/component")),
 | 
				
			||||||
  tubearchivist: dynamic(() => import("./tubearchivist/component")),
 | 
					  tubearchivist: dynamic(() => import("./tubearchivist/component")),
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										45
									
								
								src/widgets/tdarr/component.jsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								src/widgets/tdarr/component.jsx
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,45 @@
 | 
				
			|||||||
 | 
					import { useTranslation } from "next-i18next";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import Container from "components/services/widget/container";
 | 
				
			||||||
 | 
					import Block from "components/services/widget/block";
 | 
				
			||||||
 | 
					import useWidgetAPI from "utils/proxy/use-widget-api";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default function Component({ service }) {
 | 
				
			||||||
 | 
					  const { t } = useTranslation();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const { widget } = service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const { data: tdarrData, error: tdarrError } = useWidgetAPI(widget);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (tdarrError) {
 | 
				
			||||||
 | 
					    return <Container error={tdarrError} />;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (!tdarrData) {
 | 
				
			||||||
 | 
					    return (
 | 
				
			||||||
 | 
					      <Container service={service}>
 | 
				
			||||||
 | 
					        <Block label="tdarr.queue" />
 | 
				
			||||||
 | 
					        <Block label="tdarr.processed" />
 | 
				
			||||||
 | 
					        <Block label="tdarr.errored" />
 | 
				
			||||||
 | 
					        <Block label="tdarr.saved" />
 | 
				
			||||||
 | 
					      </Container>
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  // const { torrents } = tdarrData.arguments;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const queue = parseInt(tdarrData.table1Count) + parseInt(tdarrData.table4Count);
 | 
				
			||||||
 | 
					  const processed = parseInt(tdarrData.table2Count) + parseInt(tdarrData.table5Count);
 | 
				
			||||||
 | 
					  const errored = parseInt(tdarrData.table3Count) + parseInt(tdarrData.table6Count);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const saved = parseFloat(tdarrData.sizeDiff) * 1000000000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  return (
 | 
				
			||||||
 | 
					    <Container service={service}>
 | 
				
			||||||
 | 
					      <Block label="tdarr.queue" value={t("common.number", { value: queue })} />
 | 
				
			||||||
 | 
					      <Block label="tdarr.processed" value={t("common.number", { value: processed })} />
 | 
				
			||||||
 | 
					      <Block label="tdarr.errored" value={t("common.number", { value: errored })} />
 | 
				
			||||||
 | 
					      <Block label="tdarr.saved" value={t("common.bytes", { value: saved })} />    
 | 
				
			||||||
 | 
					    </Container>
 | 
				
			||||||
 | 
					  );
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										58
									
								
								src/widgets/tdarr/proxy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								src/widgets/tdarr/proxy.js
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,58 @@
 | 
				
			|||||||
 | 
					import { httpProxy } from "utils/proxy/http";
 | 
				
			||||||
 | 
					import { formatApiCall } from "utils/proxy/api-helpers";
 | 
				
			||||||
 | 
					import getServiceWidget from "utils/config/service-helpers";
 | 
				
			||||||
 | 
					import createLogger from "utils/logger";
 | 
				
			||||||
 | 
					import widgets from "widgets/widgets";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const proxyName = "tdarrProxyHandler";
 | 
				
			||||||
 | 
					const logger = createLogger(proxyName);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default async function tdarrProxyHandler(req, res) {
 | 
				
			||||||
 | 
					  const { group, service, endpoint } = req.query;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (!group || !service) {
 | 
				
			||||||
 | 
					    logger.debug("Invalid or missing service '%s' or group '%s'", service, group);
 | 
				
			||||||
 | 
					    return res.status(400).json({ error: "Invalid proxy service type" });
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const widget = await getServiceWidget(group, service);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (!widget) {
 | 
				
			||||||
 | 
					    logger.debug("Invalid or missing widget for service '%s' in group '%s'", service, group);
 | 
				
			||||||
 | 
					    return res.status(400).json({ error: "Invalid proxy service type" });
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint, ...widget }));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const method = "POST";
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					  const headers = {
 | 
				
			||||||
 | 
					    "content-type": "application/json",
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const body = JSON.stringify({
 | 
				
			||||||
 | 
					    "data": {
 | 
				
			||||||
 | 
					      "collection": "StatisticsJSONDB",
 | 
				
			||||||
 | 
					      "mode": "getById",
 | 
				
			||||||
 | 
					      "docID": "statistics"
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  let [status, contentType, data, responseHeaders] = await httpProxy(url, {
 | 
				
			||||||
 | 
					    method,
 | 
				
			||||||
 | 
					    body,
 | 
				
			||||||
 | 
					    headers,
 | 
				
			||||||
 | 
					  });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (status !== 200) {
 | 
				
			||||||
 | 
					    logger.error("Error getting data from Tdarr: %d.  Data: %s", status, data);
 | 
				
			||||||
 | 
					    return res.status(500).send({error: {message:"Error getting data from Tdarr", url, data}});
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (contentType) res.setHeader("Content-Type", contentType);
 | 
				
			||||||
 | 
					  return res.status(status).send(data);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										8
									
								
								src/widgets/tdarr/widget.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/widgets/tdarr/widget.js
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,8 @@
 | 
				
			|||||||
 | 
					import tdarrProxyHandler from "./proxy";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const widget = {
 | 
				
			||||||
 | 
					  api: "{url}/api/v2/cruddb",
 | 
				
			||||||
 | 
					  proxyHandler: tdarrProxyHandler,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default widget;
 | 
				
			||||||
@ -38,6 +38,7 @@ import sonarr from "./sonarr/widget";
 | 
				
			|||||||
import speedtest from "./speedtest/widget";
 | 
					import speedtest from "./speedtest/widget";
 | 
				
			||||||
import strelaysrv from "./strelaysrv/widget";
 | 
					import strelaysrv from "./strelaysrv/widget";
 | 
				
			||||||
import tautulli from "./tautulli/widget";
 | 
					import tautulli from "./tautulli/widget";
 | 
				
			||||||
 | 
					import tdarr from "./tdarr/widget";
 | 
				
			||||||
import traefik from "./traefik/widget";
 | 
					import traefik from "./traefik/widget";
 | 
				
			||||||
import transmission from "./transmission/widget";
 | 
					import transmission from "./transmission/widget";
 | 
				
			||||||
import tubearchivist from "./tubearchivist/widget";
 | 
					import tubearchivist from "./tubearchivist/widget";
 | 
				
			||||||
@ -87,6 +88,7 @@ const widgets = {
 | 
				
			|||||||
  speedtest,
 | 
					  speedtest,
 | 
				
			||||||
  strelaysrv,
 | 
					  strelaysrv,
 | 
				
			||||||
  tautulli,
 | 
					  tautulli,
 | 
				
			||||||
 | 
					  tdarr,
 | 
				
			||||||
  traefik,
 | 
					  traefik,
 | 
				
			||||||
  transmission,
 | 
					  transmission,
 | 
				
			||||||
  tubearchivist,
 | 
					  tubearchivist,
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user