From 1b66681eb9db1916461e077a3f4380fc7bb68372 Mon Sep 17 00:00:00 2001 From: Jan Betley Date: Mon, 24 Apr 2023 16:15:31 +0200 Subject: [PATCH] draft of the interface --- README.md | 37 ++++++++++++++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index f88bdc29..6e635928 100644 --- a/README.md +++ b/README.md @@ -1 +1,36 @@ -# golem-ray \ No newline at end of file +# golem-ray + +## Interface + +``` +async with GolemNode() as golem: + # PaymentManager: + # * Creates/recreates allocations + # * Manages budget + # * Accepts debit notes/invoices + payment_manager = PaymentManager(golem) + + # ActivityManager: + # * On request creates/terminates activities + # * Keeps internal state of a cluster and updates it: + # * When activities are created/terminated + # * When provider dies (--> checks activity state every 5s or so) + # * Keeps cached demands, proposals etc to speed up activity creation + # * Manages a Network object and adds all new activities to the network + activity_manager = ActivityManager(golem) + + tasks = ( + asyncio.create_task(payment_manager.run()), + asyncio.create_task(activity_manager.run()), + ) + + new_nodes = await activity_manager.add_nodes({"min_cpu": 2}) + print(new_nodes) + # [{some_id: {"ip": "192.168.0.2"}}] + print(activity_manager.cluster_state) + # {{"nodes": { some_id: {"ip": "192.168.0.2"}}}, ...} + + await cluster_manager.terminate_nodes([some_id]) + print(activity_manager.cluster_state) + # {"nodes": {}} +```