Improve .tokens output
This commit is contained in:
parent
7630f57f17
commit
4ccf350dc7
|
@ -1,5 +1,5 @@
|
|||
#i hate begging for this too em SPDX-License-Identifier: AGPL-3.0-only
|
||||
import asyncdispatch, times, json, random, strutils, tables
|
||||
#SPDX-License-Identifier: AGPL-3.0-only
|
||||
import asyncdispatch, times, json, random, strutils, tables, sets
|
||||
import types
|
||||
|
||||
# max requests at a time per account to avoid race conditions
|
||||
|
@ -19,14 +19,16 @@ proc getPoolJson*(): JsonNode =
|
|||
list = newJObject()
|
||||
totalReqs = 0
|
||||
totalPending = 0
|
||||
totalLimited = 0
|
||||
limited: HashSet[string]
|
||||
reqsPerApi: Table[string, int]
|
||||
|
||||
let now = epochTime().int
|
||||
|
||||
for account in accountPool:
|
||||
totalPending.inc(account.pending)
|
||||
list[account.id] = %*{
|
||||
|
||||
var includeAccount = false
|
||||
let accountJson = %*{
|
||||
"apis": newJObject(),
|
||||
"pending": account.pending,
|
||||
}
|
||||
|
@ -36,17 +38,18 @@ proc getPoolJson*(): JsonNode =
|
|||
apiStatus = account.apis[api]
|
||||
obj = %*{}
|
||||
|
||||
if apiStatus.limited:
|
||||
obj["limited"] = %true
|
||||
inc totalLimited
|
||||
|
||||
if apiStatus.reset > now.int:
|
||||
obj["remaining"] = %apiStatus.remaining
|
||||
|
||||
if "remaining" notin obj and not apiStatus.limited:
|
||||
continue
|
||||
|
||||
list[account.id]["apis"][$api] = obj
|
||||
if apiStatus.limited:
|
||||
obj["limited"] = %true
|
||||
limited.incl account.id
|
||||
|
||||
accountJson{"apis", $api} = obj
|
||||
includeAccount = true
|
||||
|
||||
let
|
||||
maxReqs =
|
||||
|
@ -64,9 +67,12 @@ proc getPoolJson*(): JsonNode =
|
|||
reqsPerApi[$api] = reqsPerApi.getOrDefault($api, 0) + reqs
|
||||
totalReqs.inc(reqs)
|
||||
|
||||
if includeAccount:
|
||||
list[account.id] = accountJson
|
||||
|
||||
return %*{
|
||||
"amount": accountPool.len,
|
||||
"limited": totalLimited,
|
||||
"limited": limited.card,
|
||||
"requests": totalReqs,
|
||||
"pending": totalPending,
|
||||
"apis": reqsPerApi,
|
||||
|
|
Loading…
Reference in New Issue