Go to file
OpenIM-Gordon 383758782e
optimization: change the configuration file from being read globally … (#1935)
* optimization: change the configuration file from being read globally to being read independently.

* optimization: change the configuration file from being read globally to being read independently.

* optimization: change the configuration file from being read globally to being read independently.

* optimization: config file changed to dependency injection.

* fix: replace global config with dependency injection

* fix: replace global config with dependency injection

* fix: import the enough param

* fix: import the enough param

* fix: import the enough param

* fix: fix the component check of path

* fix: fix the kafka of tls is nil problem

* fix: fix the TLS.CACrt is nil error

* fix: fix the valiable shadows problem

* fix: fix the comflect

* optimization: message remove options.

* fix: fix the param pass error

* fix: find error

* fix: find error

* fix: find eror

* fix: find error

* fix: find error

* fix: del the undifined func

* fix: find error

* fix: fix the error

* fix: pass config

* fix: find error

* fix: find error

* fix: find error

* fix: find error

* fix: find error

* fix: fix the config

* fix: fix the error

* fix: fix the config pass error

* fix: fix the eror

* fix: fix the error

* fix: fix the error

* fix: fix the error

* fix: find error

* fix: fix the error

* fix: fix the config

* fix: add return err

* fix: fix the err2

* fix: err

* fix: fix the func

* fix: del the chinese comment

* fix: fix the func

* fix: fix the gateway_test logic

* fix: s3

* test

* test

* fix: not found

---------

Co-authored-by: luhaoling <2198702716@qq.com>
Co-authored-by: withchao <993506633@qq.com>
2024-03-05 17:53:22 +08:00
.github feat: Integrate Comprehensive E2E Testing for GoChat (#1906) 2024-03-04 04:12:14 +00:00
CHANGELOG cicd: bump League Patch (#1998) 2024-03-05 02:51:55 +00:00
assets feat: Enhance Script Details and Add MacOS Compatibility with Documentation Updates (#1794) 2024-01-21 02:49:08 +00:00
build Delete build/images/openim-rpc-encryption directory (#1842) 2024-01-31 06:16:19 +00:00
cmd optimization: change the configuration file from being read globally … (#1935) 2024-03-05 17:53:22 +08:00
config feat: Introduce Language-Specific Comment Detection Tool and Standardize Log Filename Convention (#1992) 2024-03-04 09:30:17 +00:00
deployments add aws upload, but not complete, leave some todos (#1858) 2024-02-26 14:47:01 +00:00
docs feat: Introduce Language-Specific Comment Detection Tool and Standardize Log Filename Convention (#1992) 2024-03-04 09:30:17 +00:00
internal optimization: change the configuration file from being read globally … (#1935) 2024-03-05 17:53:22 +08:00
pkg optimization: change the configuration file from being read globally … (#1935) 2024-03-05 17:53:22 +08:00
scripts feat: Introduce Language-Specific Comment Detection Tool and Standardize Log Filename Convention (#1992) 2024-03-04 09:30:17 +00:00
test cicd: bump League Patch (#1998) 2024-03-05 02:51:55 +00:00
tools optimization: change the configuration file from being read globally … (#1935) 2024-03-05 17:53:22 +08:00
.dockerignore Ⓜ️feat: openim docker fix (#1502) 2023-11-30 10:25:38 +00:00
.gitignore feat(main): 🚀 Database Name Correction and S3 Module Int32 Overflow Fix with Go Routine Integration for Automated Checks and Script Optimization (#1799) 2024-01-26 02:02:53 +00:00
.golangci.yml Update readme and golangci lint (#1999) 2024-03-05 07:27:26 +00:00
CHANGELOG.md feat: add link file 2023-07-10 18:19:25 +08:00
CODE_OF_CONDUCT.md Feat/add test scripts (#1341) 2023-11-05 10:36:37 +00:00
CONTRIBUTING-zh_CN.md feat: add architecture layers (#1860) 2024-02-02 11:47:16 +00:00
CONTRIBUTING.md feat: add architecture layers (#1860) 2024-02-02 11:47:16 +00:00
Dockerfile Ⓜ️feat: openim docker fix (#1502) 2023-11-30 10:25:38 +00:00
LICENSE v3 - main to cut out 2023-06-29 22:35:31 +08:00
Makefile feat: Integrate Comprehensive E2E Testing for GoChat (#1906) 2024-03-04 04:12:14 +00:00
README.md Update readme and golangci lint (#1999) 2024-03-05 07:27:26 +00:00
README_zh_CN.md docs: renmae README files about other languages (#1915) 2024-02-18 09:23:22 +00:00
docker-compose-1.yml feat: add docker-compse-1.yml and cancel the openim-admin annotate in docker-compose.yml (#1881) 2024-02-18 10:42:56 +00:00
docker-compose.yml feat: add docker-compse-1.yml and cancel the openim-admin annotate in docker-compose.yml (#1881) 2024-02-18 10:42:56 +00:00
go.mod cicd: bump League Patch (#1963) 2024-02-28 03:01:30 +00:00
go.sum cicd: bump League Patch (#1963) 2024-02-28 03:01:30 +00:00
go.work feat: Introduce Language-Specific Comment Detection Tool and Standardize Log Filename Convention (#1992) 2024-03-04 09:30:17 +00:00
install.sh fix: reconstruct the script of 'make start' 'make stop' and 'make check' (#1953) 2024-02-27 09:58:54 +00:00

README.md

👥 Community

Ⓜ️ About OpenIM

OpenIM is a service platform specifically designed for integrating chat, audio-video calls, notifications, and AI chatbots into applications. It provides a range of powerful APIs and Webhooks, enabling developers to easily incorporate these interactive features into their applications. OpenIM is not a standalone chat application, but rather serves as a platform to support other applications in achieving rich communication functionalities. The following diagram illustrates the interaction between AppServer, AppClient, OpenIMServer, and OpenIMSDK to explain in detail.

App-OpenIM Relationship

🚀 About OpenIMSDK

OpenIMSDK is an IM SDK designed for OpenIMServer, created specifically for embedding in client applications. Its main features and modules are as follows:

  • 🌟 Main Features:

    • 📦 Local storage
    • 🔔 Listener callbacks
    • 🛡️ API wrapping
    • 🌐 Connection management
  • 📚 Main Modules:

    1. 🚀 Initialization and Login
    2. 👤 User Management
    3. 👫 Friend Management
    4. 🤖 Group Functions
    5. 💬 Conversation Handling

It is built using Golang and supports cross-platform deployment, ensuring a consistent access experience across all platforms.

👉 Explore GO SDK

🌐 About OpenIMServer

  • OpenIMServer has the following characteristics:
    • 🌐 Microservice architecture: Supports cluster mode, including a gateway and multiple rpc services.
    • 🚀 Diverse deployment methods: Supports deployment via source code, Kubernetes, or Docker.
    • Support for massive user base: Super large groups with hundreds of thousands of users, tens of millions of users, and billions of messages.

Enhanced Business Functionality:

  • REST API: OpenIMServer offers REST APIs for business systems, aimed at empowering businesses with more functionalities, such as creating groups and sending push messages through backend interfaces.
  • Webhooks: OpenIMServer provides callback capabilities to extend more business forms. A callback means that OpenIMServer sends a request to the business server before or after a certain event, like callbacks before or after sending a message.

👉 Learn more

🏗️ Overall Architecture

Delve into the heart of Open-IM-Server's functionality with our architecture diagram.

Overall Architecture

🚀 Quick Start

We support many platforms. Here are the addresses for quick experience on the web side

👉 OpenIM online web demo

🤲 To facilitate user experience, we offer various deployment solutions. You can choose your deployment method from the list below:

🛠️ To Start Developing OpenIM

Open in Dev Container

Open in GitHub Codespaces

OpenIM Our goal is to build a top-level open source community. We have a set of standards, in the Community repository.

If you'd like to contribute to this Open-IM-Server repository, please read our contributor documentation.

Before you start, please make sure your changes are in demand. The best for that is to create a new discussion OR Slack Communication, or if you find an issue, report it first.

📆 Community Meetings

We want anyone to get involved in our community and contributing code, we offer gifts and rewards, and we welcome you to join us every Thursday night.

Our conference is in the OpenIM Slack 🎯, then you can search the Open-IM-Server pipeline to join

We take notes of each biweekly meeting in GitHub discussions, Our historical meeting notes, as well as replays of the meetings are available at Google Docs 📑.

👀 Who Are Using OpenIM

Check out our user case studies page for a list of the project users. Don't hesitate to leave a 📝comment and share your use case.

📄 License

OpenIM is licensed under the Apache 2.0 license. See LICENSE for the full license text.

The OpenIM logo, including its variations and animated versions, displayed in this repository OpenIM under the assets/logo and assets/logo-gif directories, are protected by copyright laws.

🔮 Thanks to our contributors!