Skip to content

Commit

Permalink
Dev: Update ruff precommit hooks (#434)
Browse files Browse the repository at this point in the history
* update ruff

* test

* update ruff

* only ruff check

* CI rename
  • Loading branch information
callebtc authored Feb 17, 2024
1 parent c285d48 commit fca2a6c
Show file tree
Hide file tree
Showing 9 changed files with 410 additions and 556 deletions.
6 changes: 3 additions & 3 deletions .github/workflows/checks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ on:
type: string

jobs:
formatting:
format:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
Expand All @@ -26,8 +26,8 @@ jobs:
cache: "poetry"
- name: Install packages
run: poetry install
- name: Check black
run: make black-check
- name: Ruff check
run: make ruff-check
mypy:
runs-on: ubuntu-latest
steps:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Nutshell CI
name: CI
on:
push:
branches:
Expand Down
12 changes: 4 additions & 8 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
exclude: "^cashu/nostr/.*"
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.3.0
rev: v4.5.0
hooks:
- id: trailing-whitespace
- id: end-of-file-fixer
Expand All @@ -12,16 +12,12 @@ repos:
- id: debug-statements
- id: mixed-line-ending
- id: check-case-conflict
# - repo: https://github.com/psf/black
# rev: 23.11.0
# hooks:
# - id: black
# args: [--line-length=150]
- repo: https://github.com/astral-sh/ruff-pre-commit
rev: v0.0.283
rev: v0.2.1
hooks:
- id: ruff
args: [--fix, --exit-non-zero-on-fix]
args: [--fix]
- id: ruff-format
- repo: https://github.com/pre-commit/mirrors-mypy
rev: v1.6.0
hooks:
Expand Down
10 changes: 2 additions & 8 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,12 @@ ruff:
ruff-check:
poetry run ruff check .

black:
poetry run black .

black-check:
poetry run black . --check

mypy:
poetry run mypy cashu --check-untyped-defs

format: black ruff
format: ruff

check: black-check ruff-check mypy
check: ruff-check mypy

clean:
rm -r cashu.egg-info/ || true
Expand Down
17 changes: 5 additions & 12 deletions cashu/core/crypto/b_dhke.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ def hash_to_curve(message: bytes) -> PublicKey:
point = PublicKey(b"\x02" + _hash, raw=True)
except Exception:
msg_to_hash = _hash
print(_hash)
return point


Expand Down Expand Up @@ -101,18 +102,14 @@ def hash_to_curve_domain_separated(message: bytes) -> PublicKey:
raise ValueError("No valid point found")


def step1_alice(
secret_msg: str, blinding_factor: Optional[PrivateKey] = None
) -> tuple[PublicKey, PrivateKey]:
def step1_alice(secret_msg: str, blinding_factor: Optional[PrivateKey] = None) -> tuple[PublicKey, PrivateKey]:
Y: PublicKey = hash_to_curve(secret_msg.encode("utf-8"))
r = blinding_factor or PrivateKey()
B_: PublicKey = Y + r.pubkey # type: ignore
return B_, r


def step1_alice_domain_separated(
secret_msg: str, blinding_factor: Optional[PrivateKey] = None
) -> tuple[PublicKey, PrivateKey]:
def step1_alice_domain_separated(secret_msg: str, blinding_factor: Optional[PrivateKey] = None) -> tuple[PublicKey, PrivateKey]:
Y: PublicKey = hash_to_curve_domain_separated(secret_msg.encode("utf-8"))
r = blinding_factor or PrivateKey()
B_: PublicKey = Y + r.pubkey # type: ignore
Expand Down Expand Up @@ -151,9 +148,7 @@ def hash_e(*publickeys: PublicKey) -> bytes:
return e


def step2_bob_dleq(
B_: PublicKey, a: PrivateKey, p_bytes: bytes = b""
) -> Tuple[PrivateKey, PrivateKey]:
def step2_bob_dleq(B_: PublicKey, a: PrivateKey, p_bytes: bytes = b"") -> Tuple[PrivateKey, PrivateKey]:
if p_bytes:
# deterministic p for testing
p = PrivateKey(privkey=p_bytes, raw=True)
Expand All @@ -174,9 +169,7 @@ def step2_bob_dleq(
return epk, spk


def alice_verify_dleq(
B_: PublicKey, C_: PublicKey, e: PrivateKey, s: PrivateKey, A: PublicKey
) -> bool:
def alice_verify_dleq(B_: PublicKey, C_: PublicKey, e: PrivateKey, s: PrivateKey, A: PublicKey) -> bool:
R1 = s.pubkey - A.mult(e) # type: ignore
R2 = B_.mult(s) - C_.mult(e) # type: ignore
e_bytes = e.private_key
Expand Down
46 changes: 12 additions & 34 deletions cashu/lightning/blink.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@


class BlinkWallet(LightningBackend):
"""https://dev.blink.sv/
"""
https://dev.blink.sv/
Create API Key at: https://dashboard.blink.sv/
"""

Expand All @@ -54,10 +55,7 @@ async def status(self) -> StatusResponse:
try:
r = await self.client.post(
url=self.endpoint,
data=(
'{"query":"query me { me { defaultAccount { wallets { id'
' walletCurrency balance }}}}", "variables":{}}'
),
data=('{"query":"query me { me { defaultAccount { wallets { id' ' walletCurrency balance }}}}", "variables":{}}'),
)
r.raise_for_status()
except Exception as exc:
Expand All @@ -71,9 +69,7 @@ async def status(self) -> StatusResponse:
resp: dict = r.json()
except Exception:
return StatusResponse(
error_message=(
f"Received invalid response from {self.endpoint}: {r.text}"
),
error_message=(f"Received invalid response from {self.endpoint}: {r.text}"),
balance=0,
)

Expand Down Expand Up @@ -137,9 +133,7 @@ async def create_invoice(

resp = r.json()
assert resp, "invalid response"
payment_request = resp["data"]["lnInvoiceCreateOnBehalfOfRecipient"]["invoice"][
"paymentRequest"
]
payment_request = resp["data"]["lnInvoiceCreateOnBehalfOfRecipient"]["invoice"]["paymentRequest"]
checking_id = payment_request

return InvoiceResponse(
Expand All @@ -148,9 +142,7 @@ async def create_invoice(
payment_request=payment_request,
)

async def pay_invoice(
self, quote: MeltQuote, fee_limit_msat: int
) -> PaymentResponse:
async def pay_invoice(self, quote: MeltQuote, fee_limit_msat: int) -> PaymentResponse:
variables = {
"input": {
"paymentRequest": quote.request,
Expand Down Expand Up @@ -185,9 +177,7 @@ async def pay_invoice(
return PaymentResponse(ok=False, error_message=str(e))

resp: dict = r.json()
paid = self.payment_execution_statuses[
resp["data"]["lnInvoicePaymentSend"]["status"]
]
paid = self.payment_execution_statuses[resp["data"]["lnInvoicePaymentSend"]["status"]]
fee = resp["data"]["lnInvoicePaymentSend"]["transaction"]["settlementFee"]
checking_id = quote.request

Expand Down Expand Up @@ -222,9 +212,7 @@ async def get_invoice_status(self, checking_id: str) -> PaymentStatus:
return PaymentStatus(paid=None)
resp: dict = r.json()
if resp["data"]["lnInvoicePaymentStatus"]["errors"]:
logger.error(
"Blink Error", resp["data"]["lnInvoicePaymentStatus"]["errors"]
)
logger.error("Blink Error", resp["data"]["lnInvoicePaymentStatus"]["errors"])
return PaymentStatus(paid=None)
paid = self.invoice_statuses[resp["data"]["lnInvoicePaymentStatus"]["status"]]
return PaymentStatus(paid=paid)
Expand Down Expand Up @@ -267,19 +255,11 @@ async def get_payment_status(self, checking_id: str) -> PaymentStatus:

resp: dict = r.json()
# no result found
if not resp["data"]["me"]["defaultAccount"]["walletById"][
"transactionsByPaymentHash"
]:
if not resp["data"]["me"]["defaultAccount"]["walletById"]["transactionsByPaymentHash"]:
return PaymentStatus(paid=None)

paid = self.payment_statuses[
resp["data"]["me"]["defaultAccount"]["walletById"][
"transactionsByPaymentHash"
][0]["status"]
]
fee = resp["data"]["me"]["defaultAccount"]["walletById"][
"transactionsByPaymentHash"
][0]["settlementFee"]
paid = self.payment_statuses[resp["data"]["me"]["defaultAccount"]["walletById"]["transactionsByPaymentHash"][0]["status"]]
fee = resp["data"]["me"]["defaultAccount"]["walletById"]["transactionsByPaymentHash"][0]["settlementFee"]

return PaymentStatus(
paid=paid,
Expand Down Expand Up @@ -326,9 +306,7 @@ async def get_payment_quote(self, bolt11: str) -> PaymentQuoteResponse:

fees_response_msat = int(resp["data"]["lnInvoiceFeeProbe"]["amount"]) * 1000
# we either take fee_msat_response or the BLINK_MAX_FEE_PERCENT, whichever is higher
fees_msat = max(
fees_response_msat, math.ceil(amount_msat * BLINK_MAX_FEE_PERCENT)
)
fees_msat = max(fees_response_msat, math.ceil(amount_msat * BLINK_MAX_FEE_PERCENT))

fees = Amount(unit=Unit.msat, amount=fees_msat)
amount = Amount(unit=Unit.msat, amount=amount_msat)
Expand Down
Loading

0 comments on commit fca2a6c

Please sign in to comment.