|
|
@ -45,7 +45,7 @@ func GetGroupInfoByGroupID(groupId string) (*db.Group, error) {
|
|
|
|
return nil, utils.Wrap(err, "")
|
|
|
|
return nil, utils.Wrap(err, "")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var groupInfo db.Group
|
|
|
|
var groupInfo db.Group
|
|
|
|
err = dbConn.Table("groups").Where("group_id=?", groupId).Find(&groupInfo).Error
|
|
|
|
err = dbConn.Table("groups").Where("group_id=?", groupId).Take(&groupInfo).Error
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -86,11 +86,10 @@ func GetGroups(pageNumber, showNumber int) ([]db.Group, error) {
|
|
|
|
return groups, nil
|
|
|
|
return groups, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func OperateGroupStatus(groupId string, groupStatus int32) error {
|
|
|
|
func OperateGroupStatus(groupId string, groupStatus int32) error {
|
|
|
|
group := db.Group{
|
|
|
|
group := db.Group{
|
|
|
|
GroupID: groupId,
|
|
|
|
GroupID: groupId,
|
|
|
|
Status: groupStatus,
|
|
|
|
Status: groupStatus,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if err := SetGroupInfo(group); err != nil {
|
|
|
|
if err := SetGroupInfo(group); err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
@ -98,7 +97,6 @@ func OperateGroupStatus(groupId string, groupStatus int32) error {
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func DeleteGroup(groupId string) error {
|
|
|
|
func DeleteGroup(groupId string) error {
|
|
|
|
dbConn, err := db.DB.MysqlDB.DefaultGormDB()
|
|
|
|
dbConn, err := db.DB.MysqlDB.DefaultGormDB()
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
@ -129,15 +127,14 @@ func OperateGroupRole(userId, groupId string, roleLevel int32) (string, string,
|
|
|
|
updateInfo := db.GroupMember{
|
|
|
|
updateInfo := db.GroupMember{
|
|
|
|
RoleLevel: roleLevel,
|
|
|
|
RoleLevel: roleLevel,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
groupMaster := db.GroupMember{
|
|
|
|
groupMaster := db.GroupMember{}
|
|
|
|
}
|
|
|
|
|
|
|
|
switch roleLevel {
|
|
|
|
switch roleLevel {
|
|
|
|
case constant.GroupOwner:
|
|
|
|
case constant.GroupOwner:
|
|
|
|
err = dbConn.Transaction(func(tx *gorm.DB) error {
|
|
|
|
err = dbConn.Transaction(func(tx *gorm.DB) error {
|
|
|
|
result := dbConn.Table("group_members").Where("group_id = ? and role_level = ?", groupId, constant.GroupOwner).First(&groupMaster).Update(&db.GroupMember{
|
|
|
|
result := dbConn.Table("group_members").Where("group_id = ? and role_level = ?", groupId, constant.GroupOwner).First(&groupMaster).Update(&db.GroupMember{
|
|
|
|
RoleLevel: constant.GroupOrdinaryUsers,
|
|
|
|
RoleLevel: constant.GroupOrdinaryUsers,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
if result.Error != nil {
|
|
|
|
if result.Error != nil {
|
|
|
|
return result.Error
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
@ -145,7 +142,7 @@ func OperateGroupRole(userId, groupId string, roleLevel int32) (string, string,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
result = dbConn.Table("group_members").First(&groupMember).Update(updateInfo)
|
|
|
|
result = dbConn.Table("group_members").First(&groupMember).Update(updateInfo)
|
|
|
|
if result.Error != nil {
|
|
|
|
if result.Error != nil {
|
|
|
|
return result.Error
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
@ -161,7 +158,7 @@ func OperateGroupRole(userId, groupId string, roleLevel int32) (string, string,
|
|
|
|
return result.Error
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
return errors.New(fmt.Sprintf("user %s not exist in group %s or already operate", userId, groupId))
|
|
|
|
return errors.New(fmt.Sprintf("user %s not exist in group %s or already operate", userId, groupId))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if groupMaster.UserID == userId {
|
|
|
|
if groupMaster.UserID == userId {
|
|
|
|
return errors.New(fmt.Sprintf("user %s is master of %s, cant set to ordinary user", userId, groupId))
|
|
|
|
return errors.New(fmt.Sprintf("user %s is master of %s, cant set to ordinary user", userId, groupId))
|
|
|
@ -171,7 +168,7 @@ func OperateGroupRole(userId, groupId string, roleLevel int32) (string, string,
|
|
|
|
return result.Error
|
|
|
|
return result.Error
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
if result.RowsAffected == 0 {
|
|
|
|
return errors.New(fmt.Sprintf("user %s not exist in group %s or already operate", userId, groupId))
|
|
|
|
return errors.New(fmt.Sprintf("user %s not exist in group %s or already operate", userId, groupId))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|