123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 |
- package session
- import (
- "container/list"
- "fmt"
- "sync"
- "time"
- )
- type MemStore struct {
- sid string
- lock sync.RWMutex
- data map[interface{}]interface{}
- lastAccess time.Time
- }
- func NewMemStore(sid string) *MemStore {
- return &MemStore{
- sid: sid,
- data: make(map[interface{}]interface{}),
- lastAccess: time.Now(),
- }
- }
- func (s *MemStore) Set(key, val interface{}) error {
- s.lock.Lock()
- defer s.lock.Unlock()
- s.data[key] = val
- return nil
- }
- func (s *MemStore) Get(key interface{}) interface{} {
- s.lock.RLock()
- defer s.lock.RUnlock()
- return s.data[key]
- }
- func (s *MemStore) Delete(key interface{}) error {
- s.lock.Lock()
- defer s.lock.Unlock()
- delete(s.data, key)
- return nil
- }
- func (s *MemStore) ID() string {
- return s.sid
- }
- func (_ *MemStore) Release() error {
- return nil
- }
- func (s *MemStore) Flush() error {
- s.lock.Lock()
- defer s.lock.Unlock()
- s.data = make(map[interface{}]interface{})
- return nil
- }
- type MemProvider struct {
- lock sync.RWMutex
- maxLifetime int64
- data map[string]*list.Element
-
- list *list.List
- }
- func (p *MemProvider) Init(maxLifetime int64, _ string) error {
- p.lock.Lock()
- p.maxLifetime = maxLifetime
- p.lock.Unlock()
- return nil
- }
- func (p *MemProvider) update(sid string) error {
- p.lock.Lock()
- defer p.lock.Unlock()
- if e, ok := p.data[sid]; ok {
- e.Value.(*MemStore).lastAccess = time.Now()
- p.list.MoveToFront(e)
- return nil
- }
- return nil
- }
- func (p *MemProvider) Read(sid string) (_ RawStore, err error) {
- p.lock.RLock()
- e, ok := p.data[sid]
- p.lock.RUnlock()
- if ok {
- if err = p.update(sid); err != nil {
- return nil, err
- }
- return e.Value.(*MemStore), nil
- }
-
- p.lock.Lock()
- defer p.lock.Unlock()
- s := NewMemStore(sid)
- p.data[sid] = p.list.PushBack(s)
- return s, nil
- }
- func (p *MemProvider) Exist(sid string) bool {
- p.lock.RLock()
- defer p.lock.RUnlock()
- _, ok := p.data[sid]
- return ok
- }
- func (p *MemProvider) Destory(sid string) error {
- p.lock.Lock()
- defer p.lock.Unlock()
- e, ok := p.data[sid]
- if !ok {
- return nil
- }
- p.list.Remove(e)
- delete(p.data, sid)
- return nil
- }
- func (p *MemProvider) Regenerate(oldsid, sid string) (RawStore, error) {
- if p.Exist(sid) {
- return nil, fmt.Errorf("new sid '%s' already exists", sid)
- }
- s, err := p.Read(oldsid)
- if err != nil {
- return nil, err
- }
- if err = p.Destory(oldsid); err != nil {
- return nil, err
- }
- s.(*MemStore).sid = sid
- p.lock.Lock()
- defer p.lock.Unlock()
- p.data[sid] = p.list.PushBack(s)
- return s, nil
- }
- func (p *MemProvider) Count() int {
- return p.list.Len()
- }
- func (p *MemProvider) GC() {
- p.lock.RLock()
- for {
-
- e := p.list.Back()
- if e == nil {
- break
- }
- if (e.Value.(*MemStore).lastAccess.Unix() + p.maxLifetime) < time.Now().Unix() {
- p.lock.RUnlock()
- p.lock.Lock()
- p.list.Remove(e)
- delete(p.data, e.Value.(*MemStore).sid)
- p.lock.Unlock()
- p.lock.RLock()
- } else {
- break
- }
- }
- p.lock.RUnlock()
- }
- func init() {
- Register("memory", &MemProvider{list: list.New(), data: make(map[string]*list.Element)})
- }
|