This repo will likely go through some refactoring, but in the mean time here is an alphabetic list of all .py files of the main dir, so you know where to look.
Each file maybe a module (library of functions, to be included but not run) or a script (to be run).
See also the most useful files: https://github.com/EggPool/Bismuth/blob/patch-51/_MOST_USEFUL_FILES.md Some files have been moved to https://github.com/hclivess/BismuthProjects
Handles the aliases index (ie: labels for bismuth addresses)
Class to handle extra API commands, that are not part of the core nodes protocol.
Used by Json-RPC server and other third party interaction.
Prefered entry point for adding new generic features.
To be used by GUI wallet. Finds local user storage location.
Get balance from the command line.
Outdated, still uses privkey.der/pubkey.der instead or modern wallet.der
bisurl encoding and decoding functions.
A bisurl is a single string that encodes recipient, amount, data and a checksum into a single url like string, to be used in the wallet.
Exchanges could use this feature to give each user a bis url for deposit. The bis url would include the required custom data field, and the user would only have to adjust the required amount.
Initialization of classes commonly used by node (Node, Client, Logger, Keys), which are then populated by the node code.
Command line interface to node commands. Undocumented. Better refer to the dedicated API repo.
Low level protocol functions, header + json over raw socket.
Len of payload, decimal, on 10 chars, followed by json encoded data. See API repo.
Connection manager thread module. Reports status to output.
Compiles executables for Windows. Nuitka is cross-platform, however.
Standard database handler class for initiation and closing of database connections per thread, includes error handling.
Difficulty calculation.
Block processing.
Common helpers. Some DB related, mainly crypto helpers and common abstract operations.
Rules for upcoming hardforks should be stored here.
Do not use.
Helper script to create a new genesis block, from an empty chain. Not maintained.
HMAC_DRBG (sha512) helper class, used by the "heavy3" PoW algorithm.
Module that handles hyperlane integration to node.
Sample script to generate a new address.
Helpers to generate and read wallet.der (privkey, pubkey, address)
Early version of a block explorer. Not maintained.
Logging - console, file - helpers.
Benchmark Helper for wallet.
Mempool module for Bismuth nodes
Legacy mining algo: block validity check.
Heavy3 mining algo: block validity check.
Main script to run a bismuth node.
Config helper. Beware: imported as "config" in the node.
Peers handler class.
Plugin manager class for nodes. See the plugins repo for usage and sample plugins.
Helper to test for a process presence.
Helpers. Workaround for float rounding.
Helper. Recovers pubkey and address from privkey alone.
Regnet mode for bismuth testing.
System script to reindex dev rewards, manual block level input. Do not use.
Tests if there is a dev reward every 10 blocks. Do not use.
Helper. rollbacks indexes on block rollback.
Command line script to send a transaction.
Can be used as base for automated payment scripts.
Does not send anything sensitive to the node.
As send_nogui.py, without confirmation.
Windows installer generator for Inno Setup when compiled with nuitka.
Helper. Handles wallet encryption/decryption with password.
Helper. Proof of concept for offline staking.
Tokens functions.
Bundled/Legacy GUI Wallet.
Proof of concept asyncio GUI wallet.
Outgoing traffic thread node module.