forked from dapr/components-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrequests.go
57 lines (46 loc) · 1.58 KB
/
requests.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
// ------------------------------------------------------------
// Copyright (c) Microsoft Corporation and Dapr Contributors.
// Licensed under the MIT License.
// ------------------------------------------------------------
package bindings
import (
"fmt"
"strconv"
)
// InvokeRequest is the object given to a dapr output binding.
type InvokeRequest struct {
Data []byte `json:"data"`
Metadata map[string]string `json:"metadata"`
Operation OperationKind `json:"operation"`
}
// OperationKind defines an output binding operation.
type OperationKind string
// Non exhaustive list of operations. A binding can add operations that are not in this list.
const (
GetOperation OperationKind = "get"
CreateOperation OperationKind = "create"
DeleteOperation OperationKind = "delete"
ListOperation OperationKind = "list"
)
// GetMetadataAsBool parses metadata as bool.
func (r *InvokeRequest) GetMetadataAsBool(key string) (bool, error) {
if val, ok := r.Metadata[key]; ok {
boolVal, err := strconv.ParseBool(val)
if err != nil {
return false, fmt.Errorf("error parsing metadata `%s` with value `%s` as bool: %w", key, val, err)
}
return boolVal, nil
}
return false, nil
}
// GetMetadataAsInt64 parses metadata as int64.
func (r *InvokeRequest) GetMetadataAsInt64(key string, bitSize int) (int64, error) {
if val, ok := r.Metadata[key]; ok {
intVal, err := strconv.ParseInt(val, 10, bitSize)
if err != nil {
return 0, fmt.Errorf("error parsing metadata `%s` with value `%s` as int%d: %w", key, val, bitSize, err)
}
return intVal, nil
}
return 0, nil
}