mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-06-15 23:29:23 +08:00
errcode
This commit is contained in:
parent
5e4e960524
commit
945449108d
@ -27,7 +27,7 @@ type GroupController struct {
|
|||||||
database DataBase
|
database DataBase
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewGroupController(db *gorm.DB, rdb redis.UniversalClient, mgoDB *mongo.Database) GroupInterface {
|
func NewGroupController(db *gorm.DB, rdb redis.UniversalClient, mgoDB *mongo.Client) GroupInterface {
|
||||||
groupController := &GroupController{database: newGroupDatabase(db, rdb, mgoDB)}
|
groupController := &GroupController{database: newGroupDatabase(db, rdb, mgoDB)}
|
||||||
return groupController
|
return groupController
|
||||||
}
|
}
|
||||||
@ -69,19 +69,22 @@ type GroupDataBase struct {
|
|||||||
groupDB *relation.Group
|
groupDB *relation.Group
|
||||||
groupMemberDB *relation.GroupMember
|
groupMemberDB *relation.GroupMember
|
||||||
groupRequestDB *relation.GroupRequest
|
groupRequestDB *relation.GroupRequest
|
||||||
|
db *gorm.DB
|
||||||
|
|
||||||
cache *cache.GroupCache
|
cache *cache.GroupCache
|
||||||
mongoDB *unrelation.SuperGroupMgoDB
|
mongoDB *unrelation.SuperGroupMgoDB
|
||||||
}
|
}
|
||||||
|
|
||||||
func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoDB *mongo.Database) DataBase {
|
func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoDB *mongo.Client) DataBase {
|
||||||
groupDB := relation.NewGroupDB(db)
|
groupDB := relation.NewGroupDB(db)
|
||||||
groupMemberDB := relation.NewGroupMemberDB(db)
|
groupMemberDB := relation.NewGroupMemberDB(db)
|
||||||
groupRequestDB := relation.NewGroupRequest(db)
|
groupRequestDB := relation.NewGroupRequest(db)
|
||||||
|
newDB := db
|
||||||
database := &GroupDataBase{
|
database := &GroupDataBase{
|
||||||
groupDB: groupDB,
|
groupDB: groupDB,
|
||||||
groupMemberDB: groupMemberDB,
|
groupMemberDB: groupMemberDB,
|
||||||
groupRequestDB: groupRequestDB,
|
groupRequestDB: groupRequestDB,
|
||||||
|
db: newDB,
|
||||||
cache: cache.NewGroupCache(rdb, groupDB, groupMemberDB, groupRequestDB, rockscache.Options{
|
cache: cache.NewGroupCache(rdb, groupDB, groupMemberDB, groupRequestDB, rockscache.Options{
|
||||||
RandomExpireAdjustment: 0.2,
|
RandomExpireAdjustment: 0.2,
|
||||||
DisableCacheRead: false,
|
DisableCacheRead: false,
|
||||||
@ -118,7 +121,7 @@ func (g *GroupDataBase) TakeGroupByID(ctx context.Context, groupID string) (grou
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (g *GroupDataBase) Update(ctx context.Context, groups []*relation.Group) error {
|
func (g *GroupDataBase) Update(ctx context.Context, groups []*relation.Group) error {
|
||||||
return g.groupDB.DB.Transaction(func(tx *gorm.DB) error {
|
return g.db.Transaction(func(tx *gorm.DB) error {
|
||||||
if err := g.groupDB.Update(ctx, groups, tx); err != nil {
|
if err := g.groupDB.Update(ctx, groups, tx); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -134,7 +137,22 @@ func (g *GroupDataBase) Update(ctx context.Context, groups []*relation.Group) er
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (g *GroupDataBase) CreateSuperGroup(ctx context.Context, groupID string, initMemberIDList []string, memberNumCount int) error {
|
func (g *GroupDataBase) CreateSuperGroup(ctx context.Context, groupID string, initMemberIDList []string, memberNumCount int) error {
|
||||||
return g.mongoDB.CreateSuperGroup(ctx, groupID, initMemberIDList, memberNumCount, g.cache.DelJoinedSuperGroupIDs)
|
sess, err := g.mongoDB.MgoClient.StartSession()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer sess.EndSession(ctx)
|
||||||
|
sCtx := mongo.NewSessionContext(ctx, sess)
|
||||||
|
if err = g.mongoDB.CreateSuperGroup(sCtx, groupID, initMemberIDList, memberNumCount); err != nil {
|
||||||
|
_ = sess.AbortTransaction(ctx)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err = g.cache.DelJoinedSuperGroupIDs(ctx, initMemberIDList); err != nil {
|
||||||
|
_ = sess.AbortTransaction(ctx)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return sess.CommitTransaction(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *GroupDataBase) GetSuperGroupByID(ctx context.Context, groupID string) (superGroup *unrelation.SuperGroup, err error) {
|
func (g *GroupDataBase) GetSuperGroupByID(ctx context.Context, groupID string) (superGroup *unrelation.SuperGroup, err error) {
|
||||||
|
@ -14,7 +14,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Mongo struct {
|
type Mongo struct {
|
||||||
DB *mongo.Database
|
DB *mongo.Client
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) InitMongo() {
|
func (m *Mongo) InitMongo() {
|
||||||
@ -54,7 +54,7 @@ func (m *Mongo) InitMongo() {
|
|||||||
panic(err.Error() + " mongo.Connect failed " + uri)
|
panic(err.Error() + " mongo.Connect failed " + uri)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
m.DB = mongoClient.Database(config.Config.Mongo.DBDatabase)
|
m.DB = mongoClient
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) CreateTagIndex() {
|
func (m *Mongo) CreateTagIndex() {
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package unrelation
|
package unrelation
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"Open_IM/pkg/common/config"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
"context"
|
"context"
|
||||||
"go.mongodb.org/mongo-driver/bson"
|
"go.mongodb.org/mongo-driver/bson"
|
||||||
@ -15,7 +16,8 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type SuperGroupMgoDB struct {
|
type SuperGroupMgoDB struct {
|
||||||
mgoDB *mongo.Database
|
MgoClient *mongo.Client
|
||||||
|
MgoDB *mongo.Database
|
||||||
superGroupCollection *mongo.Collection
|
superGroupCollection *mongo.Collection
|
||||||
userToSuperGroupCollection *mongo.Collection
|
userToSuperGroupCollection *mongo.Collection
|
||||||
}
|
}
|
||||||
@ -30,47 +32,32 @@ type UserToSuperGroup struct {
|
|||||||
GroupIDList []string `bson:"group_id_list" json:"groupIDList"`
|
GroupIDList []string `bson:"group_id_list" json:"groupIDList"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewSuperGroupMgoDB(mgoDB *mongo.Database) *SuperGroupMgoDB {
|
func NewSuperGroupMgoDB(mgoClient *mongo.Client) *SuperGroupMgoDB {
|
||||||
return &SuperGroupMgoDB{mgoDB: mgoDB, superGroupCollection: mgoDB.Collection(cSuperGroup), userToSuperGroupCollection: mgoDB.Collection(cUserToSuperGroup)}
|
mgoDB := mgoClient.Database(config.Config.Mongo.DBDatabase)
|
||||||
|
return &SuperGroupMgoDB{MgoDB: mgoDB, MgoClient: mgoClient, superGroupCollection: mgoDB.Collection(cSuperGroup), userToSuperGroupCollection: mgoDB.Collection(cUserToSuperGroup)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) CreateSuperGroup(ctx context.Context, groupID string, initMemberIDList []string, memberNumCount int, cacheFunc func(ctx context.Context, userIDs []string) error) error {
|
func (db *SuperGroupMgoDB) CreateSuperGroup(sCtx mongo.SessionContext, groupID string, initMemberIDList []string, memberNumCount int) error {
|
||||||
//ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
superGroup := SuperGroup{
|
||||||
//c := db.mgoDB.Database(config.Config.Mongo.DBDatabase).Collection(cSuperGroup)
|
GroupID: groupID,
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
MemberIDList: initMemberIDList,
|
||||||
return db.mgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
}
|
||||||
err := sCtx.StartTransaction()
|
_, err := db.superGroupCollection.InsertOne(sCtx, superGroup)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
upsert := true
|
||||||
|
opts := &options.UpdateOptions{
|
||||||
|
Upsert: &upsert,
|
||||||
|
}
|
||||||
|
for _, userID := range initMemberIDList {
|
||||||
|
_, err = db.userToSuperGroupCollection.UpdateOne(sCtx, bson.M{"user_id": userID}, bson.M{"$addToSet": bson.M{"group_id_list": groupID}}, opts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
superGroup := SuperGroup{
|
}
|
||||||
GroupID: groupID,
|
return nil
|
||||||
MemberIDList: initMemberIDList,
|
|
||||||
}
|
|
||||||
_, err = db.superGroupCollection.InsertOne(sCtx, superGroup)
|
|
||||||
if err != nil {
|
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
upsert := true
|
|
||||||
opts := &options.UpdateOptions{
|
|
||||||
Upsert: &upsert,
|
|
||||||
}
|
|
||||||
for _, userID := range initMemberIDList {
|
|
||||||
_, err = db.userToSuperGroupCollection.UpdateOne(sCtx, bson.M{"user_id": userID}, bson.M{"$addToSet": bson.M{"group_id_list": groupID}}, opts)
|
|
||||||
if err != nil {
|
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if cacheFunc != nil {
|
|
||||||
if err = cacheFunc(ctx, initMemberIDList); err != nil {
|
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return sCtx.CommitTransaction(ctx)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) GetSuperGroup(ctx context.Context, groupID string) (*SuperGroup, error) {
|
func (db *SuperGroupMgoDB) GetSuperGroup(ctx context.Context, groupID string) (*SuperGroup, error) {
|
||||||
@ -81,7 +68,7 @@ func (db *SuperGroupMgoDB) GetSuperGroup(ctx context.Context, groupID string) (*
|
|||||||
|
|
||||||
func (db *SuperGroupMgoDB) AddUserToSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
func (db *SuperGroupMgoDB) AddUserToSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.mgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$addToSet": bson.M{"member_id_list": bson.M{"$each": userIDList}}})
|
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$addToSet": bson.M{"member_id_list": bson.M{"$each": userIDList}}})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
_ = sCtx.AbortTransaction(ctx)
|
||||||
@ -104,7 +91,7 @@ func (db *SuperGroupMgoDB) AddUserToSuperGroup(ctx context.Context, groupID stri
|
|||||||
|
|
||||||
func (db *SuperGroupMgoDB) RemoverUserFromSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
func (db *SuperGroupMgoDB) RemoverUserFromSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.mgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$pull": bson.M{"member_id_list": bson.M{"$in": userIDList}}})
|
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$pull": bson.M{"member_id_list": bson.M{"$in": userIDList}}})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
_ = sCtx.AbortTransaction(ctx)
|
||||||
@ -127,7 +114,7 @@ func (db *SuperGroupMgoDB) GetSuperGroupByUserID(ctx context.Context, userID str
|
|||||||
|
|
||||||
func (db *SuperGroupMgoDB) DeleteSuperGroup(ctx context.Context, groupID string) error {
|
func (db *SuperGroupMgoDB) DeleteSuperGroup(ctx context.Context, groupID string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.mgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
superGroup := &SuperGroup{}
|
superGroup := &SuperGroup{}
|
||||||
_, err := db.superGroupCollection.DeleteOne(sCtx, bson.M{"group_id": groupID})
|
_, err := db.superGroupCollection.DeleteOne(sCtx, bson.M{"group_id": groupID})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user