| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 | package mainimport (	"time"	"github.com/dgrijalva/jwt-go")func generateTokenPair(user userInfo) (map[string]string, error) {	// Create token	token := jwt.New(jwt.SigningMethodHS256)	// Set claims	// This is the information which frontend can use	// The backend can also decode the token and get admin etc.	claims := token.Claims.(jwt.MapClaims)	claims["admin"] = false	for _, v := range user.Result.Result.MemberofGroup {		if v == "admins" {			claims["admin"] = true		}	}	claims["sub"] = 1	claims["name"] = user.Result.Value	claims["exp"] = time.Now().Add(time.Minute * 15).Unix()	// Generate encoded token and send it as response.	// The signing string should be secret (a generated UUID works too)	t, err := token.SignedString([]byte("secret"))	if err != nil {		return nil, err	}	refreshToken := jwt.New(jwt.SigningMethodHS256)	rtClaims := refreshToken.Claims.(jwt.MapClaims)	rtClaims["sub"] = 1	rtClaims["exp"] = time.Now().Add(time.Hour * 24).Unix()	rt, err := refreshToken.SignedString([]byte("secret"))	if err != nil {		return nil, err	}	return map[string]string{		"access_token":  t,		"refresh_token": rt,	}, nil}
 |