mirror of
https://github.com/nbd-wtf/nostr-tools.git
synced 2026-01-31 06:28:50 +00:00
This commit upgrades the noble cryptography dependencies to v2.0.1, which includes: Breaking changes addressed: - Updated all @noble imports to include .js extensions (required by v2 ESM-only API) - Changed @noble/hashes/sha256 to @noble/hashes/sha2.js across 8 files - Fixed secp256k1 API changes: methods now require Uint8Array instead of hex strings - Updated schnorr.utils.randomPrivateKey() to schnorr.utils.randomSecretKey() Files modified (27 total): - package.json: Bump dependency versions - Source files (12): pure.ts, nip04.ts, nip06.ts, nip13.ts, nip19.ts, nip44.ts, nip49.ts, nip77.ts, nip98.ts, nipb7.ts, utils.ts, wasm.ts - Test files (14): All corresponding test files updated Benefits: - Latest security updates from audited noble libraries - Smaller bundle sizes from v2 optimizations - Future-proof ESM-only compatibility - All tests passing Co-authored-by: OpenCode <opencode@anomalyco.com>
61 lines
1.5 KiB
TypeScript
61 lines
1.5 KiB
TypeScript
import { bytesToHex } from '@noble/hashes/utils.js'
|
|
import { type UnsignedEvent, type Event } from './pure.ts'
|
|
import { sha256 } from '@noble/hashes/sha2.js'
|
|
|
|
import { utf8Encoder } from './utils.ts'
|
|
|
|
/** Get POW difficulty from a Nostr hex ID. */
|
|
export function getPow(hex: string): number {
|
|
let count = 0
|
|
|
|
for (let i = 0; i < 64; i += 8) {
|
|
const nibble = parseInt(hex.substring(i, i + 8), 16)
|
|
if (nibble === 0) {
|
|
count += 32
|
|
} else {
|
|
count += Math.clz32(nibble)
|
|
break
|
|
}
|
|
}
|
|
|
|
return count
|
|
}
|
|
|
|
/**
|
|
* Mine an event with the desired POW. This function mutates the event.
|
|
* Note that this operation is synchronous and should be run in a worker context to avoid blocking the main thread.
|
|
*/
|
|
export function minePow(unsigned: UnsignedEvent, difficulty: number): Omit<Event, 'sig'> {
|
|
let count = 0
|
|
|
|
const event = unsigned as Omit<Event, 'sig'>
|
|
const tag = ['nonce', count.toString(), difficulty.toString()]
|
|
|
|
event.tags.push(tag)
|
|
|
|
while (true) {
|
|
const now = Math.floor(new Date().getTime() / 1000)
|
|
|
|
if (now !== event.created_at) {
|
|
count = 0
|
|
event.created_at = now
|
|
}
|
|
|
|
tag[1] = (++count).toString()
|
|
|
|
event.id = fastEventHash(event)
|
|
|
|
if (getPow(event.id) >= difficulty) {
|
|
break
|
|
}
|
|
}
|
|
|
|
return event
|
|
}
|
|
|
|
export function fastEventHash(evt: UnsignedEvent): string {
|
|
return bytesToHex(
|
|
sha256(utf8Encoder.encode(JSON.stringify([0, evt.pubkey, evt.created_at, evt.kind, evt.tags, evt.content]))),
|
|
)
|
|
}
|