2024-03-13 14:59:27 +01:00
|
|
|
from dataclasses import dataclass
|
2025-01-29 10:42:53 +00:00
|
|
|
from typing import List, Generator
|
2024-02-12 15:35:23 +01:00
|
|
|
|
2025-06-04 15:44:15 +02:00
|
|
|
from da.common import NodeId, Column
|
2024-02-12 15:35:23 +01:00
|
|
|
from da.encoder import EncodedData
|
2025-06-04 15:31:52 +02:00
|
|
|
from da.verifier import DAShare
|
2024-02-12 15:35:23 +01:00
|
|
|
|
|
|
|
|
|
2024-03-13 14:59:27 +01:00
|
|
|
@dataclass
|
|
|
|
|
class DispersalSettings:
|
|
|
|
|
nodes_ids: List[NodeId]
|
|
|
|
|
threshold: int
|
|
|
|
|
|
|
|
|
|
|
2024-02-12 15:35:23 +01:00
|
|
|
class Dispersal:
|
2024-03-13 14:59:27 +01:00
|
|
|
def __init__(self, settings: DispersalSettings):
|
|
|
|
|
self.settings = settings
|
2024-03-15 11:34:43 +01:00
|
|
|
# sort over public keys
|
2025-01-29 10:42:53 +00:00
|
|
|
self.settings.nodes_ids.sort()
|
2024-02-12 15:35:23 +01:00
|
|
|
|
2025-06-04 15:31:52 +02:00
|
|
|
def _prepare_data(self, encoded_data: EncodedData) -> Generator[DAShare, None, None]:
|
2024-03-08 14:16:14 +01:00
|
|
|
columns = encoded_data.extended_matrix.columns
|
2024-02-12 15:35:23 +01:00
|
|
|
row_commitments = encoded_data.row_commitments
|
2025-06-04 15:44:15 +02:00
|
|
|
column_proofs = encoded_data.combined_column_proofs
|
|
|
|
|
blobs_data = zip(columns, column_proofs)
|
|
|
|
|
for column_idx, (column, proof) in enumerate(blobs_data):
|
2025-06-04 15:31:52 +02:00
|
|
|
blob = DAShare(
|
2025-06-04 15:44:15 +02:00
|
|
|
Column(column),
|
2025-01-29 10:42:53 +00:00
|
|
|
column_idx,
|
2025-06-04 15:44:15 +02:00
|
|
|
proof,
|
|
|
|
|
row_commitments
|
2024-02-12 15:35:23 +01:00
|
|
|
)
|
|
|
|
|
yield blob
|
|
|
|
|
|
2025-06-04 15:31:52 +02:00
|
|
|
def _send_and_await_response(self, node: NodeId, blob: DAShare) -> bool:
|
2024-02-12 15:35:23 +01:00
|
|
|
pass
|
|
|
|
|
|
2025-01-29 10:42:53 +00:00
|
|
|
def disperse(self, encoded_data: EncodedData):
|
2024-03-14 12:20:46 +01:00
|
|
|
blob_data = zip(
|
|
|
|
|
self.settings.nodes_ids,
|
|
|
|
|
self._prepare_data(encoded_data)
|
|
|
|
|
)
|
2025-01-29 10:42:53 +00:00
|
|
|
for node, blob in blob_data:
|
|
|
|
|
self._send_and_await_response(node, blob)
|
|
|
|
|
|