-
Notifications
You must be signed in to change notification settings - Fork 40
/
method_listbyautomationaccount.go
117 lines (96 loc) · 3.27 KB
/
method_listbyautomationaccount.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
package sourcecontrolsyncjob
import (
"context"
"fmt"
"net/http"
"github.com/hashicorp/go-azure-sdk/sdk/client"
"github.com/hashicorp/go-azure-sdk/sdk/odata"
)
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License. See NOTICE.txt in the project root for license information.
type ListByAutomationAccountOperationResponse struct {
HttpResponse *http.Response
OData *odata.OData
Model *[]SourceControlSyncJob
}
type ListByAutomationAccountCompleteResult struct {
Items []SourceControlSyncJob
}
type ListByAutomationAccountOperationOptions struct {
Filter *string
}
func DefaultListByAutomationAccountOperationOptions() ListByAutomationAccountOperationOptions {
return ListByAutomationAccountOperationOptions{}
}
func (o ListByAutomationAccountOperationOptions) ToHeaders() *client.Headers {
out := client.Headers{}
return &out
}
func (o ListByAutomationAccountOperationOptions) ToOData() *odata.Query {
out := odata.Query{}
return &out
}
func (o ListByAutomationAccountOperationOptions) ToQuery() *client.QueryParams {
out := client.QueryParams{}
if o.Filter != nil {
out.Append("$filter", fmt.Sprintf("%v", *o.Filter))
}
return &out
}
// ListByAutomationAccount ...
func (c SourceControlSyncJobClient) ListByAutomationAccount(ctx context.Context, id SourceControlId, options ListByAutomationAccountOperationOptions) (result ListByAutomationAccountOperationResponse, err error) {
opts := client.RequestOptions{
ContentType: "application/json; charset=utf-8",
ExpectedStatusCodes: []int{
http.StatusOK,
},
HttpMethod: http.MethodGet,
Path: fmt.Sprintf("%s/sourceControlSyncJobs", id.ID()),
OptionsObject: options,
}
req, err := c.Client.NewRequest(ctx, opts)
if err != nil {
return
}
var resp *client.Response
resp, err = req.ExecutePaged(ctx)
if resp != nil {
result.OData = resp.OData
result.HttpResponse = resp.Response
}
if err != nil {
return
}
var values struct {
Values *[]SourceControlSyncJob `json:"value"`
}
if err = resp.Unmarshal(&values); err != nil {
return
}
result.Model = values.Values
return
}
// ListByAutomationAccountComplete retrieves all the results into a single object
func (c SourceControlSyncJobClient) ListByAutomationAccountComplete(ctx context.Context, id SourceControlId, options ListByAutomationAccountOperationOptions) (ListByAutomationAccountCompleteResult, error) {
return c.ListByAutomationAccountCompleteMatchingPredicate(ctx, id, options, SourceControlSyncJobOperationPredicate{})
}
// ListByAutomationAccountCompleteMatchingPredicate retrieves all the results and then applies the predicate
func (c SourceControlSyncJobClient) ListByAutomationAccountCompleteMatchingPredicate(ctx context.Context, id SourceControlId, options ListByAutomationAccountOperationOptions, predicate SourceControlSyncJobOperationPredicate) (result ListByAutomationAccountCompleteResult, err error) {
items := make([]SourceControlSyncJob, 0)
resp, err := c.ListByAutomationAccount(ctx, id, options)
if err != nil {
err = fmt.Errorf("loading results: %+v", err)
return
}
if resp.Model != nil {
for _, v := range *resp.Model {
if predicate.Matches(v) {
items = append(items, v)
}
}
}
result = ListByAutomationAccountCompleteResult{
Items: items,
}
return
}