mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-05 05:12:45 +08:00
* fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: implement no gob encoder. * update unitTest content. * Update hub_server.go * feat: GroupApplicationAgreeMemberEnterNotification * fix: encoder replace to json encoder. * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * merge: merge main code into js branch. (#2648) * feat: update group notification when set to null. (#2590) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * feat: update group notification when set to null. * update log standard. * feat: add long time push msg in prometheus (#2584) * feat: add long time push msg in prometheus * fix: log print * fix: go mod * fix: log msg * fix: log init * feat: push msg * feat: go mod ,remove cgo package * feat: remove error log * feat: test dummy push * feat:redis pool config * feat: push to kafka log * feat: supports getting messages based on session ID and seq (#2582) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: implement request batch count limit. (#2591) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * fix: getting messages based on session ID and seq (#2595) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: avoid pulling messages from sessions with a large number of max seq values of 0 (#2602) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * refactor: improve db structure in `storage/controller` (#2604) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * refactor: improve db structure in `storage/controller` * feat: implement offline push using kafka (#2600) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * feat: implement offline push. * feat: implement batch Push spilt * update go mod * feat: implement kafka producer and consumer. * update format, * add PushMQ log. * feat: update Handler logic. * update MQ logic. * update * update * fix: update OfflinePushConsumerHandler. * feat: API supports gzip (#2609) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * Fix err (#2608) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * feat: add rocksTimeout * feat: wrap logs * feat: add logs * feat: listen config * feat: enable listen TIME_WAIT port * feat: add logs * feat: cache batch * chore: enable fullUserCache * feat: push rpc num * feat: push err * feat: with operationID * feat: sleep * feat: change 1s * feat: change log * feat: implement Getbatch in rpcCache. * feat: print getOnline cost * feat: change log * feat: change kafka and push config * feat: del interface * feat: fix err * feat: change config * feat: go mod * feat: change config * feat: change config * feat: add sleep in push * feat: warn logs * feat: logs * feat: logs * feat: change port * feat: start config * feat: remove port reuse * feat: prometheus config * feat: prometheus config * feat: prometheus config * feat: add long time send msg to grafana * feat: init * feat: init * feat: implement offline push. * feat: batch get user online * feat: implement batch Push spilt * update go mod * Revert "feat: change port" This reverts commit 06d5e944 * feat: change port * feat: change config * feat: implement kafka producer and consumer. * update format, * add PushMQ log. * feat: get all online users and init push * feat: lock in online cache * feat: config * fix: init online status * fix: add logs * fix: userIDs * fix: add logs * feat: update Handler logic. * update MQ logic. * update * update * fix: method name * fix: update OfflinePushConsumerHandler. * fix: prommetrics * fix: add logs * fix: ctx * fix: log * fix: config * feat: change port * fix: atomic online cache status --------- Co-authored-by: Monet Lee <monet_lee@163.com> * feature: add GetConversationsHasReadAndMaxSeq interface to the WebSocket API. (#2611) * fix: lru lock (#2613) * fix: lru lock * fix: lru lock * fix: lru lock * fix: nil pointer error on close (#2618) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: create group can push notification (#2617) * fix: blockage caused by listen error (#2620) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: go.mod (#2621) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: improve searchMsg implement. (#2614) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * remove unused script. * feat: improve searchMsg implement. * update mongo config. * Fix lock (#2622) * fix:log * fix: lock * fix: update setGroupInfoEX field name. (#2625) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * fix: update setGroupInfoEX field name. * fix: update setGroupInfoEX field name (#2626) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * fix: update setGroupInfoEX field name. * fix: update setGroupInfoEX field name * feat: msg gateway add log (#2631) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: update setGroupInfoEx func name and field. (#2634) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * fix: update setGroupInfoEx func name and field. * refactor: update groupinfoEx field. * refactor: update database name in mongodb.yml * add groupName Condition * fix: fix setConversations req fill. (#2645) * refactor: refactor workflows contents. * add tool workflows. * update field. * fix: remove chat error. * Fix err. * fix error. * remove cn comment. * update workflows files. * update infra config. * move workflows. * feat: update bot. * fix: solve uncorrect outdated msg get. * update get docIDs logic. * update * update skip logic. * fix * update. * fix: delay deleteObject func. * remove unused content. * update log type. * feat: implement request batch count limit. * update * update * fix: fix setConversations req fill. * fix: GetMsgBySeqs boundary issues (#2647) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: the attribute version is obsolete, remove it (#2644) * refactor: update Userregister request field. (#2650) --------- Co-authored-by: Monet Lee <monet_lee@163.com> Co-authored-by: icey-yu <119291641+icey-yu@users.noreply.github.com> Co-authored-by: chao <48119764+withchao@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com> Co-authored-by: 蔡相跃 <caixiangyue007@gmail.com> * update go mod * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb * fix: cannot modify group member avatars * merge: update code from main to v3.8-js-sdk-only. (#2720) * fix: fix update groupName invalid. (#2673) * refactor: change platform to platformID (#2670) * feat: don`t return nil data (#2675) Co-authored-by: Monet Lee <monet_lee@163.com> * refactor: update fields type in userStatus and check registered. (#2676) * fix: usertoken auth. (#2677) * refactor: update fields type in userStatus and check registered. * fix: usertoken auth. * update contents. * update content. * update * fix * update pb file. * feat: add friend agree after callback (#2680) * fix: sn not sort (#2682) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * refactor: add GetAdminToken interface. (#2684) * refactor: add GetAdminToken interface. * update config. * fix: admin token (#2686) * fix: update workflows logic. (#2688) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * fix: admin token (#2687) * update the front image (#2692) * update the front image * update version * feat: improve publish docker image workflows (#2697) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * feat: improve publish docker image workflows * update condition logic. * fix: update load file logic. (#2700) * refactor: add GetAdminToken interface. * update config. * update workflows logic. * feat: improve publish docker image workflows * update condition logic. * fix: update load file logic. * feat: Msg filter (#2703) * feat: msg filter * feat: msg filter * feat: msg filter * feat: provide the interface required by js sdk (#2712) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * Line webhook (#2716) * feat: online and offline webhook * feat: online and offline webhook * feat: remove zk * fix: the message I sent is not set to read seq in mongodb (#2718) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: cannot modify group member avatars (#2719) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb * fix: cannot modify group member avatars --------- Co-authored-by: withchao <withchao@users.noreply.github.com> --------- Co-authored-by: Monet Lee <monet_lee@163.com> Co-authored-by: icey-yu <119291641+icey-yu@users.noreply.github.com> Co-authored-by: chao <48119764+withchao@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com> Co-authored-by: skiffer-git <72860476+skiffer-git@users.noreply.github.com> * fix: MemberEnterNotification * fix: MemberEnterNotification * fix: MsgData status * merge * merge: update code from main to v3.8-js-sdk-only. (#2818) * feat: implement merge milestone PR to target-branch. (#2796) * build: improve workflows logic. (#2801) * fix: improve time condition check mehtod. (#2804) * fix: improve time condition check mehtod. * fix * fix: webhook before online push (#2805) * fix: set own read seq in MongoDB when sender send a message. (#2808) * fix: solve err Notification when setGroupInfo. (#2806) * fix: solve err Notification when setGroupInfo. * build: update checkout version. * fix: update notification contents. * Introducing OpenIM Guru on Gurubase.io (#2788) * feat: support app update service (#2811) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb * fix: cannot modify group member avatars * fix: MemberEnterNotification * fix: MemberEnterNotification * fix: MsgData status * feat: add ApplicationVersion * feat: add ApplicationVersion * feat: add ApplicationVersion --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: ApplicationVersion move chat (#2813) * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * cicd: robot automated Change * fix: component * fix: getConversationInfo * feat: cron task * feat: cron task * feat: cron task * feat: cron task * feat: cron task * fix: minio config url recognition error * update gomake version * update gomake version * fix: seq conversion bug * fix: redis pipe exec * fix: ImportFriends * fix: A large number of logs keysAndValues length is not even * feat: mark read aggregate write * feat: online status supports redis cluster * feat: online status supports redis cluster * feat: online status supports redis cluster * merge * merge * read seq is written to mongo * read seq is written to mongo * fix: invitation to join group notification * fix: friend op_user_id * feat: optimizing asynchronous context * feat: optimizing memamq size * feat: add GetSeqMessage * feat: GroupApplicationAgreeMemberEnterNotification * feat: GroupApplicationAgreeMemberEnterNotification * feat: go.mod * feat: go.mod * feat: join group notification and get seq * feat: join group notification and get seq * feat: avoid pulling messages from sessions with a large number of max seq values of 0 * feat: API supports gzip * go.mod * fix: nil pointer error on close * fix: listen error * fix: listen error * update go.mod * feat: add log * fix: token parse token value * fix: GetMsgBySeqs boundary issues * fix: sn_ not sort * fix: sn_ not sort * fix: sn_ not sort * fix: jssdk add * fix: jssdk support * fix: jssdk support * fix: jssdk support * fix: the message I sent is not set to read seq in mongodb * fix: cannot modify group member avatars * fix: MemberEnterNotification * fix: MemberEnterNotification * fix: MsgData status * feat: add ApplicationVersion * feat: ApplicationVersion move chat --------- Co-authored-by: withchao <withchao@users.noreply.github.com> * fix: improve condition check. (#2815) --------- Co-authored-by: Monet Lee <monet_lee@163.com> Co-authored-by: icey-yu <119291641+icey-yu@users.noreply.github.com> Co-authored-by: Kürşat Aktaş <kursat.ce@gmail.com> Co-authored-by: chao <48119764+withchao@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com> * feat: support text ping pong * feat: support text ping pong * feat: gob json encoder * feat: gob json encoder * feat: gob json encoder * feat: gob json encoder * feat: gob json encoder * feat: gob json encoder * fix: concurrent write to websocket connection * fix: concurrent write to websocket connection * fix: concurrent write to websocket connection * fix: group member update face_url * feat: support aws * feat: support aws * feat: support aws --------- Co-authored-by: withchao <withchao@users.noreply.github.com> Co-authored-by: Monet Lee <monet_lee@163.com> Co-authored-by: OpenIM-Gordon <46924906+FGadvancer@users.noreply.github.com> Co-authored-by: icey-yu <119291641+icey-yu@users.noreply.github.com> Co-authored-by: 蔡相跃 <caixiangyue007@gmail.com> Co-authored-by: skiffer-git <72860476+skiffer-git@users.noreply.github.com> Co-authored-by: Kürşat Aktaş <kursat.ce@gmail.com>
603 lines
23 KiB
Go
603 lines
23 KiB
Go
// Copyright © 2023 OpenIM. All rights reserved.
|
|
//
|
|
// Licensed 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 config
|
|
|
|
import (
|
|
"github.com/openimsdk/tools/s3/aws"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/openimsdk/tools/db/mongoutil"
|
|
"github.com/openimsdk/tools/db/redisutil"
|
|
"github.com/openimsdk/tools/mq/kafka"
|
|
"github.com/openimsdk/tools/s3/cos"
|
|
"github.com/openimsdk/tools/s3/kodo"
|
|
"github.com/openimsdk/tools/s3/minio"
|
|
"github.com/openimsdk/tools/s3/oss"
|
|
)
|
|
|
|
type CacheConfig struct {
|
|
Topic string `mapstructure:"topic"`
|
|
SlotNum int `mapstructure:"slotNum"`
|
|
SlotSize int `mapstructure:"slotSize"`
|
|
SuccessExpire int `mapstructure:"successExpire"`
|
|
FailedExpire int `mapstructure:"failedExpire"`
|
|
}
|
|
|
|
type LocalCache struct {
|
|
User CacheConfig `mapstructure:"user"`
|
|
Group CacheConfig `mapstructure:"group"`
|
|
Friend CacheConfig `mapstructure:"friend"`
|
|
Conversation CacheConfig `mapstructure:"conversation"`
|
|
}
|
|
|
|
type Log struct {
|
|
StorageLocation string `mapstructure:"storageLocation"`
|
|
RotationTime uint `mapstructure:"rotationTime"`
|
|
RemainRotationCount uint `mapstructure:"remainRotationCount"`
|
|
RemainLogLevel int `mapstructure:"remainLogLevel"`
|
|
IsStdout bool `mapstructure:"isStdout"`
|
|
IsJson bool `mapstructure:"isJson"`
|
|
IsSimplify bool `mapstructure:"isSimplify"`
|
|
WithStack bool `mapstructure:"withStack"`
|
|
}
|
|
|
|
type Minio struct {
|
|
Bucket string `mapstructure:"bucket"`
|
|
AccessKeyID string `mapstructure:"accessKeyID"`
|
|
SecretAccessKey string `mapstructure:"secretAccessKey"`
|
|
SessionToken string `mapstructure:"sessionToken"`
|
|
InternalAddress string `mapstructure:"internalAddress"`
|
|
ExternalAddress string `mapstructure:"externalAddress"`
|
|
PublicRead bool `mapstructure:"publicRead"`
|
|
}
|
|
|
|
type Mongo struct {
|
|
URI string `mapstructure:"uri"`
|
|
Address []string `mapstructure:"address"`
|
|
Database string `mapstructure:"database"`
|
|
Username string `mapstructure:"username"`
|
|
Password string `mapstructure:"password"`
|
|
AuthSource string `mapstructure:"authSource"`
|
|
MaxPoolSize int `mapstructure:"maxPoolSize"`
|
|
MaxRetry int `mapstructure:"maxRetry"`
|
|
}
|
|
type Kafka struct {
|
|
Username string `mapstructure:"username"`
|
|
Password string `mapstructure:"password"`
|
|
ProducerAck string `mapstructure:"producerAck"`
|
|
CompressType string `mapstructure:"compressType"`
|
|
Address []string `mapstructure:"address"`
|
|
ToRedisTopic string `mapstructure:"toRedisTopic"`
|
|
ToMongoTopic string `mapstructure:"toMongoTopic"`
|
|
ToPushTopic string `mapstructure:"toPushTopic"`
|
|
ToOfflinePushTopic string `mapstructure:"toOfflinePushTopic"`
|
|
ToRedisGroupID string `mapstructure:"toRedisGroupID"`
|
|
ToMongoGroupID string `mapstructure:"toMongoGroupID"`
|
|
ToPushGroupID string `mapstructure:"toPushGroupID"`
|
|
ToOfflineGroupID string `mapstructure:"toOfflinePushGroupID"`
|
|
|
|
Tls TLSConfig `mapstructure:"tls"`
|
|
}
|
|
type TLSConfig struct {
|
|
EnableTLS bool `mapstructure:"enableTLS"`
|
|
CACrt string `mapstructure:"caCrt"`
|
|
ClientCrt string `mapstructure:"clientCrt"`
|
|
ClientKey string `mapstructure:"clientKey"`
|
|
ClientKeyPwd string `mapstructure:"clientKeyPwd"`
|
|
InsecureSkipVerify bool `mapstructure:"insecureSkipVerify"`
|
|
}
|
|
|
|
type API struct {
|
|
Api struct {
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
Ports []int `mapstructure:"ports"`
|
|
CompressionLevel int `mapstructure:"compressionLevel"`
|
|
} `mapstructure:"api"`
|
|
Prometheus struct {
|
|
Enable bool `mapstructure:"enable"`
|
|
Ports []int `mapstructure:"ports"`
|
|
GrafanaURL string `mapstructure:"grafanaURL"`
|
|
} `mapstructure:"prometheus"`
|
|
}
|
|
|
|
type CronTask struct {
|
|
CronExecuteTime string `mapstructure:"cronExecuteTime"`
|
|
RetainChatRecords int `mapstructure:"retainChatRecords"`
|
|
FileExpireTime int `mapstructure:"fileExpireTime"`
|
|
DeleteObjectType []string `mapstructure:"deleteObjectType"`
|
|
}
|
|
|
|
type OfflinePushConfig struct {
|
|
Enable bool `mapstructure:"enable"`
|
|
Title string `mapstructure:"title"`
|
|
Desc string `mapstructure:"desc"`
|
|
Ext string `mapstructure:"ext"`
|
|
}
|
|
|
|
type NotificationConfig struct {
|
|
IsSendMsg bool `mapstructure:"isSendMsg"`
|
|
ReliabilityLevel int `mapstructure:"reliabilityLevel"`
|
|
UnreadCount bool `mapstructure:"unreadCount"`
|
|
OfflinePush OfflinePushConfig `mapstructure:"offlinePush"`
|
|
}
|
|
|
|
type Notification struct {
|
|
GroupCreated NotificationConfig `mapstructure:"groupCreated"`
|
|
GroupInfoSet NotificationConfig `mapstructure:"groupInfoSet"`
|
|
JoinGroupApplication NotificationConfig `mapstructure:"joinGroupApplication"`
|
|
MemberQuit NotificationConfig `mapstructure:"memberQuit"`
|
|
GroupApplicationAccepted NotificationConfig `mapstructure:"groupApplicationAccepted"`
|
|
GroupApplicationRejected NotificationConfig `mapstructure:"groupApplicationRejected"`
|
|
GroupOwnerTransferred NotificationConfig `mapstructure:"groupOwnerTransferred"`
|
|
MemberKicked NotificationConfig `mapstructure:"memberKicked"`
|
|
MemberInvited NotificationConfig `mapstructure:"memberInvited"`
|
|
MemberEnter NotificationConfig `mapstructure:"memberEnter"`
|
|
GroupDismissed NotificationConfig `mapstructure:"groupDismissed"`
|
|
GroupMuted NotificationConfig `mapstructure:"groupMuted"`
|
|
GroupCancelMuted NotificationConfig `mapstructure:"groupCancelMuted"`
|
|
GroupMemberMuted NotificationConfig `mapstructure:"groupMemberMuted"`
|
|
GroupMemberCancelMuted NotificationConfig `mapstructure:"groupMemberCancelMuted"`
|
|
GroupMemberInfoSet NotificationConfig `mapstructure:"groupMemberInfoSet"`
|
|
GroupMemberSetToAdmin NotificationConfig `yaml:"groupMemberSetToAdmin"`
|
|
GroupMemberSetToOrdinary NotificationConfig `yaml:"groupMemberSetToOrdinaryUser"`
|
|
GroupInfoSetAnnouncement NotificationConfig `mapstructure:"groupInfoSetAnnouncement"`
|
|
GroupInfoSetName NotificationConfig `mapstructure:"groupInfoSetName"`
|
|
FriendApplicationAdded NotificationConfig `mapstructure:"friendApplicationAdded"`
|
|
FriendApplicationApproved NotificationConfig `mapstructure:"friendApplicationApproved"`
|
|
FriendApplicationRejected NotificationConfig `mapstructure:"friendApplicationRejected"`
|
|
FriendAdded NotificationConfig `mapstructure:"friendAdded"`
|
|
FriendDeleted NotificationConfig `mapstructure:"friendDeleted"`
|
|
FriendRemarkSet NotificationConfig `mapstructure:"friendRemarkSet"`
|
|
BlackAdded NotificationConfig `mapstructure:"blackAdded"`
|
|
BlackDeleted NotificationConfig `mapstructure:"blackDeleted"`
|
|
FriendInfoUpdated NotificationConfig `mapstructure:"friendInfoUpdated"`
|
|
UserInfoUpdated NotificationConfig `mapstructure:"userInfoUpdated"`
|
|
UserStatusChanged NotificationConfig `mapstructure:"userStatusChanged"`
|
|
ConversationChanged NotificationConfig `mapstructure:"conversationChanged"`
|
|
ConversationSetPrivate NotificationConfig `mapstructure:"conversationSetPrivate"`
|
|
}
|
|
|
|
type Prometheus struct {
|
|
Enable bool `mapstructure:"enable"`
|
|
Ports []int `mapstructure:"ports"`
|
|
}
|
|
|
|
type MsgGateway struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
LongConnSvr struct {
|
|
Ports []int `mapstructure:"ports"`
|
|
WebsocketMaxConnNum int `mapstructure:"websocketMaxConnNum"`
|
|
WebsocketMaxMsgLen int `mapstructure:"websocketMaxMsgLen"`
|
|
WebsocketTimeout int `mapstructure:"websocketTimeout"`
|
|
} `mapstructure:"longConnSvr"`
|
|
}
|
|
|
|
type MsgTransfer struct {
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
}
|
|
|
|
type Push struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
MaxConcurrentWorkers int `mapstructure:"maxConcurrentWorkers"`
|
|
Enable string `mapstructure:"enable"`
|
|
GeTui struct {
|
|
PushUrl string `mapstructure:"pushUrl"`
|
|
MasterSecret string `mapstructure:"masterSecret"`
|
|
AppKey string `mapstructure:"appKey"`
|
|
Intent string `mapstructure:"intent"`
|
|
ChannelID string `mapstructure:"channelID"`
|
|
ChannelName string `mapstructure:"channelName"`
|
|
} `mapstructure:"geTui"`
|
|
FCM struct {
|
|
FilePath string `mapstructure:"filePath"`
|
|
AuthURL string `mapstructure:"authURL"`
|
|
} `mapstructure:"fcm"`
|
|
JPush struct {
|
|
AppKey string `mapstructure:"appKey"`
|
|
MasterSecret string `mapstructure:"masterSecret"`
|
|
PushURL string `mapstructure:"pushURL"`
|
|
PushIntent string `mapstructure:"pushIntent"`
|
|
} `mapstructure:"jpush"`
|
|
IOSPush struct {
|
|
PushSound string `mapstructure:"pushSound"`
|
|
BadgeCount bool `mapstructure:"badgeCount"`
|
|
Production bool `mapstructure:"production"`
|
|
} `mapstructure:"iosPush"`
|
|
FullUserCache bool `mapstructure:"fullUserCache"`
|
|
}
|
|
|
|
type Auth struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
TokenPolicy struct {
|
|
Expire int64 `mapstructure:"expire"`
|
|
} `mapstructure:"tokenPolicy"`
|
|
}
|
|
|
|
type Conversation struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
}
|
|
|
|
type Friend struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
}
|
|
|
|
type Group struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
EnableHistoryForNewMembers bool `mapstructure:"enableHistoryForNewMembers"`
|
|
}
|
|
|
|
type Msg struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
FriendVerify bool `mapstructure:"friendVerify"`
|
|
}
|
|
|
|
type Third struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
Object struct {
|
|
Enable string `mapstructure:"enable"`
|
|
Cos Cos `mapstructure:"cos"`
|
|
Oss Oss `mapstructure:"oss"`
|
|
Kodo Kodo `mapstructure:"kodo"`
|
|
Aws Aws `mapstructure:"aws"`
|
|
} `mapstructure:"object"`
|
|
}
|
|
type Cos struct {
|
|
BucketURL string `mapstructure:"bucketURL"`
|
|
SecretID string `mapstructure:"secretID"`
|
|
SecretKey string `mapstructure:"secretKey"`
|
|
SessionToken string `mapstructure:"sessionToken"`
|
|
PublicRead bool `mapstructure:"publicRead"`
|
|
}
|
|
type Oss struct {
|
|
Endpoint string `mapstructure:"endpoint"`
|
|
Bucket string `mapstructure:"bucket"`
|
|
BucketURL string `mapstructure:"bucketURL"`
|
|
AccessKeyID string `mapstructure:"accessKeyID"`
|
|
AccessKeySecret string `mapstructure:"accessKeySecret"`
|
|
SessionToken string `mapstructure:"sessionToken"`
|
|
PublicRead bool `mapstructure:"publicRead"`
|
|
}
|
|
|
|
type Kodo struct {
|
|
Endpoint string `mapstructure:"endpoint"`
|
|
Bucket string `mapstructure:"bucket"`
|
|
BucketURL string `mapstructure:"bucketURL"`
|
|
AccessKeyID string `mapstructure:"accessKeyID"`
|
|
AccessKeySecret string `mapstructure:"accessKeySecret"`
|
|
SessionToken string `mapstructure:"sessionToken"`
|
|
PublicRead bool `mapstructure:"publicRead"`
|
|
}
|
|
|
|
type Aws struct {
|
|
Region string `mapstructure:"region"`
|
|
Bucket string `mapstructure:"bucket"`
|
|
AccessKeyID string `mapstructure:"accessKeyID"`
|
|
SecretAccessKey string `mapstructure:"secretAccessKey"`
|
|
SessionToken string `mapstructure:"sessionToken"`
|
|
PublicRead bool `mapstructure:"publicRead"`
|
|
}
|
|
|
|
type User struct {
|
|
RPC struct {
|
|
RegisterIP string `mapstructure:"registerIP"`
|
|
ListenIP string `mapstructure:"listenIP"`
|
|
AutoSetPorts bool `mapstructure:"autoSetPorts"`
|
|
Ports []int `mapstructure:"ports"`
|
|
} `mapstructure:"rpc"`
|
|
Prometheus Prometheus `mapstructure:"prometheus"`
|
|
}
|
|
|
|
type Redis struct {
|
|
Address []string `mapstructure:"address"`
|
|
Username string `mapstructure:"username"`
|
|
Password string `mapstructure:"password"`
|
|
ClusterMode bool `mapstructure:"clusterMode"`
|
|
DB int `mapstructure:"storage"`
|
|
MaxRetry int `mapstructure:"maxRetry"`
|
|
PoolSize int `mapstructure:"poolSize"`
|
|
}
|
|
|
|
type BeforeConfig struct {
|
|
Enable bool `mapstructure:"enable"`
|
|
Timeout int `mapstructure:"timeout"`
|
|
FailedContinue bool `mapstructure:"failedContinue"`
|
|
AllowedTypes []string `mapstructure:"allowedTypes"`
|
|
DeniedTypes []string `mapstructure:"deniedTypes"`
|
|
}
|
|
|
|
type AfterConfig struct {
|
|
Enable bool `mapstructure:"enable"`
|
|
Timeout int `mapstructure:"timeout"`
|
|
AttentionIds []string `mapstructure:"attentionIds"`
|
|
AllowedTypes []string `mapstructure:"allowedTypes"`
|
|
DeniedTypes []string `mapstructure:"deniedTypes"`
|
|
}
|
|
|
|
type Share struct {
|
|
Secret string `mapstructure:"secret"`
|
|
IMAdminUserID []string `mapstructure:"imAdminUserID"`
|
|
MultiLogin MultiLogin `mapstructure:"multiLogin"`
|
|
}
|
|
|
|
type MultiLogin struct {
|
|
Policy int `mapstructure:"policy"`
|
|
MaxNumOneEnd int `mapstructure:"maxNumOneEnd"`
|
|
}
|
|
|
|
type RpcService struct {
|
|
User string `mapstructure:"user"`
|
|
Friend string `mapstructure:"friend"`
|
|
Msg string `mapstructure:"msg"`
|
|
Push string `mapstructure:"push"`
|
|
MessageGateway string `mapstructure:"messageGateway"`
|
|
Group string `mapstructure:"group"`
|
|
Auth string `mapstructure:"auth"`
|
|
Conversation string `mapstructure:"conversation"`
|
|
Third string `mapstructure:"third"`
|
|
}
|
|
|
|
func (r *RpcService) GetServiceNames() []string {
|
|
return []string{
|
|
r.User,
|
|
r.Friend,
|
|
r.Msg,
|
|
r.Push,
|
|
r.MessageGateway,
|
|
r.Group,
|
|
r.Auth,
|
|
r.Conversation,
|
|
r.Third,
|
|
}
|
|
}
|
|
|
|
// FullConfig stores all configurations for before and after events
|
|
type Webhooks struct {
|
|
URL string `mapstructure:"url"`
|
|
BeforeSendSingleMsg BeforeConfig `mapstructure:"beforeSendSingleMsg"`
|
|
BeforeUpdateUserInfoEx BeforeConfig `mapstructure:"beforeUpdateUserInfoEx"`
|
|
AfterUpdateUserInfoEx AfterConfig `mapstructure:"afterUpdateUserInfoEx"`
|
|
AfterSendSingleMsg AfterConfig `mapstructure:"afterSendSingleMsg"`
|
|
BeforeSendGroupMsg BeforeConfig `mapstructure:"beforeSendGroupMsg"`
|
|
BeforeMsgModify BeforeConfig `mapstructure:"beforeMsgModify"`
|
|
AfterSendGroupMsg AfterConfig `mapstructure:"afterSendGroupMsg"`
|
|
AfterUserOnline AfterConfig `mapstructure:"afterUserOnline"`
|
|
AfterUserOffline AfterConfig `mapstructure:"afterUserOffline"`
|
|
AfterUserKickOff AfterConfig `mapstructure:"afterUserKickOff"`
|
|
BeforeOfflinePush BeforeConfig `mapstructure:"beforeOfflinePush"`
|
|
BeforeOnlinePush BeforeConfig `mapstructure:"beforeOnlinePush"`
|
|
BeforeGroupOnlinePush BeforeConfig `mapstructure:"beforeGroupOnlinePush"`
|
|
BeforeAddFriend BeforeConfig `mapstructure:"beforeAddFriend"`
|
|
BeforeUpdateUserInfo BeforeConfig `mapstructure:"beforeUpdateUserInfo"`
|
|
AfterUpdateUserInfo AfterConfig `mapstructure:"afterUpdateUserInfo"`
|
|
BeforeCreateGroup BeforeConfig `mapstructure:"beforeCreateGroup"`
|
|
AfterCreateGroup AfterConfig `mapstructure:"afterCreateGroup"`
|
|
BeforeMemberJoinGroup BeforeConfig `mapstructure:"beforeMemberJoinGroup"`
|
|
BeforeSetGroupMemberInfo BeforeConfig `mapstructure:"beforeSetGroupMemberInfo"`
|
|
AfterSetGroupMemberInfo AfterConfig `mapstructure:"afterSetGroupMemberInfo"`
|
|
AfterQuitGroup AfterConfig `mapstructure:"afterQuitGroup"`
|
|
AfterKickGroupMember AfterConfig `mapstructure:"afterKickGroupMember"`
|
|
AfterDismissGroup AfterConfig `mapstructure:"afterDismissGroup"`
|
|
BeforeApplyJoinGroup BeforeConfig `mapstructure:"beforeApplyJoinGroup"`
|
|
AfterGroupMsgRead AfterConfig `mapstructure:"afterGroupMsgRead"`
|
|
AfterSingleMsgRead AfterConfig `mapstructure:"afterSingleMsgRead"`
|
|
BeforeUserRegister BeforeConfig `mapstructure:"beforeUserRegister"`
|
|
AfterUserRegister AfterConfig `mapstructure:"afterUserRegister"`
|
|
AfterTransferGroupOwner AfterConfig `mapstructure:"afterTransferGroupOwner"`
|
|
BeforeSetFriendRemark BeforeConfig `mapstructure:"beforeSetFriendRemark"`
|
|
AfterSetFriendRemark AfterConfig `mapstructure:"afterSetFriendRemark"`
|
|
AfterGroupMsgRevoke AfterConfig `mapstructure:"afterGroupMsgRevoke"`
|
|
AfterJoinGroup AfterConfig `mapstructure:"afterJoinGroup"`
|
|
BeforeInviteUserToGroup BeforeConfig `mapstructure:"beforeInviteUserToGroup"`
|
|
AfterSetGroupInfo AfterConfig `mapstructure:"afterSetGroupInfo"`
|
|
BeforeSetGroupInfo BeforeConfig `mapstructure:"beforeSetGroupInfo"`
|
|
AfterSetGroupInfoEx AfterConfig `mapstructure:"afterSetGroupInfoEx"`
|
|
BeforeSetGroupInfoEx BeforeConfig `mapstructure:"beforeSetGroupInfoEx"`
|
|
AfterRevokeMsg AfterConfig `mapstructure:"afterRevokeMsg"`
|
|
BeforeAddBlack BeforeConfig `mapstructure:"beforeAddBlack"`
|
|
AfterAddFriend AfterConfig `mapstructure:"afterAddFriend"`
|
|
BeforeAddFriendAgree BeforeConfig `mapstructure:"beforeAddFriendAgree"`
|
|
AfterAddFriendAgree AfterConfig `mapstructure:"afterAddFriendAgree"`
|
|
AfterDeleteFriend AfterConfig `mapstructure:"afterDeleteFriend"`
|
|
BeforeImportFriends BeforeConfig `mapstructure:"beforeImportFriends"`
|
|
AfterImportFriends AfterConfig `mapstructure:"afterImportFriends"`
|
|
AfterRemoveBlack AfterConfig `mapstructure:"afterRemoveBlack"`
|
|
}
|
|
|
|
type ZooKeeper struct {
|
|
Schema string `mapstructure:"schema"`
|
|
Address []string `mapstructure:"address"`
|
|
Username string `mapstructure:"username"`
|
|
Password string `mapstructure:"password"`
|
|
}
|
|
|
|
type Discovery struct {
|
|
Enable string `mapstructure:"enable"`
|
|
Etcd Etcd `mapstructure:"etcd"`
|
|
RpcService RpcService `mapstructure:"rpcService"`
|
|
}
|
|
|
|
type Etcd struct {
|
|
RootDirectory string `mapstructure:"rootDirectory"`
|
|
Address []string `mapstructure:"address"`
|
|
Username string `mapstructure:"username"`
|
|
Password string `mapstructure:"password"`
|
|
}
|
|
|
|
func (m *Mongo) Build() *mongoutil.Config {
|
|
return &mongoutil.Config{
|
|
Uri: m.URI,
|
|
Address: m.Address,
|
|
Database: m.Database,
|
|
Username: m.Username,
|
|
Password: m.Password,
|
|
AuthSource: m.AuthSource,
|
|
MaxPoolSize: m.MaxPoolSize,
|
|
MaxRetry: m.MaxRetry,
|
|
}
|
|
}
|
|
|
|
func (r *Redis) Build() *redisutil.Config {
|
|
return &redisutil.Config{
|
|
ClusterMode: r.ClusterMode,
|
|
Address: r.Address,
|
|
Username: r.Username,
|
|
Password: r.Password,
|
|
DB: r.DB,
|
|
MaxRetry: r.MaxRetry,
|
|
PoolSize: r.PoolSize,
|
|
}
|
|
}
|
|
|
|
func (k *Kafka) Build() *kafka.Config {
|
|
return &kafka.Config{
|
|
Username: k.Username,
|
|
Password: k.Password,
|
|
ProducerAck: k.ProducerAck,
|
|
CompressType: k.CompressType,
|
|
Addr: k.Address,
|
|
TLS: kafka.TLSConfig{
|
|
EnableTLS: k.Tls.EnableTLS,
|
|
CACrt: k.Tls.CACrt,
|
|
ClientCrt: k.Tls.ClientCrt,
|
|
ClientKey: k.Tls.ClientKey,
|
|
ClientKeyPwd: k.Tls.ClientKeyPwd,
|
|
InsecureSkipVerify: k.Tls.InsecureSkipVerify,
|
|
},
|
|
}
|
|
}
|
|
|
|
func (m *Minio) Build() *minio.Config {
|
|
formatEndpoint := func(address string) string {
|
|
if strings.HasPrefix(address, "http://") || strings.HasPrefix(address, "https://") {
|
|
return address
|
|
}
|
|
return "http://" + address
|
|
}
|
|
return &minio.Config{
|
|
Bucket: m.Bucket,
|
|
AccessKeyID: m.AccessKeyID,
|
|
SecretAccessKey: m.SecretAccessKey,
|
|
SessionToken: m.SessionToken,
|
|
PublicRead: m.PublicRead,
|
|
Endpoint: formatEndpoint(m.InternalAddress),
|
|
SignEndpoint: formatEndpoint(m.ExternalAddress),
|
|
}
|
|
}
|
|
|
|
func (c *Cos) Build() *cos.Config {
|
|
return &cos.Config{
|
|
BucketURL: c.BucketURL,
|
|
SecretID: c.SecretID,
|
|
SecretKey: c.SecretKey,
|
|
SessionToken: c.SessionToken,
|
|
PublicRead: c.PublicRead,
|
|
}
|
|
}
|
|
|
|
func (o *Oss) Build() *oss.Config {
|
|
return &oss.Config{
|
|
Endpoint: o.Endpoint,
|
|
Bucket: o.Bucket,
|
|
BucketURL: o.BucketURL,
|
|
AccessKeyID: o.AccessKeyID,
|
|
AccessKeySecret: o.AccessKeySecret,
|
|
SessionToken: o.SessionToken,
|
|
PublicRead: o.PublicRead,
|
|
}
|
|
}
|
|
|
|
func (o *Kodo) Build() *kodo.Config {
|
|
return &kodo.Config{
|
|
Endpoint: o.Endpoint,
|
|
Bucket: o.Bucket,
|
|
BucketURL: o.BucketURL,
|
|
AccessKeyID: o.AccessKeyID,
|
|
AccessKeySecret: o.AccessKeySecret,
|
|
SessionToken: o.SessionToken,
|
|
PublicRead: o.PublicRead,
|
|
}
|
|
}
|
|
|
|
func (o *Aws) Build() *aws.Config {
|
|
return &aws.Config{
|
|
Region: o.Region,
|
|
Bucket: o.Bucket,
|
|
AccessKeyID: o.AccessKeyID,
|
|
SecretAccessKey: o.SecretAccessKey,
|
|
SessionToken: o.SessionToken,
|
|
}
|
|
}
|
|
|
|
func (l *CacheConfig) Failed() time.Duration {
|
|
return time.Second * time.Duration(l.FailedExpire)
|
|
}
|
|
|
|
func (l *CacheConfig) Success() time.Duration {
|
|
return time.Second * time.Duration(l.SuccessExpire)
|
|
}
|
|
|
|
func (l *CacheConfig) Enable() bool {
|
|
return l.Topic != "" && l.SlotNum > 0 && l.SlotSize > 0
|
|
}
|