/
oauthclientrequest.go
58 lines (36 loc) · 2.81 KB
/
oauthclientrequest.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
package platformclientv2
import (
"time"
"encoding/json"
"strconv"
"strings"
)
// Oauthclientrequest
type Oauthclientrequest struct {
// Name - The name of the OAuth client.
Name *string `json:"name,omitempty"`
// AccessTokenValiditySeconds - The number of seconds, between 5mins and 48hrs, until tokens created with this client expire. If this field is omitted, a default of 24 hours will be applied.
AccessTokenValiditySeconds *int `json:"accessTokenValiditySeconds,omitempty"`
// Description
Description *string `json:"description,omitempty"`
// RegisteredRedirectUri - List of allowed callbacks for this client. For example: https://myap.example.com/auth/callback
RegisteredRedirectUri *[]string `json:"registeredRedirectUri,omitempty"`
// RoleIds - Deprecated. Use roleDivisions instead.
RoleIds *[]string `json:"roleIds,omitempty"`
// AuthorizedGrantType - The OAuth Grant/Client type supported by this client. Code Authorization Grant/Client type - Preferred client type where the Client ID and Secret are required to create tokens. Used where the secret can be secured. PKCE-Enabled Code Authorization grant type - Code grant type which requires PKCE challenge and verifier to create tokens. Used in public clients for increased security. Implicit grant type - Client ID only is required to create tokens. Used in browser and mobile apps where the secret can not be secured. SAML2-Bearer extension grant type - SAML2 assertion provider for user authentication at the token endpoint. Client Credential grant type - Used to created access tokens that are tied only to the client.
AuthorizedGrantType *string `json:"authorizedGrantType,omitempty"`
// Scope - The scope requested by this client. Scopes only apply to clients not using the client_credential grant
Scope *[]string `json:"scope,omitempty"`
// RoleDivisions - Set of roles and their corresponding divisions associated with this client. Roles and divisions only apply to clients using the client_credential grant
RoleDivisions *[]Roledivision `json:"roleDivisions,omitempty"`
// State - The state of the OAuth client. Active: The OAuth client can be used to create access tokens. This is the default state. Disabled: Access tokens created by the client are invalid and new ones cannot be created. Inactive: Access tokens cannot be created with this OAuth client and it will be deleted.
State *string `json:"state,omitempty"`
// DateToDelete - The time at which this client will be deleted. Date time is represented as an ISO-8601 string. For example: yyyy-MM-ddTHH:mm:ss[.mmm]Z
DateToDelete *time.Time `json:"dateToDelete,omitempty"`
}
// String returns a JSON representation of the model
func (o *Oauthclientrequest) String() string {
j, _ := json.Marshal(o)
str, _ := strconv.Unquote(strings.Replace(strconv.Quote(string(j)), `\\u`, `\u`, -1))
return str
}