mirror of
https://github.com/logos-messaging/logos-messaging-python-bindings.git
synced 2026-02-23 07:03:39 +00:00
Add rest of wrappers
This commit is contained in:
parent
cab26c889f
commit
36a8b2945d
176
waku/wrapper.py
176
waku/wrapper.py
@ -18,6 +18,38 @@ int logosdelivery_start_node(
|
||||
FFICallBack callback,
|
||||
void *userData
|
||||
);
|
||||
|
||||
int logosdelivery_stop_node(
|
||||
void *ctx,
|
||||
FFICallBack callback,
|
||||
void *userData
|
||||
);
|
||||
|
||||
void logosdelivery_set_event_callback(
|
||||
void *ctx,
|
||||
FFICallBack callback,
|
||||
void *userData
|
||||
);
|
||||
|
||||
int logosdelivery_destroy(
|
||||
void *ctx,
|
||||
FFICallBack callback,
|
||||
void *userData
|
||||
);
|
||||
|
||||
int logosdelivery_subscribe(
|
||||
void *ctx,
|
||||
FFICallBack callback,
|
||||
void *userData,
|
||||
const char *contentTopic
|
||||
);
|
||||
|
||||
int logosdelivery_unsubscribe(
|
||||
void *ctx,
|
||||
FFICallBack callback,
|
||||
void *userData,
|
||||
const char *contentTopic
|
||||
);
|
||||
""")
|
||||
|
||||
_repo_root = Path(__file__).resolve().parents[1]
|
||||
@ -25,29 +57,112 @@ lib = ffi.dlopen(str(_repo_root / "lib" / "liblogosdelivery.so"))
|
||||
|
||||
CallbackType = ffi.callback("void(int, const char*, size_t, void*)")
|
||||
|
||||
class NodeHandle:
|
||||
def __init__(self, ctx, cb_handle):
|
||||
|
||||
class NodeWrapper:
|
||||
def __init__(self, ctx, config_buffer):
|
||||
self.ctx = ctx
|
||||
self._cb_handle = cb_handle # keep callback alive
|
||||
self._config_buffer = config_buffer
|
||||
self._event_cb_handler = None
|
||||
|
||||
def logosdelivery_create_node(config: dict, py_callback):
|
||||
config_json = json.dumps(config, separators=(",", ":"), ensure_ascii=False)
|
||||
cnfig_bytes = config_json.encode("utf-8")
|
||||
|
||||
def c_cb(ret, char_p, length, userData):
|
||||
if char_p != ffi.NULL and length :
|
||||
@staticmethod
|
||||
def _make_cb(py_callback):
|
||||
def c_cb(ret, char_p, length, userData):
|
||||
msg = ffi.buffer(char_p, length)[:]
|
||||
else :
|
||||
msg = b""
|
||||
py_callback(ret, msg)
|
||||
py_callback(ret, msg)
|
||||
|
||||
return CallbackType(c_cb)
|
||||
|
||||
@classmethod
|
||||
def create_node(cls, config: dict, py_callback):
|
||||
config_json = json.dumps(config, separators=(",", ":"), ensure_ascii=False)
|
||||
config_buffer = ffi.new("char[]", config_json.encode("utf-8"))
|
||||
|
||||
cb = cls._make_cb(py_callback)
|
||||
|
||||
ctx = lib.logosdelivery_create_node(
|
||||
config_buffer,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
)
|
||||
|
||||
return cls(ctx, config_buffer)
|
||||
|
||||
def start_node(self, py_callback):
|
||||
cb = self._make_cb(py_callback)
|
||||
|
||||
ret = lib.logosdelivery_start_node(
|
||||
self.ctx,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
)
|
||||
|
||||
return int(ret)
|
||||
|
||||
@classmethod
|
||||
def create_and_start(cls, config: dict, create_cb, start_cb):
|
||||
node = cls.create_node(config, create_cb)
|
||||
rc = node.start_node(start_cb)
|
||||
return node, rc
|
||||
|
||||
def stop_node(self, py_callback):
|
||||
cb = self._make_cb(py_callback)
|
||||
|
||||
ret = lib.logosdelivery_stop_node(
|
||||
self.ctx,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
)
|
||||
|
||||
return int(ret)
|
||||
|
||||
self._event_cb_handler = cb
|
||||
|
||||
def destroy(self, py_callback):
|
||||
cb = self._make_cb(py_callback)
|
||||
|
||||
ret = lib.logosdelivery_destroy(
|
||||
self.ctx,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
)
|
||||
|
||||
return int(ret)
|
||||
|
||||
def stop_and_destroy(self, callback):
|
||||
stop_rc = self.stop_node(callback)
|
||||
if stop_rc != 0:
|
||||
raise RuntimeError(f"Stop failed (ret={stop_rc})")
|
||||
|
||||
destroy_rc = self.destroy(callback)
|
||||
if destroy_rc != 0:
|
||||
raise RuntimeError(f"Destroy failed (ret={destroy_rc})")
|
||||
|
||||
return 0
|
||||
|
||||
def subscribe_content_topic(self, content_topic: str, py_callback):
|
||||
cb = self._make_cb(py_callback)
|
||||
|
||||
ret = lib.logosdelivery_subscribe(
|
||||
self.ctx,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
content_topic.encode("utf-8"),
|
||||
)
|
||||
|
||||
return int(ret)
|
||||
|
||||
def unsubscribe_content_topic(self, content_topic: str, py_callback):
|
||||
cb = self._make_cb(py_callback)
|
||||
|
||||
ret = lib.logosdelivery_unsubscribe(
|
||||
self.ctx,
|
||||
cb,
|
||||
ffi.NULL,
|
||||
content_topic.encode("utf-8"),
|
||||
)
|
||||
|
||||
return int(ret)
|
||||
|
||||
cb_handle = CallbackType(c_cb)
|
||||
ctx = lib.logosdelivery_create_node(
|
||||
cnfig_bytes,
|
||||
cb_handle,
|
||||
ffi.NULL,
|
||||
)
|
||||
return NodeHandle(ctx, cb_handle)
|
||||
|
||||
if __name__ == "__main__":
|
||||
config = {
|
||||
@ -57,7 +172,7 @@ if __name__ == "__main__":
|
||||
"entryNodes": [
|
||||
"/dns4/node-01.do-ams3.misc.logos-chat.status.im/tcp/30303/p2p/16Uiu2HAkxoqUTud5LUPQBRmkeL2xP4iKx2kaABYXomQRgmLUgf78"
|
||||
],
|
||||
"clusterId": 3,
|
||||
"clusterId": 42,
|
||||
"autoShardingConfig": {"numShardsInCluster": 8},
|
||||
},
|
||||
"networkingConfig": {
|
||||
@ -68,8 +183,21 @@ if __name__ == "__main__":
|
||||
}
|
||||
|
||||
def cb(ret, msg):
|
||||
print("ret:", ret)
|
||||
print("msg:", msg)
|
||||
print("ret:", ret, "msg:", msg)
|
||||
|
||||
h = logosdelivery_create_node(config, cb)
|
||||
print("ctx:", h.ctx)
|
||||
node = NodeWrapper.create_node(config, cb)
|
||||
rc = node.start_node(cb)
|
||||
print("start rc:", rc)
|
||||
|
||||
topic = "/myapp/1/chat/proto"
|
||||
rc = node.subscribe(topic, cb)
|
||||
print("subscribe rc:", rc)
|
||||
|
||||
rc = node.unsubscribe(topic, cb)
|
||||
print("unsubscribe rc:", rc)
|
||||
|
||||
rc = node.stop_node(cb)
|
||||
print("stop rc:", rc)
|
||||
|
||||
rc = node.destroy(cb)
|
||||
print("destroy rc:", rc)
|
||||
Loading…
x
Reference in New Issue
Block a user