Diode is a serverless P2P collaboration suite. It offers chat, file sharing, network sharing and more features usually found in centralized cloud applications such as slack, microsoft teams or discord. With it's peer to peer model similiar to BitTorrent it's decentralized and resilient. But it also has a unique availability problem compared to centralized applications when no peers are online.
This project addresses this issue by defining the Diode Zone Availability canisters to keep Diode zones data available even if no diode peer is online. For this it's using the IC decentralized large storage capabilities.
Currently the cost for Storing 1GiB of data on the IC is ($5.36 USD/year)[https://internetcomputer.org/docs/current/developer-docs/gas-cost#storage]. With just a fraction of this cost availability for encrypted messages can be achieved for zones improving the Diode user experience by quite a lot.
It might also be interesting to store additional file data encrypted on the IC for zones. Zone metadata like avatar pictures, zone info, etc. would add to the user experience a lot while being small enough to be stored for a long time.
Further we would like to investigate the usage of the IC for storing all files and folders of a file sharing Diode zone. This would increase the cost quite a bit more but again might be useful for certain use cases.
The Diode App is structured into "Zones" each zone has it's own set of owners, members, messages, files, etc. Zones are fully isolated from each other. To map this correspondingly to the IC we define one Zone Availability Canister (ZAC) per zone. This ZAC is storing all the data for one zone.
Diagram showing the zone availability canister and multiple client apps uploading and downloading zone data:
graph TD
subgraph IC[Internet Computer]
ZAC1[Zone 1 Availability Canister]
ZAC2[Zone 2 Availability Canister]
end
C1[Client App 1] <-->|Upload/Download| ZAC1
C2[Client App 2] <-->|Upload/Download| ZAC1
C3[Client App 3] <-->|Upload/Download| ZAC1
C3[Client App 3] <-->|Upload/Download| ZAC2
C5[Client App 2] <-->|Upload/Download| ZAC2
C6[Client App 3] <-->|Upload/Download| ZAC2
Detailed descrptions of the Architecture in each development milestone:
- MS1: IC Capacity evaluation storing 100k encrytped messages in a canister and retrieving them.
- MS2: Authentication only allowing Zone members to interact with the Canister.
- MS3: Integration integration of the canisters into the Diode App.
This project requires an installation of:
- nodejs >= 22.9
- mops https://cli.mops.one/
- DFX version 0.22.0 or newer
- The Internet Computer SDK.
$ cd diode_messages
$ mops test
$ dfx start --background
$ dfx deploy