1.9 KiB
1.9 KiB
id, name, status, depends_on, scope, risk, impact, level
| id | name | status | depends_on | scope | risk | impact | level | |
|---|---|---|---|---|---|---|---|---|
| napi/project-setup | Set up wraith-napi project with napi-rs build tooling and TypeScript types | pending |
|
moderate | low | component | implementation |
Description
Set up the napi-rs project for the @alkdev/wraith Node.js native addon. This includes the napi-rs build configuration, TypeScript type definitions, and the package structure.
Per ADR-015 and ADR-016: napi-rs is the FFI bridge, and the wrapper exposes connect() and serve() functions. The NAPI layer is transport-agnostic — it doesn't know about pubsub's EventEnvelope.
The Cargo.toml skeleton was created in setup/project-init. This task configures the actual napi-rs build pipeline, TypeScript types, and verifies the build works.
Acceptance Criteria
crates/wraith-napi/hasCargo.tomlwithcrate-type = ["cdylib"],napiandnapi-derivedependenciescrates/wraith-napi/src/lib.rswith napi module registrationpackages/wraith-napi/directory (or similar) withpackage.jsonnamed@alkdev/wraithpackages/wraith-napi/tsconfig.jsonfor TypeScript type generation- TypeScript type definitions for
WraithConnectOptions,WraithServeOptions,WraithServer,ConnectionInfomatching napi-and-pubsub.md interfaces napi.config.jsorNapiRs.configwith correct cargo path, module name- Build command:
npm run buildbuilds the native addon - Feature flags:
irohfeature optional; base package includes tcp + tls npm installand initial build succeed
References
- docs/architecture/napi-and-pubsub.md — NAPI Wrapper section, TypeScript interfaces
- docs/architecture/decisions/015-napi-rs-for-ffi-bridge.md — napi-rs choice
- docs/architecture/decisions/016-napi-expose-connect-and-serve.md — both connect() and serve()
Notes
To be filled by implementation agent
Summary
To be filled on completion