Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jimktrains/freebooks
Distributed Ledger
https://github.com/jimktrains/freebooks
Last synced: 3 months ago
JSON representation
Distributed Ledger
- Host: GitHub
- URL: https://github.com/jimktrains/freebooks
- Owner: jimktrains
- License: gpl-3.0
- Created: 2013-09-29T22:10:20.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-10-20T03:22:28.000Z (over 10 years ago)
- Last Synced: 2024-08-02T12:48:05.467Z (6 months ago)
- Language: Python
- Size: 250 KB
- Stars: 26
- Watchers: 5
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - jimktrains/freebooks - Distributed Ledger (others)
README
freebooks
=========Distributed Ledger designed for groups of people known to each other (_e.g._ corporations, families, friends, communes, &c). It utilizes git for synchronization and storage as well as AES-256-CBC and ECC-p384 for encryption and signatures.
All information is stored in 3 branches within git:
* key - master key
* users - Stores all user records
* tx - Stores all transaction recordsData is stored and signed within the commit itself
* Summary - Human readable description of the action
* Signature - Signature of the record
* Data - The raw data describing the action
* Actor - User ID. Stored as part of the git commit normally
* Time - The commit time. Stored as part of the git commit normally
* Parent - The commits' parents. Stored as part of the git commit normallySince data is stored within the commits, batch processing programs (_e.g._: GUI or web-service) may find it beneficial to cache data-to-read in a database.
Also, since all data is stored in commits, it would be necessary to cause a SHA-1 conflict to have a merge conflict, as such merges simply just take divergent heads and make a parent with both to become a single branch again.
Basic Ideas
-----------* master key - Random AES-256 key stored with repo and encrypted with "ledger password." This is used encrypt fields for each record, such as the transaction amount and a description of the transaction. It is also used to encrypt the account names and metadata.
* user key - Random ECC key stored for each user. Private key encrypted with user password. Used to sign commits.
* commit signature - Each time a commit happens, 5 pieces of information as signed: 1) the sha for the tree of all added or modified files. 2) the unix timestamp. 3) username, 4) parent commits' SHAs, 5) human readable description
* all users are trusted - If someone has the ledger password and a key-pair it is assumed that they will not act maliciously. However, valid clients will never accept a forced commit and will not work on an in-valid repository
* clocks will be assumed to be correct - Most uses of this won't need split-second precisions and will normally have lots of human error as well (the time it takes to enter the tx from the time it was made). Thus, I'm making the assumption that I can order tx by their commit time, which should be more than enough from most, if not all, cases.
* All tx amounts are stored as ints. Eventually I would like to store the currency and format of the field as well (in a per-account manner)This should prevent any one person from rewriting any commit including and before the last commit not done by them.
*NOTE:* Passwords are mimicked at the moment because I got tired of typing the same dummy password in all the time. They can be enabled by removing the first return in the SymEncPasswordKey.get_password function
Example
-------Try the `init_test` script or longhand
To initialize a ledger:
python freebooks.py -l test-ledger init jim "Jim K" [email protected]
To add a user:
python freebooks.py -l test-ledger -u jim add-user you "You There" [email protected]
Now, let's move some money around and look at balances. (Note: account ids don't have to be numeric. They're strings and will eventually be a .-separated hierarchy)
python freebooks.py -u jim -l test-ledger tx 1 2 jim 100
python freebooks.py -u jim -l test-ledger bal
Account|Balance
-------+-------
1 | -100
2 | 100python freebooks.py -u jim -l test-ledger tx 2 1 jim 400
python freebooks.py -u jim -l test-ledger bal
Account|Balance
-------+-------
1 | 300
2 | -300
python freebooks.py -u you -l test-ledger tx 3 1 jim 200python freebooks.py -u jim -l test-ledger bal
Account|Balance
-------+-------
1 | 500
3 | -200
2 | -300python freebooks.py -u jim -l test-ledger ls 1
Jim K |2013-10-01 13:38:35|3 |1 |jim | 200
You There |2013-10-01 13:38:31|2 |1 |jim | 400
Jim K |2013-10-01 13:38:28|2 |1 |jim | -100For Fun
-------cd to `test-ledger` and do
git branch -a
git co key
git log
git co users
git log
git co txs
git logTo get a feel for how things are being stored
ToDo
----* Fetch from a remote (multi branch for dev)
* Merge fetched branches (multi branch for dev)
* Push to a remote (multi branch for dev)
* Account management
* Store account_id.account_id...... as the to/from_account in each tx
* Store account descriptions
* Name
* Description
* Account numbers
* Currency
* Unit