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

bjorn afc95fcaef Variable uses are defined; 9 năm trước cách đây
tests 0f494589a0 More tests; 9 năm trước cách đây
README.md a62c0048c8 Update README; 9 năm trước cách đây
parse.lua 590fa1817a uniqueInputObjectFields; 9 năm trước cách đây
rules.lua afc95fcaef Variable uses are defined; 9 năm trước cách đây
schema.lua af0930639a Variable rules; 9 năm trước cách đây
types.lua 733f1c1aff Directive rules; 9 năm trước cách đây
validate.lua afc95fcaef Variable uses are defined; 9 năm trước cách đây

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