/usr/share/gocode/src/github.com/socketplane/libovsdb/notation.go is in golang-github-socketplane-libovsdb-dev 0.1+git20160503.9.d4b9e7a53548-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | package libovsdb
import "encoding/json"
// Operation represents an operation according to RFC7047 section 5.2
type Operation struct {
Op string `json:"op"`
Table string `json:"table"`
Row map[string]interface{} `json:"row,omitempty"`
Rows []map[string]interface{} `json:"rows,omitempty"`
Columns []string `json:"columns,omitempty"`
Mutations []interface{} `json:"mutations,omitempty"`
Timeout int `json:"timeout,omitempty"`
Where []interface{} `json:"where,omitempty"`
Until string `json:"until,omitempty"`
UUIDName string `json:"uuid-name,omitempty"`
}
// MonitorRequests represents a group of monitor requests according to RFC7047
// We cannot use MonitorRequests by inlining the MonitorRequest Map structure till GoLang issue #6213 makes it.
// The only option is to go with raw map[string]interface{} option :-( that sucks !
// Refer to client.go : MonitorAll() function for more details
type MonitorRequests struct {
Requests map[string]MonitorRequest `json:"requests,overflow"`
}
// MonitorRequest represents a monitor request according to RFC7047
type MonitorRequest struct {
Columns []string `json:"columns,omitempty"`
Select MonitorSelect `json:"select,omitempty"`
}
// MonitorSelect represents a monitor select according to RFC7047
type MonitorSelect struct {
Initial bool `json:"initial,omitempty"`
Insert bool `json:"insert,omitempty"`
Delete bool `json:"delete,omitempty"`
Modify bool `json:"modify,omitempty"`
}
// TableUpdates is a collection of TableUpdate entries
// We cannot use TableUpdates directly by json encoding by inlining the TableUpdate Map
// structure till GoLang issue #6213 makes it.
// The only option is to go with raw map[string]map[string]interface{} option :-( that sucks !
// Refer to client.go : MonitorAll() function for more details
type TableUpdates struct {
Updates map[string]TableUpdate `json:"updates,overflow"`
}
// TableUpdate represents a table update according to RFC7047
type TableUpdate struct {
Rows map[string]RowUpdate `json:"rows,overflow"`
}
// RowUpdate represents a row update according to RFC7047
type RowUpdate struct {
UUID UUID `json:"-,omitempty"`
New Row `json:"new,omitempty"`
Old Row `json:"old,omitempty"`
}
// OvsdbError is an OVS Error Condition
type OvsdbError struct {
Error string `json:"error"`
Details string `json:"details,omitempty"`
}
// NewCondition creates a new condition as specified in RFC7047
func NewCondition(column string, function string, value interface{}) []interface{} {
return []interface{}{column, function, value}
}
// NewMutation creates a new mutation as specified in RFC7047
func NewMutation(column string, mutator string, value interface{}) []interface{} {
return []interface{}{column, mutator, value}
}
// TransactResponse represents the response to a Transact Operation
type TransactResponse struct {
Result []OperationResult `json:"result"`
Error string `json:"error"`
}
// OperationResult is the result of an Operation
type OperationResult struct {
Count int `json:"count,omitempty"`
Error string `json:"error,omitempty"`
Details string `json:"details,omitempty"`
UUID UUID `json:"uuid,omitempty"`
Rows []map[string]interface{} `json:"rows,omitempty"`
}
func ovsSliceToGoNotation(val interface{}) (interface{}, error) {
switch val.(type) {
case []interface{}:
sl := val.([]interface{})
bsliced, err := json.Marshal(sl)
if err != nil {
return nil, err
}
switch sl[0] {
case "uuid":
var uuid UUID
err = json.Unmarshal(bsliced, &uuid)
return uuid, err
case "set":
var oSet OvsSet
err = json.Unmarshal(bsliced, &oSet)
return oSet, err
case "map":
var oMap OvsMap
err = json.Unmarshal(bsliced, &oMap)
return oMap, err
}
return val, nil
}
return val, nil
}
// TODO : add Condition, Function, Mutation and Mutator notations
|