mirror of
				https://github.com/karl0ss/homepage.git
				synced 2025-10-22 11:13:57 +01:00 
			
		
		
		
	Add flood widget
This commit is contained in:
		
							parent
							
								
									df5ff48000
								
							
						
					
					
						commit
						7087ed80cc
					
				| @ -70,6 +70,12 @@ | ||||
|         "bitrate": "Bitrate", | ||||
|         "no_active": "No Active Streams" | ||||
|     }, | ||||
|     "flood": { | ||||
|         "download": "Download", | ||||
|         "upload": "Upload", | ||||
|         "leech": "Leech", | ||||
|         "seed": "Seed" | ||||
|     }, | ||||
|     "changedetectionio": { | ||||
|         "totalObserved": "Total Observed", | ||||
|         "diffsDetected": "Diffs Detected" | ||||
|  | ||||
| @ -11,6 +11,7 @@ const components = { | ||||
|   diskstation: dynamic(() => import("./diskstation/component")), | ||||
|   docker: dynamic(() => import("./docker/component")), | ||||
|   emby: dynamic(() => import("./emby/component")), | ||||
|   flood: dynamic(() => import("./flood/component")), | ||||
|   gluetun: dynamic(() => import("./gluetun/component")), | ||||
|   gotify: dynamic(() => import("./gotify/component")), | ||||
|   hdhomerun: dynamic(() => import("./hdhomerun/component")), | ||||
|  | ||||
							
								
								
									
										53
									
								
								src/widgets/flood/component.jsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								src/widgets/flood/component.jsx
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,53 @@ | ||||
| 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: torrentData, error: torrentError } = useWidgetAPI(widget, "torrents"); | ||||
| 
 | ||||
|   if (torrentError) { | ||||
|     return <Container error={torrentError} />; | ||||
|   } | ||||
| 
 | ||||
|   if (!torrentData) { | ||||
|     return ( | ||||
|       <Container service={service}> | ||||
|         <Block label="flood.leech" /> | ||||
|         <Block label="flood.download" /> | ||||
|         <Block label="flood.seed" /> | ||||
|         <Block label="flood.upload" /> | ||||
|       </Container> | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   let rateDl = 0; | ||||
|   let rateUl = 0; | ||||
|   let completed = 0; | ||||
|   let leech = 0; | ||||
| 
 | ||||
|   for (var torrent in torrentData.torrents) { | ||||
|     rateDl += torrentData.torrents[torrent].downRate; | ||||
|     rateUl += torrentData.torrents[torrent].upRate; | ||||
|     if(torrentData.torrents[torrent].status.includes('complete')){ | ||||
|       completed += 1; | ||||
|     } | ||||
|     if(torrentData.torrents[torrent].status.includes('downloading')){ | ||||
|       leech += 1; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <Container service={service}> | ||||
|       <Block label="flood.leech" value={t("common.number", { value: leech })} /> | ||||
|       <Block label="flood.download" value={t("common.bitrate", { value: rateDl })} /> | ||||
|       <Block label="flood.seed" value={t("common.number", { value: completed })} /> | ||||
|       <Block label="flood.upload" value={t("common.bitrate", { value: rateUl })} /> | ||||
|     </Container> | ||||
|   ); | ||||
| } | ||||
							
								
								
									
										61
									
								
								src/widgets/flood/proxy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								src/widgets/flood/proxy.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,61 @@ | ||||
| import { formatApiCall } from "utils/proxy/api-helpers"; | ||||
| import { httpProxy } from "utils/proxy/http"; | ||||
| import getServiceWidget from "utils/config/service-helpers"; | ||||
| import createLogger from "utils/logger"; | ||||
| 
 | ||||
| const logger = createLogger("floodProxyHandler"); | ||||
| 
 | ||||
| async function login(widget) { | ||||
|   logger.debug("flood is rejecting the request, logging in."); | ||||
|   const loginUrl = new URL(`${widget.url}/api/auth/authenticate`).toString(); | ||||
|   const loginHeaders = { | ||||
|     "Accept-Encoding": "application/json" | ||||
|   }; | ||||
|   if (widget.username && widget.password) { | ||||
|     loginHeaders.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}` | ||||
|   } | ||||
| 
 | ||||
|   const loginParams = { method: "POST", loginHeaders }; | ||||
| 
 | ||||
|   // eslint-disable-next-line no-unused-vars
 | ||||
|   const [status, contentType, data] = await httpProxy(loginUrl, loginParams); | ||||
|   return [status, data]; | ||||
| } | ||||
| 
 | ||||
| export default async function floodProxyHandler(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("{url}/api/{endpoint}", { endpoint, ...widget })); | ||||
|   const params = { method: "GET", headers: {} }; | ||||
| 
 | ||||
|   let [status, contentType, data] = await httpProxy(url, params); | ||||
|   if (status === 401) { | ||||
|     [status, data] = await login(widget); | ||||
| 
 | ||||
|     if (status !== 200) { | ||||
|       logger.error("HTTP %d logging in to flood.  Data: %s", status, data); | ||||
|       return res.status(status).end(data); | ||||
|     } | ||||
| 
 | ||||
|     [status, contentType, data] = await httpProxy(url, params); | ||||
|   } | ||||
| 
 | ||||
|   if (status !== 200) { | ||||
|     logger.error("HTTP %d getting data from flood.  Data: %s", status, data); | ||||
|   } | ||||
| 
 | ||||
|   if (contentType) res.setHeader("Content-Type", contentType); | ||||
|   return res.status(status).send(data); | ||||
| } | ||||
							
								
								
									
										7
									
								
								src/widgets/flood/widget.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								src/widgets/flood/widget.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| import floodProxyHandler from "./proxy"; | ||||
| 
 | ||||
| const widget = { | ||||
|   proxyHandler: floodProxyHandler, | ||||
| }; | ||||
| 
 | ||||
| export default widget; | ||||
| @ -7,6 +7,7 @@ import coinmarketcap from "./coinmarketcap/widget"; | ||||
| import deluge from "./deluge/widget"; | ||||
| import diskstation from "./diskstation/widget"; | ||||
| import emby from "./emby/widget"; | ||||
| import flood from "./flood/widget"; | ||||
| import gluetun from "./gluetun/widget"; | ||||
| import gotify from "./gotify/widget"; | ||||
| import hdhomerun from "./hdhomerun/widget"; | ||||
| @ -54,6 +55,7 @@ const widgets = { | ||||
|   deluge, | ||||
|   diskstation, | ||||
|   emby, | ||||
|   flood, | ||||
|   gluetun, | ||||
|   gotify, | ||||
|   hdhomerun, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 JigSawFr
						JigSawFr