package sql import ( "database/sql" "github.com/Masterminds/squirrel" "github.com/ansible-semaphore/semaphore/db" "golang.org/x/crypto/bcrypt" "time" ) func (d *SqlDb) CreateUserWithoutPassword(user db.User) (newUser db.User, err error) { err = db.ValidateUser(user) if err != nil { return } user.Password = "" user.Created = db.GetParsedTime(time.Now()) err = d.sql.Insert(&user) if err != nil { return } newUser = user return } func (d *SqlDb) CreateUser(user db.UserWithPwd) (newUser db.User, err error) { err = db.ValidateUser(user.User) if err != nil { return } pwdHash, err := bcrypt.GenerateFromPassword([]byte(user.Pwd), 11) if err != nil { return } user.Password = string(pwdHash) user.Created = db.GetParsedTime(time.Now()) err = d.sql.Insert(&user.User) if err != nil { return } newUser = user.User return } func (d *SqlDb) DeleteUser(userID int) error { res, err := d.exec("delete from `user` where id=?", userID) return validateMutationResult(res, err) } func (d *SqlDb) UpdateUser(user db.UserWithPwd) error { var err error if user.Pwd != "" { var pwdHash []byte pwdHash, err = bcrypt.GenerateFromPassword([]byte(user.Pwd), 11) if err != nil { return err } _, err = d.exec( "update `user` set name=?, username=?, email=?, alert=?, admin=?, password=? where id=?", user.Name, user.Username, user.Email, user.Alert, user.Admin, string(pwdHash), user.ID) } else { _, err = d.exec( "update `user` set name=?, username=?, email=?, alert=?, admin=? where id=?", user.Name, user.Username, user.Email, user.Alert, user.Admin, user.ID) } return err } func (d *SqlDb) SetUserPassword(userID int, password string) error { hash, err := bcrypt.GenerateFromPassword([]byte(password), 11) if err != nil { return err } _, err = d.exec( "update `user` set password=? where id=?", string(hash), userID) return err } func (d *SqlDb) CreateProjectUser(projectUser db.ProjectUser) (newProjectUser db.ProjectUser, err error) { _, err = d.exec( "insert into project__user (project_id, user_id, `role`) values (?, ?, ?)", projectUser.ProjectID, projectUser.UserID, projectUser.Role) if err != nil { return } newProjectUser = projectUser return } func (d *SqlDb) GetProjectUser(projectID, userID int) (db.ProjectUser, error) { var user db.ProjectUser err := d.selectOne(&user, "select * from project__user where project_id=? and user_id=?", projectID, userID) if err == sql.ErrNoRows { err = db.ErrNotFound } return user, err } func (d *SqlDb) GetProjectUsers(projectID int, params db.RetrieveQueryParams) (users []db.UserWithProjectRole, err error) { q := squirrel.Select("u.*"). Column("pu.role"). From("project__user as pu"). LeftJoin("`user` as u on pu.user_id=u.id"). Where("pu.project_id=?", projectID) sortDirection := "ASC" if params.SortInverted { sortDirection = "DESC" } switch params.SortBy { case "name", "username", "email": q = q.OrderBy("u." + params.SortBy + " " + sortDirection) case "role": q = q.OrderBy("pu." + params.SortBy + " " + sortDirection) default: q = q.OrderBy("u.name " + sortDirection) } query, args, err := q.ToSql() if err != nil { return } _, err = d.selectAll(&users, query, args...) return } func (d *SqlDb) UpdateProjectUser(projectUser db.ProjectUser) error { _, err := d.exec( "update `project__user` set role=? where user_id=? and project_id = ?", projectUser.Role, projectUser.UserID, projectUser.ProjectID) return err } func (d *SqlDb) DeleteProjectUser(projectID, userID int) error { _, err := d.exec("delete from project__user where user_id=? and project_id=?", userID, projectID) return err } // GetUser retrieves a user from the database by ID func (d *SqlDb) GetUser(userID int) (db.User, error) { var user db.User err := d.selectOne(&user, "select * from `user` where id=?", userID) if err == sql.ErrNoRows { err = db.ErrNotFound } return user, err } func (d *SqlDb) GetUserCount() (count int, err error) { cnt, err := d.sql.SelectInt("select count(*) from `user`") count = int(cnt) return } func (d *SqlDb) GetUsers(params db.RetrieveQueryParams) (users []db.User, err error) { query, args, err := getSqlForTable("user", params) if err != nil { return } _, err = d.selectAll(&users, query, args...) return } func (d *SqlDb) GetUserByLoginOrEmail(login string, email string) (existingUser db.User, err error) { err = d.selectOne( &existingUser, d.PrepareQuery("select * from `user` where email=? or username=?"), email, login) if err == sql.ErrNoRows { err = db.ErrNotFound } return } func (d *SqlDb) GetAllAdmins() (users []db.User, err error) { _, err = d.selectAll(&users, "select * from `user` where `admin` = true") return }