blob: bc50883d274ba06d1af9d3c12b8cf9e1398fa228 (
plain) (
blame)
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
|
package msauth
import (
"context"
"golang.org/x/oauth2"
"golang.org/x/oauth2/clientcredentials"
"golang.org/x/oauth2/microsoft"
)
// ClientCredentialsGrant performs OAuth 2.0 client credentials grant and returns auto-refreshing TokenSource
func (m *Manager) ClientCredentialsGrant(ctx context.Context, tenantID, clientID, clientSecret string, scopes []string) (oauth2.TokenSource, error) {
config := &clientcredentials.Config{
ClientID: clientID,
ClientSecret: clientSecret,
TokenURL: microsoft.AzureADEndpoint(tenantID).TokenURL,
Scopes: scopes,
AuthStyle: oauth2.AuthStyleInParams,
}
var err error
ts := config.TokenSource(ctx)
_, err = ts.Token()
if err != nil {
return nil, err
}
return ts, nil
}
|