73e5c36f25
* Upgrade xorm to v1.2.2 (#16663) Backport #16663 Fix #16683 * Upgrade xorm to v1.2.2 * Change the Engine interface to match xorm v1.2.2 * Add test to ensure that dumping of login sources remains correct (#16847) #16831 has occurred because of a missed regression. This PR adds a simple test to try to prevent this occuring again. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
30 lines
798 B
Go
Vendored
30 lines
798 B
Go
Vendored
// +build go1.10
|
|
|
|
package mssql
|
|
|
|
import (
|
|
"context"
|
|
"database/sql/driver"
|
|
"errors"
|
|
)
|
|
|
|
// NewAccessTokenConnector creates a new connector from a DSN and a token provider.
|
|
// The token provider func will be called when a new connection is requested and should return a valid access token.
|
|
// The returned connector may be used with sql.OpenDB.
|
|
func NewAccessTokenConnector(dsn string, tokenProvider func() (string, error)) (driver.Connector, error) {
|
|
if tokenProvider == nil {
|
|
return nil, errors.New("mssql: tokenProvider cannot be nil")
|
|
}
|
|
|
|
conn, err := NewConnector(dsn)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
conn.params.fedAuthLibrary = fedAuthLibrarySecurityToken
|
|
conn.securityTokenProvider = func(ctx context.Context) (string, error) {
|
|
return tokenProvider()
|
|
}
|
|
|
|
return conn, nil
|
|
}
|