mirror of https://github.com/synctv-org/synctv
Opt: oauth2 provider
parent
83843d3c3c
commit
d3ced2c376
@ -0,0 +1,68 @@
|
|||||||
|
package provider
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
providerpb "github.com/synctv-org/synctv/proto/provider"
|
||||||
|
"golang.org/x/oauth2"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GRPCClient struct{ client providerpb.Oauth2PluginClient }
|
||||||
|
|
||||||
|
var _ ProviderInterface = (*GRPCClient)(nil)
|
||||||
|
|
||||||
|
func (c *GRPCClient) Init(o Oauth2Option) {
|
||||||
|
c.client.Init(context.Background(), &providerpb.InitReq{
|
||||||
|
ClientId: o.ClientID,
|
||||||
|
ClientSecret: o.ClientSecret,
|
||||||
|
RedirectUrl: o.RedirectURL,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *GRPCClient) Provider() OAuth2Provider {
|
||||||
|
resp, err := c.client.Provider(context.Background(), &providerpb.Enpty{})
|
||||||
|
if err != nil {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
return OAuth2Provider(resp.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *GRPCClient) NewAuthURL(state string) string {
|
||||||
|
resp, err := c.client.NewAuthURL(context.Background(), &providerpb.NewAuthURLReq{State: state})
|
||||||
|
if err != nil {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
return resp.Url
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *GRPCClient) GetToken(ctx context.Context, code string) (*oauth2.Token, error) {
|
||||||
|
resp, err := c.client.GetToken(ctx, &providerpb.GetTokenReq{Code: code})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &oauth2.Token{
|
||||||
|
AccessToken: resp.AccessToken,
|
||||||
|
TokenType: resp.TokenType,
|
||||||
|
RefreshToken: resp.RefreshToken,
|
||||||
|
Expiry: time.Unix(resp.Expiry, 0),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *GRPCClient) GetUserInfo(ctx context.Context, tk *oauth2.Token) (*UserInfo, error) {
|
||||||
|
resp, err := c.client.GetUserInfo(ctx, &providerpb.GetUserInfoReq{
|
||||||
|
Token: &providerpb.Token{
|
||||||
|
AccessToken: tk.AccessToken,
|
||||||
|
TokenType: tk.TokenType,
|
||||||
|
RefreshToken: tk.RefreshToken,
|
||||||
|
Expiry: tk.Expiry.Unix(),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &UserInfo{
|
||||||
|
Username: resp.Username,
|
||||||
|
ProviderUserID: uint(resp.ProviderUserId),
|
||||||
|
}, nil
|
||||||
|
}
|
@ -0,0 +1,69 @@
|
|||||||
|
package provider
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
providerpb "github.com/synctv-org/synctv/proto/provider"
|
||||||
|
"golang.org/x/oauth2"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GRPCServer struct {
|
||||||
|
providerpb.UnimplementedOauth2PluginServer
|
||||||
|
Impl ProviderInterface
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *GRPCServer) Init(ctx context.Context, req *providerpb.InitReq) (*providerpb.Enpty, error) {
|
||||||
|
s.Impl.Init(Oauth2Option{
|
||||||
|
ClientID: req.ClientId,
|
||||||
|
ClientSecret: req.ClientSecret,
|
||||||
|
RedirectURL: req.RedirectUrl,
|
||||||
|
})
|
||||||
|
return &providerpb.Enpty{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *GRPCServer) Provider(ctx context.Context, req *providerpb.Enpty) (*providerpb.ProviderResp, error) {
|
||||||
|
return &providerpb.ProviderResp{Name: string(s.Impl.Provider())}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *GRPCServer) NewAuthURL(ctx context.Context, req *providerpb.NewAuthURLReq) (*providerpb.NewAuthURLResp, error) {
|
||||||
|
return &providerpb.NewAuthURLResp{Url: s.Impl.NewAuthURL(req.State)}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *GRPCServer) GetToken(ctx context.Context, req *providerpb.GetTokenReq) (*providerpb.Token, error) {
|
||||||
|
token, err := s.Impl.GetToken(ctx, req.Code)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &providerpb.Token{
|
||||||
|
AccessToken: token.AccessToken,
|
||||||
|
TokenType: token.TokenType,
|
||||||
|
RefreshToken: token.RefreshToken,
|
||||||
|
Expiry: token.Expiry.Unix(),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *GRPCServer) GetUserInfo(ctx context.Context, req *providerpb.GetUserInfoReq) (*providerpb.GetUserInfoResp, error) {
|
||||||
|
userInfo, err := s.Impl.GetUserInfo(ctx, &oauth2.Token{
|
||||||
|
AccessToken: req.Token.AccessToken,
|
||||||
|
TokenType: req.Token.TokenType,
|
||||||
|
Expiry: time.Unix(req.Token.Expiry, 0),
|
||||||
|
RefreshToken: req.Token.RefreshToken,
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
resp := &providerpb.GetUserInfoResp{
|
||||||
|
Username: userInfo.Username,
|
||||||
|
ProviderUserId: uint64(userInfo.ProviderUserID),
|
||||||
|
}
|
||||||
|
if userInfo.TokenRefreshed != nil {
|
||||||
|
resp.TokenRefreshed = &providerpb.Token{
|
||||||
|
AccessToken: userInfo.TokenRefreshed.Token.AccessToken,
|
||||||
|
TokenType: userInfo.TokenRefreshed.Token.TokenType,
|
||||||
|
RefreshToken: userInfo.TokenRefreshed.Token.RefreshToken,
|
||||||
|
Expiry: userInfo.TokenRefreshed.Token.Expiry.Unix(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return resp, nil
|
||||||
|
}
|
Loading…
Reference in New Issue