This project aims to use neelance/graphql-go to build a starter web application. This project would be continuously under development. Pull request is welcome.
- Integrated with sqlx
- Integrated with graphql-go
- Use go-bindata to generate Go code from .graphql file
- Use psql
- Integrated with dataloader
- Add authentication & authorization
- Add unit test cases
- Support subscription
- Support web-socket notification and messaging
-
Install go-bindata
go get -u github.com/jteeuwen/go-bindata/...
-
Setup GOPATH
For example: MacOS
export GOPATH=/Users/${username}/go export PATH=$PATH:$GOPATH/bin
-
Run the following command at root directory to generate Go code from .graphql file
go-bindata -ignore=\.go -pkg=schema -o=schema/bindata.go schema/...
OR
go generate ./schema
There would be bindata.go generated under
schema
folder -
Start the server
go build server.go
Test in graphiql by the following endpoint
localhost:3000
Basically there are two graphql queries and one mutation
Query:
- Get an user by email
- Get user list by cursor pagination
Mutation:
- Create an user
For user list query, you need to be authenticated in order to use it. Authentication is not required for other operations.
In order to perform authentication/login, you need to create a user by graphql mutation first
Then you could submit your email and password by Basic Authorization Header with the following endpoint using POST method
localhost:3000/login
After that, you would get an access token(jwt)
You can change the Authorization of request header in graphiql.html
and restart the server to see the effect of authentication using token
You could use the notificationHub to broadcast message to specific target
Demo Code:
notificationHub := ctx.Value("notificationHub").(*model.NotificationHub)
noti := &model.Notification{From: 1, To: 9, Message: "1234222"}
notificationHub.BroadcastMessage(noti)
- Run Unit Tests
go test