goth: Index | Files

package seatalk

import ""


Package Files

seatalk.go session.go


var Endpoint = oauth2.Endpoint{
    AuthURL:  "",
    TokenURL: "",

Endpoint is SeaTalk's OAuth 2.0 endpoint.

type Provider Uses

type Provider struct {
    ClientKey   string
    Secret      string
    CallbackURL string
    // contains filtered or unexported fields

Provider is the implementation of `goth.Provider` for accessing SeaTalk.

func New Uses

func New(clientKey, secret, callbackURL string, scopes ...string) *Provider

New creates a new SeaTalk provider and sets up important connection details. You should always call `seatalk.New` to get a new provider. Never try to create one manually.

func (*Provider) BeginAuth Uses

func (p *Provider) BeginAuth(state string) (goth.Session, error)

BeginAuth asks SeaTalk for an authentication endpoint.

func (*Provider) Debug Uses

func (p *Provider) Debug(bool)

Debug is a no-op for the seatalk package.

func (*Provider) FetchUser Uses

func (p *Provider) FetchUser(session goth.Session) (goth.User, error)

FetchUser will go to SeaTalk and access basic information about the user.

func (*Provider) Name Uses

func (p *Provider) Name() string

Name is the name used to retrieve this provider later.

func (*Provider) RefreshToken Uses

func (p *Provider) RefreshToken(refreshToken string) (*oauth2.Token, error)

RefreshToken get new access token based on the refresh token

func (*Provider) RefreshTokenAvailable Uses

func (p *Provider) RefreshTokenAvailable() bool

RefreshTokenAvailable refresh token is provided by auth provider or not

func (*Provider) SetName Uses

func (p *Provider) SetName(name string)

SetName is to update the name of the provider (needed in case of multiple providers of 1 type)

func (*Provider) UnmarshalSession Uses

func (p *Provider) UnmarshalSession(data string) (goth.Session, error)

UnmarshalSession will unmarshal a JSON string into a session.

type Session Uses

type Session struct {
    AuthURL      string
    AccessToken  string
    RefreshToken string
    ExpiresAt    time.Time

Session stores data during the auth process with SeaTalk.

func (*Session) Authorize Uses

func (s *Session) Authorize(provider goth.Provider, params goth.Params) (string, error)

Authorize the session with SeaTalk and return the access token to be stored for future use.

func (*Session) GetAuthURL Uses

func (s *Session) GetAuthURL() (string, error)

GetAuthURL will return the URL set by calling the `BeginAuth` function on the Google provider.

func (*Session) Marshal Uses

func (s *Session) Marshal() string

Marshal the session into a string

func (Session) String Uses

func (s Session) String() string

Package seatalk imports 11 packages (graph) and is imported by 3 packages. Updated 2020-05-18. Refresh now. Tools for package owners.