Ktor¶
If you are running a ktor server, there is a separate package that makes it easy to set up a fully functional GraphQL server.
You first need to add the KGraphQL-ktor package to your dependency
implementation("de.stuebingerb:kgraphql-ktor:$KGraphQLVersion")
implementation 'de.stuebingerb:kgraphql-ktor:${KGraphQLVersion}'
<dependency>
<groupId>de.stuebingerb</groupId>
<artifactId>kgraphql-ktor</artifactId>
<version>${KGraphQLVersion}</version>
</dependency>
Initial setup¶
To set up KGraphQL you'll need to install the GraphQL feature like you would any other ktor feature.
fun Application.module() {
install(GraphQL) {
playground = true
schema {
query("hello") {
resolver { -> "World!" }
}
}
}
}
Now you have a fully working GraphQL server. We have also set playground = true
, so when running this you will be able
to open http://localhost:8080/graphql (your port number may vary) in your browser and
test it out directly within the browser.
Configuration options¶
The GraphQL feature is extending the standard KGraphQL configuration and providing its own set of configuration as described in the table below.
Property | Description | Default value |
---|---|---|
playground | Gives you out of the box access to a GraphQL playground | false |
endpoint | This specifies what route will be delivering the GraphQL endpoint. When playground is enabled, it will use this endpoint also. |
/graphql |
context | Refer to example below | |
wrap | If you want to wrap the route into something before KGraphQL will install the GraphQL route. You can use this wrapper. See example below for a more in depth on how to use it. | |
schema | This is where you are defining your schema. Please refer to KGraphQL References for further documentation on this. | required |
Wrap¶
Sometimes you would need to wrap your route within something. A good example of this would be the authenticate
function provided by ktor Authentication feature.
wrap {
authenticate(optional = true, build = it)
}
This works great alongside the context to provide a context to the KGraphQL resolvers.
Context¶
To get access to the context
context { call ->
// access to authentication is only available if this is wrapped inside a `authenticate` before hand.
call.authentication.principal<User>()?.let {
+it
}
}
schema {
query("hello") {
resolver { ctx: Context ->
val user = ctx.get<User>()!!
"Hello ${user.name}"
}
}
}
Schema Definition Language (SDL)¶
The Schema Definition Language (or Type System Definition Language) is a human-readable, language-agnostic representation of a GraphQL schema.
See the following comparison:
schema {
data class SampleData(
val id: Int,
val stringData: String,
val optionalList: List<String>?
)
query("getSampleData") {
resolver { quantity: Int ->
(1..quantity).map { SampleData(it, "sample-$it", emptyList()) }
}.withArgs {
arg<Int> { name = "quantity"; defaultValue = 10 }
}
}
}
type Query {
getSampleData(quantity: Int! = 10): [SampleData!]!
}
type SampleData {
id: Int!
optionalList: [String!]
stringData: String!
}
If schema introspection is enabled, the ktor feature will expose the current schema in Schema Definition Language under http://localhost:8080/graphql?schema.