August 9, 2024
17 contributors
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:
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
.
I'm hinto-janai.
The 1st/2nd milestones are for the RPC handlers. This is the majority of the work.
This includes:
/json_rpc
)/get_blocks.bin
)/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.
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.
The 3rd milestone is for any miscellaneous work that needs to be done for Cuprate, but also, these 2 concrete things:
I'd like to focus on these as:
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:
I am asking for $65 + 0.05 XMR per hour for 480 hours at $158/XMR. This gives 221 XMR.
View community discussion, comments, and proposal updates on GitLab
To be paid: 40% (88.4)
Completion date:
To be paid: 40% (88.4)
Completion date:
To be paid: 20% (44.2)
Completion date: