/
api_op_update.go
59 lines (51 loc) · 1.88 KB
/
api_op_update.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
// Package role contains auto-generated files. DO NOT MODIFY
package role
import (
"context"
"net/http"
"time"
"github.com/RJPearson94/twilio-sdk-go/client"
)
// UpdateRoleInput defines input fields for updating a role resource
type UpdateRoleInput struct {
Permissions []string `validate:"required" form:"Permission"`
}
// UpdateRoleResponse defines the response fields for the updated role
type UpdateRoleResponse struct {
AccountSid string `json:"account_sid"`
DateCreated time.Time `json:"date_created"`
DateUpdated *time.Time `json:"date_updated,omitempty"`
FriendlyName string `json:"friendly_name"`
Permissions []string `json:"permissions"`
ServiceSid string `json:"service_sid"`
Sid string `json:"sid"`
Type string `json:"type"`
URL string `json:"url"`
}
// Update modifies a role resource
// See https://www.twilio.com/docs/chat/rest/role-resource#update-a-role-resource for more details
// Context is defaulted to Background. See https://golang.org/pkg/context/#Background for more information
func (c Client) Update(input *UpdateRoleInput) (*UpdateRoleResponse, error) {
return c.UpdateWithContext(context.Background(), input)
}
// UpdateWithContext modifies a role resource
// See https://www.twilio.com/docs/chat/rest/role-resource#update-a-role-resource for more details
func (c Client) UpdateWithContext(context context.Context, input *UpdateRoleInput) (*UpdateRoleResponse, error) {
op := client.Operation{
Method: http.MethodPost,
URI: "/Services/{serviceSid}/Roles/{sid}",
ContentType: client.URLEncoded,
PathParams: map[string]string{
"serviceSid": c.serviceSid,
"sid": c.sid,
},
}
if input == nil {
input = &UpdateRoleInput{}
}
response := &UpdateRoleResponse{}
if err := c.client.Send(context, op, input, response); err != nil {
return nil, err
}
return response, nil
}