-
Notifications
You must be signed in to change notification settings - Fork 180
/
util.go
123 lines (111 loc) · 3.2 KB
/
util.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
* Copyright (c) 2019-2022. Abstrium SAS <team (at) pydio.com>
* This file is part of Pydio Cells.
*
* Pydio Cells is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Pydio Cells is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Pydio Cells. If not, see <http://www.gnu.org/licenses/>.
*
* The latest code can be found at <https://pydio.com>.
*/
package util
import (
pb "github.com/pydio/cells/v4/common/proto/registry"
"github.com/pydio/cells/v4/common/registry"
)
// ToProtoItems transforms a list of interfaces to protobuf for serialization
func ToProtoItems(ii []registry.Item) []*pb.Item {
var items []*pb.Item
for _, i := range ii {
items = append(items, ToProtoItem(i))
}
return items
}
// ToProtoItem transforms a registry.Item to its protobuf counterpart
func ToProtoItem(i registry.Item) *pb.Item {
item := &pb.Item{
Id: i.ID(),
Name: i.Name(),
Metadata: i.Metadata(),
}
switch v := i.(type) {
case registry.Node:
item.Item = &pb.Item_Node{Node: ToProtoNode(v)}
case registry.Service:
item.Item = &pb.Item_Service{Service: ToProtoService(v)}
case registry.Server:
item.Item = &pb.Item_Server{Server: ToProtoServer(v)}
case registry.Dao:
item.Item = &pb.Item_Dao{Dao: ToProtoDao(v)}
case registry.Edge:
item.Item = &pb.Item_Edge{Edge: ToProtoEdge(v)}
case registry.Generic:
item.Item = &pb.Item_Generic{Generic: ToProtoGeneric(v)}
}
return item
}
// ToItem wraps a protobuf item in a registry.Item interface
func ToItem(s *pb.Item) registry.Item {
switch v := s.Item.(type) {
case *pb.Item_Node:
return ToNode(s, v.Node)
case *pb.Item_Service:
return ToService(s, v.Service)
case *pb.Item_Server:
return ToServer(s, v.Server)
case *pb.Item_Dao:
return ToDao(s, v.Dao)
case *pb.Item_Edge:
return ToEdge(s, v.Edge)
case *pb.Item_Generic:
return ToGeneric(s, v.Generic)
}
return nil
}
// ToOptions parses a protobuf pb.Options to a slice of registry.Option
func ToOptions(s *pb.Options) (oo []registry.Option) {
if s == nil {
return
}
for _, name := range s.Names {
oo = append(oo, registry.WithName(name))
}
for _, itemType := range s.Types {
oo = append(oo, registry.WithType(itemType))
}
if s.GetMetaName() != "" {
oo = append(oo, registry.WithMeta(s.GetMetaName(), s.GetMetaValue()))
}
return
}
func DetectType(i registry.Item) pb.ItemType {
var n registry.Node
var s registry.Service
var sr registry.Server
var d registry.Dao
var e registry.Edge
var g registry.Generic
if i.As(&n) {
return pb.ItemType_NODE
} else if i.As(&s) {
return pb.ItemType_SERVICE
} else if i.As(&sr) {
return pb.ItemType_SERVER
} else if i.As(&d) {
return pb.ItemType_DAO
} else if i.As(&e) {
return pb.ItemType_EDGE
} else if i.As(&g) {
return g.Type()
}
return pb.ItemType_ALL
}