mirror of
https://github.com/weloe/token-go.git
synced 2025-10-04 23:22:41 +08:00
feat: add SerializerAdapter support custom serializer
This commit is contained in:
65
enforcer.go
65
enforcer.go
@@ -449,14 +449,57 @@ func (e *Enforcer) AddTokenGenerateFun(tokenStyle string, f model.GenerateFunc)
|
|||||||
|
|
||||||
func (e *Enforcer) GetSession(id string) *model.Session {
|
func (e *Enforcer) GetSession(id string) *model.Session {
|
||||||
if v := e.adapter.Get(e.spliceSessionKey(id)); v != nil {
|
if v := e.adapter.Get(e.spliceSessionKey(id)); v != nil {
|
||||||
session := v.(*model.Session)
|
if s := e.sessionUnSerialize(v); s != nil {
|
||||||
return session
|
return s
|
||||||
|
} else {
|
||||||
|
session, ok := v.(*model.Session)
|
||||||
|
if !ok {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return session
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (e *Enforcer) sessionUnSerialize(v interface{}) *model.Session {
|
||||||
|
// get serializer
|
||||||
|
serializer, ok := e.adapter.(persist.SerializerAdapter)
|
||||||
|
if !ok {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// to bytes
|
||||||
|
bytes, err := util.InterfaceToBytes(v)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
session, err := serializer.UnSerialize(bytes)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return session
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Enforcer) sessionSerialize(v *model.Session) ([]byte, error) {
|
||||||
|
serializer, ok := e.adapter.(persist.SerializerAdapter)
|
||||||
|
|
||||||
|
if !ok {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
return serializer.Serialize(v)
|
||||||
|
}
|
||||||
|
|
||||||
func (e *Enforcer) SetSession(id string, session *model.Session, timeout int64) error {
|
func (e *Enforcer) SetSession(id string, session *model.Session, timeout int64) error {
|
||||||
err := e.adapter.Set(e.spliceSessionKey(id), session, timeout)
|
bytes, err := e.sessionSerialize(session)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if bytes != nil {
|
||||||
|
err = e.adapter.Set(e.spliceSessionKey(id), bytes, timeout)
|
||||||
|
} else {
|
||||||
|
err = e.adapter.Set(e.spliceSessionKey(id), session, timeout)
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -470,3 +513,19 @@ func (e *Enforcer) deleteSession(id string) error {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (e *Enforcer) updateSession(id string, session *model.Session) error {
|
||||||
|
bytes, err := e.sessionSerialize(session)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if bytes != nil {
|
||||||
|
err = e.adapter.Update(e.spliceSessionKey(id), bytes)
|
||||||
|
} else {
|
||||||
|
err = e.adapter.Update(e.spliceSessionKey(id), session)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@@ -378,3 +378,44 @@ func TestNewEnforcer1(t *testing.T) {
|
|||||||
t.Log(err)
|
t.Log(err)
|
||||||
t.Log(enforcer)
|
t.Log(enforcer)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestEnforcer_JsonAdapter(t *testing.T) {
|
||||||
|
enforcer, err := NewEnforcer(persist.NewJsonAdapter(), config.DefaultTokenConfig())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("NewEnforcer() failed: %v", err)
|
||||||
|
}
|
||||||
|
newSession := model.NewSession("1", "2", "3")
|
||||||
|
newSession.AddTokenSign(&model.TokenSign{
|
||||||
|
Value: "2",
|
||||||
|
Device: "device",
|
||||||
|
})
|
||||||
|
newSession.AddTokenSign(&model.TokenSign{
|
||||||
|
Value: "3",
|
||||||
|
Device: "device",
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Log(newSession.Json())
|
||||||
|
println(newSession.TokenSignSize())
|
||||||
|
|
||||||
|
err = enforcer.SetSession("1", newSession, 565)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("SetSession() failed: %v", err)
|
||||||
|
}
|
||||||
|
session := enforcer.GetSession("1")
|
||||||
|
if id := session.Id; id != "1" {
|
||||||
|
t.Errorf("GetSession() failed")
|
||||||
|
}
|
||||||
|
if num := len(session.TokenSignList); num != 2 {
|
||||||
|
t.Fatalf("unexpected session tokenSignList length = %v", num)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = enforcer.updateSession("1", model.NewSession("4", "5", "6"))
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("updateSession() failed: %v", err)
|
||||||
|
}
|
||||||
|
session = enforcer.GetSession("1")
|
||||||
|
if id := session.Id; id != "4" {
|
||||||
|
t.Errorf("GetSession() failed")
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
27
persist/json_adapter.go
Normal file
27
persist/json_adapter.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package persist
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"github.com/weloe/token-go/model"
|
||||||
|
)
|
||||||
|
|
||||||
|
type JsonAdapter struct {
|
||||||
|
*DefaultAdapter
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewJsonAdapter() *JsonAdapter {
|
||||||
|
return &JsonAdapter{NewDefaultAdapter()}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (j *JsonAdapter) Serialize(session *model.Session) ([]byte, error) {
|
||||||
|
return json.Marshal(session)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (j *JsonAdapter) UnSerialize(bytes []byte) (*model.Session, error) {
|
||||||
|
s := &model.Session{}
|
||||||
|
err := json.Unmarshal(bytes, s)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return s, nil
|
||||||
|
}
|
9
persist/serializer_adapter.go
Normal file
9
persist/serializer_adapter.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package persist
|
||||||
|
|
||||||
|
import "github.com/weloe/token-go/model"
|
||||||
|
|
||||||
|
type SerializerAdapter interface {
|
||||||
|
Adapter
|
||||||
|
Serialize(*model.Session) ([]byte, error)
|
||||||
|
UnSerialize([]byte) (*model.Session, error)
|
||||||
|
}
|
@@ -1,5 +1,7 @@
|
|||||||
package util
|
package util
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
func HasNil(arr []interface{}) bool {
|
func HasNil(arr []interface{}) bool {
|
||||||
for _, elem := range arr {
|
for _, elem := range arr {
|
||||||
if elem == nil {
|
if elem == nil {
|
||||||
@@ -17,3 +19,10 @@ func HasStr(arr []string, str string) bool {
|
|||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func InterfaceToBytes(data interface{}) ([]byte, error) {
|
||||||
|
if b, ok := data.([]byte); ok {
|
||||||
|
return b, nil
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("unable to convert %T to []byte", data)
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user