40 lines
1.2 KiB
Plaintext
40 lines
1.2 KiB
Plaintext
import "date"
|
|
|
|
|
|
runTask = (start,stop,srcBucket,destBucket,destMeasurement) => {
|
|
|
|
data = from(bucket: srcBucket)
|
|
|> range(start: start,stop: stop)
|
|
|> filter(fn: (r) => r._measurement == "vaa_volume_v2" and r._field == "volume")
|
|
|> group(columns: ["emitter_chain", "destination_chain", "app_id"])
|
|
|
|
data
|
|
|> sum(column: "_value")
|
|
|> set(key: "_field", value: "volume")
|
|
|> map(fn: (r) => ({ r with _time: start }))
|
|
|> set(key: "to", value: string(v:date.add(d: 1h, to: start)))
|
|
|> set(key: "_measurement", value: destMeasurement)
|
|
|> to(bucket: destBucket)
|
|
|
|
return data
|
|
|> count(column: "_value")
|
|
|> set(key: "_field", value: "count")
|
|
|> map(fn: (r) => ({ r with _time: start }))
|
|
|> set(key: "to", value: string(v:date.add(d: 1h, to: start)))
|
|
|> set(key: "_measurement", value: destMeasurement)
|
|
|> to(bucket: destBucket)
|
|
}
|
|
|
|
|
|
bucketInfinite = "wormscan"
|
|
destMeasurement = "chain_activity_1h"
|
|
|
|
stop = date.truncate(t: now(),unit: 1h)
|
|
start = date.sub(d: 1h, from: stop)
|
|
|
|
option task = {
|
|
name: "calculate chain activity every hour",
|
|
every: 1h,
|
|
}
|
|
|
|
runTask(start:start, stop: stop, srcBucket: bucketInfinite, destBucket: bucketInfinite, destMeasurement: destMeasurement) |