2022-06-07 22:51:33 +02:00
// Copyright 2022 The Gitea Authors. All rights reserved.
2022-11-27 13:20:29 -05:00
// SPDX-License-Identifier: MIT
2022-06-07 22:51:33 +02:00
package doctor
import (
"context"
"fmt"
"code.gitea.io/gitea/models/db"
"code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/modules/log"
"xorm.io/builder"
)
func iterateUserAccounts ( ctx context . Context , each func ( * user . User ) error ) error {
err := db . Iterate (
ctx ,
builder . Gt { "id" : 0 } ,
2022-10-31 23:51:14 +08:00
func ( ctx context . Context , bean * user . User ) error {
return each ( bean )
2022-06-07 22:51:33 +02:00
} ,
)
return err
}
// Since 1.16.4 new restrictions has been set on email addresses. However users with invalid email
// addresses would be currently facing a error due to their invalid email address.
// Ref: https://github.com/go-gitea/gitea/pull/19085 & https://github.com/go-gitea/gitea/pull/17688
func checkUserEmail ( ctx context . Context , logger log . Logger , _ bool ) error {
// We could use quirky SQL to get all users that start without a [a-zA-Z0-9], but that would mean
Fix various typos (#20338)
* Fix various typos
Found via `codespell -q 3 -S ./options/locale,./options/license,./public/vendor -L actived,allways,attachements,ba,befores,commiter,pullrequest,pullrequests,readby,splitted,te,unknwon`
Co-authored-by: zeripath <art27@cantab.net>
2022-07-12 17:32:37 -04:00
// DB provider-specific SQL and only works _now_. So instead we iterate through all user accounts
// and use the user.ValidateEmail function to be future-proof.
2022-06-07 22:51:33 +02:00
var invalidUserCount int64
if err := iterateUserAccounts ( ctx , func ( u * user . User ) error {
// Only check for users, skip
if u . Type != user . UserTypeIndividual {
return nil
}
if err := user . ValidateEmail ( u . Email ) ; err != nil {
invalidUserCount ++
logger . Warn ( "User[id=%d name=%q] have not a valid e-mail: %v" , u . ID , u . Name , err )
}
return nil
} ) ; err != nil {
2022-10-24 21:29:17 +02:00
return fmt . Errorf ( "iterateUserAccounts: %w" , err )
2022-06-07 22:51:33 +02:00
}
if invalidUserCount == 0 {
logger . Info ( "All users have a valid e-mail." )
} else {
logger . Warn ( "%d user(s) have a non-valid e-mail." , invalidUserCount )
}
return nil
}
2022-06-28 01:45:50 +02:00
// From time to time Gitea makes changes to the reserved usernames and which symbols
// are allowed for various reasons. This check helps with detecting users that, according
// to our reserved names, don't have a valid username.
func checkUserName ( ctx context . Context , logger log . Logger , _ bool ) error {
var invalidUserCount int64
if err := iterateUserAccounts ( ctx , func ( u * user . User ) error {
if err := user . IsUsableUsername ( u . Name ) ; err != nil {
invalidUserCount ++
logger . Warn ( "User[id=%d] does not have a valid username: %v" , u . ID , err )
}
return nil
} ) ; err != nil {
2022-10-24 21:29:17 +02:00
return fmt . Errorf ( "iterateUserAccounts: %w" , err )
2022-06-28 01:45:50 +02:00
}
if invalidUserCount == 0 {
logger . Info ( "All users have a valid username." )
} else {
logger . Warn ( "%d user(s) have a non-valid username." , invalidUserCount )
}
return nil
}
2022-06-07 22:51:33 +02:00
func init ( ) {
Register ( & Check {
Title : "Check if users has an valid email address" ,
Name : "check-user-email" ,
IsDefault : false ,
Run : checkUserEmail ,
Priority : 9 ,
} )
2022-06-28 01:45:50 +02:00
Register ( & Check {
Title : "Check if users have a valid username" ,
Name : "check-user-names" ,
IsDefault : false ,
Run : checkUserName ,
Priority : 9 ,
} )
2022-06-07 22:51:33 +02:00
}