diff --git a/.github/workflows/e2e-test.yml b/.github/workflows/e2e-test.yml
index f98221e41..62df69ed5 100644
--- a/.github/workflows/e2e-test.yml
+++ b/.github/workflows/e2e-test.yml
@@ -73,14 +73,22 @@ jobs:
- name: Docker Operations
run: |
- sudo make init
sudo docker compose up -d
+ sudo bash bootstrap.sh
+ sudo mage
sudo sleep 20
- name: Module Operations
run: |
- sudo make tidy
- sudo make tools.verify.go-gitlint
+ sudo go mod tidy
+ echo "===========> Verifying go-gitlint is installed"
+ if [ ! -f ./_output/tools/go-gitlint ]; then
+ export GOBIN=$(pwd)/_output/tools
+ echo "===========> Installing The default installation path is /home/ubuntu/DF/open-im-server/_output/tools/go-gitlint"
+ sudo go install github.com/marmotedu/go-gitlint/cmd/go-gitlint@latest
+ echo "===========> go-gitlint is installed in /home/ubuntu/DF/open-im-server/_output/tools/go-gitlint"
+ fi
+
- name: Build, Start(make build && make start)
run: |
@@ -90,7 +98,8 @@ jobs:
run: |
sudo ./scripts/install/install.sh -s
- - name: Exec OpenIM API test (make test-api)
+# - name: Exec OpenIM API test (make test-api)
+ - name: Exec OpenIM test (make test)
run: |
mkdir -p ./tmp
touch ./tmp/test.md
@@ -98,23 +107,27 @@ jobs:
echo "## OpenIM API Test" >> ./tmp/test.md
echo "Command Output for OpenIM API Test
" >> ./tmp/test.md
echo "" >> ./tmp/test.md
- sudo make test-api | tee -a ./tmp/test.md
+ echo "===========> Run api test"
+ ./scripts/install/test.sh
+ echo "===========> Run api test" >> ./tmp/test.md
+ ./scripts/install/test.sh >> ./tmp/test.md
echo "
" >> ./tmp/test.md
echo " " >> ./tmp/test.md
- sudo make test-api
+ echo "===========> Run api test"
+ ./scripts/install/test.sh
- - name: Exec OpenIM E2E Test (make test-e2e)
- run: |
- echo "" >> ./tmp/test.md
- echo "## OpenIM E2E Test" >> ./tmp/test.md
- echo "Command Output for OpenIM E2E Test
" >> ./tmp/test.md
- echo "" >> ./tmp/test.md
- sudo make test-e2e | tee -a ./tmp/test.md
- echo "
" >> ./tmp/test.md
- echo " " >> ./tmp/test.md
+ # - name: Exec OpenIM E2E Test (make test-e2e)
+ # run: |
+ # echo "" >> ./tmp/test.md
+ # echo "## OpenIM E2E Test" >> ./tmp/test.md
+ # echo "Command Output for OpenIM E2E Test
" >> ./tmp/test.md
+ # echo "" >> ./tmp/test.md
+ # sudo make test-e2e | tee -a ./tmp/test.md
+ # echo "
" >> ./tmp/test.md
+ # echo " " >> ./tmp/test.md
- sudo make test-e2e
+ # sudo make test-e2e
- name: Comment PR with file
uses: thollander/actions-comment-pull-request@v2
diff --git a/.github/workflows/golangci-lint.yml b/.github/workflows/golangci-lint.yml
index 31e491d6b..64bd498c5 100644
--- a/.github/workflows/golangci-lint.yml
+++ b/.github/workflows/golangci-lint.yml
@@ -29,7 +29,13 @@ jobs:
go-version: '1.21'
cache: false
- name: OpenIM Scripts Verification(make verify)
- run: sudo make verify
+ run: |
+ cd scripts
+ for script in verify-*; do
+ if [ -x "$script" ]; then
+ ./"$script"
+ fi
+ done
- name: golangci-lint
uses: golangci/golangci-lint-action@v4.0.0
with:
diff --git a/.github/workflows/openimci.yml b/.github/workflows/openimci.yml
index f47283997..033868a2e 100644
--- a/.github/workflows/openimci.yml
+++ b/.github/workflows/openimci.yml
@@ -1,3 +1,4 @@
+
# Copyright © 2023 OpenIM open source community. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
@@ -11,8 +12,7 @@
# 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.
-
-name: OpenIM CI Aotu Build and Install
+name: OpenIM CI Auto Build
on:
push:
@@ -37,269 +37,154 @@ on:
- "**.md"
- "docs/**"
-env:
- GO_VERSION: "1.19"
- GOLANGCI_VERSION: "v1.50.1"
-
jobs:
- openim:
- name: Test with go ${{ matrix.go_version }} on ${{ matrix.os }}
- runs-on: ${{ matrix.os }}
- permissions:
- contents: write
- pull-requests: write
- environment:
- name: openim
- strategy:
- matrix:
- go_version: ["1.19","1.20","1.21"]
- os: [ubuntu-latest]
- steps:
- - name: Setup
- uses: actions/checkout@v4
- - name: Set up Go ${{ matrix.go_version }}
- uses: actions/setup-go@v5
- with:
- go-version: ${{ matrix.go_version }}
- id: go
-
- - name: Install Task
- uses: arduino/setup-task@v1
- with:
- version: '3.x' # If available, use the latest major version that's compatible
- repo-token: ${{ secrets.GITHUB_TOKEN }}
-
- - name: Code Typecheck Detector
- uses: kubecub/typecheck@main
-
- - name: Conformity Checker for Project
- uses: kubecub/standardizer@main
-
- - name: Module Operations
- run: |
- sudo make tidy
- sudo make tools.verify.go-gitlint
-
- - name: Format Code
- run: sudo make format
- continue-on-error: true
-
- - name: Generate Files
- run: make gen
- continue-on-error: true
-
- - name: Build Source
- run: sudo make build
-
- - name: Build multiarch PLATFORMS
- if: startsWith(github.ref, 'refs/heads/release-')
- run: |
- sudo make multiarch
-
- - name: Cleanup Build
- run: sudo make clean
-
- - name: Set Current Directory
- id: set_directory
- run: echo "::set-output name=directory::$(pwd)"
- continue-on-error: true
-
- - name: Collect and Display Test Coverage
- id: collect_coverage
- run: |
- cd ${{ steps.set_directory.outputs.directory }}
- make cover
- echo "::set-output name=coverage_file::./_output/tmp/coverage.out"
- echo "Test Coverage:"
- cat ${{ steps.collect_coverage.outputs.coverage_file }}
- continue-on-error: true
-
- openim-start:
- name: Test OpenIM install/start on ${{ matrix.os }}-${{ matrix.arch }}
- runs-on: ${{ matrix.os }}
- permissions:
- contents: write
- pull-requests: write
- environment:
- name: openim
- strategy:
- matrix:
- go_version: ["1.21"]
- os: ["ubuntu-latest"]
- steps:
- - name: Checkout and Install OpenIM
- uses: actions/checkout@v4
- - name: Install Task
- uses: arduino/setup-task@v1
- with:
- version: '3.x' # If available, use the latest major version that's compatible
- repo-token: ${{ secrets.GITHUB_TOKEN }}
- - name: Run OpenIM make install start
- run: |
- sudo make install
-
- # - name: Check the OpenIM environment and status
- # run: |
- # sudo docker images
- # sudo docker ps
-
- - name: Check the OpenIM environment and status
- if: runner.os == 'Linux' && matrix.arch == 'amd64'
- id: docker_info
- run: |
- sleep 30
- echo "images<> $GITHUB_ENV
- sudo docker images >> $GITHUB_ENV
- echo "EOF" >> $GITHUB_ENV
- echo "containers<> $GITHUB_ENV
- sudo docker ps >> $GITHUB_ENV
- echo "EOF" >> $GITHUB_ENV
-
- - name: Comment PR
- uses: thollander/actions-comment-pull-request@v2
- if: runner.os == 'Linux' && matrix.arch == 'amd64'
- with:
- message: |
- > [!TIP]
- > Run make install to check the status
-
- ### Docker Images:
- Click to expand docker images
- ```bash
- ${{ env.images }}
- ```
-
-
- ### Docker Processes:
- Click to expand docker ps
- ```bash
- ${{ env.containers }}
- ```
-
- GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }}
-
- execute-scripts:
- name: Execute OpenIM Script On ${{ matrix.os }}-${{ matrix.arch }}
- runs-on: ${{ matrix.os }}
- permissions:
- contents: write
- pull-requests: write
- environment:
- name: openim
- strategy:
- matrix:
- go_version: ["1.21"]
- os: ["ubuntu-latest", "macos-latest"]
- arch: [arm64, armv7, amd64]
- steps:
- - name: Checkout code
- uses: actions/checkout@v4
-
- - name: Set up Go ${{ matrix.go_version }}
- uses: actions/setup-go@v5
- with:
- go-version: ${{ matrix.go_version }}
- id: go
-
- - name: Install Task
- uses: arduino/setup-task@v1
- with:
- version: '3.x' # If available, use the latest major version that's compatible
- repo-token: ${{ secrets.GITHUB_TOKEN }}
-
- # - name: Install latest Bash (macOS only)
- # if: runner.os == 'macOS' && matrix.arch == 'arm64'
- # run: |
- # /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
- # brew update
-
- # brew install bash
- # brew install gnu-sed
-
- # echo "/usr/local/bin" >> $GITHUB_PATH
- # echo "$(brew --prefix)/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH
- # continue-on-error: true
-
- - name: Set up Docker for Ubuntu
- if: runner.os == 'Linux'
- run: |
- sudo make init
- sudo docker compose up -d
- sudo sleep 20
-
- # - name: Set up Docker for macOS
- # if: runner.os == 'macOS' && matrix.arch == 'arm64'
- # run: |
- # brew install --cask docker
- # open /Applications/Docker.app
-
- # sleep 10
- # docker-compose --version || brew install docker-compose
-
- # docker-compose up -d
- # sleep 20
-
- - name: Module Operations for Ubuntu
- if: runner.os == 'Linux'
- run: |
- sudo make tidy
- sudo make tools.verify.go-gitlint
-
- # - name: Module Operations for macOS
- # if: runner.os == 'macOS'
- # run: |
- # make tidy
- # make tools.verify.go-gitlint
-
- - name: Build, Start, Check Services and Print Logs for Ubuntu
- if: runner.os == 'Linux'
- run: |
- sudo make build
- sudo make start
- sudo make check
-
- - name: Restart Services and Print Logs for Ubuntu
- if: runner.os == 'Linux' && matrix.arch == 'amd64'
- run: |
- sudo make restart
- sudo make check
-
- - name: Build, Start, Check Services and Print Logs for macOS
- if: runner.os == 'macOS' && matrix.arch == 'arm64'
- run: |
- make build
-
- openim-test-build-image:
- name: Build OpenIM Docker Image
+ build-linux:
+ name: Execute OpenIM Script On Linux
runs-on: ubuntu-latest
permissions:
- contents: write
- pull-requests: write
+ contents: write
+ pull-requests: write
environment:
name: openim
+ strategy:
+ matrix:
+ arch: [arm64, armv7, amd64]
+
steps:
- - name: Checkout code
- uses: actions/checkout@v4
- - name: Set up Go ${{ matrix.go_version }}
- uses: actions/setup-go@v5
+ - uses: actions/checkout@v3
+
+ - name: Set up Go
+ uses: actions/setup-go@v4
with:
- go-version: ${{ matrix.go_version }}
- id: go
+ go-version: '1.21'
- - name: Install Task
- uses: arduino/setup-task@v1
- with:
- version: '3.x' # If available, use the latest major version that's compatible
- repo-token: ${{ secrets.GITHUB_TOKEN }}
-
- - name: Test Docker Build
+ - name: Set up Docker for Linux
run: |
- sudo make init
- sudo make image
+ sudo docker compose up -d
+ sudo sleep 30 # Increased sleep time for better stability
+ timeout-minutes: 20 # Increased timeout for Docker setup
- - name: Get OpenIM Docker Images Status
- id: docker_processes
+
+ - name: init
+ run: sudo bash bootstrap.sh
+ timeout-minutes: 20
+
+ - name: Build, Start, Check Services and Print Logs for Linux
run: |
- sudo docker images
- sudo docker ps
+ sudo mage
+ sudo mage start
+ sudo mage check
+
+
+ - name: Restart Services and Print Logs
+ run: |
+ sudo mage stop
+ sudo mage start
+ sudo mage check
+
+
+# build-mac:
+# name: Execute OpenIM Script On macOS
+# runs-on: macos-latest
+# permissions:
+# contents: write
+# pull-requests: write
+# environment:
+# name: openim
+# strategy:
+# matrix:
+# arch: [arm64, armv7, amd64]
+#
+# steps:
+# - uses: actions/checkout@v3
+
+# - name: Set up Go
+# uses: actions/setup-go@v4
+# with:
+# go-version: '1.21'
+
+
+# while ! docker system info > /dev/null 2>&1; do
+# echo "Waiting for Docker to start..."
+# sleep 10 # Increased delay to ensure Docker starts properly
+# done
+
+# - name: Install Docker
+# run: |
+# brew install docker
+# brew install docker-compose
+# sleep 10
+# docker-compose up -d
+# sleep 30
+# timeout-minutes: 20
+#
+
+# - name: init
+# run: sudo bash bootstrap.sh
+# timeout-minutes: 20
+
+# - name: Build, Start, Check Services and Print Logs for Linux
+# run: |
+# sudo mage
+# sudo mage start
+# sudo mage check
+
+# - name: Restart Services and Print Logs
+# run: |
+# sudo mage stop
+# sudo mage start
+# sudo mage check
+
+# build-windows:
+# name: Execute OpenIM Script On Windows
+# runs-on: windows-latest
+# permissions:
+# contents: write
+# pull-requests: write
+# environment:
+# name: openim
+# strategy:
+# matrix:
+# arch: [arm64, armv7, amd64]
+#
+# steps:
+# - uses: actions/checkout@v3
+
+# - name: Set up Go
+# uses: actions/setup-go@v4
+# with:
+# go-version: '1.21'
+
+# - name: Set up Docker for Windows
+# run: |
+# $images = @("zookeeper", "redis", "kafka")
+# foreach ($image in $images) {
+# $tag = "$image:latest"
+# docker pull $tag | Out-Null
+# if ($LASTEXITCODE -ne 0) {
+# Write-Host "Skipping $image as it is not available for Windows"
+# } else {
+# Write-Host "Successfully pulled $image"
+# }
+# }
+# docker compose up -d
+# Start-Sleep -Seconds 30
+# timeout-minutes: 20
+# shell: pwsh
+
+# - name: init
+# run: bootstrap.bat
+# timeout-minutes: 20
+
+# - name: Build, Start, Check Services and Print Logs for Linux
+# run: |
+# mage
+# mage start
+# mage check
+
+# - name: Restart Services and Print Logs
+# run: |
+# mage stop
+# mage start
+# mage check
diff --git a/config/kafka.yml b/config/kafka.yml
index b1773c80a..d412e1be0 100644
--- a/config/kafka.yml
+++ b/config/kafka.yml
@@ -1,18 +1,36 @@
+# Username for authentication
username: ''
+# Password for authentication
password: ''
+# Producer acknowledgment settings
producerAck: ""
+# Compression type to use (e.g., none, gzip, snappy)
compressType: "none"
+# List of Kafka broker addresses
address: [ localhost:19094 ]
+# Kafka topic for Redis integration
toRedisTopic: "toRedis"
+# Kafka topic for MongoDB integration
toMongoTopic: "toMongo"
+# Kafka topic for push notifications
toPushTopic: "toPush"
+# Consumer group ID for Redis topic
toRedisGroupID: redis
+# Consumer group ID for MongoDB topic
toMongoGroupID: mongo
+# Consumer group ID for push notifications topic
toPushGroupID: push
+# TLS (Transport Layer Security) configuration
tls:
+ # Enable or disable TLS
enableTLS: false
+ # CA certificate file path
caCrt: ""
+ # Client certificate file path
clientCrt: ""
+ # Client key file path
clientKey: ""
+ # Client key password
clientKeyPwd: ""
+ # Whether to skip TLS verification (not recommended for production)
insecureSkipVerify: false
diff --git a/config/minio.yml b/config/minio.yml
index 0a80bb845..11a9ace35 100644
--- a/config/minio.yml
+++ b/config/minio.yml
@@ -1,7 +1,16 @@
+# Name of the bucket in MinIO
bucket: "openim"
+# Access key ID for MinIO authentication
accessKeyID: "root"
+# Secret access key for MinIO authentication
secretAccessKey: "openIM123"
+# Session token for MinIO authentication (optional)
sessionToken: ''
-internalAddress: "minio:9000"
+# Internal address of the MinIO server
+internalAddress: "localhost:10005"
+# External address of the MinIO server, accessible from outside. Supports both HTTP and HTTPS using a domain name
externalAddress: "http://external_ip:10005"
-publicRead: false
\ No newline at end of file
+# Flag to enable or disable public read access to the bucket
+publicRead: false
+
+
diff --git a/config/mongodb.yml b/config/mongodb.yml
index 12f1f66a5..98f5694e4 100644
--- a/config/mongodb.yml
+++ b/config/mongodb.yml
@@ -1,7 +1,14 @@
+# URI for database connection, leave empty if using address and credential settings directly
uri: ''
+# List of MongoDB server addresses
address: [ localhost:37017 ]
+# Name of the database
database: openim_v3
+# Username for database authentication
username: openIM
+# Password for database authentication
password: openIM123
+# Maximum number of connections in the connection pool
maxPoolSize: 100
-maxRetry: 10
\ No newline at end of file
+# Maximum number of retry attempts for a failed database connection
+maxRetry: 10
diff --git a/config/notification.yml b/config/notification.yml
index 1afb44e46..278376c24 100644
--- a/config/notification.yml
+++ b/config/notification.yml
@@ -17,32 +17,23 @@
# The options field 'isNotification' indicates if it's a notification.
groupCreated:
isSendMsg: true
-
# Reliability level of the message sending.
# Set to 1 to send only when online, 2 for guaranteed delivery.
reliabilityLevel: 1
-
# This setting is effective only when 'isSendMsg' is true.
# It controls whether to count unread messages.
unreadCount: false
-
# Configuration for offline push notifications.
offlinePush:
# Enables or disables offline push notifications.
enable: false
-
# Title for the notification when a group is created.
title: "create group title"
-
# Description for the notification.
desc: "create group desc"
-
# Additional information for the notification.
ext: "create group ext"
-# Content type is not added here.
-# Content should use a JSON structure conforming to the protobuf format.
-
groupInfoSet:
isSendMsg: false
reliabilityLevel: 1
diff --git a/config/openim-msggateway.yml b/config/openim-msggateway.yml
index ad6e180cc..0c92d8327 100644
--- a/config/openim-msggateway.yml
+++ b/config/openim-msggateway.yml
@@ -1,19 +1,30 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10140 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20112 ]
+# IP address that the RPC/WebSocket service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
longConnSvr:
+ # WebSocket listening ports, must match the number of rpc.ports
ports: [ 10001 ]
+ # Maximum number of WebSocket connections
websocketMaxConnNum: 100000
+ # Maximum length of the entire WebSocket message packet
websocketMaxMsgLen: 4096
+ # WebSocket connection handshake timeout in seconds
websocketTimeout: 10
+# 1: For Android, iOS, Windows, Mac, and web platforms, only one instance can be online at a time
multiLoginPolicy: 1
+
diff --git a/config/openim-msgtransfer.yml b/config/openim-msgtransfer.yml
index 9cb1598b5..07a7dc1ab 100644
--- a/config/openim-msgtransfer.yml
+++ b/config/openim-msgtransfer.yml
@@ -1,3 +1,6 @@
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly
+ # Because four instances have been launched, four ports need to be specified
ports: [ 20108, 20109, 20110, 20111 ]
diff --git a/config/openim-push.yml b/config/openim-push.yml
index 35e1b2c07..a1abfcf88 100644
--- a/config/openim-push.yml
+++ b/config/openim-push.yml
@@ -1,14 +1,20 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10170 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20107 ]
maxConcurrentWorkers: 3
-enable: getui
+#"Use geTui for offline push notifications, or choose fcm or jpns; corresponding configuration settings must be specified."
+enable: "geTui"
geTui:
pushUrl: "https://restapi.getui.com/v2/$appId"
masterSecret: ''
@@ -24,6 +30,7 @@ jpns:
pushURL: ''
pushIntent: ''
+# iOS system push sound and badge count
iosPush:
pushSound: "xxx"
badgeCount: true
diff --git a/config/openim-rpc-auth.yml b/config/openim-rpc-auth.yml
index a77b5457e..2d861cd5a 100644
--- a/config/openim-rpc-auth.yml
+++ b/config/openim-rpc-auth.yml
@@ -1,13 +1,18 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10160 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20106 ]
tokenPolicy:
- #token有效期,单位(天)
+ # Token validity period, in days
expire: 90
diff --git a/config/openim-rpc-conversation.yml b/config/openim-rpc-conversation.yml
index e2d9b6a53..a094bfac1 100644
--- a/config/openim-rpc-conversation.yml
+++ b/config/openim-rpc-conversation.yml
@@ -1,11 +1,13 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10180 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20105 ]
-
-
-
diff --git a/config/openim-rpc-friend.yml b/config/openim-rpc-friend.yml
index 109e3f658..7b829f971 100644
--- a/config/openim-rpc-friend.yml
+++ b/config/openim-rpc-friend.yml
@@ -1,8 +1,13 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10120 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20104 ]
diff --git a/config/openim-rpc-group.yml b/config/openim-rpc-group.yml
index a70d6f96e..78b44030e 100644
--- a/config/openim-rpc-group.yml
+++ b/config/openim-rpc-group.yml
@@ -1,9 +1,13 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10150 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20103 ]
-
diff --git a/config/openim-rpc-msg.yml b/config/openim-rpc-msg.yml
index de5e2324d..17ce26e9b 100644
--- a/config/openim-rpc-msg.yml
+++ b/config/openim-rpc-msg.yml
@@ -1,13 +1,19 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10130 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20102 ]
-#发消息是否需要好友验证
+
+# Does sending messages require friend verification
friendVerify: false
diff --git a/config/openim-rpc-third.yml b/config/openim-rpc-third.yml
index e3a847bf2..bb41c93ae 100644
--- a/config/openim-rpc-third.yml
+++ b/config/openim-rpc-third.yml
@@ -1,13 +1,20 @@
rpc:
+ # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP
registerIP: ''
+ # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP
listenIP: 0.0.0.0
+ # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports
ports: [ 10190 ]
prometheus:
+ # Enable or disable Prometheus monitoring
enable: true
+ # List of ports that Prometheus listens on; these must match the number of rpc.ports to ensure correct monitoring setup
ports: [ 20101 ]
+
object:
+ # Use MinIO as object storage, or set to "cos", "oss", "kodo", "aws", while also configuring the corresponding settings
enable: "minio"
cos:
bucketURL: https://temp-1252357374.cos.ap-chengdu.myqcloud.com
diff --git a/go.mod b/go.mod
index 891125a89..1279a1285 100644
--- a/go.mod
+++ b/go.mod
@@ -1,6 +1,6 @@
module github.com/openimsdk/open-im-server/v3
-go 1.20
+go 1.21.2
require (
firebase.google.com/go v3.13.0+incompatible
diff --git a/go.sum b/go.sum
index 5dc0cc524..9b31342d8 100644
--- a/go.sum
+++ b/go.sum
@@ -22,10 +22,13 @@ github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mo
github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible h1:8psS8a+wKfiLt1iVDX79F7Y6wUM49Lcha2FMXt4UM8g=
github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible/go.mod h1:T/Aws4fEfogEE9v+HPhhw+CntffsBHJ8nXQCwKr0/g8=
github.com/benbjohnson/clock v1.1.0 h1:Q92kusRqC1XV2MjkWETPvjJVqKetz1OzxZB7mHJLju8=
+github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA=
github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM=
github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
github.com/bsm/ginkgo/v2 v2.12.0 h1:Ny8MWAHyOepLGlLKYmXG4IEkioBysk6GpaRTLC8zwWs=
+github.com/bsm/ginkgo/v2 v2.12.0/go.mod h1:SwYbGRRDovPVboqFv0tPTcG1sN61LM1Z4ARdbAV9g4c=
github.com/bsm/gomega v1.27.10 h1:yeMWxP2pV2fG3FgAODIY8EiRE3dy0aeFYt4l7wh6yKA=
+github.com/bsm/gomega v1.27.10/go.mod h1:JyEr/xRbxbtgWNi8tIEVPUYZ5Dzef52k01W3YH0H+O0=
github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM=
github.com/bytedance/sonic v1.9.1 h1:6iJ6NqdoxCDr6mbY8h18oSO+cShGSMRGCEo7F2h0x8s=
github.com/bytedance/sonic v1.9.1/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U=
@@ -43,6 +46,7 @@ github.com/clbanning/mxj v1.8.4/go.mod h1:BVjHeAH+rl9rs6f+QIpeRl0tfu10SXn1pUSa5P
github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc=
github.com/cncf/xds/go v0.0.0-20231128003011-0fa0005c9caa h1:jQCWAUqqlij9Pgj2i/PB79y4KOPYVyFYdROxgaCwdTQ=
+github.com/cncf/xds/go v0.0.0-20231128003011-0fa0005c9caa/go.mod h1:x/1Gn8zydmfq8dk6e9PdstVsDgu9RuyIIJqAaF//0IM=
github.com/cpuguy83/go-md2man/v2 v2.0.3/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
@@ -66,12 +70,15 @@ github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.m
github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98=
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
github.com/envoyproxy/protoc-gen-validate v1.0.4 h1:gVPz/FMfvh57HdSJQyvBtF00j8JU4zdyUgIUNhlgg0A=
+github.com/envoyproxy/protoc-gen-validate v1.0.4/go.mod h1:qys6tmnRsYrQqIhm2bvKZH4Blx/1gTIZ2UKVY1M+Yew=
github.com/fatih/color v1.14.1 h1:qfhVLaG5s+nCROl1zJsZRxFeYrHLqWroPOQ8BWiNb4w=
github.com/fatih/color v1.14.1/go.mod h1:2oHN61fhTpgcxD3TSWCgKDiH1+x4OiDVVGH8WlgGZGg=
github.com/felixge/httpsnoop v1.0.4 h1:NFTV2Zj1bL4mc9sqWACXbQFVBBg2W3GPvqp8/ESS2Wg=
github.com/felixge/httpsnoop v1.0.4/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8vw=
+github.com/fortytw2/leaktest v1.3.0/go.mod h1:jDsjWgpAGjm2CA7WthBh/CdZYEPF31XHquHwclZch5g=
github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHkI4W8=
+github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0=
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA=
@@ -90,6 +97,7 @@ github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre
github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY=
github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0=
github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s=
+github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA=
github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY=
github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY=
@@ -137,11 +145,13 @@ github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/
github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
+github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck=
github.com/google/go-querystring v1.1.0 h1:AnCroh3fv4ZBgVIf1Iwtovgjaw/GiKJo8M8yD/fhyJ8=
github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17icRSOU623lUBU=
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
github.com/google/martian/v3 v3.3.2 h1:IqNFLAmvJOgVlpdEBiQbDc2EwKW77amAycfTuWKdfvw=
+github.com/google/martian/v3 v3.3.2/go.mod h1:oBOf6HBosgwRXnUGWUB05QECsc6uvmMiJ3+6W4l/CUk=
github.com/google/pprof v0.0.0-20210407192527-94a9f03dee38/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
github.com/google/s2a-go v0.1.7 h1:60BLSyTrOV4/haCDW4zb1guZItoSq8foHCXrAnjBo/o=
github.com/google/s2a-go v0.1.7/go.mod h1:50CgR4k1jNlWBu4UfS4AcfhVe1r6pdZPygJ3R8F0Qdw=
@@ -194,6 +204,7 @@ github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkr
github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ=
github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
github.com/jonboulle/clockwork v0.4.0 h1:p4Cf1aMWXnXAUh8lVfewRBx1zaTSYKrKMF2g3ST4RZ4=
+github.com/jonboulle/clockwork v0.4.0/go.mod h1:xgRqUGwRcjKCO1vbZUEtSLrqKoPSsUpK7fnezOII0kc=
github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
github.com/kelindar/bitmap v1.5.2 h1:XwX7CTvJtetQZ64zrOkApoZZHBJRkjE23NfqUALA/HE=
@@ -209,7 +220,9 @@ github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa02
github.com/klauspost/cpuid/v2 v2.2.6 h1:ndNyv040zDGIDh8thGkXYjnFtiN02M1PVVF+JE/48xc=
github.com/klauspost/cpuid/v2 v2.2.6/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
+github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
+github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ=
github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI=
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc h1:RKf14vYWi2ttpEmkA4aQ3j4u9dStX2t4M8UM6qqNsG8=
@@ -282,6 +295,7 @@ github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZN
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 h1:Jamvg5psRIccs7FGNTlIRMkT8wgtp5eCXdBlqhYGL6U=
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/prashantv/gostub v1.1.0 h1:BTyx3RfQjRHnUWaGF9oQos79AlQ5k8WNktv7VGvVH4g=
+github.com/prashantv/gostub v1.1.0/go.mod h1:A5zLQHz7ieHGG7is6LLXLz7I8+3LZzsrV0P1IAHhP5U=
github.com/prometheus/client_golang v1.18.0 h1:HzFfmkOzH5Q8L8G+kSJKUx5dtG87sewO+FoDDqP5Tbk=
github.com/prometheus/client_golang v1.18.0/go.mod h1:T+GXkCk5wSJyOqMIzVgvvjFDlkOQntgjkJWKrN5txjA=
github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
@@ -298,6 +312,7 @@ github.com/redis/go-redis/v9 v9.4.0/go.mod h1:hdY0cQFCN4fnSYT6TkisLufl/4W5UIXyv0
github.com/robfig/cron/v3 v3.0.1 h1:WdRxkvbJztn8LMz/QEvLN5sBU+xKpSqwwUO1Pjr4qDs=
github.com/robfig/cron/v3 v3.0.1/go.mod h1:eQICP3HwyT7UooqI/z+Ov+PtYAWygg1TEWWzGIFLtro=
github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M=
+github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA=
github.com/rs/xid v1.5.0 h1:mKX4bl4iPYJtEIxp6CYiUuLQ/8DYMoz0PUdtGgMFRVc=
github.com/rs/xid v1.5.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg=
github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
@@ -376,6 +391,7 @@ go.opentelemetry.io/otel v1.23.0/go.mod h1:YCycw9ZeKhcJFrb34iVSkyT0iczq/zYDtZYFu
go.opentelemetry.io/otel/metric v1.23.0 h1:pazkx7ss4LFVVYSxYew7L5I6qvLXHA0Ap2pwV+9Cnpo=
go.opentelemetry.io/otel/metric v1.23.0/go.mod h1:MqUW2X2a6Q8RN96E2/nqNoT+z9BSms20Jb7Bbp+HiTo=
go.opentelemetry.io/otel/sdk v1.21.0 h1:FTt8qirL1EysG6sTQRZ5TokkU8d0ugCj8htOgThZXQ8=
+go.opentelemetry.io/otel/sdk v1.21.0/go.mod h1:Nna6Yv7PWTdgJHVRD9hIYywQBRx7pbox6nwBnZIxl/E=
go.opentelemetry.io/otel/trace v1.23.0 h1:37Ik5Ib7xfYVb4V1UtnT97T1jI+AoIYkJyPkuL4iJgI=
go.opentelemetry.io/otel/trace v1.23.0/go.mod h1:GSGTbIClEsuZrGIzoEHqsVfxgn5UkggkflQwDScNUsk=
go.uber.org/atomic v1.9.0 h1:ECmE8Bn/WFTYwEW/bpKD3M8VtR/zQVbavAoalC1PYyE=
@@ -383,6 +399,7 @@ go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc=
go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8=
go.uber.org/automaxprocs v1.5.3/go.mod h1:eRbA25aqJrxAbsLO0xy5jVwPt7FQnRgjW+efnwa1WM0=
go.uber.org/goleak v1.1.11 h1:wy28qYRKZgnJTxGxvye5/wgWr1EKjmUDGYox5mGlRlI=
+go.uber.org/goleak v1.1.11/go.mod h1:cwTWslyiVhfpKIDGSZEM2HlOvcqm+tG4zioyIeLoqMQ=
go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0=
go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60=
@@ -489,6 +506,7 @@ golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8T
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 h1:H2TDz8ibqkAF6YGhCdN3jS9O0/s90v0rJh3X/OLHEUk=
+golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8=
google.golang.org/api v0.165.0 h1:zd5d4JIIIaYYsfVy1HzoXYZ9rWCSBxxAglbczzo7Bgc=
google.golang.org/api v0.165.0/go.mod h1:2OatzO7ZDQsoS7IFf3rvsE17/TldiU3F/zxFHeqUB5o=
google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
@@ -526,6 +544,7 @@ google.golang.org/protobuf v1.33.0 h1:uNO2rsAINq/JlFpSdYEKIZ0uKD/R9cpdv0T+yoGwGm
google.golang.org/protobuf v1.33.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
+gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA=
gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k=
diff --git a/internal/push/offlinepush/offlinepusher.go b/internal/push/offlinepush/offlinepusher.go
index 0706be64a..d4fcae434 100644
--- a/internal/push/offlinepush/offlinepusher.go
+++ b/internal/push/offlinepush/offlinepusher.go
@@ -26,7 +26,7 @@ import (
)
const (
- geTUI = "getui"
+ geTUI = "geTui"
firebase = "fcm"
jPush = "jpush"
)
diff --git a/internal/push/push_handler.go b/internal/push/push_handler.go
index e09b0b2ec..3a9a696f6 100644
--- a/internal/push/push_handler.go
+++ b/internal/push/push_handler.go
@@ -259,7 +259,7 @@ func (c *ConsumerHandler) groupMessagesHandler(ctx context.Context, groupID stri
*pushToUserIDs = append(*pushToUserIDs, kickedUsers...)
case constant.GroupDismissedNotification:
- if msgprocessor.IsNotification(msgprocessor.GetConversationIDByMsg(msg)) { // 消息先到,通知后到
+ if msgprocessor.IsNotification(msgprocessor.GetConversationIDByMsg(msg)) {
var tips sdkws.GroupDismissedTips
if unmarshalNotificationElem(msg.Content, &tips) != nil {
return err
diff --git a/start-config.yml b/start-config.yml
index cd9663c98..a9c412b33 100644
--- a/start-config.yml
+++ b/start-config.yml
@@ -4,7 +4,7 @@ serviceBinaries:
openim-rpc-user: 1
openim-msggateway: 1
openim-push: 1
- openim-msgtransfer: 1
+ openim-msgtransfer: 4
openim-rpc-conversation: 1
openim-rpc-auth: 1
openim-rpc-group: 1
@@ -12,8 +12,6 @@ serviceBinaries:
openim-rpc-msg: 1
openim-rpc-third: 1
toolBinaries:
- - ncpu
- check-free-memory
- - versionchecker
- check-component
maxFileDescriptors: 10000