Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Middleware Pattern w/ Actions (Re-Use Types, Less Boilerplate) #7824

Open
zlanich opened this issue Nov 19, 2021 · 3 comments
Open

Middleware Pattern w/ Actions (Re-Use Types, Less Boilerplate) #7824

zlanich opened this issue Nov 19, 2021 · 3 comments
Labels
c/actions Related to actions k/enhancement New feature or improve an existing feature k/v3-beta t/gql-services

Comments

@zlanich
Copy link

zlanich commented Nov 19, 2021

Is your proposal related to a problem?

Preface: I'm aware of ALL of documented Hasura features as of time of writing.

One of the main concerns I hear about with Hasura is how unwieldy the Actions/Types, etc will get once the API matures and there has to be TONS of exceptions for intermediary logic between the initial GraphQL request & the response. Obvious examples are:

  1. Advanced validation that can't be accomplished with Check Constraints, etc
  2. Custom authorization

Currently, every exception requires an Action w/ Derived types that needs to be maintained from there on, etc, and this is going to be rough once the API matures. If the boilerplate was simpler, and the types for these actions could be automatically derived from the original request, this would make maintenance simpler by using introspection & codegen for TS types in code, etc.

Describe the solution you'd like

I quite honestly don't know what this solution looks like yet, consider Hasura is written in Haskell. I would like to start a conversation about how this could improve.

Describe alternatives you've considered

Simple examples of other setups being more usable would be Node Express + custom resolvers, Prisma, etc, though I realize that Hausra has serious performance and initial time-to-launch advantages over these. Every middleware option in Node JS could be considered if you were using these other options.

If the feature is approved, would you be willing to submit a PR?

I have no idea how to write in Haskell, but I would be willing to contribute in JS/Node/TS environments and in any specification/planning manner.

Other Notes

Similar issues have been mentioned in the past, namely: #5001

If anyone has any questions, please let me know! I'm almost 100% dead set on using Hasura for my company's go-to web/app API stack in the near future, and I want to iron out all possible foreseen issues in near/mid-term scale before I commit. Thank you!

@zlanich zlanich added the k/enhancement New feature or improve an existing feature label Nov 19, 2021
@soorajshankar
Copy link
Member

Partially related to #5001

@rahulagarwal13
Copy link
Contributor

@zlanich Thanks for the detailed comment here!

We're working on a set of enhancements on Actions:

Would love to get on a quick chat with you if you're open to it to:
a) discuss your current Authz and API system you've built around Hasura and help review it
b) review what we're planning and see how that might be of immediate help to you

My email is rahul.agarwal@hasura.io - please do reach out!

@manasag
Copy link
Contributor

manasag commented Apr 16, 2024

Hi, I want to update that we are launching Hasura V3 (DDN) this month. V3 introduces a new code driven architecture for the enahnced and ever evolving business logic usecases. To start with, you can write your actions entirely in typescript, using our typescript connector (with support of auto introspection of your functions so that you dont have to maintain the Graphql types for your actions). Would like to hear if this new approach in V3 helps address your concerns here.

I would highly suggest to join us to see the full power of Hasura DDN at the Hasura Dev Day on April 16 🎉. Sign up here: https://hasura.io/dev-day. Can't make it? Sign up anyway and we'll send you the recording.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
c/actions Related to actions k/enhancement New feature or improve an existing feature k/v3-beta t/gql-services
Projects
None yet
Development

No branches or pull requests

4 participants