mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-28 07:35:56 +00:00
Minor fixes for chat2 and store (#407)
This commit is contained in:
parent
307a49bb78
commit
398b701f4f
@ -48,6 +48,7 @@ type Chat = ref object
|
|||||||
connected: bool # if the node is connected to another peer
|
connected: bool # if the node is connected to another peer
|
||||||
started: bool # if the node has started
|
started: bool # if the node has started
|
||||||
nick: string # nickname for this chat session
|
nick: string # nickname for this chat session
|
||||||
|
prompt: bool # chat prompt is showing
|
||||||
|
|
||||||
type
|
type
|
||||||
PrivateKey* = crypto.PrivateKey
|
PrivateKey* = crypto.PrivateKey
|
||||||
@ -70,6 +71,12 @@ proc connectToNodes(c: Chat, nodes: seq[string]) {.async.} =
|
|||||||
await c.node.connectToNodes(nodes)
|
await c.node.connectToNodes(nodes)
|
||||||
c.connected = true
|
c.connected = true
|
||||||
|
|
||||||
|
proc showChatPrompt(c: Chat) =
|
||||||
|
if not c.prompt:
|
||||||
|
stdout.write(">> ")
|
||||||
|
stdout.flushFile()
|
||||||
|
c.prompt = true
|
||||||
|
|
||||||
proc selectRandomNode(): string =
|
proc selectRandomNode(): string =
|
||||||
randomize()
|
randomize()
|
||||||
let
|
let
|
||||||
@ -125,8 +132,7 @@ proc writeAndPrint(c: Chat) {.async.} =
|
|||||||
# echo "type /[help|?] for help"
|
# echo "type /[help|?] for help"
|
||||||
|
|
||||||
# Chat prompt
|
# Chat prompt
|
||||||
stdout.write(">> ")
|
showChatPrompt(c)
|
||||||
stdout.flushFile()
|
|
||||||
|
|
||||||
let line = await c.transp.readLine()
|
let line = await c.transp.readLine()
|
||||||
if line.startsWith("/help") or line.startsWith("/?") or not c.started:
|
if line.startsWith("/help") or line.startsWith("/?") or not c.started:
|
||||||
@ -212,7 +218,7 @@ proc processInput(rfd: AsyncFD, rng: ref BrHmacDrbgContext) {.async.} =
|
|||||||
let nick = await readNick(transp)
|
let nick = await readNick(transp)
|
||||||
echo "Welcome, " & nick & "!"
|
echo "Welcome, " & nick & "!"
|
||||||
|
|
||||||
var chat = Chat(node: node, transp: transp, subscribed: true, connected: false, started: true, nick: nick)
|
var chat = Chat(node: node, transp: transp, subscribed: true, connected: false, started: true, nick: nick, prompt: false)
|
||||||
|
|
||||||
if conf.staticnodes.len > 0:
|
if conf.staticnodes.len > 0:
|
||||||
await connectToNodes(chat, conf.staticnodes)
|
await connectToNodes(chat, conf.staticnodes)
|
||||||
@ -288,6 +294,8 @@ proc processInput(rfd: AsyncFD, rng: ref BrHmacDrbgContext) {.async.} =
|
|||||||
if decodedPayload.isOK():
|
if decodedPayload.isOK():
|
||||||
let payload = string.fromBytes(decodedPayload.get().payload)
|
let payload = string.fromBytes(decodedPayload.get().payload)
|
||||||
echo &"{payload}"
|
echo &"{payload}"
|
||||||
|
chat.prompt = false
|
||||||
|
showChatPrompt(chat)
|
||||||
info "Hit subscribe handler", topic, payload,
|
info "Hit subscribe handler", topic, payload,
|
||||||
contentTopic = msg.contentTopic
|
contentTopic = msg.contentTopic
|
||||||
else:
|
else:
|
||||||
@ -297,6 +305,8 @@ proc processInput(rfd: AsyncFD, rng: ref BrHmacDrbgContext) {.async.} =
|
|||||||
# No payload encoding/encryption from Waku
|
# No payload encoding/encryption from Waku
|
||||||
let payload = string.fromBytes(msg.payload)
|
let payload = string.fromBytes(msg.payload)
|
||||||
echo &"{payload}"
|
echo &"{payload}"
|
||||||
|
chat.prompt = false
|
||||||
|
showChatPrompt(chat)
|
||||||
info "Hit subscribe handler", topic, payload,
|
info "Hit subscribe handler", topic, payload,
|
||||||
contentTopic = msg.contentTopic
|
contentTopic = msg.contentTopic
|
||||||
else:
|
else:
|
||||||
|
@ -93,7 +93,7 @@ method getAll*(db: WakuMessageStore, onData: message_store.DataProc): MessageSto
|
|||||||
|
|
||||||
onData(uint64(timestamp), WakuMessage(contentTopic: ContentTopic(int(topic)), payload: @(toOpenArray(p, 0, l-1))))
|
onData(uint64(timestamp), WakuMessage(contentTopic: ContentTopic(int(topic)), payload: @(toOpenArray(p, 0, l-1))))
|
||||||
|
|
||||||
let res = db.database.query("SELECT timestamp, contentTopic, payload FROM messages", msg)
|
let res = db.database.query("SELECT timestamp, contentTopic, payload FROM messages ORDER BY timestamp ASC", msg)
|
||||||
if res.isErr:
|
if res.isErr:
|
||||||
return err("failed")
|
return err("failed")
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user