GithubHelp home page GithubHelp logo

Query as an @auth option about graphql HOT 5 CLOSED

neo4j avatar neo4j commented on July 28, 2024
Query as an @auth option

from graphql.

Comments (5)

danstarns avatar danstarns commented on July 28, 2024

Hey @tlester thanks for subbmitng your idea! Im struggling to get the concept do you have any more examples or info ? Given the below:

type User {
  name: String
}

extend type User @auth(rules: [{ 
    operations: [CREATE],
    isAuthenticated: true,
    query: {
        match: "allen",
        gql:  `users(where: {name: "bob"}) { name }`
    }
}])

Then someone performs a CREATE operation:

mutation {
  createUsers(input: [{ name: "SOME NAME" }]) {
    users {
      name
    }
  }
}

Where and how does the below query bit get incorporated with this mutation?

query: {
        match: "allen",
        gql:  `users(where: {name: "bob"}) { name }`
    }

from graphql.

darrellwarde avatar darrellwarde commented on July 28, 2024

I need to have a flexible option validate date as a condition for authenticity.

I find myself especially intrigued by this use case, an example of how and where you might use this could really provide some clarity here.

from graphql.

bloomdido avatar bloomdido commented on July 28, 2024

@tlester Would my suggested feature #163 satisfy your needs? The @cypher directive can already handle parameters, and you'd have full access to the power of Cypher (not just GraphQL) in determining the conditions for your validation.

from graphql.

jacob-buscher avatar jacob-buscher commented on July 28, 2024

I need to have a flexible option validate date as a condition for authenticity.

I find myself especially intrigued by this use case, an example of how and where you might use this could really provide some clarity here.

@darrellwarde

This would be especially useful in places where you need tenant based auth, if you have numerous "organizations" and "suborganizations" and you want to have RBAC style roles

Something like ${teamId}:admin, ${teamId}:owner, ${teamId}:guest where teamId is populated from based on the query.

I'm having a hard time using the @auth directive to make tenant based roles and permissions. I believe this is possible with allow but my rules are looking way more complex than I think they should.

I go into a bit of detail about my use case in #163

from graphql.

darrellwarde avatar darrellwarde commented on July 28, 2024

This is not something we're ever going to do - auth is a big enough beast as it is and is overdue a much needed refactor, but GraphQL within a directive definitely won't be a part of it - far too meta!! 😆 In the interest in making some progress on the feature backlog, closing this one.

from graphql.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.