Remix.run Logo
A Principled Approach to Querying Data – A Type-Safe Search DSL(claudiu-ivan.com)
93 points by kioku 6 months ago | 21 comments
fire_lake 6 months ago | parent | next [-]

> Users expect near-native responsiveness, even when offline

Do they? I think users are amazed if anything works without internet with modern applications.

scarletphoenix 6 months ago | parent | next [-]

In my mental model of an offline app, I expect instant responses. However, I know to the complexities of apps, the diverse wants of a big, diverse user base that it can be hard/impossible for an app to be well-architected enough to achieve this ideal.

Failover is hard, and there generally aren't hard rules for what to do if data isn't available or how to communicate to a user in a specific offline situation on how the current state of an offline app affects what they see -- and even when they would care or what they could do about it when they do care

cdaringe 6 months ago | parent | prev [-]

The two are not mutually exclusive!

FrustratedMonky 6 months ago | parent | prev | next [-]

Seems a lot like FSharp Type Providers? Is that a good analogy?

williamcotton 6 months ago | parent | prev | next [-]

I've got a similar project that includes a React component for the search input. The React component is actually a Monaco text editor so you get syntax highlighting, error highlighting, tab completion and more.

Check it out here: https://github.com/williamcotton/search-input-query

There's an animated GIF of the demo so you can get a very quick idea of how it works!

6 months ago | parent | prev | next [-]
[deleted]
gitroom 6 months ago | parent | prev | next [-]

Nice, Ive bounced around between Prisma and Kysely too. I get nervous about locking too much into one thing, you ever worry if leaning on too much codegen or magic ends up biting you down the road?

tehlike 6 months ago | parent | prev | next [-]

LINQ or PRQL.

hu3 6 months ago | parent | prev | next [-]

Looks good.

For a more database specific, type-safe, data querying solution, I like to use https://kysely.dev

damidekronik 6 months ago | parent | next [-]

I am using both prisma and kysely in the same codebase with a great success. The db schema is driven by SQL, not prisma. It is then introspected by both kysely and prisma, prisma is used in 95% of the places while kysely is used whenever performance is critical or when prisma doesn't support the SQL features we need.

tough 6 months ago | parent [-]

any underlying negative consequences on letting prisma schema handle the underlynig model/migrations

I found out about stackzen yesterday, really like the RBAC/ABAC backed up into the models/codegen stuff, been thinking about just using that for our custom logic and maybe add RLS pg a la supabase but also codegen from the same .zmodel from zenstack model that generates prisma models/migrations have it generate RLS sql migrations code

thoughts??

also maybe postgres views to handle field/attribute level security since rows is mostly about whole columns

main goal is to secure the data at all the levels of the stack from db to api to app so there's no footguns in the future where someone with a pg user or modifying our clients can see data they shouldn't etc

damidekronik 6 months ago | parent | next [-]

Prisma doesn't cover plenty of SQL features. custom types, more complex indexes (like where clause). It is also a VC backed biznes, need to be ready to drop it at almost any time, SQL/postgres on the other hand is here to stay.

RLS is hard to work with, hard to debug, hard to reason about, cumbersome. It is however powerful.

tough 6 months ago | parent [-]

Right! for RLS i found out about atlasgo, which lets you do Schemas as Code including RLS stuff,

so my mind went to leverage the .zmodel to generate not only the prisma schemas through it and the client api codegen sdk, but also the RLS stuff either with plain sql migrations or a specific framework for rls.

all in all this is probably too much and as long as the app-api level is secure with zenstack and i dont use pg directly anywhere else it should be 'safe' i just wanted to harden all the stack speaking of sorts... idk

krashidov 6 months ago | parent | prev [-]

what is stackzen? I googled it and found nothing

ebalit 6 months ago | parent | next [-]

It's most probably ZenStack given the description: https://zenstack.dev/

tough 6 months ago | parent [-]

yes sorry, typo, i meant ZenStack!

krashidov 6 months ago | parent | prev [-]

is it this? https://github.com/stacksjs/stacks

tough 6 months ago | parent [-]

Nope sorry it was zenstack https://zenstack.dev/

6 months ago | parent | prev [-]
[deleted]
mifydev 6 months ago | parent | prev [-]

The same should apply to configuration, we have prisma for sql, we should have something like this for JSONs, like https://typeconf.dev (I’m one of the founders)

6 months ago | parent [-]
[deleted]