121 lines
3.5 KiB
Go
121 lines
3.5 KiB
Go
package peer
|
|
|
|
import (
|
|
"strconv"
|
|
|
|
"cloud.o-forge.io/core/oc-lib/dbs"
|
|
"cloud.o-forge.io/core/oc-lib/dbs/mongo"
|
|
"cloud.o-forge.io/core/oc-lib/logs"
|
|
"cloud.o-forge.io/core/oc-lib/models/utils"
|
|
"cloud.o-forge.io/core/oc-lib/tools"
|
|
)
|
|
|
|
type peerMongoAccessor struct {
|
|
utils.AbstractAccessor // AbstractAccessor contains the basic fields of an accessor (model, caller)
|
|
}
|
|
|
|
// New creates a new instance of the peerMongoAccessor
|
|
func NewShallow() *peerMongoAccessor {
|
|
return &peerMongoAccessor{
|
|
utils.AbstractAccessor{
|
|
Logger: logs.CreateLogger(tools.PEER.String()), // Create a logger with the data type
|
|
Type: tools.PEER.String(),
|
|
},
|
|
}
|
|
}
|
|
|
|
func New(t tools.DataType, peerID string, groups []string, caller *tools.HTTPCaller) *peerMongoAccessor {
|
|
return &peerMongoAccessor{
|
|
utils.AbstractAccessor{
|
|
Logger: logs.CreateLogger(t.String()), // Create a logger with the data type
|
|
Caller: caller,
|
|
PeerID: peerID,
|
|
Groups: groups, // Set the caller
|
|
Type: t.String(),
|
|
},
|
|
}
|
|
}
|
|
|
|
/*
|
|
* Nothing special here, just the basic CRUD operations
|
|
*/
|
|
|
|
func (wfa *peerMongoAccessor) DeleteOne(id string) (utils.DBObject, int, error) {
|
|
return wfa.GenericDeleteOne(id, wfa)
|
|
}
|
|
|
|
func (wfa *peerMongoAccessor) UpdateOne(set utils.DBObject, id string) (utils.DBObject, int, error) {
|
|
return wfa.GenericUpdateOne(set.(*Peer), id, wfa, &Peer{})
|
|
}
|
|
|
|
func (wfa *peerMongoAccessor) StoreOne(data utils.DBObject) (utils.DBObject, int, error) {
|
|
return wfa.GenericStoreOne(data.(*Peer), wfa)
|
|
}
|
|
|
|
func (wfa *peerMongoAccessor) CopyOne(data utils.DBObject) (utils.DBObject, int, error) {
|
|
return wfa.GenericStoreOne(data, wfa)
|
|
}
|
|
|
|
func (wfa *peerMongoAccessor) LoadOne(id string) (utils.DBObject, int, error) {
|
|
var peer Peer
|
|
res_mongo, code, err := mongo.MONGOService.LoadOne(id, wfa.GetType())
|
|
if err != nil {
|
|
wfa.Logger.Error().Msg("Could not retrieve " + id + " from db. Error: " + err.Error())
|
|
return nil, code, err
|
|
}
|
|
res_mongo.Decode(&peer)
|
|
|
|
return &peer, 200, nil
|
|
}
|
|
|
|
func (wfa peerMongoAccessor) LoadAll() ([]utils.ShallowDBObject, int, error) {
|
|
objs := []utils.ShallowDBObject{}
|
|
res_mongo, code, err := mongo.MONGOService.LoadAll(wfa.GetType())
|
|
if err != nil {
|
|
wfa.Logger.Error().Msg("Could not retrieve any from db. Error: " + err.Error())
|
|
return nil, code, err
|
|
}
|
|
var results []Peer
|
|
if err = res_mongo.All(mongo.MngoCtx, &results); err != nil {
|
|
return nil, 404, err
|
|
}
|
|
for _, r := range results {
|
|
objs = append(objs, &r)
|
|
}
|
|
return objs, 200, nil
|
|
}
|
|
|
|
func (wfa *peerMongoAccessor) Search(filters *dbs.Filters, search string) ([]utils.ShallowDBObject, int, error) {
|
|
objs := []utils.ShallowDBObject{}
|
|
if (filters == nil || len(filters.And) == 0 || len(filters.Or) == 0) && search != "" {
|
|
s, err := strconv.Atoi(search)
|
|
if err == nil {
|
|
filters = &dbs.Filters{
|
|
Or: map[string][]dbs.Filter{ // search by name if no filters are provided
|
|
"state": {{Operator: dbs.EQUAL.String(), Value: s}},
|
|
},
|
|
}
|
|
} else {
|
|
filters = &dbs.Filters{
|
|
Or: map[string][]dbs.Filter{ // search by name if no filters are provided
|
|
"abstractobject.name": {{Operator: dbs.LIKE.String(), Value: search}},
|
|
"url": {{Operator: dbs.LIKE.String(), Value: search}},
|
|
},
|
|
}
|
|
}
|
|
}
|
|
res_mongo, code, err := mongo.MONGOService.Search(filters, wfa.GetType())
|
|
if err != nil {
|
|
wfa.Logger.Error().Msg("Could not store to db. Error: " + err.Error())
|
|
return nil, code, err
|
|
}
|
|
var results []Peer
|
|
if err = res_mongo.All(mongo.MngoCtx, &results); err != nil {
|
|
return nil, 404, err
|
|
}
|
|
for _, r := range results {
|
|
objs = append(objs, &r)
|
|
}
|
|
return objs, 200, nil
|
|
}
|