OCap layer for Haskell Actor Library

Summary

This project aims to develop network/IPC capabilities for the a Haskell actor library troupe, using ocap-based protocols. This would enable modern, secure, and efficient communication in distributed systems.

The protocols are OCapN and Syndicate - both related to CapTP, but different in focus (RPC vs sharing state).

The result will be a set of packages for protocol implementations, their integrations into the actor framework, and a set of demonstration environments. To get more momentum behind the project we will provide starter projects and guix/nix environments. Finally, we want to prepare to conduct a workshop on making distributed applications.

Context

Three evolving technologies can contribute to the development of the Haskell actor library:

  • Troupe: A new iteration of the actor framework for Haskell. The previous attempt in form of Cloud Haskell had a well-documented model and achieved production use, but the consensus was that the resulting system ended up too complex. The focus now lies on intra-process organization, leaving network communication out of scope. This is where we pick up and provide the complementary part.
  • Spritely: Inter-actor communication based on object capabilities, designed for a wide ecosystem of services, and a continuation of the CapTP protocol/framework.
  • Syndicate: Also, an ocap-based actor framework, but with primary concern in task-oriented data sharing.

Project Opportunity

We propose developing support libraries for OCapN and Syndicate protocols, then integrating them with the Troupe library, thus allowing actors to cooperatively solve tasks in a wider environment. Implementing both Spritely and Syndicate simultaneously will bridge the gap between action and knowledge networks.

Expected Benefits

  • Haskell developers will gain access to a modern actor framework with secure RPC.
  • Spritely will receive a new, parallel implementation in another language, providing an opportunity to verify protocol descriptions, compatibility, and community mechanisms.
  • Syndicate will allow a direct comparison of the two approaches, their strengths, and weaknesses. A simultaneous implementation may reveal opportunities for unification into a single standard.
  • Application developers will have a unified local/remote actor model, with a multilingual ecosystem of services, built-in PubSub without brokers, and a widely applicable network model.
  • Users will benefit from trustworthy network communication implementation, applications working in Friend-to-Friend networks, and other mesh networks and applications that can discover their instances and synchronize.

Expected Results

  • A set of packages implementing the protocols and integrating them with Troupe.
  • Test bench for the Haskell parts.
  • Demo environment for working with Spritely.
  • Demo environment for working with Syndicate.
  • A cookbook for actor-based applications.
  • A workshop covering the entire project.

Why Us?

We have a serendipitous combination of experience for the project: having developed and deployed Cloud Haskell products, implemented libraries and tools for bridging the GNUnet services, and participated in a ocap-based microkernel OS development. Also, we are huge fans of P2P building blocks like CRDTs and mesh networks.