mirror of
https://github.com/aljazceru/nutshell.git
synced 2025-12-23 03:34:19 +01:00
Nutshell cleanup wishlist (#332)
* fix keys * fix tests * backwards compatible api upgrade * upgrade seems to work * fix tests * add deprecated api functions * add more tests of backwards compat * add test serialization for nut00 * remove a redundant test * move mint and melt to new api * mypy works * CI: mypy --check-untyped-defs * add deprecated router * add hints and remove logs * fix tests * cleanup * use new mint and melt endpoints * tests passing? * fix mypy * make format * make format * make format * commit * errors gone * save * adjust the API * store quotes in db * make mypy happy * add fakewallet settings * remove LIGHTNING=True and pass quote id for melt * format * tests passing * add CoreLightningRestWallet * add macaroon loader * add correct config * preimage -> proof * move wallet.status() to cli.helpers.print_status() * remove statuses from tests * remove * make format * Use httpx in deprecated wallet * fix cln interface * create invoice before quote * internal transactions and deprecated api testing * fix tests * add deprecated API tests * fastapi type hints break things * fix duplicate wallet error * make format * update poetry in CI to 1.7.1 * precommit restore * remove bolt11 * oops * default poetry * store fee reserve for melt quotes and refactor melt() * works? * make format * test * finally * fix deprecated models * rename v1 endpoints to bolt11 * raise restore and check to v1, bump version to 0.15.0 * add version byte to keyset id * remove redundant fields in json * checks * generate bip32 keyset wip * migrate old keysets * load duplicate keys * duplicate old keysets * revert router changes * add deprecated /check and /restore endpoints * try except invalidate * parse unit from derivation path, adjust keyset id calculation with bytes * remove keyest id from functions again and rely on self.keyset_id * mosts tests work * mint loads multiple derivation paths * make format * properly print units * fix tests * wallet works with multiple units * add strike wallet and choose backend dynamically * fix mypy * add get_payment_quote to lightning backends * make format * fix startup * fix lnbitswallet * fix tests * LightningWallet -> LightningBackend * remove comments * make format * remove msat conversion * add Amount type * fix regtest * use melt_quote as argument for pay_invoice * test old api * fees in sats * fix deprecated fees * fixes * print balance correctly * internally index keyset response by int * add pydantic validation to input models * add timestamps to mint db * store timestamps for invoices, promises, proofs_used * fix wallet migration * rotate keys correctly for testing * remove print * update latest keyset * fix tests * fix test * make format * make format with correct black version * remove nsat and cheese * test against deprecated mint * fix tests? * actually use env var * mint run with env vars * moar test * cleanup * simplify tests, load all keys * try out testing with internal invoices * fix internal melt test * fix test * deprecated checkfees expects appropriate fees * adjust comment * drop lightning table * split migration for testing for now, remove it later * remove unused lightning table * skip_private_key -> skip_db_read * throw error on migration error * reorder * fix migrations * fix lnbits fee return value negative * fix typo * comments * add type * make format * split must use correct amount * fix tests * test deprecated api with internal/external melts * do not split if not necessary * refactor * fix test * make format with new black * cleanup and add comments * add quote state check endpoints * fix deprecated wallet response * split -> swap endpoint * make format * add expiry to quotes, get quote endpoints, and adjust to nut review comments * allow overpayment of melt * add lightning wallet tests * commiting to save * fix tests a bit * make format * remove comments * get mint info * check_spendable default False, and return payment quote checking id * make format * bump version in pyproject * update to /v1/checkstate * make format * fix mint api checks * return witness on /v1/checkstate * no failfast * try fail-fast: false in ci.yaml * fix db lookup * clean up literals
This commit is contained in:
@@ -8,7 +8,7 @@ from pydantic import BaseSettings, Extra, Field
|
||||
|
||||
env = Env()
|
||||
|
||||
VERSION = "0.14.1"
|
||||
VERSION = "0.15.0"
|
||||
|
||||
|
||||
def find_env_file():
|
||||
@@ -25,7 +25,6 @@ def find_env_file():
|
||||
|
||||
class CashuSettings(BaseSettings):
|
||||
env_file: str = Field(default=None)
|
||||
lightning: bool = Field(default=True)
|
||||
lightning_fee_percent: float = Field(default=1.0)
|
||||
lightning_reserve_fee_min: int = Field(default=2000)
|
||||
max_order: int = Field(default=64)
|
||||
@@ -45,11 +44,13 @@ class EnvSettings(CashuSettings):
|
||||
log_level: str = Field(default="INFO")
|
||||
cashu_dir: str = Field(default=os.path.join(str(Path.home()), ".cashu"))
|
||||
debug_profiling: bool = Field(default=False)
|
||||
debug_mint_only_deprecated: bool = Field(default=False)
|
||||
|
||||
|
||||
class MintSettings(CashuSettings):
|
||||
mint_private_key: str = Field(default=None)
|
||||
mint_derivation_path: str = Field(default="0/0/0/0")
|
||||
mint_derivation_path: str = Field(default="m/0'/0'/0'")
|
||||
mint_derivation_path_list: List[str] = Field(default=[])
|
||||
mint_listen_host: str = Field(default="127.0.0.1")
|
||||
mint_listen_port: int = Field(default=3338)
|
||||
mint_lightning_backend: str = Field(default="LNbitsWallet")
|
||||
@@ -57,11 +58,19 @@ class MintSettings(CashuSettings):
|
||||
mint_peg_out_only: bool = Field(default=False)
|
||||
mint_max_peg_in: int = Field(default=None)
|
||||
mint_max_peg_out: int = Field(default=None)
|
||||
mint_max_request_length: int = Field(default=1000)
|
||||
mint_max_balance: int = Field(default=None)
|
||||
|
||||
mint_lnbits_endpoint: str = Field(default=None)
|
||||
mint_lnbits_key: str = Field(default=None)
|
||||
|
||||
mint_strike_key: str = Field(default=None)
|
||||
|
||||
|
||||
class FakeWalletSettings(MintSettings):
|
||||
fakewallet_brr: bool = Field(default=True)
|
||||
fakewallet_delay_payment: bool = Field(default=False)
|
||||
fakewallet_stochastic_invoice: bool = Field(default=False)
|
||||
mint_cache_secrets: bool = Field(default=True)
|
||||
|
||||
|
||||
@@ -75,7 +84,6 @@ class MintInformation(CashuSettings):
|
||||
|
||||
|
||||
class WalletSettings(CashuSettings):
|
||||
lightning: bool = Field(default=True)
|
||||
tor: bool = Field(default=True)
|
||||
socks_host: str = Field(default=None) # deprecated
|
||||
socks_port: int = Field(default=9050) # deprecated
|
||||
@@ -85,6 +93,7 @@ class WalletSettings(CashuSettings):
|
||||
mint_host: str = Field(default="8333.space")
|
||||
mint_port: int = Field(default=3338)
|
||||
wallet_name: str = Field(default="wallet")
|
||||
wallet_unit: str = Field(default="sat")
|
||||
|
||||
api_port: int = Field(default=4448)
|
||||
api_host: str = Field(default="127.0.0.1")
|
||||
@@ -121,6 +130,7 @@ class Settings(
|
||||
EnvSettings,
|
||||
LndRestFundingSource,
|
||||
CoreLightningRestFundingSource,
|
||||
FakeWalletSettings,
|
||||
MintSettings,
|
||||
MintInformation,
|
||||
WalletSettings,
|
||||
|
||||
Reference in New Issue
Block a user