redis_lock.go 1.3 KB
package xredis

import (
	"fmt"

	"github.com/go-redsync/redsync/v4"
)

type LockSummaryEvaluation struct {
	m *redsync.Mutex
}

func NewLockSummaryEvaluation(targetUserId int) *LockSummaryEvaluation {
	key := fmt.Sprintf("performance:summary_evaluation_targetuser:%d", targetUserId)

	return &LockSummaryEvaluation{
		m: rsync.NewMutex(key),
	}
}

func (lk *LockSummaryEvaluation) Lock() error {
	return lk.m.Lock()
}

func (lk *LockSummaryEvaluation) UnLock() (bool, error) {
	return lk.m.Unlock()
}

type LockSummaryEvaluationId struct {
	m *redsync.Mutex
}

func NewLockSummaryEvaluationId(summaryEvaluationId int) *LockSummaryEvaluation {
	key := fmt.Sprintf("performance:summary_evaluation_id:%d", summaryEvaluationId)
	return &LockSummaryEvaluation{
		m: rsync.NewMutex(key),
	}
}

func (lk *LockSummaryEvaluationId) Lock() error {
	return lk.m.Lock()
}

func (lk *LockSummaryEvaluationId) UnLock() (bool, error) {
	return lk.m.Unlock()
}

type LockStaffAssess struct {
	m *redsync.Mutex
}

func NewLockStaffAssess(staffAssessId int) *LockStaffAssess {
	key := fmt.Sprintf("performance:staff_assess_id:%d", staffAssessId)
	return &LockStaffAssess{
		m: rsync.NewMutex(key),
	}
}

func (lk *LockStaffAssess) Lock() error {
	return lk.m.Lock()
}

func (lk *LockStaffAssess) UnLock() (bool, error) {
	return lk.m.Unlock()
}