-
Notifications
You must be signed in to change notification settings - Fork 50
/
webhook.go
136 lines (104 loc) · 4.06 KB
/
webhook.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
124
125
126
127
128
129
130
131
132
133
134
135
136
package webhook
import (
"context"
"strconv"
"github.com/go-openapi/runtime"
v2client "github.com/mittwald/goharbor-client/v5/apiv2/internal/api/client"
"github.com/mittwald/goharbor-client/v5/apiv2/internal/api/client/webhook"
"github.com/mittwald/goharbor-client/v5/apiv2/model"
"github.com/mittwald/goharbor-client/v5/apiv2/pkg/config"
"github.com/mittwald/goharbor-client/v5/apiv2/pkg/errors"
)
// RESTClient is a subclient for handling webhook related actions.
type RESTClient struct {
// Options contains optional configuration when making API calls.
Options *config.Options
// The new client of the harbor v2 API
V2Client *v2client.Harbor
// AuthInfo contains the auth information that is provided on API calls.
AuthInfo runtime.ClientAuthInfoWriter
}
func NewClient(v2Client *v2client.Harbor, opts *config.Options, authInfo runtime.ClientAuthInfoWriter) *RESTClient {
return &RESTClient{
Options: opts,
V2Client: v2Client,
AuthInfo: authInfo,
}
}
type Client interface {
ListProjectWebhookPolicies(ctx context.Context, projectID int) ([]*model.WebhookPolicy, error)
AddProjectWebhookPolicy(ctx context.Context, projectID int, policy *model.WebhookPolicy) error
UpdateProjectWebhookPolicy(ctx context.Context, projectID int, policy *model.WebhookPolicy) error
DeleteProjectWebhookPolicy(ctx context.Context, projectID int, policyID int64) error
}
// ListProjectWebhookPolicies returns a list of all webhook policies in project p.
func (c *RESTClient) ListProjectWebhookPolicies(ctx context.Context, projectID int) ([]*model.WebhookPolicy, error) {
var webhookPolicies []*model.WebhookPolicy
page := c.Options.Page
params := &webhook.ListWebhookPoliciesOfProjectParams{
Page: &page,
PageSize: &c.Options.PageSize,
ProjectNameOrID: strconv.Itoa(projectID),
Q: &c.Options.Query,
Sort: &c.Options.Sort,
Context: ctx,
}
params.WithTimeout(c.Options.Timeout)
for {
resp, err := c.V2Client.Webhook.ListWebhookPoliciesOfProject(params, c.AuthInfo)
if err != nil {
return nil, handleSwaggerWebhookErrors(err)
}
if len(resp.Payload) == 0 {
break
}
totalCount := resp.XTotalCount
webhookPolicies = append(webhookPolicies, resp.Payload...)
if int64(len(webhookPolicies)) >= totalCount {
break
}
page++
}
return webhookPolicies, nil
}
// AddProjectWebhookPolicy adds a webhook policy to project p.
func (c *RESTClient) AddProjectWebhookPolicy(ctx context.Context, projectID int, policy *model.WebhookPolicy) error {
if policy == nil {
return &errors.ErrProjectNoWebhookPolicyProvided{}
}
params := &webhook.CreateWebhookPolicyOfProjectParams{
Policy: policy,
ProjectNameOrID: strconv.Itoa(projectID),
Context: ctx,
}
params.WithTimeout(c.Options.Timeout)
_, err := c.V2Client.Webhook.CreateWebhookPolicyOfProject(params, c.AuthInfo)
return handleSwaggerWebhookErrors(err)
}
// UpdateProjectWebhookPolicy updates the WebhookPolicy 'policy' in the project identified by 'projectID'.
func (c *RESTClient) UpdateProjectWebhookPolicy(ctx context.Context, projectID int, policy *model.WebhookPolicy) error {
if policy == nil {
return &errors.ErrProjectNoWebhookPolicyProvided{}
}
params := &webhook.UpdateWebhookPolicyOfProjectParams{
Policy: policy,
ProjectNameOrID: strconv.Itoa(projectID),
WebhookPolicyID: policy.ID,
Context: ctx,
}
params.WithTimeout(c.Options.Timeout)
_, err := c.V2Client.Webhook.UpdateWebhookPolicyOfProject(params, c.AuthInfo)
return handleSwaggerWebhookErrors(err)
}
// DeleteProjectWebhookPolicy deletes the webhook policy identified
// by 'policyID' from the project identified by 'projectID'.
func (c *RESTClient) DeleteProjectWebhookPolicy(ctx context.Context, projectID int, policyID int64) error {
params := &webhook.DeleteWebhookPolicyOfProjectParams{
ProjectNameOrID: strconv.Itoa(projectID),
WebhookPolicyID: policyID,
Context: ctx,
}
params.WithTimeout(c.Options.Timeout)
_, err := c.V2Client.Webhook.DeleteWebhookPolicyOfProject(params, c.AuthInfo)
return handleSwaggerWebhookErrors(err)
}