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