Use this client to access the FusionAuth APIs in your Go application. For additional information and documentation on FusionAuth refer to https://fusionauth.io.
- @medhir Thank you for the initial commit and initial implementation of the Go client!
- @markschmid Thank you for your PRs, feedback and suggestions!
- The FusionAuth team - couldn't have done it without you!
go get github.com/FusionAuth/go-client/pkg/fusionauth
The following example uses the FusionAuth Go client to create a request handling function that logs in a user:
package example
import (
"encoding/json"
"net/http"
"net/url"
"time"
"github.com/FusionAuth/go-client/pkg/fusionauth"
)
const host = "http://localhost:9011"
var apiKey = "YOUR_FUSIONAUTH_API_KEY"
var httpClient = &http.Client{
Timeout: time.Second * 10,
}
var baseURL, _ = url.Parse(host)
// Construct a new FusionAuth Client
var auth = fusionauth.NewClient(httpClient, baseURL, apiKey)
// Login logs in the user using the FusionAuth Go client library
func Login() http.HandlerFunc {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
// Read response body
var credentials fusionauth.LoginRequest
defer r.Body.Close()
json.NewDecoder(r.Body).Decode(&credentials)
// Use FusionAuth Go client to log in the user
authResponse, errors, err := auth.Login(credentials)
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
// Write the response from the FusionAuth client as JSON
var responseJSON []byte
if errors != nil {
responseJSON, err = json.Marshal(errors)
} else {
responseJSON, err = json.Marshal(authResponse)
}
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusOK)
w.Write(responseJSON)
})
}
Bug reports and pull requests are welcome on GitHub at https://github.com/FusionAuth/go-client.
If you find an issue with syntax, etc - this is likely a bug in the template. Feel free to submit a PR against the Client Builder project.
The code is available as open source under the terms of the Apache v2.0 License.