正在显示
6 个修改的文件
包含
159 行增加
和
8 行删除
| @@ -208,3 +208,11 @@ func CreateLogSmsRepository(options map[string]interface{}) domain.LogSmsReposit | @@ -208,3 +208,11 @@ func CreateLogSmsRepository(options map[string]interface{}) domain.LogSmsReposit | ||
| 208 | } | 208 | } |
| 209 | return repository.NewLogSmsRepository(transactionContext) | 209 | return repository.NewLogSmsRepository(transactionContext) |
| 210 | } | 210 | } |
| 211 | + | ||
| 212 | +func CreateMessagePersonalRepository(options map[string]interface{}) domain.MessagePersonalRepository { | ||
| 213 | + var transactionContext *pg.TransactionContext | ||
| 214 | + if value, ok := options["transactionContext"]; ok { | ||
| 215 | + transactionContext = value.(*pg.TransactionContext) | ||
| 216 | + } | ||
| 217 | + return repository.NewMessagePersonalRepository(transactionContext) | ||
| 218 | +} |
| 1 | package notify | 1 | package notify |
| 2 | 2 | ||
| 3 | import ( | 3 | import ( |
| 4 | + "encoding/json" | ||
| 5 | + "fmt" | ||
| 6 | + "strconv" | ||
| 4 | "time" | 7 | "time" |
| 5 | 8 | ||
| 6 | "github.com/linmadan/egglib-go/core/application" | 9 | "github.com/linmadan/egglib-go/core/application" |
| @@ -20,7 +23,7 @@ func NewMessagePersonalService() *MessagePersonalService { | @@ -20,7 +23,7 @@ func NewMessagePersonalService() *MessagePersonalService { | ||
| 20 | } | 23 | } |
| 21 | 24 | ||
| 22 | // 获取今天的周期综合自评消息提示 | 25 | // 获取今天的周期综合自评消息提示 |
| 23 | -func (srv *MessagePersonalService) TodayMessageSummaryEvaluationSelf(param *command.GetUserMessageCommand) (interface{}, error) { | 26 | +func (srv *MessagePersonalService) TodayMessageSummaryEvaluationSelf(param *command.GetUserMessageCommand) (map[string]interface{}, error) { |
| 24 | transactionContext, err := factory.CreateTransactionContext(nil) | 27 | transactionContext, err := factory.CreateTransactionContext(nil) |
| 25 | if err != nil { | 28 | if err != nil { |
| 26 | return nil, application.ThrowError(application.TRANSACTION_ERROR, err.Error()) | 29 | return nil, application.ThrowError(application.TRANSACTION_ERROR, err.Error()) |
| @@ -41,11 +44,61 @@ func (srv *MessagePersonalService) TodayMessageSummaryEvaluationSelf(param *comm | @@ -41,11 +44,61 @@ func (srv *MessagePersonalService) TodayMessageSummaryEvaluationSelf(param *comm | ||
| 41 | "types": domain.EvaluationSelf, | 44 | "types": domain.EvaluationSelf, |
| 42 | "beginTime": nowTime, | 45 | "beginTime": nowTime, |
| 43 | "endTime": nowTime, | 46 | "endTime": nowTime, |
| 44 | - "limit": 20, | ||
| 45 | }) | 47 | }) |
| 46 | - _ = evaluationList | 48 | + if err != nil { |
| 49 | + return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "周期综合自评"+err.Error()) | ||
| 50 | + } | ||
| 51 | + resp := map[string]interface{}{ | ||
| 52 | + "needNotify": false, | ||
| 53 | + "content": "", | ||
| 54 | + } | ||
| 55 | + if len(evaluationList) == 0 { | ||
| 56 | + return resp, nil | ||
| 57 | + } | ||
| 58 | + | ||
| 59 | + messageRepo := factory.CreateMessagePersonalRepository(map[string]interface{}{ | ||
| 60 | + "transactionContext": transactionContext, | ||
| 61 | + }) | ||
| 62 | + newMessageList := []domain.MessagePersonal{} | ||
| 63 | + for _, val := range evaluationList { | ||
| 64 | + payload := map[string]string{ | ||
| 65 | + "id": strconv.Itoa(val.Id), | ||
| 66 | + } | ||
| 67 | + payloadStr, _ := json.Marshal(payload) | ||
| 68 | + cnt, _, err := messageRepo.Find(map[string]interface{}{ | ||
| 69 | + "types": domain.MessageTypesOther, | ||
| 70 | + "targetUserId": param.UserId, | ||
| 71 | + "playload": string(payloadStr), | ||
| 72 | + "limit": 1, | ||
| 73 | + }) | ||
| 74 | + if err != nil { | ||
| 75 | + return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "检查自评消息记录"+err.Error()) | ||
| 76 | + } | ||
| 77 | + if cnt == 0 { | ||
| 78 | + newMessageList = append(newMessageList, domain.MessagePersonal{ | ||
| 79 | + Id: 0, | ||
| 80 | + Types: domain.MessageTypesOther, | ||
| 81 | + TargetUserId: val.TargetUser.UserId, | ||
| 82 | + ReadFlag: domain.MessageIsRead, | ||
| 83 | + Title: fmt.Sprintf("%s综合自评已开启,请前往进行评估", val.CycleName), | ||
| 84 | + Content: fmt.Sprintf("%s综合自评已开启,请前往进行评估", val.CycleName), | ||
| 85 | + CreatedAt: time.Time{}, | ||
| 86 | + UpdatedAt: time.Time{}, | ||
| 87 | + Payload: string(payloadStr), | ||
| 88 | + }) | ||
| 89 | + resp["needNotify"] = true | ||
| 90 | + resp["content"] = fmt.Sprintf("%s综合自评已开启,请前往进行评估", val.CycleName) | ||
| 91 | + break | ||
| 92 | + } | ||
| 93 | + } | ||
| 94 | + for i := range newMessageList { | ||
| 95 | + err = messageRepo.Save(&newMessageList[i]) | ||
| 96 | + if err != nil { | ||
| 97 | + return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, "保存自评消息记录"+err.Error()) | ||
| 98 | + } | ||
| 99 | + } | ||
| 47 | if err := transactionContext.CommitTransaction(); err != nil { | 100 | if err := transactionContext.CommitTransaction(); err != nil { |
| 48 | return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, err.Error()) | 101 | return nil, application.ThrowError(application.INTERNAL_SERVER_ERROR, err.Error()) |
| 49 | } | 102 | } |
| 50 | - return nil, nil | 103 | + return resp, nil |
| 51 | } | 104 | } |
| @@ -5,7 +5,7 @@ import "time" | @@ -5,7 +5,7 @@ import "time" | ||
| 5 | // MessagePersonal 个人的消息提示 | 5 | // MessagePersonal 个人的消息提示 |
| 6 | type MessagePersonal struct { | 6 | type MessagePersonal struct { |
| 7 | Id int `json:"id"` // | 7 | Id int `json:"id"` // |
| 8 | - Types string `json:"types"` //消息类型 | 8 | + Types MessageTypes `json:"types"` //消息类型 |
| 9 | TargetUserId int `json:"targetUserId"` //消息指向的用户 | 9 | TargetUserId int `json:"targetUserId"` //消息指向的用户 |
| 10 | ReadFlag MessageReadFlag `json:"readFlag"` //1:已读、2:未读 | 10 | ReadFlag MessageReadFlag `json:"readFlag"` //1:已读、2:未读 |
| 11 | Title string `json:"title"` //消息的标题 | 11 | Title string `json:"title"` //消息的标题 |
| @@ -27,3 +27,8 @@ const ( | @@ -27,3 +27,8 @@ const ( | ||
| 27 | MessageIsRead MessageReadFlag = "read" | 27 | MessageIsRead MessageReadFlag = "read" |
| 28 | MessageUnread MessageReadFlag = "unread" | 28 | MessageUnread MessageReadFlag = "unread" |
| 29 | ) | 29 | ) |
| 30 | + | ||
| 31 | +type MessagePersonalRepository interface { | ||
| 32 | + Save(param *MessagePersonal) error | ||
| 33 | + Find(queryOptions map[string]interface{}) (int, []*MessagePersonal, error) | ||
| 34 | +} |
| @@ -9,8 +9,8 @@ import ( | @@ -9,8 +9,8 @@ import ( | ||
| 9 | func TestGenerateToken(t *testing.T) { | 9 | func TestGenerateToken(t *testing.T) { |
| 10 | ut := UserAuth{ | 10 | ut := UserAuth{ |
| 11 | CompanyId: 8, | 11 | CompanyId: 8, |
| 12 | - UserId: 3435675157551872, | ||
| 13 | - Phone: "18060823798", | 12 | + UserId: 3422181461696000, |
| 13 | + Phone: "13066667702", | ||
| 14 | PlatformId: 29, | 14 | PlatformId: 29, |
| 15 | AdminType: 1, | 15 | AdminType: 1, |
| 16 | } | 16 | } |
| @@ -13,5 +13,5 @@ type MessagePersonal struct { | @@ -13,5 +13,5 @@ type MessagePersonal struct { | ||
| 13 | Content string `pg:"content"` //消息的内容 | 13 | Content string `pg:"content"` //消息的内容 |
| 14 | CreatedAt time.Time `pg:"created_at"` | 14 | CreatedAt time.Time `pg:"created_at"` |
| 15 | UpdatedAt time.Time `pg:"updated_at"` | 15 | UpdatedAt time.Time `pg:"updated_at"` |
| 16 | - Payload string `pg:"payload"` //消息的额外承载的数据 | 16 | + Payload string `pg:"payload,type:jsonb"` //消息的额外承载的数据 |
| 17 | } | 17 | } |
| 1 | +package repository | ||
| 2 | + | ||
| 3 | +import ( | ||
| 4 | + "time" | ||
| 5 | + | ||
| 6 | + pgTransaction "github.com/linmadan/egglib-go/transaction/pg" | ||
| 7 | + "gitlab.fjmaimaimai.com/allied-creation/performance/pkg/domain" | ||
| 8 | + "gitlab.fjmaimaimai.com/allied-creation/performance/pkg/infrastructure/pg/models" | ||
| 9 | +) | ||
| 10 | + | ||
| 11 | +type MessagePersonalRepository struct { | ||
| 12 | + transactionContext *pgTransaction.TransactionContext | ||
| 13 | +} | ||
| 14 | + | ||
| 15 | +var _ domain.MessagePersonalRepository = (*MessagePersonalRepository)(nil) | ||
| 16 | + | ||
| 17 | +func NewMessagePersonalRepository(tx *pgTransaction.TransactionContext) *MessagePersonalRepository { | ||
| 18 | + return &MessagePersonalRepository{ | ||
| 19 | + transactionContext: tx, | ||
| 20 | + } | ||
| 21 | +} | ||
| 22 | + | ||
| 23 | +func (repo *MessagePersonalRepository) TransformToDomain(param *models.MessagePersonal) *domain.MessagePersonal { | ||
| 24 | + return &domain.MessagePersonal{ | ||
| 25 | + Id: param.Id, | ||
| 26 | + Types: domain.MessageTypes(param.Types), | ||
| 27 | + TargetUserId: param.TargetUserId, | ||
| 28 | + ReadFlag: domain.MessageReadFlag(param.ReadFlag), | ||
| 29 | + Title: param.Title, | ||
| 30 | + Content: param.Content, | ||
| 31 | + Payload: param.Payload, | ||
| 32 | + UpdatedAt: param.UpdatedAt, | ||
| 33 | + CreatedAt: param.CreatedAt, | ||
| 34 | + } | ||
| 35 | +} | ||
| 36 | + | ||
| 37 | +func (repo *MessagePersonalRepository) Save(param *domain.MessagePersonal) error { | ||
| 38 | + message := &models.MessagePersonal{ | ||
| 39 | + Id: param.Id, | ||
| 40 | + Types: string(param.Types), | ||
| 41 | + TargetUserId: param.TargetUserId, | ||
| 42 | + ReadFlag: string(param.ReadFlag), | ||
| 43 | + Title: param.Title, | ||
| 44 | + Content: param.Content, | ||
| 45 | + Payload: param.Payload, | ||
| 46 | + UpdatedAt: time.Now(), | ||
| 47 | + CreatedAt: param.CreatedAt, | ||
| 48 | + } | ||
| 49 | + tx := repo.transactionContext.PgTx | ||
| 50 | + if message.Id == 0 { | ||
| 51 | + message.CreatedAt = time.Now() | ||
| 52 | + _, err := tx.Model(message).Insert() | ||
| 53 | + | ||
| 54 | + return err | ||
| 55 | + } | ||
| 56 | + _, err := tx.Model(message).WherePK().Update() | ||
| 57 | + return err | ||
| 58 | +} | ||
| 59 | + | ||
| 60 | +func (repo *MessagePersonalRepository) Find(param map[string]interface{}) (int, []*domain.MessagePersonal, error) { | ||
| 61 | + tx := repo.transactionContext.PgTx | ||
| 62 | + var m []*models.MessagePersonal | ||
| 63 | + query := tx.Model(&m).Limit(20) | ||
| 64 | + if v, ok := param["targetUserId"]; ok { | ||
| 65 | + query.Where("target_user_id=?", v) | ||
| 66 | + } | ||
| 67 | + if v, ok := param["types"]; ok { | ||
| 68 | + query.Where("types=?", v) | ||
| 69 | + } | ||
| 70 | + if v, ok := param["playload"]; ok { | ||
| 71 | + query.Where("playload @>?", v) | ||
| 72 | + } | ||
| 73 | + query.Order("id desc") | ||
| 74 | + count, err := query.SelectAndCount() | ||
| 75 | + if err != nil { | ||
| 76 | + return 0, nil, err | ||
| 77 | + } | ||
| 78 | + var datas []*domain.MessagePersonal | ||
| 79 | + for _, v := range m { | ||
| 80 | + d := repo.TransformToDomain(v) | ||
| 81 | + datas = append(datas, d) | ||
| 82 | + } | ||
| 83 | + return count, datas, nil | ||
| 84 | + | ||
| 85 | +} |
-
请 注册 或 登录 后发表评论