import (
"fmt"
+ "sync"
)
+var trackerMutex = &sync.Mutex{}
+
/*
Implements a record of ongoing transactions and helper functions to CRUD the records.
*/
Returns error if there is similar transatcion ongoing.
*/
func (t *Tracker) TrackTransaction(key TransactionKey, xact Transaction) error {
+ trackerMutex.Lock()
+ defer trackerMutex.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()
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()
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()
if xact, ok := t.transactionTable[key]; ok {
delete(t.transactionTable, key)
return xact, nil