@bun-win32/ktmw32
v1.0.1
Published
Zero-dependency, zero-overhead Win32 KTMW32 bindings for Bun (FFI) on Windows.
Downloads
390
Maintainers
Readme
@bun-win32/ktmw32
Zero-dependency, zero-overhead Win32 KTM (Kernel Transaction Manager) bindings for Bun on Windows.
Overview
@bun-win32/ktmw32 exposes the ktmw32.dll exports using Bun's FFI. It provides a single class, Ktmw32, which lazily binds native symbols on first use. You can optionally preload a subset or all symbols up-front via Preload().
The Kernel Transaction Manager is Windows' built-in distributed-transaction engine. Open a transaction with CreateTransaction, enlist work in it — transacted-NTFS files (via kernel32's CreateFileTransactedW), the transacted registry, or your own resource manager — then CommitTransaction to apply everything atomically and durably, or RollbackTransaction to discard the whole batch as if it never happened. The full Transaction-Manager → Resource-Manager → Enlistment object graph, the two-phase-commit verbs, and virtual-clock recovery are all bound.
The bindings are strongly typed for a smooth DX in TypeScript.
Features
- Bun-first ergonomics on Windows 10/11.
- Direct FFI to
ktmw32.dll(transactions, transaction managers, resource managers, enlistments, two-phase commit). - In-source docs in
structs/Ktmw32.tswith links to Microsoft Docs. - Lazy binding on first call; optional eager preload (
Ktmw32.Preload()). - No wrapper overhead; calls map 1:1 to native APIs.
- Strongly-typed Win32 aliases and the full KTM enum set (see
types/Ktmw32.ts).
Requirements
- Bun runtime
- Windows 10 or later (KTM since Windows Vista / Server 2008)
Installation
bun add @bun-win32/ktmw32Quick Start
import Ktmw32, { TransactionOutcome } from '@bun-win32/ktmw32';
import Kernel32 from '@bun-win32/kernel32';
// Open a KTM transaction (all-access handle; INVALID_HANDLE_VALUE on failure).
const hTx = Ktmw32.CreateTransaction(null, null, 0, 0, 0, 0, null);
// Create/replace a file *inside* the transaction — invisible to outside readers until commit.
const path = Buffer.from('C:\\Temp\\ledger.txt\0', 'utf16le');
const hFile = Kernel32.CreateFileTransactedW(path.ptr, 0x4000_0000 /* GENERIC_WRITE */, 0, null!, 2 /* CREATE_ALWAYS */, 0x80 /* FILE_ATTRIBUTE_NORMAL */, 0n, hTx, null!, null!);
const data = Buffer.from('balance=100');
Kernel32.WriteFile(hFile, data.ptr, data.byteLength, Buffer.alloc(4).ptr, null!);
Kernel32.CloseHandle(hFile);
// Inspect the live transaction, then resolve it atomically.
const outcome = Buffer.alloc(4);
Ktmw32.GetTransactionInformation(hTx, outcome.ptr, null, null, null, 0, null);
console.log('outcome:', TransactionOutcome[outcome.readUInt32LE(0)]); // TransactionOutcomeUndetermined
Ktmw32.CommitTransaction(hTx); // ...or Ktmw32.RollbackTransaction(hTx) to discard everything
Kernel32.CloseHandle(hTx);[!NOTE] AI agents: see
AI.mdfor the package binding contract and source-navigation guidance. It explains how to use the package without scanning the entire implementation.
Examples
Run the included examples:
bun run example/atomic-ledger.ts
bun run example/transaction-forensics.tsNotes
- Either rely on lazy binding or call
Ktmw32.Preload(). CreateTransaction/CreateTransactionManager/CreateResourceManager/CreateEnlistment/Open*return aHANDLE; failure isINVALID_HANDLE_VALUE(0xFFFFFFFFFFFFFFFFn), not0n. Close every handle withkernel32'sCloseHandle.- Closing the last transaction handle before
CommitTransactionimplicitly rolls the transaction back. - After
CreateTransactionManager/OpenTransactionManager*you must callRecoverTransactionManagerfor durable TMs; volatile TMs (TRANSACTION_MANAGER_VOLATILE,LogFileName=NULL) do not perform recovery. - A volatile resource manager can live on a durable TM, but a durable RM cannot live on a volatile TM.
- Every resource manager must register at least
TRANSACTION_NOTIFY_PREPREPARE | PREPARE | COMMIT | ROLLBACKin itsCreateEnlistmentnotification mask. GetTransactionInformationreturnsBOOL; theOutcomeout-param decodes via theTransactionOutcomeenum.- Windows only. Bun runtime required.
