An opinionated ORM for TypeScript/node.
- Schema-Driven Code Generation (continually-generated classes w/the getter/setter/relation boilerplate)
- Guaranteed N+1 safe (pervasive use of DataLoader)
- All Relations are Async/Await (with a type-safe escape hatch)
- Best-in-class Performance (all
SELECT
/INSERT
/UPDATE
operations are bulk) - Fast Unit Tests (for downstream projects, baseline is 10-20ms/test case)
- Unit of Work (navigate between entities as a consistent graph)
- Small & simple codebase (maintainable by a single engineer if needed)
(See goals for more in-depth descriptions of each bullet and misc features for "kinda like docs" highlights of things.)
(Also see Schema Assumptions for the assumptions Joist makes about your database schema.)
- NoSQL/Mongo/etc. support.
- Anything-but-Postgres support at this point.
- Browser/client-side support
Joist is currently used in production at Homebound. All of the features should generally be solid/working, with a caveat that fill a bug report if you run into anything.
See Getting Started and the integration-tests, which is essentially a sample app with a domain model of Author
, Book
, etc. entities.
Lack of documentation is currently Joist's biggest pain point.
The current "best" documentation sources are:
- Misc Features,
- Getting Started, and
- the integration-tests setup for copy/pasting a docker-compose setup
After checkout:
- Run
yarn install
- Run
yarn build
cd packages/integration-tests
- Run
make db
to boot up a Docker postgres instance w/the integration test schema. - Run
yarn test
to run the tests. - Prior to committing your changes, please run
yarn workspaces run format
In general priority/itch order:
- Open source
joist-graphql-utils
with theentityResolver
logic in it - Fix reactive rules not catching "middle-references" changing (fixed?)
- Optionally move
begin
to the start of Unit of Work readonly asyncValue
that integrations intopopulate
- Add Collection.load(loadHint) (see branch, potential tsc 3.9 issue)
- Support user-defined types
- Hack day:
CalendarInterval
that matches*_start_date
,*_end_date
,_duration_in_days
- Would need to be able to add to
Opts
,Filters
,derivedValue
?
- Would need to be able to add to
- Hack day:
- LargeCollection support
- I.e.
joist-config.json
entry to mark (say)publisher.authors
as "too big to never read at once" and use a different/restricted API, i.e. forced paging
- I.e.
- JSON support, i.e.
toJSON
- First-class support for soft deletion?
- Op locks/
version
column? - An in-memory backend
hasOneThrough
that can be used asfind
/SQL filters- Need to declare in codegen to a) add to FilterType + b) verify once traverses relations
Joist is also the name for a Java-based ORM I wrote circa 2008.
joist-ts has many of the same ideas (in terms of opinionated codegen), just applied to TypeScript, and leveraging DataLoader.
The EntityManager.find
syntax is heavily inspired from MikroORM, as well as the concept of EntityManager.populate
.
MIT