| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| package migrations |
| |
| import ( |
| "context" |
| "fmt" |
| "time" |
| |
| "github.com/apache/answer/internal/entity" |
| "github.com/apache/answer/internal/service/permission" |
| "github.com/segmentfault/pacman/log" |
| "xorm.io/xorm" |
| ) |
| |
| func addRolePinAndHideFeatures(ctx context.Context, x *xorm.Engine) error { |
| powers := []*entity.Power{ |
| {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"}, |
| } |
| // insert default powers |
| for _, power := range powers { |
| exist, err := x.Context(ctx).Get(&entity.Power{ID: power.ID}) |
| if err != nil { |
| return err |
| } |
| if exist { |
| _, err = x.Context(ctx).ID(power.ID).Update(power) |
| } else { |
| _, err = x.Context(ctx).Insert(power) |
| } |
| if err != nil { |
| return err |
| } |
| } |
| |
| rolePowerRels := []*entity.RolePowerRel{ |
| |
| {RoleID: 2, PowerType: permission.QuestionPin}, |
| {RoleID: 2, PowerType: permission.QuestionHide}, |
| {RoleID: 2, PowerType: permission.QuestionUnPin}, |
| {RoleID: 2, PowerType: permission.QuestionShow}, |
| |
| {RoleID: 3, PowerType: permission.QuestionPin}, |
| {RoleID: 3, PowerType: permission.QuestionHide}, |
| {RoleID: 3, PowerType: permission.QuestionUnPin}, |
| {RoleID: 3, PowerType: permission.QuestionShow}, |
| } |
| |
| // insert default powers |
| for _, rel := range rolePowerRels { |
| exist, err := x.Context(ctx).Get(&entity.RolePowerRel{RoleID: rel.RoleID, PowerType: rel.PowerType}) |
| if err != nil { |
| return err |
| } |
| if exist { |
| continue |
| } |
| _, err = x.Context(ctx).Insert(rel) |
| if err != nil { |
| return err |
| } |
| } |
| |
| defaultConfigTable := []*entity.Config{ |
| {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`}, |
| } |
| for _, c := range defaultConfigTable { |
| exist, err := x.Context(ctx).Get(&entity.Config{ID: c.ID}) |
| if err != nil { |
| return fmt.Errorf("get config failed: %w", err) |
| } |
| if exist { |
| if _, err = x.Context(ctx).Update(c, &entity.Config{ID: c.ID}); err != nil { |
| log.Errorf("update %+v config failed: %s", c, err) |
| return fmt.Errorf("update config failed: %w", err) |
| } |
| continue |
| } |
| if _, err = x.Context(ctx).Insert(&entity.Config{ID: c.ID, Key: c.Key, Value: c.Value}); err != nil { |
| log.Errorf("insert %+v config failed: %s", c, err) |
| return fmt.Errorf("add config failed: %w", err) |
| } |
| } |
| |
| 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"` |
| } |
| err := x.Context(ctx).Sync(new(Question)) |
| if err != nil { |
| return err |
| } |
| |
| return nil |
| } |