2019-06-05 18:59:04 +02:00
|
|
|
package providers
|
|
|
|
|
|
|
|
import (
|
2020-05-05 17:53:33 +02:00
|
|
|
"context"
|
2019-06-05 18:59:04 +02:00
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
2020-03-29 15:54:36 +02:00
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/pkg/apis/sessions"
|
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/pkg/logger"
|
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/pkg/requests"
|
2019-06-05 18:59:04 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// NextcloudProvider represents an Nextcloud based Identity Provider
|
|
|
|
type NextcloudProvider struct {
|
|
|
|
*ProviderData
|
|
|
|
}
|
|
|
|
|
2020-05-05 17:53:33 +02:00
|
|
|
var _ Provider = (*NextcloudProvider)(nil)
|
|
|
|
|
2019-06-05 18:59:04 +02:00
|
|
|
// NewNextcloudProvider initiates a new NextcloudProvider
|
|
|
|
func NewNextcloudProvider(p *ProviderData) *NextcloudProvider {
|
|
|
|
p.ProviderName = "Nextcloud"
|
|
|
|
return &NextcloudProvider{ProviderData: p}
|
|
|
|
}
|
|
|
|
|
|
|
|
func getNextcloudHeader(accessToken string) http.Header {
|
|
|
|
header := make(http.Header)
|
|
|
|
header.Set("Authorization", fmt.Sprintf("Bearer %s", accessToken))
|
|
|
|
return header
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetEmailAddress returns the Account email address
|
2020-05-05 17:53:33 +02:00
|
|
|
func (p *NextcloudProvider) GetEmailAddress(ctx context.Context, s *sessions.SessionState) (string, error) {
|
|
|
|
req, err := http.NewRequestWithContext(ctx, "GET",
|
2019-06-05 18:59:04 +02:00
|
|
|
p.ValidateURL.String(), nil)
|
|
|
|
if err != nil {
|
|
|
|
logger.Printf("failed building request %s", err)
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
req.Header = getNextcloudHeader(s.AccessToken)
|
|
|
|
json, err := requests.Request(req)
|
|
|
|
if err != nil {
|
|
|
|
logger.Printf("failed making request %s", err)
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
email, err := json.Get("ocs").Get("data").Get("email").String()
|
|
|
|
return email, err
|
|
|
|
}
|