mirror of
https://github.com/astaxie/beego.git
synced 2025-06-13 18:10:39 +00:00
support using json string to init session
This commit is contained in:
@ -3,6 +3,7 @@ package ledis
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
"strconv"
|
||||
"strings"
|
||||
@ -79,35 +80,51 @@ func (ls *SessionStore) SessionRelease(ctx context.Context, w http.ResponseWrite
|
||||
// Provider ledis session provider
|
||||
type Provider struct {
|
||||
maxlifetime int64
|
||||
savePath string
|
||||
db int
|
||||
SavePath string `json:"save_path"`
|
||||
Db int `json:"db"`
|
||||
}
|
||||
|
||||
// SessionInit init ledis session
|
||||
// savepath like ledis server saveDataPath,pool size
|
||||
// e.g. 127.0.0.1:6379,100,astaxie
|
||||
func (lp *Provider) SessionInit(ctx context.Context, maxlifetime int64, savePath string) error {
|
||||
// v1.x e.g. 127.0.0.1:6379,100
|
||||
// v2.x you should pass a json string
|
||||
// e.g. { "save_path": "my save path", "db": 100}
|
||||
func (lp *Provider) SessionInit(ctx context.Context, maxlifetime int64, cfgStr string) error {
|
||||
var err error
|
||||
lp.maxlifetime = maxlifetime
|
||||
configs := strings.Split(savePath, ",")
|
||||
if len(configs) == 1 {
|
||||
lp.savePath = configs[0]
|
||||
} else if len(configs) == 2 {
|
||||
lp.savePath = configs[0]
|
||||
lp.db, err = strconv.Atoi(configs[1])
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
cfgStr = strings.TrimSpace(cfgStr)
|
||||
// we think cfgStr is v2.0, using json to init the session
|
||||
if strings.HasPrefix(cfgStr, "{") {
|
||||
err = json.Unmarshal([]byte(cfgStr), lp)
|
||||
} else {
|
||||
err = lp.initOldStyle(cfgStr)
|
||||
}
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
cfg := new(config.Config)
|
||||
cfg.DataDir = lp.savePath
|
||||
cfg.DataDir = lp.SavePath
|
||||
|
||||
var ledisInstance *ledis.Ledis
|
||||
ledisInstance, err = ledis.Open(cfg)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
c, err = ledisInstance.Select(lp.db)
|
||||
c, err = ledisInstance.Select(lp.Db)
|
||||
return err
|
||||
}
|
||||
|
||||
func (lp *Provider) initOldStyle(cfgStr string) error {
|
||||
var err error
|
||||
configs := strings.Split(cfgStr, ",")
|
||||
if len(configs) == 1 {
|
||||
lp.SavePath = configs[0]
|
||||
} else if len(configs) == 2 {
|
||||
lp.SavePath = configs[0]
|
||||
lp.Db, err = strconv.Atoi(configs[1])
|
||||
}
|
||||
return err
|
||||
}
|
||||
|
||||
|
41
server/web/session/ledis/ledis_session_test.go
Normal file
41
server/web/session/ledis/ledis_session_test.go
Normal file
@ -0,0 +1,41 @@
|
||||
// Copyright 2020
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package ledis
|
||||
|
||||
import (
|
||||
"context"
|
||||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestProvider_SessionInit(t *testing.T) {
|
||||
// using old style
|
||||
savePath := `http://host:port/,100`
|
||||
cp := &Provider{}
|
||||
cp.SessionInit(context.Background(), 12, savePath)
|
||||
assert.Equal(t, "http://host:port/", cp.SavePath)
|
||||
assert.Equal(t, 100, cp.Db)
|
||||
assert.Equal(t, int64(12), cp.maxlifetime)
|
||||
|
||||
savePath = `
|
||||
{ "save_path": "my save path", "db": 100}
|
||||
`
|
||||
cp = &Provider{}
|
||||
cp.SessionInit(context.Background(), 12, savePath)
|
||||
assert.Equal(t, "my save path", cp.SavePath)
|
||||
assert.Equal(t, 100, cp.Db)
|
||||
assert.Equal(t, int64(12), cp.maxlifetime)
|
||||
}
|
Reference in New Issue
Block a user