Skip to content

Authentication

FastSchema uses JWT (JSON Web Token) for authentication. When a user logs in, the server will generate a JWT token and send it back to the client.

The client should store the token and send it back to the server in every request.

Public Resources

Every FastSchema resources are protected by authentication except the following types of resources:

  • Resource that was marked as public: This must be set in the resource registration.
  • Resource that was granted to the guest role: By default, the guest role has no permissions.

Login

The client should send the login request to the /api/user/login endpoint with the user's login and password.

Request

http
POST /api/user/login HTTP/1.1
Accept: */*
Accept-Encoding: gzip, deflate, br, zstd
Accept-Language: en;q=0.9,ja;q=0.8
Cache-Control: max-age=0
Content-Type: application/json;charset=utf-8
Host: localhost:8000
Origin: http://localhost:3000
Referer: http://localhost:3000/
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36

Response

json
{
  "login": "admin",
  "password": "123"
}
json
{
  "data": {
    "token": "<jwt token>",
    "expires": "2024-06-24T20:21:10.085177874+07:00"
  }
}

The client should store the token and send it back to the server in every request.

Token usage

There are two ways to send the token to the server:

  • In the Authorization header: Bearer <jwt token>
  • In the Cookie header: token=<jwt token>
http
GET /api/user/me HTTP/1.1
Accept: */*
Accept-Encoding: gzip, deflate, br, zstd
Accept-Language: en;q=0.9,ja;q=0.8
Authorization: Bearer <jwt token>
Cache-Control: max-age=0
Connection: keep-alive
Content-Type: application/json;charset=utf-8
Cookie: token=<jwt token>
Host: localhost:8000
Referer: http://localhost:8000/dash/
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36

IMPORTANT

The token will be expired after a certain time. The server will return 401 Unauthorized if the token is expired.

If the jwt token is valid, but the user does not have permission to access the resource, the server will return 403 Forbidden.

Auth Provider

Besides the built-in authentication, you can also use the third-party authentication providers such as Google, Facebook, GitHub, etc.

You can enable the third-party authentication by setting the environment variable AUTH. The value is the minified JSON string that represents the AuthConfig struct.

go
type AuthConfig struct {
	EnabledProviders []string       `json:"enabled_providers"`
	Providers        map[string]Map `json:"providers"`
}

Example

json
{
  "enabled_providers": [
    "github",
    "google"
  ],
  "providers": {
    "local": {
      "activation_method": "email",
      "activation_url": "http://frontend-site.local/activation",
      "recovery_url": "http://frontend-site.local/recover"
    },
    "github": {
      "client_id": "github_client_id",
      "client_secret": "github_client_secret"
    },
    "google": {
      "client_id": "xxxxxxxxxxxxxxxxxxxx.apps.googleusercontent.com",
      "client_secret": "xxx"
    }
  }
}

Auth Provider endpoints

  • /api/auth/:provider/login: Redirect to the provider login page.
  • /api/auth/:provider/callback: The provider will redirect to this endpoint after the user logs in.

Custom Auth Provider

Only GitHub and Google are supported at the moment. We will add more providers in the future.

If you want to add a custom provider, you can implement the fs.AuthProvider interface.

go
type AuthProvider interface {
	Name() string
	Login(Context) (any, error)
	Callback(Context) (*User, error)
}

FastSchema allow registering the auth provider maker function. The maker function should return a new instance of the AuthProvider.

go
package main

import "github.com/fastschema/fastschema/fs"

func main() {
  fs.RegisterAuthProviderMaker("custom", NewCustomAuthProvider)
}

Released under the MIT License.