mirror of
https://repo.getmonero.org/monero-project/ccs-proposals.git
synced 2025-01-20 12:21:46 -05:00
add Modularize Monero
This commit is contained in:
parent
57ac5de74c
commit
2102f285cb
184
Modularize Monero
Normal file
184
Modularize Monero
Normal file
@ -0,0 +1,184 @@
|
|||||||
|
---
|
||||||
|
layout: fr
|
||||||
|
title:
|
||||||
|
author: Thor a.k.a vthor a.k.a DiosDelRayo
|
||||||
|
date: Augost 27, 2024
|
||||||
|
amount: 135
|
||||||
|
milestones:
|
||||||
|
- name: First month
|
||||||
|
funds: 45 XMR
|
||||||
|
done:
|
||||||
|
status: unfinished
|
||||||
|
- name: Second month
|
||||||
|
funds: 45 XMR
|
||||||
|
done:
|
||||||
|
status: unfinished
|
||||||
|
- name: Third month
|
||||||
|
funds: 45 XMR
|
||||||
|
done:
|
||||||
|
status: unfinished
|
||||||
|
payouts:
|
||||||
|
- date:
|
||||||
|
amount: 45 XMR
|
||||||
|
- date:
|
||||||
|
amount: 45 XMR
|
||||||
|
- date:
|
||||||
|
amount: 45 XMR
|
||||||
|
---
|
||||||
|
## About
|
||||||
|
This proposal aims to modularize the Monero codebase, transforming it from
|
||||||
|
it's current monolithic structure into a more modular codebase which can be
|
||||||
|
cherry-picked and taken apart for different use cases.
|
||||||
|
|
||||||
|
### Objectives:
|
||||||
|
(Ordered by importance)
|
||||||
|
1. 100% Backward compatibility with the exiting code case. The source base
|
||||||
|
will be transformed that a complete compile will yield still the same
|
||||||
|
outcome and functionality. Where necessary there will be created wrapper
|
||||||
|
code to stay compatible.
|
||||||
|
2. Separations of concerns. All functionalities should be separated modules
|
||||||
|
to cherry pick what to use and/or compile. E.g. if you build an hardware
|
||||||
|
wallet, you don't need a huge part of the code, but at the moment it is a
|
||||||
|
very difficult part to separate it. Maybe there even possibilities to run
|
||||||
|
on micro controller an hardware wallet, what at the moment looks already
|
||||||
|
out of scope. XmrSigner on a pi zero armv6@800MHz and 512MB RAM, needs >3
|
||||||
|
minutes to load or restore a wallet. But there is hope with the findings on
|
||||||
|
separating all in modules, to find better ways to do signing and handling
|
||||||
|
of outputs and key images.
|
||||||
|
3. Minimize external dependencies, all cryptographic code should be
|
||||||
|
included in the source code. External dependencies often lead to breaking
|
||||||
|
things later, maybe the domain vanished, or the author wants to make a
|
||||||
|
statement and takes it offline, etc. Cryptographic code anyway almost never
|
||||||
|
changes after established once, and normally the license allows to include
|
||||||
|
the that source code into your own. To make sure that changes because of
|
||||||
|
vulnerabilities/fixes get updated asap the source should be monitored if
|
||||||
|
possible. Other dependencies like boost should be minimized as far as
|
||||||
|
possible, and if not possible to get rid of the dependency at least it
|
||||||
|
should be possible to compile without if the provided functionality is not
|
||||||
|
needed. All code that can be substituted to Qt6/C++ will be substituted
|
||||||
|
with the hope of eliminate things like epee.
|
||||||
|
4. Improved readability and understandability. How almost all touching real
|
||||||
|
world value, a new developer should have it easier to understand what is
|
||||||
|
going on, then browsing through a source file with 15K LOC and then jump
|
||||||
|
through external helper functions or complicated constructs. Source should
|
||||||
|
be as simple as possible but not simpler.
|
||||||
|
5. Flexible compilation. The source should be restructured in a way that
|
||||||
|
you can cherry-pick which code to import into your project, have it easy to
|
||||||
|
update modules when modules change. Also should it be easy to generate a
|
||||||
|
library where you cherry-pick the needed modules/functionality.
|
||||||
|
6. Modular architecture. Redesigning the architecture so that it is
|
||||||
|
possible to exchange modules easily, like want to test a new blockchain
|
||||||
|
back-end, simply inherit from the blockchain interface and write the new
|
||||||
|
module using another database or protocol to retrieve the new blocks....
|
||||||
|
7. Comprehensive documentation. Every developer loves to have up to date
|
||||||
|
and complete documentation, and every developer hates to write it. In the
|
||||||
|
transformation the current monolithic source and the new modular source
|
||||||
|
should get a top notch documentation, because before transforming the
|
||||||
|
source one anyway first needs to understand, and so 70% of the
|
||||||
|
documentation work is almost done, only missing to write it down and phrase
|
||||||
|
it in the best possible way. After transforming also the differences and
|
||||||
|
what the code does is pretty clear and therefore is the best moment in time
|
||||||
|
to write. This effort should benefit the current like the new
|
||||||
|
implementation equal.
|
||||||
|
8. Enhanced auditability. Through a more broken down and easier to read
|
||||||
|
code base and improved structure and documentation, both current and new
|
||||||
|
source should be easier to audit by entities not familiar with the source
|
||||||
|
yet. (If you audit source you already know, you get also blind to some
|
||||||
|
issues, because they are simply familiar).
|
||||||
|
9. Facilitate future translations. The modularized structure with clear
|
||||||
|
interfaces and comprehensive documentation should it end also lead to
|
||||||
|
potential future translations into other languages like Rust, Kotlin,
|
||||||
|
Erlang or Python (the current monero-python library is e.g. almost only a
|
||||||
|
wrapper for the wallet rpc).
|
||||||
|
10. Cleaner Code. Somehow a bit redundant to point 2, 3 and 4, only
|
||||||
|
addition to adhere to modern C++ practices and clean code principles.
|
||||||
|
|
||||||
|
### Non-objectives:
|
||||||
|
1. Performance. Of course the code should be as performed as possible, but
|
||||||
|
no objective will be sacrificed for performance, clarity above performance.
|
||||||
|
2. Substitute the work of the original authors or diminish the worth of
|
||||||
|
their work. Their work is highly respected and cooperation is searched to
|
||||||
|
tame the monster. It is only natural that the monster grows as long you
|
||||||
|
feed it. And it is logical that you feed the monster if you love it and if
|
||||||
|
it lives in your house. That this source has become a so monolithic beast
|
||||||
|
is almost unavoidable. Of course it would be cool if one day this effort
|
||||||
|
will lead to the core development on the more modularized code base, and
|
||||||
|
for that I will search also current developers opinions while walking the
|
||||||
|
path, but the transformation is not done for that purpose. The current
|
||||||
|
developers have light-years more experience and knowledge in that source -
|
||||||
|
but like normal (I assume) no time to refactor the whole monster - even
|
||||||
|
less while worked on that very source actively.
|
||||||
|
3. Another language, introducing new libraries or tool-kits. The very
|
||||||
|
purpose is less of all with the same functionality. And sticking with
|
||||||
|
Qt6/C++ is very intentional, first needs to be a modularization and
|
||||||
|
comprehensive documentation, only after that it can be thought to go a step
|
||||||
|
further IMO.
|
||||||
|
|
||||||
|
### Challenges
|
||||||
|
1. Transforming source which is under current development. Somehow like
|
||||||
|
making a surgery on a person out for a walk, while walking... But I hope I
|
||||||
|
can mitigate this challenge in working on modules, one at the time and have
|
||||||
|
like a recipe from A to B, so if there are not huge changes it should not
|
||||||
|
derail me.
|
||||||
|
2. Qt6/C++ newest C++ standards and best practices how I'm a novice on C++.
|
||||||
|
I develop for more then 20 years now, but touched during that 20 years only
|
||||||
|
C and once for a hack I modified C++ code and only recently I started with
|
||||||
|
Qt/C++. So as usual I need to get up to speed while I'm doing. It is always
|
||||||
|
easier (in the beginning) to modify source in a language you are not fit
|
||||||
|
yet then write from ground up until it flips and writing from ground up
|
||||||
|
will be easier. But I still in the phase where I will have to read some
|
||||||
|
books in parallel.
|
||||||
|
3. The time effort is impossible to estimate as long the the source is not
|
||||||
|
completely understood, and even then it is hard - but I assume as soon the
|
||||||
|
complete source is understood, almost all the work is also done.
|
||||||
|
|
||||||
|
## Who
|
||||||
|
Me, Thor a.k.a vThor a.k.a DiosDelRayo, I'm about to finishing the
|
||||||
|
XmrSigner [Monero Signer
|
||||||
|
Resurrection](https://ccs.getmonero.org/proposals/%20MoneroSignerResurrecti
|
||||||
|
on.html) and encountered various difficulties on getting XmrSigner
|
||||||
|
production ready, like main points monero-python is almost only a mere
|
||||||
|
wrapper for wallet RPC, the monero source is (almost) take all and digest
|
||||||
|
or take nothing. So finishing this proposal will be directly beneficial for
|
||||||
|
XmrSigner and probably even lead to a XmrSigner NG dropping a lot of
|
||||||
|
ballast, going directly bare metal and not using an interpreted language
|
||||||
|
like Python, but Qt/C++, Rust or Zig. Since more then 20 years I'm in the
|
||||||
|
IT field, from developing (where I started) over network administration, to
|
||||||
|
secure communication systems. Wrote code in a lot of different languages
|
||||||
|
and prefer always to learn what is needed on the way instead of only making
|
||||||
|
that what I know fitting for the operation. The hammer I know well, but it
|
||||||
|
is not always the best tool to archive anything.
|
||||||
|
|
||||||
|
## Why it is important for community
|
||||||
|
- It would make developing new wallets or even projects not heard about
|
||||||
|
easier for new developer and so attracting more developers creating
|
||||||
|
products for the Monero Ecosystem.
|
||||||
|
- It would improve audits of the monero source.
|
||||||
|
- Me getting familiar with the monero source would create also the
|
||||||
|
opportunity to help one day on that very source.
|
||||||
|
- Possibility of finding hidden bugs, how I will need to read and
|
||||||
|
understand the source code intensively.
|
||||||
|
- Maybe the possibility to get parts of monero working on even more
|
||||||
|
restricted/limited hardware like micro controller for hardware wallets or
|
||||||
|
similar products
|
||||||
|
- Getting XmrSigner well done, at the moment the state is unsatisfying at
|
||||||
|
best.
|
||||||
|
|
||||||
|
## Milestones
|
||||||
|
How it is impossible to predict or estimate anything as long not familiar
|
||||||
|
with the whole source, I prefer to propose to work at least 130h/month for
|
||||||
|
45 XMR (don't care about the exchange rate because XMR should be the
|
||||||
|
anchor) for 3 months, and very probably writing a new proposal to continue.
|
||||||
|
All what I work above 130h in one month shall go into the next
|
||||||
|
month/milestone, I will give a biweekly report below the proposal in GitLab
|
||||||
|
and commit and push the changes each day (normally I push only after a big
|
||||||
|
junk is finished, but here it makes sense to push daily for accountability
|
||||||
|
reasons).
|
||||||
|
|
||||||
|
Results in 3 Milestones of 130 hours for 45 XMR each, in total 390 hours
|
||||||
|
for 135 XMR.
|
||||||
|
|
||||||
|
## Project Timeline
|
||||||
|
Project timeline is open how time cannot really be estimated (at least for
|
||||||
|
now, maybe it becomes easier after the third milestone). So it is simply to
|
||||||
|
process as much as is possible per day.
|
Loading…
Reference in New Issue
Block a user