Documentation ¶
Index ¶
- Variables
- func CacheExpires(r *http.Response) time.Time
- func FactionNameToID(faction string) int32
- func GetJournalRefID(referenceName string) int
- func TokenFromJSON(jsonStr string) (*oauth2.Token, error)
- func TokenToJSON(token *oauth2.Token) (string, error)
- func ValidCharacterName(name string) bool
- type APIClient
- type SSOAuthenticator
- func (c *SSOAuthenticator) AuthorizeURL(state string, onlineAccess bool, scopes []string) string
- func (c *SSOAuthenticator) ChangeAuthURL(url string)
- func (c *SSOAuthenticator) ChangeTokenURL(url string)
- func (c *SSOAuthenticator) TokenExchange(code string) (*oauth2.Token, error)
- func (c *SSOAuthenticator) TokenRevoke(refreshToken string) error
- func (c *SSOAuthenticator) TokenSource(token *oauth2.Token) (oauth2.TokenSource, error)
- func (c *SSOAuthenticator) Verify(auth oauth2.TokenSource) (*VerifyResponse, error)
- type VerifyResponse
Constants ¶
This section is empty.
Variables ¶
var ( ContextOAuth2 = esi.ContextOAuth2 ContextAccessToken = esi.ContextAccessToken )
ContextOAuth2 is the context for GoESI authentication. Pass a tokenSource with this key to a context for an ESI API Call
var FactionAllies = map[int32]int32{
500001: 500003,
500003: 500001,
500002: 500004,
500004: 500002,
}
FactionAllies resolves friendly faction war IDs
var FactionsAtWar = map[int32][]int32{
500001: {500002, 500004},
500003: {500002, 500004},
500002: {500001, 500003},
500004: {500001, 500003},
}
FactionsAtWar resolves two enemy parties for each factionID
var FactionsByID = map[int32]string{500001: "Caldari", 500002: "Minmatar", 500003: "Amarr", 500004: "Gallente"}
Factions resolves faction ID to Name
var FactionsByName = map[string]int32{"Caldari": 500001, "Minmatar": 500002, "Amarr": 500003, "Gallente": 500004}
Factions resolves faction name to ID
var JournalRefID = map[string]int{}/* 176 elements not displayed */
JournalRefID Maps journal strings to CCP internal refID. CCP has stated these are subject to change. Please submit pull requests for new IDs
Functions ¶
func CacheExpires ¶
CacheExpires helper function to determine remaining time before repeating a request.
func FactionNameToID ¶
func GetJournalRefID ¶
GetJournalRefID looks up the Journal reference name and returns the internal ID WARNING: These are subject to change per CCP.
func TokenFromJSON ¶
TokenFromJSON helper function to convert stored JSON to a token.
func TokenToJSON ¶
TokenToJSON helper function to convert a token to a storable format.
Types ¶
type APIClient ¶
APIClient manages communication with the EVE Swagger Interface API In most cases there should be only one, shared, APIClient.
func NewAPIClient ¶
NewAPIClient creates a new API client. Requires a userAgent string describing your application. optionally a custom http.Client to allow for advanced features such as caching.
func (*APIClient) ChangeBasePath ¶
ChangeBasePath allows alternate ESI paths to be used for testing
type SSOAuthenticator ¶
type SSOAuthenticator struct {
// contains filtered or unexported fields
}
[TODO] lose this mutex and allow scopes to change without conflict.
func NewSSOAuthenticator ¶
func NewSSOAuthenticator(client *http.Client, clientID string, clientSecret string, redirectURL string, scopes []string) *SSOAuthenticator
NewSSOAuthenticator create a new EVE SSO Authenticator. Requires your application clientID, clientSecret, and redirectURL. RedirectURL must match exactly to what you registered with CCP.
func NewSSOAuthenticatorV2 ¶
func NewSSOAuthenticatorV2(client *http.Client, clientID string, clientSecret string, redirectURL string, scopes []string) *SSOAuthenticator
NewSSOAuthenticatorV2 create a new EVE SSO Authenticator with the v2 urls. Requires your application clientID, clientSecret, and redirectURL. RedirectURL must match exactly to what you registered with CCP.
func (*SSOAuthenticator) AuthorizeURL ¶
func (c *SSOAuthenticator) AuthorizeURL(state string, onlineAccess bool, scopes []string) string
AuthorizeURL returns a url for an end user to authenticate with EVE SSO and return success to the redirectURL. It is important to create a significatly unique state for this request and verify the state matches when returned to the redirectURL.
func (*SSOAuthenticator) ChangeAuthURL ¶
func (c *SSOAuthenticator) ChangeAuthURL(url string)
ChangeAuthURL changes the oauth2 configuration url for authentication
func (*SSOAuthenticator) ChangeTokenURL ¶
func (c *SSOAuthenticator) ChangeTokenURL(url string)
ChangeTokenURL changes the oauth2 configuration url for token
func (*SSOAuthenticator) TokenExchange ¶
func (c *SSOAuthenticator) TokenExchange(code string) (*oauth2.Token, error)
TokenExchange exchanges the code returned to the redirectURL with the CREST server to an access token. A caching client must be passed. This client MUST cache per CCP guidelines or face banning.
func (*SSOAuthenticator) TokenRevoke ¶
func (c *SSOAuthenticator) TokenRevoke(refreshToken string) error
TokenRevoke revokes a refresh token
func (*SSOAuthenticator) TokenSource ¶
func (c *SSOAuthenticator) TokenSource(token *oauth2.Token) (oauth2.TokenSource, error)
TokenSource creates a refreshable token that can be passed to ESI functions
func (*SSOAuthenticator) Verify ¶
func (c *SSOAuthenticator) Verify(auth oauth2.TokenSource) (*VerifyResponse, error)
Verify the client and collect user information.