 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Constants
- Variables
- func NewClient(ctx context.Context, goauthfile, goauthkey string) (*http.Client, error)
- func NewClientCmd(ctx context.Context, state string) (*http.Client, error)
- func NewTokenCLI(ctx context.Context, creds Credentials, state string) (token *oauth2.Token, err error)
- type AuthCodeOptions
- type CLIRequest
- type Credentials
- func (creds *Credentials) ExistingValidToken() (*oauth2.Token, error)
- func (creds *Credentials) Inflate() error
- func (creds *Credentials) NewClient(ctx context.Context) (*http.Client, error)
- func (creds *Credentials) NewClientCLI(ctx context.Context, oauth2State string) (*http.Client, error)
- func (creds *Credentials) NewOrExistingValidToken(ctx context.Context) (*oauth2.Token, error)
- func (creds *Credentials) NewSimpleClient(ctx context.Context) (*httpsimple.Client, error)
- func (creds *Credentials) NewSimpleClientHTTP(httpClient *http.Client) (*httpsimple.Client, error)
- func (creds *Credentials) NewToken(ctx context.Context) (*oauth2.Token, error)
- func (creds *Credentials) NewTokenCLI(ctx context.Context, oauth2State string) (*oauth2.Token, error)
 
- type CredentialsBasicAuth
- type CredentialsGCP
- type CredentialsGoogleOAuth2
- type CredentialsHeaderQuery
- type CredentialsJWT
- type CredentialsOAuth2
- func (oc *CredentialsOAuth2) AuthCodeURL(state string, opts map[string][]string) string
- func (oc *CredentialsOAuth2) BasicAuthHeader() (string, error)
- func (oc *CredentialsOAuth2) Config() oauth2.Config
- func (oc *CredentialsOAuth2) ConfigClientCredentials() clientcredentials.Config
- func (oc *CredentialsOAuth2) Exchange(ctx context.Context, code string, opts map[string][]string) (*oauth2.Token, error)
- func (oc *CredentialsOAuth2) InflateURL(apiURLPath string) string
- func (oc *CredentialsOAuth2) IsGrantType(grantType string) bool
- func (oc *CredentialsOAuth2) MarshalJSON(prefix, indent string) ([]byte, error)
- func (oc *CredentialsOAuth2) NewClient(ctx context.Context) (*http.Client, *oauth2.Token, error)
- func (oc *CredentialsOAuth2) NewSimpleClient(ctx context.Context) (*httpsimple.Client, error)
- func (oc *CredentialsOAuth2) NewToken(ctx context.Context) (*oauth2.Token, error)
- func (oc *CredentialsOAuth2) NewTokenPasswordCredentials(ctx context.Context) (*oauth2.Token, error)
- func (oc *CredentialsOAuth2) PasswordRequestBody() url.Values
- func (oc *CredentialsOAuth2) RefreshToken(ctx context.Context, tok *oauth2.Token) (*oauth2.Token, []byte, error)
- func (oc *CredentialsOAuth2) RefreshTokenSimple(ctx context.Context, refreshToken string) (*oauth2.Token, []byte, error)
 
- type CredentialsSet
- func (set *CredentialsSet) Accounts() []string
- func (set *CredentialsSet) Get(key string) (Credentials, error)
- func (set *CredentialsSet) Inflate() error
- func (set *CredentialsSet) Keys() []string
- func (set *CredentialsSet) NewClient(ctx context.Context, key string) (*http.Client, error)
- func (set *CredentialsSet) WriteFile(filename, prefix, indent string, perm fs.FileMode) error
 
- type Options
Constants ¶
const ( TypeBasic = "basic" TypeHeaderQuery = "headerquery" TypeOAuth2 = "oauth2" TypeJWT = "jwt" TypeGCPSA = "gcpsa" // Google Cloud Platform Service Account TypeGoogleOAuth2 = "googleoauth2" )
const ( SigningMethodES256 = "ES256" SigningMethodES384 = "ES384" SigningMethodES512 = "ES512" SigningMethodHS256 = "HS256" SigningMethodHS384 = "HS384" SigningMethodHS512 = "HS512" )
Variables ¶
var ( ErrBasicAuthNotPopulated = errors.New("basic auth is not populated") ErrHeaderQueryNotPopulated = errors.New("header query is not populated") ErrJWTNotPopulated = errors.New("jwt is not populated") ErrJWTNotSupported = errors.New("jwt is not supported for function") ErrOAuth2NotPopulated = errors.New("oauth2 is not populated") ErrTypeNotSupported = errors.New("credentials type not supported") ErrGCPSANotPopulated = errors.New("gcp service account credentials are not populated") )
var ErrsInclLocation = false
    Functions ¶
func NewClientCmd ¶ added in v0.23.15
func NewTokenCLI ¶ added in v0.18.0
Types ¶
type AuthCodeOptions ¶ added in v0.18.0
type AuthCodeOptions []oauth2.AuthCodeOption
func (*AuthCodeOptions) Add ¶ added in v0.18.0
func (opts *AuthCodeOptions) Add(k, v string)
func (*AuthCodeOptions) AddMap ¶ added in v0.18.0
func (opts *AuthCodeOptions) AddMap(m map[string][]string)
type CLIRequest ¶ added in v0.23.6
type CLIRequest struct {
	Options
	Request httpsimple.CLI
}
    CLIRequest will get a token using `goauth` and then execute the provided request parameters with the credential, e.g. OAuth 2.0 access token.
type Credentials ¶ added in v0.18.0
type Credentials struct {
	Service      string                   `json:"service,omitempty"`
	Type         string                   `json:"type,omitempty"`
	Subdomain    string                   `json:"subdomain,omitempty"`
	Basic        *CredentialsBasicAuth    `json:"basic,omitempty"`
	HeaderQuery  *CredentialsHeaderQuery  `json:"headerquery,omitempty"`
	GCPSA        *CredentialsGCP          `json:"gcpsa,omitempty"`
	GoogleOAuth2 *CredentialsGoogleOAuth2 `json:"googleoauth2,omitempty"`
	JWT          *CredentialsJWT          `json:"jwt,omitempty"`
	OAuth2       *CredentialsOAuth2       `json:"oauth2,omitempty"`
	Token        *oauth2.Token            `json:"token,omitempty"`
	Additional   url.Values               `json:"additional,omitempty"`
}
    func NewCredentialsJSON ¶ added in v0.18.0
func NewCredentialsJSON(credsData, accessToken []byte) (Credentials, error)
func ReadCredentialsFromSetFile ¶ added in v0.22.1
func ReadCredentialsFromSetFile(credentialsSetFilename, accountKey string, inclAccountsOnError bool) (Credentials, error)
func (*Credentials) ExistingValidToken ¶ added in v0.23.0
func (creds *Credentials) ExistingValidToken() (*oauth2.Token, error)
func (*Credentials) Inflate ¶ added in v0.18.0
func (creds *Credentials) Inflate() error
func (*Credentials) NewClientCLI ¶ added in v0.18.0
func (*Credentials) NewOrExistingValidToken ¶ added in v0.23.0
func (*Credentials) NewSimpleClient ¶ added in v0.18.0
func (creds *Credentials) NewSimpleClient(ctx context.Context) (*httpsimple.Client, error)
func (*Credentials) NewSimpleClientHTTP ¶ added in v0.18.0
func (creds *Credentials) NewSimpleClientHTTP(httpClient *http.Client) (*httpsimple.Client, error)
func (*Credentials) NewTokenCLI ¶ added in v0.18.0
func (creds *Credentials) NewTokenCLI(ctx context.Context, oauth2State string) (*oauth2.Token, error)
NewTokenCLI retrieves a token using CLI approach for OAuth 2.0 authorization code or password grant.
type CredentialsBasicAuth ¶ added in v0.18.0
type CredentialsBasicAuth struct {
	Username      string            `json:"username,omitempty"`
	Password      string            `json:"password,omitempty"`
	Encoded       string            `json:"encoded,omitempty"`
	ServerURL     string            `json:"serverURL,omitempty"`
	AllowInsecure bool              `json:"allowInsecure,omitempty"`
	Metadata      map[string]string `json:"metadata,omitempty"`
}
    func (*CredentialsBasicAuth) NewClient ¶ added in v0.18.0
func (c *CredentialsBasicAuth) NewClient() (*http.Client, error)
func (*CredentialsBasicAuth) NewSimpleClient ¶ added in v0.18.0
func (c *CredentialsBasicAuth) NewSimpleClient() (httpsimple.Client, error)
type CredentialsGCP ¶ added in v0.20.0
type CredentialsGCP struct {
	GCPCredentials google.Credentials `json:"gcpCredentials,omitempty"`
	Scopes         []string           `json:"scopes,omitempty"`
}
    CredentialsGCP supports OAuth 2.0 authorization_code, password, and client_credentials grant flows.
func CredentialsGCPReadFile ¶ added in v0.20.0
func CredentialsGCPReadFile(name string) (*CredentialsGCP, error)
type CredentialsGoogleOAuth2 ¶ added in v0.23.0
type CredentialsGoogleOAuth2 struct {
	GoogleWebCredentials google.Credentials `json:"web,omitempty"` // "web"
	Scopes               []string           `json:"scopes,omitempty"`
	Token                *oauth2.Token      `json:"token,omitempty"`
}
    func (CredentialsGoogleOAuth2) CredentialsOAuth2 ¶ added in v0.23.0
func (cgo CredentialsGoogleOAuth2) CredentialsOAuth2() CredentialsOAuth2
type CredentialsHeaderQuery ¶ added in v0.18.0
type CredentialsHeaderQuery struct {
	ServerURL     string      `json:"serverURL,omitempty"`
	Header        http.Header `json:"header,omitempty"`
	Query         url.Values  `json:"query,omitempty"`
	AllowInsecure bool        `json:"allowInsecure,omitempty"`
}
    func (*CredentialsHeaderQuery) NewClient ¶ added in v0.18.0
func (c *CredentialsHeaderQuery) NewClient() *http.Client
func (*CredentialsHeaderQuery) NewSimpleClient ¶ added in v0.18.0
func (c *CredentialsHeaderQuery) NewSimpleClient() httpsimple.Client
type CredentialsJWT ¶ added in v0.18.0
type CredentialsJWT struct {
	Issuer        string `json:"issuer,omitempty"`
	PrivateKey    string `json:"privateKey,omitempty"`
	SigningMethod string `json:"signingMethod,omitempty"`
}
    func (*CredentialsJWT) StandardToken ¶ added in v0.18.0
type CredentialsOAuth2 ¶ added in v0.18.0
type CredentialsOAuth2 struct {
	ServerURL            string              `json:"serverURL,omitempty"`
	ApplicationID        string              `json:"applicationID,omitempty"`
	ClientID             string              `json:"clientID,omitempty"`
	ClientSecret         string              `json:"clientSecret,omitempty"`
	Endpoint             oauth2.Endpoint     `json:"endpoint,omitempty"`
	RedirectURL          string              `json:"redirectURL,omitempty"`
	OAuthEndpointID      string              `json:"oauthEndpointID,omitempty"`
	Scopes               []string            `json:"scope,omitempty"`
	GrantType            string              `json:"grantType,omitempty"`
	PKCE                 bool                `json:"pkce"`
	Username             string              `json:"username,omitempty"`
	Password             string              `json:"password,omitempty"`
	JWT                  string              `json:"jwt,omitempty"`
	Token                *oauth2.Token       `json:"token,omitempty"`
	AuthCodeOpts         map[string][]string `json:"authCodeOpts,omitempty"`
	AuthCodeExchangeOpts map[string][]string `json:"authCodeExchangeOpts,omitempty"`
	TokenBodyOpts        url.Values          `json:"tokenBodyOpts,omitempty"`
	Metadata             map[string]string   `json:"metadata,omitempty"`
}
    CredentialsOAuth2 supports OAuth 2.0 authorization_code, password, and client_credentials grant flows.
func NewCredentialsOAuth2Env ¶ added in v0.18.0
func NewCredentialsOAuth2Env(envPrefix string) CredentialsOAuth2
func ParseCredentialsOAuth2 ¶ added in v0.18.0
func ParseCredentialsOAuth2(b []byte) (CredentialsOAuth2, error)
func (*CredentialsOAuth2) AuthCodeURL ¶ added in v0.18.0
func (oc *CredentialsOAuth2) AuthCodeURL(state string, opts map[string][]string) string
func (*CredentialsOAuth2) BasicAuthHeader ¶ added in v0.18.0
func (oc *CredentialsOAuth2) BasicAuthHeader() (string, error)
func (*CredentialsOAuth2) Config ¶ added in v0.18.0
func (oc *CredentialsOAuth2) Config() oauth2.Config
func (*CredentialsOAuth2) ConfigClientCredentials ¶ added in v0.18.0
func (oc *CredentialsOAuth2) ConfigClientCredentials() clientcredentials.Config
func (*CredentialsOAuth2) InflateURL ¶ added in v0.18.0
func (oc *CredentialsOAuth2) InflateURL(apiURLPath string) string
func (*CredentialsOAuth2) IsGrantType ¶ added in v0.18.0
func (oc *CredentialsOAuth2) IsGrantType(grantType string) bool
func (*CredentialsOAuth2) MarshalJSON ¶ added in v0.18.0
func (oc *CredentialsOAuth2) MarshalJSON(prefix, indent string) ([]byte, error)
MarshalJSON returns JSON. It is useful for exporting creating configs to be parsed.
func (*CredentialsOAuth2) NewSimpleClient ¶ added in v0.21.0
func (oc *CredentialsOAuth2) NewSimpleClient(ctx context.Context) (*httpsimple.Client, error)
func (*CredentialsOAuth2) NewToken ¶ added in v0.18.0
NewToken retrieves an `*oauth2.Token` when the requisite information is available. Note this uses `clientcredentials.Config.Token()` which doesn't always work. In This situation, use `authutil.TokenClientCredentials()` as an alternative. Note: authorization code is only supported for CLI testing purposes. In a production application, it should be done in a multi-step process to redirect the user to the authorization URL, retrieve the auth code and then `Exchange` it for a token. The `state` value is currently a randomly generated string as this should be used for testing purposes only.
func (*CredentialsOAuth2) NewTokenPasswordCredentials ¶ added in v0.21.2
func (oc *CredentialsOAuth2) NewTokenPasswordCredentials(ctx context.Context) (*oauth2.Token, error)
NewTokenPasswordCredentials provides fine-grained token request.
func (*CredentialsOAuth2) PasswordRequestBody ¶ added in v0.18.0
func (oc *CredentialsOAuth2) PasswordRequestBody() url.Values
func (*CredentialsOAuth2) RefreshToken ¶ added in v0.18.0
func (*CredentialsOAuth2) RefreshTokenSimple ¶ added in v0.18.0
type CredentialsSet ¶ added in v0.18.0
type CredentialsSet struct {
	Credentials map[string]Credentials `json:"credentials,omitempty"`
}
    func ReadFileCredentialsSet ¶ added in v0.18.0
func ReadFileCredentialsSet(filename string, inflateEndpoints bool) (*CredentialsSet, error)
func (*CredentialsSet) Accounts ¶ added in v0.18.0
func (set *CredentialsSet) Accounts() []string
func (*CredentialsSet) Get ¶ added in v0.18.0
func (set *CredentialsSet) Get(key string) (Credentials, error)
func (*CredentialsSet) Inflate ¶ added in v0.18.0
func (set *CredentialsSet) Inflate() error
func (*CredentialsSet) Keys ¶ added in v0.18.0
func (set *CredentialsSet) Keys() []string
type Options ¶ added in v0.18.0
type Options struct {
	CredsPath string `long:"creds" description:"Environment File Path"`
	Account   string `long:"account" description:"Environment Variable Name"`
	Token     string `long:"token" description:"Token"`
	CLI       []bool `long:"cli" description:"CLI"`
}
    Options is a struct to be used with `ParseOptions()` or `github.com/jessevdk/go-flags`. It can be embedded in another struct and used directly with `github.com/jessevdk/go-flags`.
func ParseOptions ¶ added in v0.22.1
func (*Options) Credentials ¶ added in v0.22.0
func (opts *Options) Credentials() (Credentials, error)
func (*Options) CredentialsSet ¶ added in v0.22.1
func (opts *Options) CredentialsSet(inflateEndpoints bool) (*CredentialsSet, error)
       Source Files
      ¶
      Source Files
      ¶
    
  
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| 
          
            examples/scim_user
            
            command
          
          
         | |
| 
          
            examples/scim_user_credentials
            
            command
          
          
         | |
| auth0 contains a Go implementation of Auth0's PKCE support: https://auth0.com/docs/api-auth/tutorials/authorization-code-grant-pkce | auth0 contains a Go implementation of Auth0's PKCE support: https://auth0.com/docs/api-auth/tutorials/authorization-code-grant-pkce | 
| 
          
            examples/auth-code-pkce
            
            command
          
          
         | |
| 
          
            introspect/cmd/server
            
            command
          
          
         | |
| cmd
       | |
| 
          
            get_token
            
            command
          
          
         | |
| 
          
            goauth
            
            command
          
          
         | |
| 
          
            interface_function
            
            command
          
          
         | |
| 
          
            jwt
            
            command
          
          
         | |
| examples
       | |
| 
          
            jwt
            
            command
          
          
         | |
| 
          
            cmd/get_contacts
            
            command
          
          
         | |
| 
          
            examples/get_token
            
            command
          
          
         | |
| 
          
            examples/query_card
            
            command
          
          
         | |
| 
          
            cmd/get_account
            
            command
          
          
         | |
| 
          
            cmd/glipbot_auth
            
            command
          
          
         | |
| 
          
            examples/salesforce_versions
            
            command
          
          
         | |
| 
          
            examples/send_ics
            
            command
          
           This package posts an ICS file to Gmail. | This package posts an ICS file to Gmail. | 
| 
          
            examples/send_one
            
            command
          
          
         | |
| util
       | |
| 
          
            examples/get_me
            
            command
          
          
         | |
| 
          
            cmd/jwt_deprecated
            
            command
          
          
         | |
| 
          
            cmd/server2server_oauth
            
            command
          
          
         |