diff --git a/zoldank/0rbit-News-Feed.lua b/zoldank/0rbit-News-Feed.lua new file mode 100644 index 00000000..287a3a80 --- /dev/null +++ b/zoldank/0rbit-News-Feed.lua @@ -0,0 +1,72 @@ +-- ao.id 5mxjA9LqVrd8WGnVTOiaY2VQzacoHOUCkRL2SD_lpzg + + +local json = require("json") +local _0RBIT = "WSXUI2JjYUldJ7CKq9wE1MGwXs-ldzlUlHOQszwQe0s" +local URL = "https://api.theblockbeats.news/v1/open-api/open-flash?size=5&page=1&type=push" +ReceivedData = ReceivedData or {} + +Handlers.add( + "Get-Request", + Handlers.utils.hasMatchingTag("Action", "Sponsored-Get-Request"), + function(msg) + Send({ + Target = _0RBIT, + Action = "Get-Real-Data", + Url = URL + }) + print("GET Request sent to the 0rbit process.") + end +) + +Handlers.add( + "Receive-Data", + Handlers.utils.hasMatchingTag("Action", "Receive-Response"), + function(msg) + if not msg.Data then + print("No data received.") + return + end + + local res = json.decode(msg.Data) + + ReceivedData1 = res.data.data + local extractedData = {} + for k, v in ipairs(ReceivedData1) do + table.insert(extractedData, { + title = v.title, + description = v.content + }) + ReceivedData = extractedData + + end + print("Processed data: " .. json.encode(ReceivedData1)) + end +) + +local function getLatestData(msg) + local data = json.encode(ReceivedData) + Handlers.utils.reply(data)(msg) + print("Latest data sent: " .. data) +end + +Handlers.add( + "GetLatestData", + Handlers.utils.hasMatchingTag("Action", "Get-Latest-Data"), + getLatestData +) + +local function fetchNewsPeriodically() + Send({ + Target = _0RBIT, + Action = "Get-Real-Data", + Url = URL + }) + print("Periodic GET Request sent to the 0rbit process.") +end + +Handlers.add( + "CronTick", + Handlers.utils.hasMatchingTag("Action", "Cron"), + fetchNewsPeriodically +) \ No newline at end of file diff --git a/zoldank/0rbit-News-Feed.lua.png.png b/zoldank/0rbit-News-Feed.lua.png.png new file mode 100644 index 00000000..64d6ef1f Binary files /dev/null and b/zoldank/0rbit-News-Feed.lua.png.png differ diff --git a/zoldank/0rbit-Price-Feed.lua b/zoldank/0rbit-Price-Feed.lua new file mode 100644 index 00000000..44a85326 --- /dev/null +++ b/zoldank/0rbit-Price-Feed.lua @@ -0,0 +1,57 @@ +-- PID -vyO_5wHCgCC_Dgktqf7ihf1KRIy2goY-vZELjWuugM + +local json = require("json") + +_ORBIT = "WSXUI2JjYUldJ7CKq9wE1MGwXs-ldzlUlHOQszwQe0s" + +function handleError(msg, errorMessage) + ao.send({ + Target = msg.From, + Tags = { + Action = "Error", + ["Message-Id"] = msg.Id, + Error = errorMessage + } + }) +end + +Handlers.add("zoldank", + Handlers.utils.hasMatchingTag("Action", "Sponsored-Get-Request"), + function(msg) + local token = msg.Tags.Token + if not token then + handleError(msg, "Token not provided") + return + end + + local url = "https://api.coingecko.com/api/v3/simple/price?ids=" .. token .. "&vs_currencies=usd" + ao.send({ + Target = _ORBIT, + Action = "Get-Real-Data", + Url = url + }) + print("Pricefetch request sent for " .. token) + end +) + +Handlers.add("ReceiveData", + Handlers.utils.hasMatchingTag("Action", "Receive-Response"), + function(msg) + print("Received data: " .. msg.Data) + local res = json.decode(msg.Data) + local token = msg.Tags.Token + if res[token] and res[token].usd then + ao.send({ + Target = msg.From, + Tags = { + Action = "Price-Response", + ["Message-Id"] = msg.Id, + Price = res[token].usd + } + }) + print("Price of " .. token .. " is " .. res[token].usd) + else + handleError(msg, "Failed to fetch price") + end + end +) diff --git a/zoldank/0rbit-Price-Feed.png b/zoldank/0rbit-Price-Feed.png new file mode 100644 index 00000000..f081bc62 Binary files /dev/null and b/zoldank/0rbit-Price-Feed.png differ