Dgraph and Slash GraphQL: Using Insomnia with Examples - Dgraph Blog

Insomnia is one of the most popular API development tools that also support GraphQL. In this article, you’ll find out how you can use Insomnia to interact with a Slash GraphQL instance and perform GraphQL requests such as mutations, queries, etc. so that you can sketch out your thoughts and start prototyping your GraphQL application.

Insomnia has some handy features that make it easier to perform administrative tasks like we did using Postman. So you’re also going to see how Insomnia can be set up with those requests.

Slash GraphQL

Slash GraphQL is Dgraph’s fully-managed backend service, which takes the hassle away from building GraphQL applications. No need to write resolvers or anything on your own to build your API, you just need to get your GraphQL schema ready with types representing your application data and Slash GraphQL will give you a complete backend with production-level features built-in. So you can just focus on building your app with no distractions from the backend.

So head over to Slash GraphQL and sign up for free. It takes only a minute or so to get a fully functional backend running.

After signing up and logging in, you’ll see your dashboard.

You can try and play around with Slash GraphQL free for a month. Then if you feel like it, you can upgrade by clicking on the Upgrade button in the lower left of the sidebar.

So click on the Launch a backend button for now; if you want you can start taking the Interactive Tutorial and get a guided tour of how to get around with Slash GraphQL.

Hit Launch and your backend will be ready in a jiffy.

After the deployment finishes, your dashboard will show you some information, including the URL of your new server. Note that down since you’ll need it for Insomnia to interact with your backend.

Remote admin operations using tools like Insomnia and Postman require authentication, so you’ll need an API key. Select Settings in the left sidebar, go to the Security tab, and click on Create New.

In the next window give your key a name and select the role (in this case choose Admin), then hit Create.

Note down the generated key and keep it somewhere safe; you won’t be able to access it after closing down that window. If you happen to lose your key or forget to copy it, you can generate a new one from Create New. Later you’ll need to include this key as an HTTP header when sending admin requests to your GraphQL backend.

Using Insomnia with Slash GraphQL

Let’s explore some features of Insomnia and get it ready so that we can start doing some fun stuff.

Workspaces

Insomnia lets users create “workspaces” for each project that they’re working on. Click on the top-left menu on the sidebar colored in purple and select Create Workspace. The tasks now at hand are all with Slash GraphQL backend, so let’s name it “Slash GraphQL”.

Just naming it so isn’t that informative. Press Shift+Ctrl+ to open your workspace settings and type in a description for your project workspace:

Environments and variables

Insomnia offers a way to set up “environments” that can contain values (or more familiarly “environment variables”) that are used throughout multiple requests and workflows. Obviously, you’ll need your server URL in all of your requests; and the /admin endpoint requires authentication in order to be accessible. So let’s wrap them up in two variables so you can reuse them at ease.

Fire up Insomnia and click on the No Environment button in the sidebar. Then select Manage Environments:

The Base Environment will work nicely for now. The base_url would hold the backend URL and token the API key for authentication. You can generate a key for your backend easily from your Slash dashboard by going to Settings and then the Security tab.

With these variables in place, you’re ready to start making requests. Let’s continue and see how Insomnia offers a clean way of organizing request workflows.

Folders

You can make folders that each represent different parts of your development in a project. For example, you’re going to make a folder that’s going to contain the necessary requests to administer the backend, according to the docs here. So it’ll have these four requests:

  • getting the schema
  • setting a new schema
  • exporting data
  • dropping data

Click on the plus (+) icon at the top left in the sidebar and select on New Folder:

If you do a right-click on the new folder you’ll see that it’s possible to create sub-folders as well!

Adding requests

Now let’s create those requests. Do a right-click on the folder and select New Request.

This request is for fetching the current schema in your server from the /admin endpoint. Select POST as the method and GraphQL as the format and hit Create.

As with writing code, it’s good practice to add documentation while working with APIs as well and tools like Insomnia and Postman offer ways to do that. Let’s add a description for the request as to what it does and the context like you saw when creating the workspace. Right click on the request and select Settings. In the new window, write a short description for the request:

As you can see, you can write it in Markdown! You can see the description in the Docs tab:

Now add the following GraphQL query in the GraphQL tab that would send a request to fetch the current schema:

query {
  getGQLSchema {
    schema
  }
}

The URL bar is still empty. Earlier you set up a variable containing the base URL for the server. If you start typing in base_url you should see an autocomplete suggestion from Insomnia. If not you can just press Ctrl+Space; base_url would be there in the modal list that appears with matching suggestions. Hit enter. Now you just type in /admin after that.

You need to get authenticated, remember? Time to use that token variable.

The token would be sent as an HTTP header as X-Auth-Token. Open the Header tab and type in those values:

You’re ready to dispatch your request. Hit send and you’ll see a satisfying response:

Well not quite… this is a null response because no schema hasn’t been added yet. We’ll get to that in a minute, but most importantly, requests are working!

In the same way, you can easily add the rest of those requests; remember to include the X-Auth-Token header with your token. After finishing, you can see all the requests under the Slash GraphQL Admin folder neatly arranged:

Now let’s add a schema.

The schema is going to represent a simple website where users can post their various works of art in the format of a photo or even a short video; it could be photography, digital or handmade paintings, sculptures, etc.

type User {
    id: ID!
    username: String! @search
    submissions: [Art] @hasInverse(field: posted_by)
}
type Art {
    id: ID!
    category: String! @search
    title: String!
    format: String!
    posted_by: User!
}

You can deploy this schema from within the Slash UI but here let’s set the schema using Insomnia. That’s just a mutation request:

mutation($sch: String!) {
  updateGQLSchema(input: { set: { schema: $sch}})
  {
    gqlSchema {
      schema
      generatedSchema
    }
  }
}

The sch variable would hold the schema:

{
    "sch": "type User {\n    id: ID!\n    username: String! @search\n    submissions: [Art] @hasInverse(field: posted_by)\n}\n\ntype Art {\n    id: ID!\n    category: String! @search\n    title: String!\n    format: String!\n       posted_by: User!}"
}

Hit send and you’ll get a response with the schema and generatedSchema field:

That’s all there’s to it! You can head over to your Slash dashboard and verify that your schema got deployed from the Schema section on the left sidebar:

The backend is now ready with a graph giving the application a well-structured skeleton where you can start putting in data. Let’s go and do that.

Performing mutations and queries

These would be just normal GraphQL mutations to add data and queries to iterate over as you wish, not admin requests, so remember to fill in the URL field with the base_url variable and /graphql endpoint.

Create another folder titled QueriesAndMutation and add a Adding user request there:

mutation($userDetails: [AddUserInput!]!) {
  addUser(input: $userDetails) {
    user {
      username
      submissions {
        title
        category
        format
        posted_by {
          username
        }
      }
    }
  }
}

With the $userDetails variabe as:

{
  "userDetails": [
    {
      "username": "thomas",
      "submissions": [
        {
          "category": "Digital Painting",
          "format": "Photo",
          "title": "The Good Times",
          "posted_by": {
            "username": "thomas"
          }
        }
      ]
    },
    {
      "username": "albert",
      "submissions": [
        {
          "category": "Short Film",
          "format": "Video",
          "title": "Songbird",
          "posted_by": {
            "username": "albert"
          }
        },
        {
          "category": "Photography",
          "format": "Photo",
          "title": "Last Sunset",
          "posted_by": {
            "username": "albert"
          }
        }
      ]
    },
    {
      "username": "phill",
      "submissions": [
        {
          "category": "Short Film",
          "format": "Video",
          "title": "Secret Skies",
          "posted_by": {
            "username": "phill"
          }
        },
        {
          "category": "Digital Painting",
          "format": "Photo",
          "title": "Melancholy",
          "posted_by": {
            "username": "phill"
          }
        }
      ]
    }
  ]
}

After hitting Send you’ll get your mutation results back:

Cool! Now let’s do a query and fetch each user’s details along with their submissions:

query {
  queryUser {
    username
    id
    submissions {
      id
      category
      title
      format
    }
  }
}
{
  "data": {
    "queryUser": [
      {
        "username": "albert",
        "id": "0xf",
        "submissions": [
          {
            "id": "0x10",
            "category": "Photography",
            "title": "Last Sunset",
            "format": "Photo"
          },
          {
            "id": "0x16",
            "category": "Short Film",
            "title": "Songbird",
            "format": "Video"
          }
        ]
      },
      {
        "username": "phill",
        "id": "0x12",
        "submissions": [
          {
            "id": "0x11",
            "category": "Short Film",
            "title": "Secret Skies",
            "format": "Video"
          },
          {
            "id": "0x13",
            "category": "Digital Painting",
            "title": "Melancholy",
            "format": "Photo"
          }
        ]
      },
      {
        "username": "thomas",
        "id": "0x15",
        "submissions": [
          {
            "id": "0x14",
            "category": "Digital Painting",
            "title": "The Good Times",
            "format": "Photo"
          }
        ]
      }
    ]
  }

There’s a @search directive on the category field of Art so you can run a query to fetch submissions that belong to the Short Film category.

query {
  queryArt(filter: { category: {allofterms: "Short Film"}}) {
    category
    title
    posted_by {
      id
      username
    }
  }
}

This returns:

{
  "data": {
    "queryArt": [
      {
        "category": "Short Film",
        "title": "Secret Skies",
        "posted_by": {
          "id": "0x12",
          "username": "phill"
        }
      },
      {
        "category": "Short Film",
        "title": "Songbird",
        "posted_by": {
          "id": "0xf",
          "username": "albert"
        }
      }
    ]
  }

Nice, we got the two “Short Film” submissions back!

Code generation

Insomnia supports code generation for several languages. For example, if you want to send those requests from the command line using curl, you can generate code for that using Insomnia.

Right-click on any request and select Copy as Curl.

Just paste and run it on your terminal; you’ll get the same response back:

Depending on your preference or scenario, to generate code for any other language, select Generate Code instead and select your preferred language from the dropdown menu:

Share, export, and import

Like Postman, you can share your workspace with your team members that also enables syncing capabilities, but this requires a purchase. Other than that you can do an export of your workspace and share that.

To do an export, click on your Slash GraphQL workspace and select Import/Export:

Select Current Workspace. You can choose which requests you want to be exported. Finally, select Export and then your desired export format (JSON, YAML, HAR).

The exported file can later be imported in Insomnia. It’s also possible to import a Postman’s exported collection as well, among some other formats. You can refer to the official docs here.

Let’s import Postman’s “Slash GraphQL Admin” collection inside Insomnia. From the Import/Export window select Import and then From File.

After importing you’ll get a confirmation popup and a new folder containing all requests of that collection.

This is quite helpful because it doesn’t matter whether or not your co-worker or some other party worked inside Postman because you can make the exported data work inside Insomnia as well.

Summary

In this article, you’ve learned how to use Insomnia to work with Slash GraphQL and perform administrative operations, as well as dispatching normal GraphQL requests, in an organized way using workspaces, environments, folders, and keeping minimal documentation of your work. You’ve also learned how to use import/exports for useful collaboration.

Tools like Insomnia and Postman can help you test and try out how to get around with GraphQL and manage deployments with Slash GraphQL. Soon you’ll want to develop applications on top of it. If you haven’t already, be sure to sign up for Slash GraphQL so that you can build GraphQL apps easily.

If you need pointers or a hands-on approach in the realm of GraphQL and app development, Dgraph Tutorial Center can give you a head start in building full-stack GraphQL applications on the Dgraph platform, using frontend solutions like React and Vue. It’s free and full of information and docs to help you along your learning journey. You can also dive into our docs section for more detailed reading on specific elements that interest you.

For further reading on the topics covered, here’s a collection of resources:


This is a companion discussion topic for the original entry at https://dgraph.io/blog/post/insomnia-with-dgraph-graphql/