GraphQL - Resolvers

Shubham Tiwari - Jun 27 '23 - - Dev Community

Hello Everyone, in this part of the GraphQL series, I will discuss resolvers.

Resolvers

  • They are functions that define how to retrieve or manipulate data for each field in a GraphQL schema. Resolvers are a crucial part of GraphQL server implementations and are responsible for fetching data from various sources, such as databases, APIs, or other services, and returning the requested data.

  • When a client sends a GraphQL query, the server matches the fields in the query to the corresponding resolvers. Each field in the schema has an associated resolver function that determines how to resolve the data for that field.

Creating a resolver-

  • In the previous part of this series, you have created a folder called "schema", inside that folder, create another file named "resolvers,js" and paste this code there.
const { fakeData } = require("../FakeData")
const lodesh = require("lodash")
const resolvers = {
    Query: {
        // Get All users
        users() {
            return fakeData
        },
        // Get user by ID
        user(parent, args) {
            const id = args.id
            const user = lodesh.find(fakeData, { id: Number(id) })
            return user
        },
        // Get user by Name
        userByName(parent, args) {
            const name = args.name
            const user = lodesh.find(fakeData, { name  })
            return user
        },
    },

    Mutation: {
        createUser(parent,args){
            const user = args.newUser
            user.id = Math.floor(Math.random() * 999999)
            fakeData.push(user)
            return user
        },
        updateUser(parent,args){
            const {id,name,role,age,isEmployee} = args.updatedUser
            let updateUserName;

            fakeData.forEach(item => {
                if(item.id == id){
                    item.name = name
                    item.age = age
                    item.role = role
                    item.isEmployee = isEmployee
                    updateUserName = item
                }
            })

            return updateUserName
        },
        deleteUser(parent,args){
            const {id} = args.delUser
            lodesh.remove(fakeData,(user) => user.id === Number(id))
            return null
        },

    }
}

module.exports = { resolvers }
Enter fullscreen mode Exit fullscreen mode
  • Here we have 2 Properties Query, which is used for data fetching, and Mutation which is used for manipulating data like adding, updating, or deleting, there properties have handler functions for our handlers created in typeDefs.
  • args will have all the properties which are defined in the typeDefs schema file.

  • Also Create a file named fakeData.js and add this data to it.

//fakeData.js
const fakeData = [
    {
        id: 101,
        name: "User 1",
        age: 24,
        isEmployee: true,
        role: "WebDeveloper",
        friends: [
            {
                id: 102,
                name: "User 2",
                age: 21,
                isEmployee: true,
                role: "Tester"
            },
            {
                id: 103,
                name: "User 3",
                age: 20,
                isEmployee: false,
                role: "SoftwareEngineer"
            },
            {
                id: 104,
                name: "User 4",
                age: 27,
                isEmployee: true,
                role: "WebDeveloper"
            }
        ]
    },
    {
        id: 102,
        name: "User 2",
        age: 21,
        isEmployee: true,
        role: "Tester",
        friends: [
            {
                id: 103,
                name: "User 3",
                age: 20,
                isEmployee: false,
                role: "SoftwareEngineer"
            },
            {
                id: 104,
                name: "User 4",
                age: 27,
                isEmployee: true,
                role: "WebDeveloper"
            }
        ]
    },
    {
        id: 103,
        name: "User 3",
        age: 20,
        isEmployee: false,
        role: "SoftwareEngineer",
        friends: [
            {
                id: 104,
                name: "User 4",
                age: 27,
                isEmployee: true,
                role: "WebDeveloper"
            }
        ]
    },
    {
        id: 104,
        name: "User 4",
        age: 27,
        isEmployee: true,
        role: "WebDeveloper",
        friends: [
            {
                id: 103,
                name: "User 3",
                age: 20,
                isEmployee: false,
                role: "SoftwareEngineer"
            }
        ]
    }
];


module.exports = { fakeData }
Enter fullscreen mode Exit fullscreen mode
  • Fake Dataset to manipulate GraphQL handler functions.

Now run this command -

npm run start
Enter fullscreen mode Exit fullscreen mode
  • It will start the server at localhost:4000 with GraphQL UI, where you can check your API responses

This is how you can create a Resolver for your GraphQL API. In the Next Part of this Series, I will be discussing Mutation, which will help in creating, updating, or deleting data from the dataset.

CREDITS - https://www.youtube.com/results?search_query=pedrotech

THANK YOU FOR CHECKING THIS POST
You can contact me on -
Instagram - https://www.instagram.com/supremacism__shubh/
LinkedIn - https://www.linkedin.com/in/shubham-tiwari-b7544b193/
Email - shubhmtiwri00@gmail.com

^^You can help me with some donation at the link below Thank you👇👇 ^^
☕ --> https://www.buymeacoffee.com/waaduheck <--

Also check these posts as well
https://dev.to/shubhamtiwari909/website-components-you-should-know-25nm

https://dev.to/shubhamtiwari909/smooth-scrolling-with-js-n56

https://dev.to/shubhamtiwari909/swiperjs-3802

https://dev.to/shubhamtiwari909/custom-tabs-with-sass-and-javascript-4dej

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .