forked from meshery/meshery
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsmiresults_persister.go
99 lines (85 loc) · 2.41 KB
/
smiresults_persister.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
package models
import (
"encoding/json"
"github.com/gofrs/uuid"
"github.com/layer5io/meshkit/database"
)
// SmiResultsPersister assists with persisting session in store
type SMIResultsPersister struct {
DB *database.Handler
}
type SmiResultWithID struct {
ID uuid.UUID
SmiResult `gorm:"embedded"`
}
// SmiResultPage - represents a page of meshery results
type SmiResultPage struct {
Page uint64 `json:"page"`
PageSize uint64 `json:"page_size"`
TotalCount int `json:"total_count"`
Results []*SmiResultWithID `json:"results"`
}
// GetSmiResults - gets result for the page and pageSize
func (s *SMIResultsPersister) GetResults(page, pageSize uint64) ([]byte, error) {
if s.DB == nil {
return nil, ErrDBConnection
}
total := int64(0)
s.DB.Model(&SmiResultWithID{}).Count(&total)
results := []*SmiResultWithID{}
order := "updated_at desc"
query := s.DB.Order(order)
Paginate(uint(page), uint(pageSize))(query).Find(&results)
bd, err := json.Marshal(&SmiResultPage{
Page: page,
PageSize: pageSize,
TotalCount: int(total),
Results: results,
})
if err != nil {
obj := "result data"
//err = errors.Wrapf(err, "Unable to marshal result data.")
return nil, ErrMarshal(err, obj)
}
return bd, nil
}
// WriteSmiResult persists the result
func (s *SMIResultsPersister) WriteResult(key uuid.UUID, result []byte) error {
if s.DB == nil {
return ErrDBConnection
}
if result == nil {
return ErrResultData()
}
var r SmiResultWithID
if err := s.DB.Model(&SmiResultWithID{}).Where("id = ?", key).First(&r).Error; err == nil {
return s.UpdateResult(key, r)
}
err := json.Unmarshal(result, &r.SmiResult)
if err != nil {
return err
}
r.ID = key
return s.DB.Model(&SmiResultWithID{}).Create(&r).Error
}
func (s *SMIResultsPersister) DeleteResult(key uuid.UUID) error {
if s.DB == nil {
return ErrDBConnection
}
return s.DB.Model(&SmiResultWithID{}).Where("id = ?", key).Delete(&SmiResultWithID{}).Error
}
func (s *SMIResultsPersister) GetResult(key uuid.UUID) ([]byte, error) {
if s.DB == nil {
return nil, ErrDBConnection
}
var result SmiResult
err := s.DB.First(&result, key).Error
if err != nil {
return nil, err
}
bd, _ := json.Marshal(result)
return bd, nil
}
func (s *SMIResultsPersister) UpdateResult(key uuid.UUID, res SmiResultWithID) error {
return s.DB.Model(&SmiResultWithID{}).Where("id = ?", key).UpdateColumns(res).Error
}