GraphQL implementation in Lua
#lua #graphql #server #library

bjorn 590fa1817a uniqueInputObjectFields; 9 years ago
tests 0f494589a0 More tests; 9 years ago
README.md a62c0048c8 Update README; 9 years ago
parse.lua 590fa1817a uniqueInputObjectFields; 9 years ago
rules.lua 590fa1817a uniqueInputObjectFields; 9 years ago
schema.lua 9f0298389e Fragment rules; Bugfixes; 9 years ago
types.lua 526e8c0ad4 InputObject type; 9 years ago
validate.lua 590fa1817a uniqueInputObjectFields; 9 years ago

README.md

GraphQL Lua

Lua implementation of GraphQL parser using LPeg. Experimental.

Example

require 'parse' [[{
  me {
    firstName
    lastName
  }
}]]

Gives you this scary table:

{
  kind = "document",
  definitions = {
    {
      kind = "operation",
      operation = "query",
      selectionSet = {
        kind = "selectionSet",
        selections = {
          {
            kind = "field",
            name = {
              kind = "name",
              value = "me"
            },
            selectionSet = {
              kind = "selectionSet",
              selections = {
                {
                  kind = "field",
                  name = {
                    kind = "name",
                    value = "firstName"
                  }
                },
                {
                  kind = "field",
                  name = {
                    kind = "name",
                    value = "lastName"
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

Status

The parser can parse virtually all of the query syntax:

  • Documents
  • Definitions
    • OperationDefinition
    • FragmentDefinition
  • Selections
  • Fields
  • Aliases
  • Arguments
  • FragmentSpreads and InlineFragments
  • All value types (scalars, enums, lists, objects, variables).
  • VariableDefinitions (typed)
  • Directives

The type system supports scalars, objects, enums, input objects, interfaces, and unions. The built in scalars are also provided (ints, floats, strings, etc.), as well as the two wrapper types (non null and list).

License

MIT