Unify is an entity-first fullstack protocol. Developers define unified entity models to seamlessly abstract over diverse implementations (APIs, protocols, schemas).
npx @unilab/urpc-cli create my-projectKills switch-case hell in multi-protocol apps ๐งน
- Frontend works with clean abstractions
- backend freely extends supported sources.
1๏ธโฃ Entity-Driven API โ Call repo().findOne() to abstract away backend differences (schema, protocol, source).
2๏ธโฃ Plug-and-Play Sources โ Switch implementation via source:"evm"/"solana" โ same interface, no logic rewrite.
3๏ธโฃ Data Standardization โ Protocol-agnostic outputs via entity contracts (e.g., unify EVM hex and Solana base58 addresses).
Query balance for an EVM and a Solana wallet โ same code pattern, different source:
repo<WalletEntity>({ entity: "wallet", source: "evm" }).findOne({ where: { address: "0x..." } });
repo<WalletEntity>({ entity: "wallet", source: "solana" }).findOne({ where: { address: "1111..." } });
repo<NFT>({ entity: "nft", source: "ethereum" }).findMany({ where: { owner: "0x..." } });
repo<NFT>({ entity: "nft", source: "polygon" }).findMany({ where: { owner: "0x..." } });Legacy vs. modern systems
repo<User>({ source: "legacy-api" }).findMany() // legacy system
repo<User>({ source: "v2-graphql" }).findMany() // new serviceDevice Agnostic IoT
repo<SensorData>({ source: "mqtt" }).create({...});
repo<SensorData>({ source: "http-api" }).create({...}}); Analytics & Logging Aggregation
// Query events from Datadog
repo<LogEntry>({ entity: "event", source: "datadog" }).find({ where: { type: "error", timestamp: { gte: "..." } } });
// Query user actions from Mixpanel
repo<LogEntry>({ entity: "userAction", source: "mixpanel" }).find({ where: { userId: "user-x", eventName: "login" } });
// Query system metrics from Prometheus
repo<Metric>({ entity: "metric", source: "prometheus" }).find({ where: { name: "cpu_usage", host: "server-a" } });MIT License ๐