9 Commits

Author SHA1 Message Date
Arseniy Klempner
c55c694298
fix(sds): reexport proto codec, use set for missing messages 2025-03-26 21:57:52 -07:00
Arseniy Klempner
dd7663f378
feat(sds): add command queue, dispatch events 2025-03-25 14:03:02 -07:00
Arseniy Klempner
23a0dc1008
feat(sds): add retrieval hint to causal history 2025-03-13 12:10:51 -07:00
Arseniy Klempner
a7f97b7d04
feat(sds): adds ephemeral messages, delivered message callback and event 2025-03-13 11:54:44 -07:00
Arseniy Klempner
13ae5d4f73
feat(sds): send and receive sync messages 2025-03-13 11:29:55 -07:00
Arseniy Klempner
f7666a6588
feat(sds): adds logic to sweep incoming and outgoing buffers 2025-03-03 22:09:44 -08:00
Arseniy Klempner
389ca4062e
feat(sds): add message channel with buffers and send/receive logic
This commit creates the class for an SDS message channel, including
buffers for outgoing and incoming messages. Adds logic for sending
messages, receiving messages, delivering messages, and reviewing
acknowledgement status of messages. Also adds byte serialization
for bloom filters.
2025-02-21 14:12:29 -08:00
Arseniy Klempner
be93e4b71f
feat(sds): migrate bloomfilter to bigint and import hashn function from nim
Uses an array of bigint to store sufficient bits in bloom filter.
Updates all arithmetic to explicitly cast to bigint where necessary.
Makes the hashn function for bloomfilter a parameter.
Adds an implementation of hashn generated using nim compiler.
Adds tests.
2025-02-05 17:27:41 -08:00
Arseniy Klempner
468512fa85
feat(sds): create package for sds and add protobuf def
Adds a new package for the browser implementation of scalable data
sync. Ports some of the nim implementation of bloom filter to ts.
Adds protobuf definition for SDS messages.
2025-01-28 18:53:41 -08:00