"sync"
)
-var trackerMutex = &sync.Mutex{}
-
/*
Implements a record of ongoing transactions and helper functions to CRUD the records.
*/
type Tracker struct {
transactionTable map[TransactionKey]Transaction
+ mutex sync.Mutex
}
func (t *Tracker) Init() {
Returns error if there is similar transatcion ongoing.
*/
func (t *Tracker) TrackTransaction(key TransactionKey, xact Transaction) error {
- trackerMutex.Lock()
- defer trackerMutex.Unlock()
+ t.mutex.Lock()
+ defer t.mutex.Unlock()
if _, ok := t.transactionTable[key]; ok {
// TODO: Implement merge related check here. If the key is same but the value is different.
err := fmt.Errorf("transaction tracker: Similar transaction with sub id %d and type %s is ongoing", key.SubID, key.transType)
*/
func (t *Tracker) UpdateTransaction(SubID uint16, transType Action, xact Transaction) error {
key := TransactionKey{SubID, transType}
- trackerMutex.Lock()
- defer trackerMutex.Unlock()
+ t.mutex.Lock()
+ defer t.mutex.Unlock()
if _, ok := t.transactionTable[key]; ok {
// TODO: Implement merge related check here. If the key is same but the value is different.
err := fmt.Errorf("transaction tracker: Similar transaction with sub id %d and type %v is ongoing", key.SubID, key.transType)
*/
func (t *Tracker) RetriveTransaction(subID uint16, act Action) (Transaction, error) {
key := TransactionKey{subID, act}
- trackerMutex.Lock()
- defer trackerMutex.Unlock()
+ t.mutex.Lock()
+ defer t.mutex.Unlock()
var xact Transaction
if xact, ok := t.transactionTable[key]; ok {
return xact, nil
func (t *Tracker) completeTransaction(subID uint16, act Action) (Transaction, error) {
key := TransactionKey{subID, act}
var emptyTransaction Transaction
- trackerMutex.Lock()
- defer trackerMutex.Unlock()
+ t.mutex.Lock()
+ defer t.mutex.Unlock()
if xact, ok := t.transactionTable[key]; ok {
delete(t.transactionTable, key)
return xact, nil