本文整理汇总了Golang中github.com/coreos/dex/pkg/log.Infof函数的典型用法代码示例。如果您正苦于以下问题:Golang Infof函数的具体用法?Golang Infof怎么用?Golang Infof使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了Infof函数的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: handleChangePasswordFunc
func handleChangePasswordFunc(o *OtsimoAccounts) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
if r.Method == "POST" {
r.ParseForm()
oldPass := r.PostFormValue("old_password")
newPass := r.PostFormValue("new_password")
userID := r.PostFormValue("user_id")
if userID == "" || oldPass == "" || newPass == "" {
log.Infof("update.go: invalid body '%s'", userID)
writeError(w, http.StatusBadRequest, "invalid body")
return
}
resp, err := o.Dex.ChangePassword(context.Background(), &pb.ChangePasswordRequest{
UserId: userID,
OldPassword: oldPass,
NewPassword: newPass,
})
log.Infof("update.go: change password result is %q %v", resp, err)
if err != nil {
writeError(w, http.StatusInternalServerError, err.Error())
return
}
writeResponseWithBody(w, http.StatusOK, resp)
} else {
writeError(w, http.StatusNotFound, "Not Found")
}
}
}
开发者ID:otsimo,项目名称:accounts,代码行数:30,代码来源:update.go
示例2: handleChangeEmailFunc
func handleChangeEmailFunc(o *OtsimoAccounts) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
if r.Method == "POST" {
r.ParseForm()
oldEmail := r.PostFormValue("old_email")
newEmail := r.PostFormValue("new_email")
if oldEmail == "" || newEmail == "" || oldEmail == newEmail {
log.Info("update.go: invalid body")
writeError(w, http.StatusBadRequest, "invalid body")
return
}
resp, err := o.Dex.ChangeEmail(context.Background(), &pb.ChangeEmailRequest{
OldEmail: oldEmail,
NewEmail: newEmail,
})
log.Infof("update.go: change email result is %q %v", resp, err)
if err != nil {
writeError(w, http.StatusInternalServerError, err.Error())
return
}
id := r.Header.Get("sub")
if bson.IsObjectIdHex(id) {
o.Api.UpdateProfile(context.Background(), &apipb.Profile{Id: bson.ObjectIdHex(id), Email: newEmail})
}
writeResponseWithBody(w, http.StatusOK, resp)
} else {
writeError(w, http.StatusNotFound, "Not Found")
}
}
}
开发者ID:otsimo,项目名称:accounts,代码行数:33,代码来源:update.go
示例3: registerUser
func registerUser(o *OtsimoAccounts, email, password, firstName, lastName, language string) (*pb.RegisterResponse, error) {
resp, err := o.Dex.Register(context.Background(), &pb.RegisterRequest{
Email: email,
DisplayName: fmt.Sprintf("%s %s", firstName, lastName),
Password: password,
})
log.Infof("register.go: register result of '%s' is %q %v", email, resp, err)
if err != nil {
return nil, err
}
_, errapi := o.Api.AddProfile(context.Background(), &apipb.Profile{
Id: bson.ObjectIdHex(resp.UserId),
Email: email,
FirstName: firstName,
LastName: lastName,
Language: language,
})
if errapi != nil {
//Disable or delete user
log.Errorf("register.go: failed to add profile %+v", errapi)
_, err = o.Dex.RemoveUser(context.Background(), &pb.RemoveRequest{Id: resp.UserId, Email: email})
if err != nil {
log.Errorf("register.go: Holly FUCK!!: failed to add profile and remove user [error]=%+v [user_id]='%s' [user_email]='%s'", err, resp.UserId, email)
return nil, err
}
return nil, fmt.Errorf("failed to register user, adding to api service failed:%v", errapi)
}
return resp, nil
}
开发者ID:otsimo,项目名称:accounts,代码行数:30,代码来源:register.go
示例4: ClientCredsToken
func (s *Server) ClientCredsToken(creds oidc.ClientCredentials) (*jose.JWT, error) {
ok, err := s.ClientIdentityRepo.Authenticate(creds)
if err != nil {
log.Errorf("Failed fetching client %s from repo: %v", creds.ID, err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
if !ok {
return nil, oauth2.NewError(oauth2.ErrorInvalidClient)
}
signer, err := s.KeyManager.Signer()
if err != nil {
log.Errorf("Failed to generate ID token: %v", err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
now := time.Now()
exp := now.Add(s.SessionManager.ValidityWindow)
claims := oidc.NewClaims(s.IssuerURL.String(), creds.ID, creds.ID, now, exp)
claims.Add("name", creds.ID)
jwt, err := jose.NewSignedJWT(claims, signer)
if err != nil {
log.Errorf("Failed to generate ID token: %v", err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
log.Infof("Client token sent: clientID=%s", creds.ID)
return jwt, nil
}
开发者ID:derekparker,项目名称:dex,代码行数:31,代码来源:server.go
示例5: Run
func (gc *GarbageCollector) Run() chan struct{} {
stop := make(chan struct{})
go func() {
var failing bool
next := gc.interval
for {
select {
case <-gc.clock.After(next):
if anyPurgeErrors(purgeAll(gc.purgers)) {
if !failing {
failing = true
next = time.Second
} else {
next = ptime.ExpBackoff(next, time.Minute)
}
log.Errorf("Failed garbage collection, retrying in %v", next)
} else {
failing = false
next = gc.interval
log.Infof("Garbage collection complete, running again in %v", next)
}
case <-stop:
return
}
}
}()
return stop
}
开发者ID:jbagel2,项目名称:dex,代码行数:30,代码来源:gc.go
示例6: NewSession
func (s *Server) NewSession(ipdcID, clientID, clientState string, redirectURL url.URL, nonce string, register bool, scope []string) (string, error) {
sessionID, err := s.SessionManager.NewSession(ipdcID, clientID, clientState, redirectURL, nonce, register, scope)
if err != nil {
return "", err
}
log.Infof("Session %s created: clientID=%s clientState=%s", sessionID, clientID, clientState)
return s.SessionManager.NewSessionKey(sessionID)
}
开发者ID:GamerockSA,项目名称:dex,代码行数:9,代码来源:server.go
示例7: step
func (r *pcsStepRetry) step(fn pcsStepFunc) (next pcsStepper) {
ttl, err := fn()
if err == nil {
next = &pcsStepNext{aft: ttl}
log.Infof("JWT refresh no longer failing")
} else {
next = &pcsStepRetry{aft: timeutil.ExpBackoff(r.aft, time.Minute)}
log.Errorf("JWT refresh still failing, retrying in %v: %v", next.after(), err)
}
return
}
开发者ID:otsimo,项目名称:accounts,代码行数:11,代码来源:oidc.go
示例8: RefreshToken
func (s *Server) RefreshToken(creds oidc.ClientCredentials, token string) (*jose.JWT, error) {
ok, err := s.ClientIdentityRepo.Authenticate(creds)
if err != nil {
log.Errorf("Failed fetching client %s from repo: %v", creds.ID, err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
if !ok {
log.Errorf("Failed to Authenticate client %s", creds.ID)
return nil, oauth2.NewError(oauth2.ErrorInvalidClient)
}
userID, err := s.RefreshTokenRepo.Verify(creds.ID, token)
switch err {
case nil:
break
case refresh.ErrorInvalidToken:
return nil, oauth2.NewError(oauth2.ErrorInvalidRequest)
case refresh.ErrorInvalidClientID:
return nil, oauth2.NewError(oauth2.ErrorInvalidClient)
default:
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
user, err := s.UserRepo.Get(nil, userID)
if err != nil {
// The error can be user.ErrorNotFound, but we are not deleting
// user at this moment, so this shouldn't happen.
log.Errorf("Failed to fetch user %q from repo: %v: ", userID, err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
signer, err := s.KeyManager.Signer()
if err != nil {
log.Errorf("Failed to refresh ID token: %v", err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
now := time.Now()
expireAt := now.Add(session.DefaultSessionValidityWindow)
claims := oidc.NewClaims(s.IssuerURL.String(), user.ID, creds.ID, now, expireAt)
user.AddToClaims(claims)
jwt, err := jose.NewSignedJWT(claims, signer)
if err != nil {
log.Errorf("Failed to generate ID token: %v", err)
return nil, oauth2.NewError(oauth2.ErrorServerError)
}
log.Infof("New token sent: clientID=%s", creds.ID)
return jwt, nil
}
开发者ID:derekparker,项目名称:dex,代码行数:53,代码来源:server.go
示例9: AddConnector
func (s *Server) AddConnector(cfg connector.ConnectorConfig) error {
connectorID := cfg.ConnectorID()
ns := s.IssuerURL
ns.Path = path.Join(ns.Path, httpPathAuth, connectorID)
idpc, err := cfg.Connector(ns, s.Login, s.Templates)
if err != nil {
return err
}
s.Connectors = append(s.Connectors, idpc)
sortable := sortableIDPCs(s.Connectors)
sort.Sort(sortable)
// We handle the LocalConnector specially because it needs access to the
// UserRepo and the PasswordInfoRepo; if it turns out that other connectors
// need access to these resources we'll figure out how to provide it in a
// cleaner manner.
localConn, ok := idpc.(*connector.LocalConnector)
if ok {
s.localConnectorID = connectorID
if s.UserRepo == nil {
return errors.New("UserRepo cannot be nil")
}
if s.PasswordInfoRepo == nil {
return errors.New("PasswordInfoRepo cannot be nil")
}
localConn.SetLocalIdentityProvider(&connector.LocalIdentityProvider{
UserRepo: s.UserRepo,
PasswordInfoRepo: s.PasswordInfoRepo,
})
localCfg, ok := cfg.(*connector.LocalConnectorConfig)
if !ok {
return errors.New("config for LocalConnector not a LocalConnectorConfig?")
}
if len(localCfg.PasswordInfos) > 0 {
err := user.LoadPasswordInfos(s.PasswordInfoRepo,
localCfg.PasswordInfos)
if err != nil {
return err
}
}
}
log.Infof("Loaded IdP connector: id=%s type=%s", connectorID, cfg.ConnectorType())
return nil
}
开发者ID:derekparker,项目名称:dex,代码行数:52,代码来源:server.go
示例10: SendMail
func (m *mailgunEmailer) SendMail(subject, text, html string, to ...string) error {
msg := m.mg.NewMessage(m.from, subject, text, to...)
if html != "" {
msg.SetHtml(html)
}
mes, id, err := m.mg.Send(msg)
if err != nil {
counterEmailSendErr.Add(1)
return err
}
log.Infof("SendMail: msgID: %v: %q", id, mes)
return nil
}
开发者ID:Tecsisa,项目名称:dex,代码行数:13,代码来源:mailgun.go
示例11: DisableUser
func (u *UsersAPI) DisableUser(creds Creds, userID string, disable bool) (schema.UserDisableResponse, error) {
log.Infof("userAPI: DisableUser")
if !u.Authorize(creds) {
return schema.UserDisableResponse{}, ErrorUnauthorized
}
if err := u.manager.Disable(userID, disable); err != nil {
return schema.UserDisableResponse{}, mapError(err)
}
return schema.UserDisableResponse{
Ok: true,
}, nil
}
开发者ID:adrianlop,项目名称:dex,代码行数:14,代码来源:api.go
示例12: GetUser
func (u *UsersAPI) GetUser(creds Creds, id string) (schema.User, error) {
log.Infof("userAPI: GetUser")
if !u.Authorize(creds) {
return schema.User{}, ErrorUnauthorized
}
usr, err := u.userManager.Get(id)
if err != nil {
return schema.User{}, mapError(err)
}
return userToSchemaUser(usr), nil
}
开发者ID:Tecsisa,项目名称:dex,代码行数:14,代码来源:api.go
示例13: CreateUser
func (u *UsersAPI) CreateUser(creds Creds, usr schema.User, redirURL url.URL) (schema.UserCreateResponse, error) {
log.Infof("userAPI: CreateUser")
if !u.Authorize(creds) {
return schema.UserCreateResponse{}, ErrorUnauthorized
}
hash, err := generateTempHash()
if err != nil {
return schema.UserCreateResponse{}, mapError(err)
}
metadata, err := u.clientIdentityRepo.Metadata(creds.ClientID)
if err != nil {
return schema.UserCreateResponse{}, mapError(err)
}
validRedirURL, err := client.ValidRedirectURL(&redirURL, metadata.RedirectURLs)
if err != nil {
return schema.UserCreateResponse{}, ErrorInvalidRedirectURL
}
id, err := u.manager.CreateUser(schemaUserToUser(usr), user.Password(hash), u.localConnectorID)
if err != nil {
return schema.UserCreateResponse{}, mapError(err)
}
userUser, err := u.manager.Get(id)
if err != nil {
return schema.UserCreateResponse{}, mapError(err)
}
usr = userToSchemaUser(userUser)
url, err := u.emailer.SendInviteEmail(usr.Email, validRedirURL, creds.ClientID)
// An email is sent only if we don't get a link and there's no error.
emailSent := err == nil && url == nil
var resetLink string
if url != nil {
resetLink = url.String()
}
return schema.UserCreateResponse{
User: &usr,
EmailSent: emailSent,
ResetPasswordLink: resetLink,
}, nil
}
开发者ID:adrianlop,项目名称:dex,代码行数:49,代码来源:api.go
示例14: handleRegisterFunc
func handleRegisterFunc(o *OtsimoAccounts) http.HandlerFunc {
handlePOST := func(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
email := r.PostFormValue("username")
password := r.PostFormValue("password")
firstName := r.PostFormValue("first_name")
lastName := r.PostFormValue("last_name")
language := r.PostFormValue("language")
if email == "" || password == "" {
writeError(w, http.StatusBadRequest, "invalid body")
return
}
result, err := registerUser(o, email, password, firstName, lastName, language)
if err != nil {
writeError(w, http.StatusInternalServerError, err.Error())
return
}
writeResponseWithBody(w, http.StatusOK, result.Token)
}
handleGET := func(w http.ResponseWriter, r *http.Request) {
oac, err := o.Oidc.OAuthClient()
if err != nil {
log.Errorf("failed to create OAuthClient %v", err)
writeError(w, http.StatusInternalServerError, err.Error())
}
u, err := url.Parse(oac.AuthCodeURL("", "", ""))
q := u.Query()
q.Set("register", "1")
if err != nil {
log.Errorf("failed to create authCoreURL %v", err)
writeError(w, http.StatusInternalServerError, err.Error())
}
u.RawQuery = q.Encode()
log.Infof("URL: %v", u.String())
http.Redirect(w, r, u.String(), http.StatusFound)
}
return func(w http.ResponseWriter, r *http.Request) {
if r.Method == "POST" {
handlePOST(w, r)
} else if r.Method == "GET" {
handleGET(w, r)
} else {
writeError(w, http.StatusNotFound, "wrong Http Verb")
}
}
}
开发者ID:otsimo,项目名称:accounts,代码行数:47,代码来源:register.go
示例15: authToken
func (s *grpcServer) authToken(jwt jose.JWT) (string, *oidc.ClientMetadata, error) {
ciRepo := s.server.ClientIdentityRepo
keys, err := s.server.KeyManager.PublicKeys()
if err != nil {
log.Errorf("grpc.go: Failed to get keys: %v", err)
return "", nil, errors.New("errorAccessDenied")
}
if len(keys) == 0 {
log.Error("grpc.go: No keys available for verification client")
return "", nil, errors.New("errorAccessDenied")
}
ok, err := oidc.VerifySignature(jwt, keys)
if err != nil {
log.Errorf("grpc.go: Failed to verify signature: %v", err)
return "", nil, err
}
if !ok {
log.Info("grpc.go: token signature is not verified")
return "", nil, errors.New("invalid token")
}
clientID, err := oidc.VerifyClientClaims(jwt, s.server.IssuerURL.String())
if err != nil {
log.Errorf("grpc.go: Failed to verify JWT claims: %v", err)
return "", nil, errors.New("failed to verify jwt claims token")
}
md, err := ciRepo.Metadata(clientID)
if md == nil || err != nil {
log.Errorf("grpc.go: Failed to find clientID: %s, error=%v", clientID, err)
return "", nil, err
}
//client must be admin in order to use login and register grpc apis.
ok, err = ciRepo.IsDexAdmin(clientID)
if err != nil {
return "", nil, err
}
if !ok {
log.Infof("grpc.go: Client [%s] is not admin", clientID)
return "", nil, errors.New("errorAccessDenied")
}
log.Debugf("grpc.go: Authenticated token for client ID %s", clientID)
return clientID, md, nil
}
开发者ID:otsimo,项目名称:accounts,代码行数:47,代码来源:grpc.go
示例16: handleLoginFunc
func handleLoginFunc(o *OtsimoAccounts) http.HandlerFunc {
handlePOST := func(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
username := r.PostFormValue("username")
password := r.PostFormValue("password")
grant_type := r.PostFormValue("grant_type")
if username == "" || password == "" || grant_type == "" {
writeError(w, http.StatusBadRequest, "invalid body")
return
}
resp, err := o.Dex.Login(context.Background(), &pb.LoginRequest{
GrantType: grant_type,
BasicAuth: "Basic " + basicAuth(username, password),
})
log.Infof("login.go: login result of '%s' is %q %v", username, resp, err)
if err != nil {
writeError(w, http.StatusInternalServerError, err.Error())
return
}
writeResponseWithBody(w, http.StatusOK, resp)
}
handleGET := func(w http.ResponseWriter, r *http.Request) {
oac, err := o.Oidc.OAuthClient()
if err != nil {
writeError(w, http.StatusInternalServerError, "unabled create oauth client")
return
}
u, err := url.Parse(oac.AuthCodeURL("", "", ""))
if err != nil {
writeError(w, http.StatusInternalServerError, "unabled create auth code url")
return
}
http.Redirect(w, r, u.String(), http.StatusFound)
}
return func(w http.ResponseWriter, r *http.Request) {
if r.Method == "POST" {
handlePOST(w, r)
} else if r.Method == "GET" {
handleGET(w, r)
} else {
writeError(w, http.StatusNotFound, "wrong HTTP Verb")
}
}
}
开发者ID:otsimo,项目名称:accounts,代码行数:47,代码来源:login.go
示例17: handleRegisterFunc
func handleRegisterFunc(c *oidc.Client) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
oac, err := c.OAuthClient()
if err != nil {
panic("unable to proceed")
}
u, err := url.Parse(oac.AuthCodeURL("", "", ""))
q := u.Query()
q.Set("register", "1")
if err != nil {
panic("unable to proceed")
}
u.RawQuery = q.Encode()
log.Infof("URL: %v", u.String())
http.Redirect(w, r, u.String(), http.StatusFound)
}
}
开发者ID:GamerockSA,项目名称:dex,代码行数:18,代码来源:main.go
示例18: ResendEmailInvitation
func (u *UsersAPI) ResendEmailInvitation(creds Creds, userID string, redirURL url.URL) (schema.ResendEmailInvitationResponse, error) {
log.Infof("userAPI: ResendEmailInvitation")
if !u.Authorize(creds) {
return schema.ResendEmailInvitationResponse{}, ErrorUnauthorized
}
metadata, err := u.clientIdentityRepo.Metadata(creds.ClientID)
if err != nil {
return schema.ResendEmailInvitationResponse{}, mapError(err)
}
validRedirURL, err := client.ValidRedirectURL(&redirURL, metadata.RedirectURIs)
if err != nil {
return schema.ResendEmailInvitationResponse{}, ErrorInvalidRedirectURL
}
// Retrieve user to check if it's already created
userUser, err := u.manager.Get(userID)
if err != nil {
return schema.ResendEmailInvitationResponse{}, mapError(err)
}
// Check if email is verified
if userUser.EmailVerified {
return schema.ResendEmailInvitationResponse{}, ErrorVerifiedEmail
}
url, err := u.emailer.SendInviteEmail(userUser.Email, validRedirURL, creds.ClientID)
// An email is sent only if we don't get a link and there's no error.
emailSent := err == nil && url == nil
// If email is not sent a reset link will be generated
var resetLink string
if url != nil {
resetLink = url.String()
}
return schema.ResendEmailInvitationResponse{
EmailSent: emailSent,
ResetPasswordLink: resetLink,
}, nil
}
开发者ID:ryanj,项目名称:dex,代码行数:43,代码来源:api.go
示例19: NewClient
func NewClient(clientID, clientSecret, discovery, redirectURL string, tlsConfig *tls.Config) (*Client, *ClientCredsTokenManager) {
cc := oidc.ClientCredentials{
ID: clientID,
Secret: clientSecret,
}
httpClient := &http.Client{Transport: &http.Transport{TLSClientConfig: tlsConfig}}
var cfg oidc.ProviderConfig
var err error
for {
cfg, err = oidc.FetchProviderConfig(httpClient, discovery)
if err == nil {
break
}
sleep := 3 * time.Second
log.Errorf("Failed fetching provider config, trying again in %v: %v", sleep, err)
time.Sleep(sleep)
}
log.Infof("Fetched provider config from %s", discovery)
ccfg := oidc.ClientConfig{
HTTPClient: httpClient,
ProviderConfig: cfg,
Credentials: cc,
RedirectURL: redirectURL,
}
client, err := NewOIDCClient(ccfg)
if err != nil {
log.Fatalf("Unable to create Client: %v", err)
}
client.SyncProviderConfig(discovery)
tm := NewClientCredsTokenManager(client, discovery)
tm.Run()
tm.WaitUntilInitialSync()
return client, tm
}
开发者ID:otsimo,项目名称:accounts,代码行数:43,代码来源:oidc.go
示例20: purge
func (r *SessionKeyRepo) purge() error {
qt := r.quote(sessionKeyTableName)
q := fmt.Sprintf("DELETE FROM %s WHERE stale = $1 OR expires_at < $2", qt)
res, err := r.executor(nil).Exec(q, true, r.clock.Now().Unix())
if err != nil {
return err
}
d := "unknown # of"
if n, err := res.RowsAffected(); err == nil {
if n == 0 {
return nil
}
d = fmt.Sprintf("%d", n)
}
log.Infof("Deleted %s stale row(s) from %s table", d, sessionKeyTableName)
return nil
}
开发者ID:Tecsisa,项目名称:dex,代码行数:19,代码来源:session_key.go
注:本文中的github.com/coreos/dex/pkg/log.Infof函数示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论