Community Crowdfunding System

Funding Required

hinto-janai full-time work on Cuprate (3 months)

hinto-janai full-time work on Cuprate (3 months)

hinto-janai

August 9, 2024

17 contributors

Raised 201.68 of 221 XMR

1. Choose the amount of XMR you wish to contribute to this proposal.

2. Scan the QR code or tap to open in your Monero wallet app

or copy the following XMR address:

8AHTpvaWU8RHzmHgaisMQdAiFfbfwNGgugBEsSdysydUgcocMUkH8Y3568d9WUDvCwbrs4NyHKQfPeAvdUhEUXCxTWMVeqg

3. Send! Thank you! You are amazing!

What

Cuprate is an alternative Monero node implementation.

The next section that needs work is the RPC handlers. The design, interface, routing, types, and (de)serialization were completed in my previous CCS, see here:

  • Past CCS: https://repo.getmonero.org/monero-project/ccs-proposals/-/merge_requests/456
  • RPC interface tracking issue: https://github.com/Cuprate/cuprate/issues/183
  • RPC book: https://architecture.cuprate.org/rpc/intro.html

This CCS is for the handlers, i.e. the functions that turn requests into responses.

Once the handlers are complete, Cuprate will have a working RPC stack that mostly mirrors monerod.

Who

I'm hinto-janai.

RPC handlers

The 1st/2nd milestones are for the RPC handlers. This is the majority of the work.

This includes:

  • JSON RPC handlers (methods behind /json_rpc)
  • Binary RPC handlers (binary endpoints, e.g. /get_blocks.bin)
  • Other handlers (other JSON endpoints, e.g. /get_height)

The RPC handlers will most likely be in its own library/section, built on-top of the RPC libraries Cuprate has so far. The current RPC interface library (cuprate-rpc-interface) allows for custom handlers, as in, the mapping of request -> response can be customized. The handler created in this CCS will be a standard implementation that (mostly) follows monerod's behavior, i.e. request comes in, get some data from the database and such, return a response. Although, other implementations are possible, such as an RPC handler that caches blocks, as mentioned in this meeting.

Testing, crate (library) documentation, and architecture book sections will also be written.

Binary strings

There are a few RPC methods that require further discussion before implementation in Cuprate, see the binary strings proposal.

If the above proposal finds consensus on future monerod behavior, this CCS will implement that behavior.

If more time is required for the proposal, the related endpoints/methods will be left in a semi-unfinished state until behavior is agreed upon, where after Cuprate will implement that behavior.

If the proposal does not move forward, Cuprate is planning to fallback to implementing monerod's current behavior.

Other work

The 3rd milestone is for any miscellaneous work that needs to be done for Cuprate, but also, these 2 concrete things:

  • Lints
  • Benchmarking

I'd like to focus on these as:

  • If they're always pushed to the side, they'll never get done
  • I believe it's important to establish these early on in the project

I started integrating lints & benchmarks into Cuprate last CCS, this CCS will finish integrating them for all the libraries I've written so far, and other libraries if time allows.

The issues tracking the progress of these two can be found here:

  • https://github.com/Cuprate/cuprate/issues/207 (lints)
  • https://github.com/Cuprate/cuprate/issues/208 (benchmarks)

Funding

I am asking for $65 + 0.05 XMR per hour for 480 hours at $158/XMR. This gives 221 XMR.

JSON RPC handlers

To be paid: 40% (88.4)

Completion date:

Binary/other RPC handlers

To be paid: 40% (88.4)

Completion date:

Other work

To be paid: 20% (44.2)

Completion date: