This repository has been archived by the owner on Feb 16, 2022. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 128
/
doc.go
77 lines (55 loc) · 1.93 KB
/
doc.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
/*
Package auth0 provides a client for using the Auth0 Management API.
Usage
import (
gopkg.in/auth0.v5
gopkg.in/auth0.v5/management
)
Initialize a new client using a domain, client ID and secret.
m, err := management.New(domain, management.WithClientCredentials(id, secret))
if err != nil {
// handle err
}
Or using a static token.
m, err := management.New(domain, management.WithStaticToken(token))
if err != nil {
// handle err
}
With a management client we can then interact with the Auth0 Management API.
c := &management.Client{
Name: auth0.String("Client Name"),
Description: auth0.String("Long description of client"),
}
err = m.Client.Create(c)
if err != nil {
// handle err
}
Authentication
The auth0 package handles authentication by exchanging the client id and secret
supplied when creating a new management client.
This is handled internally using the https://godoc.org/golang.org/x/oauth2
package.
Rate Limiting
The auth0 package also handles rate limiting by respecting the `X-Ratelimit-*`
headers sent by the server.
The amount of time the client waits for the rate limit to be reset is taken from
the `X-Ratelimit-Reset` header as the amount of seconds to wait.
Configuration
There are several other options that can be specified during the creation of a
new client.
m, err := management.New(domain,
management.WithClientCredentials(id, secret),
management.WithContext(context.Background()),
management.WithDebug(true))
Request Options
As with the global client configuration, fine grained configuration can be done
on a request basis.
c, err := m.Connection.List(
management.Context(ctx),
management.Page(2),
management.PerPage(10),
management.IncludeFields("id", "name", "options")
management.Parameter("strategy", "auth0"),
)
*/
package auth0