Initial commit

This commit is contained in:
Ehmry - 2019-12-17 03:53:51 +00:00
commit b862e5f794
5 changed files with 116 additions and 0 deletions

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
hqtoxbot
result

18
flake.lock Normal file
View File

@ -0,0 +1,18 @@
{
"inputs": {
"nimble": {
"inputs": {
"nixpkgs": {
"inputs": {},
"narHash": "sha256-aLJ6PHTU1VbWBdyZbI/lLoj2JelUCGgovUsHlnAFIOE=",
"originalUrl": "nixpkgs",
"url": "git+file:///home/repo/nixpkgs?ref=genode-19.09&rev=cc2b10a7ed78f62dc2b3afa50d34d613c36e619e"
}
},
"narHash": "sha256-ZzL+Gdl1R7UJK1I8s/ff+aQVaMCB9pu0gFmTZJeb8mA=",
"originalUrl": "git+https://git.sr.ht/~ehmry/nimble_flake",
"url": "git+https://git.sr.ht/~ehmry/nimble_flake?ref=master&rev=11ee779063eb4c78f7bfa281e36e1cc3ae161635"
}
},
"version": 3
}

19
flake.nix Normal file
View File

@ -0,0 +1,19 @@
{
description = "C3D2 Tox bot";
edition = 201909;
inputs.nimble.uri = "git+https://git.sr.ht/~ehmry/nimble_flake";
outputs = { self, nimble }: {
packages.x86_64-linux.hqtoxbot =
nimble.defaultPackage.x86_64-linux.buildNimble {
name = "hqtoxbot";
src = self;
homepage = "https://gitea.c3d2.de/ehmry/hqtoxbot";
};
defaultPackage.x86_64-linux = self.packages.x86_64-linux.hqtoxbot;
};
}

12
hqtoxbot.nimble Normal file
View File

@ -0,0 +1,12 @@
# Package
version = "0.1.0"
author = "Emery Hemingway"
description = "A Tox bot for C3D2 HQ"
license = "GPL-3.0-or-later"
srcDir = "src"
bin = @["hqtoxbot"]
# Dependencies
requires "nim >= 1.0.0", "toxcore"

65
src/hqtoxbot.nim Normal file
View File

@ -0,0 +1,65 @@
import toxcore
import std/asyncdispatch, std/json, std/httpclient
const spaceApiUrl = "http://spaceapi.hq.c3d2.de:3000/spaceapi.json"
const adminIds = [
toAddress "DF0AC9107E0A30E7201C6832B017AC836FBD1EDAC390EE99B68625D73C3FD929FB47F1872CA4"
# Emery
]
proc bootstrap(bot: Tox) =
const servers = [ ("tox.neuland.technology", "15E9C309CFCB79FDDF0EBA057DABB49FE15F3803B1BFF06536AE2E5BA5E4690E".toPublicKey ) ]
for host, key in servers.items:
bot.bootstrap(host, key)
proc addAdmin(bot: Tox; id: Address) =
discard bot.addFriend(
id, "You have been granted administrative rights to " & bot.name)
proc setupCallbacks(bot: Tox) =
#[
bot.onConferenceInvite do (friend: Friend; kind: TOX_CONFERENCE_TYPE;
cookie: string):
discard bot.join(friend, cookie)
]#
bot.onFriendMessage do (f: Friend; msg: string; kind: TOX_MESSAGE_TYPE):
echo msg
for id in adminIds:
bot.addAdmin(id)
proc newBot(name: string): Tox =
result = newTox do (opts: Options):
opts.localDiscoveryEnabled = true
opts.ipv6Enabled = true
result.name = name
result.setupCallbacks()
result.bootstrap()
echo result.name, " is at ", result.address
proc updateStatus(bot: Tox; http: AsyncHttpClient) {.async.} =
let
rsp = await http.get(spaceApiUrl)
body = await rsp.body
space = parseJson body
status = $(space["status"])
if bot.statusMessage != status:
bot.statusMessage = $(space["status"])
proc main() =
let
bot = newBot("HQ Bot")
http = newAsyncHttpClient()
addTimer(20*1000, oneshot=false) do (fd: AsyncFD) -> bool:
asyncCheck updateStatus(bot, http)
while true:
iterate bot
poll bot.iterationInterval
main()