2023-04-13 11:17:17 +08:00
|
|
|
package migrations
|
|
|
|
|
|
|
|
import (
|
2023-07-13 16:16:13 +08:00
|
|
|
"context"
|
2023-04-13 18:20:26 +08:00
|
|
|
"fmt"
|
2023-04-13 15:46:36 +08:00
|
|
|
"time"
|
|
|
|
|
2023-04-13 11:17:17 +08:00
|
|
|
"github.com/answerdev/answer/internal/entity"
|
|
|
|
"github.com/answerdev/answer/internal/service/permission"
|
2023-04-13 18:20:26 +08:00
|
|
|
"github.com/segmentfault/pacman/log"
|
2023-04-13 11:17:17 +08:00
|
|
|
"xorm.io/xorm"
|
|
|
|
)
|
|
|
|
|
2023-07-13 16:16:13 +08:00
|
|
|
func addRolePinAndHideFeatures(ctx context.Context, x *xorm.Engine) error {
|
2023-04-13 11:17:17 +08:00
|
|
|
powers := []*entity.Power{
|
2023-04-13 18:20:26 +08:00
|
|
|
{ID: 34, Name: "question pin", PowerType: permission.QuestionPin, Description: "top the question"},
|
|
|
|
{ID: 35, Name: "question hide", PowerType: permission.QuestionHide, Description: "hide the question"},
|
|
|
|
{ID: 36, Name: "question unpin", PowerType: permission.QuestionUnPin, Description: "untop the question"},
|
|
|
|
{ID: 37, Name: "question show", PowerType: permission.QuestionShow, Description: "show the question"},
|
2023-04-13 11:17:17 +08:00
|
|
|
}
|
|
|
|
// insert default powers
|
|
|
|
for _, power := range powers {
|
2023-07-13 16:16:13 +08:00
|
|
|
exist, err := x.Context(ctx).Get(&entity.Power{ID: power.ID})
|
2023-04-13 11:17:17 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if exist {
|
2023-07-13 16:16:13 +08:00
|
|
|
_, err = x.Context(ctx).ID(power.ID).Update(power)
|
2023-04-13 11:17:17 +08:00
|
|
|
} else {
|
2023-07-13 16:16:13 +08:00
|
|
|
_, err = x.Context(ctx).Insert(power)
|
2023-04-13 11:17:17 +08:00
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rolePowerRels := []*entity.RolePowerRel{
|
|
|
|
|
|
|
|
{RoleID: 2, PowerType: permission.QuestionPin},
|
|
|
|
{RoleID: 2, PowerType: permission.QuestionHide},
|
2023-04-13 18:20:26 +08:00
|
|
|
{RoleID: 2, PowerType: permission.QuestionUnPin},
|
|
|
|
{RoleID: 2, PowerType: permission.QuestionShow},
|
2023-04-13 11:17:17 +08:00
|
|
|
|
|
|
|
{RoleID: 3, PowerType: permission.QuestionPin},
|
|
|
|
{RoleID: 3, PowerType: permission.QuestionHide},
|
2023-04-13 18:20:26 +08:00
|
|
|
{RoleID: 3, PowerType: permission.QuestionUnPin},
|
|
|
|
{RoleID: 3, PowerType: permission.QuestionShow},
|
2023-04-13 11:17:17 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// insert default powers
|
|
|
|
for _, rel := range rolePowerRels {
|
2023-07-13 16:16:13 +08:00
|
|
|
exist, err := x.Context(ctx).Get(&entity.RolePowerRel{RoleID: rel.RoleID, PowerType: rel.PowerType})
|
2023-04-13 11:17:17 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if exist {
|
|
|
|
continue
|
|
|
|
}
|
2023-07-13 16:16:13 +08:00
|
|
|
_, err = x.Context(ctx).Insert(rel)
|
2023-04-13 11:17:17 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
2023-04-13 18:20:26 +08:00
|
|
|
|
|
|
|
defaultConfigTable := []*entity.Config{
|
2023-04-25 15:49:54 +08:00
|
|
|
{ID: 119, Key: "question.pin", Value: `0`},
|
|
|
|
{ID: 120, Key: "question.unpin", Value: `0`},
|
|
|
|
{ID: 121, Key: "question.show", Value: `0`},
|
|
|
|
{ID: 122, Key: "question.hide", Value: `0`},
|
|
|
|
{ID: 123, Key: "rank.question.pin", Value: `-1`},
|
|
|
|
{ID: 124, Key: "rank.question.unpin", Value: `-1`},
|
|
|
|
{ID: 125, Key: "rank.question.show", Value: `-1`},
|
|
|
|
{ID: 126, Key: "rank.question.hide", Value: `-1`},
|
2023-04-13 18:20:26 +08:00
|
|
|
}
|
|
|
|
for _, c := range defaultConfigTable {
|
2023-07-13 16:16:13 +08:00
|
|
|
exist, err := x.Context(ctx).Get(&entity.Config{ID: c.ID})
|
2023-04-13 18:20:26 +08:00
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("get config failed: %w", err)
|
|
|
|
}
|
|
|
|
if exist {
|
2023-07-13 16:16:13 +08:00
|
|
|
if _, err = x.Context(ctx).Update(c, &entity.Config{ID: c.ID}); err != nil {
|
2023-04-13 18:20:26 +08:00
|
|
|
log.Errorf("update %+v config failed: %s", c, err)
|
|
|
|
return fmt.Errorf("update config failed: %w", err)
|
|
|
|
}
|
|
|
|
continue
|
|
|
|
}
|
2023-07-13 16:16:13 +08:00
|
|
|
if _, err = x.Context(ctx).Insert(&entity.Config{ID: c.ID, Key: c.Key, Value: c.Value}); err != nil {
|
2023-04-13 18:20:26 +08:00
|
|
|
log.Errorf("insert %+v config failed: %s", c, err)
|
|
|
|
return fmt.Errorf("add config failed: %w", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-13 15:46:36 +08:00
|
|
|
type Question struct {
|
|
|
|
ID string `xorm:"not null pk BIGINT(20) id"`
|
|
|
|
CreatedAt time.Time `xorm:"not null default CURRENT_TIMESTAMP TIMESTAMP created_at"`
|
|
|
|
UpdatedAt time.Time `xorm:"updated_at TIMESTAMP"`
|
|
|
|
UserID string `xorm:"not null default 0 BIGINT(20) INDEX user_id"`
|
|
|
|
LastEditUserID string `xorm:"not null default 0 BIGINT(20) last_edit_user_id"`
|
|
|
|
Title string `xorm:"not null default '' VARCHAR(150) title"`
|
|
|
|
OriginalText string `xorm:"not null MEDIUMTEXT original_text"`
|
|
|
|
ParsedText string `xorm:"not null MEDIUMTEXT parsed_text"`
|
|
|
|
Status int `xorm:"not null default 1 INT(11) status"`
|
|
|
|
Pin int `xorm:"not null default 1 INT(11) pin"`
|
|
|
|
Show int `xorm:"not null default 1 INT(11) show"`
|
|
|
|
ViewCount int `xorm:"not null default 0 INT(11) view_count"`
|
|
|
|
UniqueViewCount int `xorm:"not null default 0 INT(11) unique_view_count"`
|
|
|
|
VoteCount int `xorm:"not null default 0 INT(11) vote_count"`
|
|
|
|
AnswerCount int `xorm:"not null default 0 INT(11) answer_count"`
|
|
|
|
CollectionCount int `xorm:"not null default 0 INT(11) collection_count"`
|
|
|
|
FollowCount int `xorm:"not null default 0 INT(11) follow_count"`
|
|
|
|
AcceptedAnswerID string `xorm:"not null default 0 BIGINT(20) accepted_answer_id"`
|
|
|
|
LastAnswerID string `xorm:"not null default 0 BIGINT(20) last_answer_id"`
|
|
|
|
PostUpdateTime time.Time `xorm:"post_update_time TIMESTAMP"`
|
|
|
|
RevisionID string `xorm:"not null default 0 BIGINT(20) revision_id"`
|
|
|
|
}
|
2023-07-13 16:16:13 +08:00
|
|
|
err := x.Context(ctx).Sync(new(Question))
|
2023-04-13 15:46:36 +08:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-04-13 11:17:17 +08:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|