Miguel de la Cruz 08c0b7a2fd
Refactor error usage from the store level up and add API helpers (#3792)
* Refactor error usage from the store level up and add API helpers

* Complete API tests

* Fix merge errorResponse calls

* Remove ensure helpers to allow for custom messages on permission errors

* Fix bad import and call

* Remove bad user check on auth that was added as part of the main merge

* Fix empty list test

* Replace deprecated proxy calls to ioutil.ReadAll with io.ReadAll

* Add information to the NotFound errors

* Add context to all remaining errors and address review comments

* Fix linter

* Adapt the new card API endpoints to the error refactor

* Remove almost all customErrorResponse calls

* Add request entity too large to errorResponse and remove customErrorResponse

* Fix linter
2022-09-13 12:18:40 +02:00

206 lines
4.1 KiB
Go

package sqlstore
import (
"database/sql"
"encoding/json"
"github.com/mattermost/focalboard/server/model"
"github.com/mattermost/focalboard/server/utils"
"github.com/mattermost/mattermost-server/v6/shared/mlog"
sq "github.com/Masterminds/squirrel"
)
var (
teamFields = []string{
"id",
"signup_token",
"COALESCE(settings, '{}')",
"modified_by",
"update_at",
}
)
func (s *SQLStore) upsertTeamSignupToken(db sq.BaseRunner, team model.Team) error {
now := utils.GetMillis()
query := s.getQueryBuilder(db).
Insert(s.tablePrefix+"teams").
Columns(
"id",
"signup_token",
"modified_by",
"update_at",
).
Values(
team.ID,
team.SignupToken,
team.ModifiedBy,
now,
)
if s.dbType == model.MysqlDBType {
query = query.Suffix("ON DUPLICATE KEY UPDATE signup_token = ?, modified_by = ?, update_at = ?",
team.SignupToken, team.ModifiedBy, now)
} else {
query = query.Suffix(
`ON CONFLICT (id)
DO UPDATE SET signup_token = EXCLUDED.signup_token, modified_by = EXCLUDED.modified_by, update_at = EXCLUDED.update_at`,
)
}
_, err := query.Exec()
return err
}
func (s *SQLStore) upsertTeamSettings(db sq.BaseRunner, team model.Team) error {
now := utils.GetMillis()
signupToken := utils.NewID(utils.IDTypeToken)
settingsJSON, err := json.Marshal(team.Settings)
if err != nil {
return err
}
query := s.getQueryBuilder(db).
Insert(s.tablePrefix+"teams").
Columns(
"id",
"signup_token",
"settings",
"modified_by",
"update_at",
).
Values(
team.ID,
signupToken,
settingsJSON,
team.ModifiedBy,
now,
)
if s.dbType == model.MysqlDBType {
query = query.Suffix("ON DUPLICATE KEY UPDATE settings = ?, modified_by = ?, update_at = ?", settingsJSON, team.ModifiedBy, now)
} else {
query = query.Suffix(
`ON CONFLICT (id)
DO UPDATE SET settings = EXCLUDED.settings, modified_by = EXCLUDED.modified_by, update_at = EXCLUDED.update_at`,
)
}
_, err = query.Exec()
return err
}
func (s *SQLStore) getTeam(db sq.BaseRunner, id string) (*model.Team, error) {
var settingsJSON string
query := s.getQueryBuilder(db).
Select(
"id",
"signup_token",
"COALESCE(settings, '{}')",
"modified_by",
"update_at",
).
From(s.tablePrefix + "teams").
Where(sq.Eq{"id": id})
row := query.QueryRow()
team := model.Team{}
err := row.Scan(
&team.ID,
&team.SignupToken,
&settingsJSON,
&team.ModifiedBy,
&team.UpdateAt,
)
if err != nil {
return nil, err
}
err = json.Unmarshal([]byte(settingsJSON), &team.Settings)
if err != nil {
s.logger.Error(`ERROR GetTeam settings json.Unmarshal`, mlog.Err(err))
return nil, err
}
return &team, nil
}
func (s *SQLStore) getTeamsForUser(db sq.BaseRunner, _ string) ([]*model.Team, error) {
return s.getAllTeams(db)
}
func (s *SQLStore) getTeamCount(db sq.BaseRunner) (int64, error) {
query := s.getQueryBuilder(db).
Select(
"COUNT(*) AS count",
).
From(s.tablePrefix + "teams")
rows, err := query.Query()
if err != nil {
s.logger.Error("ERROR GetTeamCount", mlog.Err(err))
return 0, err
}
defer s.CloseRows(rows)
var count int64
rows.Next()
err = rows.Scan(&count)
if err != nil {
s.logger.Error("Failed to fetch team count", mlog.Err(err))
return 0, err
}
return count, nil
}
func (s *SQLStore) teamsFromRows(rows *sql.Rows) ([]*model.Team, error) {
teams := []*model.Team{}
for rows.Next() {
var team model.Team
var settingsBytes []byte
err := rows.Scan(
&team.ID,
&team.SignupToken,
&settingsBytes,
&team.ModifiedBy,
&team.UpdateAt,
)
if err != nil {
return nil, err
}
err = json.Unmarshal(settingsBytes, &team.Settings)
if err != nil {
return nil, err
}
teams = append(teams, &team)
}
return teams, nil
}
func (s *SQLStore) getAllTeams(db sq.BaseRunner) ([]*model.Team, error) {
query := s.getQueryBuilder(db).
Select(teamFields...).
From(s.tablePrefix + "teams")
rows, err := query.Query()
if err != nil {
s.logger.Error("ERROR GetAllTeams", mlog.Err(err))
return nil, err
}
defer s.CloseRows(rows)
teams, err := s.teamsFromRows(rows)
if err != nil {
return nil, err
}
return teams, nil
}