mirror of
https://github.com/planetmint/planetmint-go.git
synced 2025-03-30 15:08:28 +00:00

also directly return values instead of assigning them first. Signed-off-by: Julian Strobl <jmastr@mailbox.org>
110 lines
2.9 KiB
Go
110 lines
2.9 KiB
Go
package monitor
|
|
|
|
import (
|
|
"encoding/json"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/syndtr/goleveldb/leveldb/iterator"
|
|
)
|
|
|
|
type LastSeenEvent struct {
|
|
Address string `binding:"required" json:"address"`
|
|
Timestamp int64 `binding:"required" json:"timestamp"`
|
|
}
|
|
|
|
func (mms *MqttMonitor) AddParticipant(address string, lastSeenTS int64) (err error) {
|
|
// store receive address - planetmint address pair
|
|
var lastSeen LastSeenEvent
|
|
lastSeen.Address = address
|
|
lastSeen.Timestamp = lastSeenTS
|
|
|
|
lastSeenBytes, err := json.Marshal(lastSeen)
|
|
if err != nil {
|
|
Log("error serializing ConversionRequest: " + err.Error())
|
|
return
|
|
}
|
|
|
|
// returns an error if the entry does not exist (we have to increase the counter in this case)
|
|
_, err = mms.db.Get([]byte(address), nil)
|
|
if err != nil {
|
|
mms.setNumDBElements(mms.getNumDBElements() + 1)
|
|
}
|
|
mms.dbMutex.Lock()
|
|
defer mms.dbMutex.Unlock()
|
|
err = mms.db.Put([]byte(address), lastSeenBytes, nil)
|
|
if err != nil {
|
|
Log("error storing addresses in DB: " + err.Error())
|
|
} else {
|
|
Log("stored address in DB: " + address)
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
func (mms *MqttMonitor) deleteEntry(key []byte) (err error) {
|
|
mms.setNumDBElements(mms.getNumDBElements() - 1)
|
|
mms.dbMutex.Lock()
|
|
defer mms.dbMutex.Unlock()
|
|
return mms.db.Delete(key, nil)
|
|
}
|
|
|
|
func (mms *MqttMonitor) getAmountOfElements() (amount int64, err error) {
|
|
iter := mms.db.NewIterator(nil, nil)
|
|
defer iter.Release()
|
|
|
|
for iter.Next() {
|
|
amount++
|
|
}
|
|
|
|
// Check for any errors encountered during iteration
|
|
if err := iter.Error(); err != nil {
|
|
Log("" + err.Error())
|
|
} else {
|
|
Log("elements: " + strconv.FormatInt(amount, 10))
|
|
}
|
|
|
|
return
|
|
}
|
|
func (mms *MqttMonitor) getDataFromIter(iter iterator.Iterator) (lastSeen LastSeenEvent, err error) {
|
|
key := iter.Key()
|
|
value := iter.Value()
|
|
err = json.Unmarshal(value, &lastSeen)
|
|
if err != nil {
|
|
Log("failed to unmarshal entry: " + string(key) + " - " + err.Error())
|
|
}
|
|
return
|
|
}
|
|
|
|
func (mms *MqttMonitor) CleanupDB() {
|
|
// Create an iterator for the database
|
|
Log("starting clean-up process")
|
|
iter := mms.db.NewIterator(nil, nil)
|
|
defer iter.Release() // Make sure to release the iterator at the end
|
|
|
|
// Iterate over all elements in the database
|
|
for iter.Next() && !mms.IsTerminated() {
|
|
// Use iter.Key() and iter.Value() to access the key and value
|
|
lastSeen, err := mms.getDataFromIter(iter)
|
|
if err != nil {
|
|
Log("failed to unmarshal entry: " + string(iter.Key()) + " - " + err.Error())
|
|
continue
|
|
}
|
|
timeThreshold := time.Now().Add(-1 * mms.CleanupPeriodicityInMinutes * time.Minute).Unix()
|
|
if lastSeen.Timestamp <= timeThreshold {
|
|
// If the entry is older than 12 hours, delete it
|
|
err := mms.deleteEntry(iter.Key())
|
|
if err != nil {
|
|
Log("failed to delete entry: " + err.Error())
|
|
} else {
|
|
Log("delete entry: " + string(iter.Key()))
|
|
}
|
|
}
|
|
}
|
|
|
|
// Check for any errors encountered during iteration
|
|
if err := iter.Error(); err != nil {
|
|
Log("error during cleanup : " + err.Error())
|
|
}
|
|
}
|