openimsdk / openim-sdk-core

Instant Messaging
https://openim.io
Apache License 2.0
326 stars 304 forks source link
android im imsdk ios sdk

openim-sdk-core

⭐️ Used in IOS, Android, PC and other platforms ⭐️

A+ good first

English中文

---- ## 🧩 Awesome features OpenIM-SDK-core is a core SDK of OpenIM. 1. Manage WebSocket long connections, responsible for creating, closing and reconnecting connections. 2. Encoding and decoding. Encode and decode messages in binary format to achieve cross-language compatibility. 3. Implement basic protocols of OpenIM, such as login, push, etc. 4. Provide an event handling mechanism to convert received messages into corresponding events and pass them to upper layer applications for processing. 5. Cache management. Manage user, group, blacklists, and other cache information. 6. Provide basic IM function APIs such as sending messages, creating groups, etc. Hide the underlying implementation details from the upper layer application. ## Quickstart > **Note**: You can get started quickly with openim-sdk-core.
Work with Makefile ```bash ❯ make help # show help ❯ make build # build binary ```
Work with actions Actions provide handling of PR and issue. We used the bot @kubbot, It can detect issues in Chinese and translate them to English, and you can interact with it using the command `/comment`. Comment in an issue: ```bash ❯ /intive ```
Work with Tools ```bash ❯ make tools ```
Work with Docker ```bash $ make deploy ```
## Contributing & Development OpenIM Our goal is to build a top-level open source community. We have a set of standards, in the [Community repository](https://github.com/openimsdk/community). If you'd like to contribute to this openim-sdk-core repository, please read our [contributor documentation](https://github.com/openimsdk/openim-sdk-core/blob/main/CONTRIBUTING.md). ## community meeting We welcome everyone to join us and contribute to openim-sdk-core, whether you are new to open source or professional. We are committed to promoting an open source culture, so we offer community members neighborhood prizes and reward money in recognition of their contributions. We believe that by working together, we can build a strong community and make valuable open source tools and resources available to more people. So if you are interested in openim-sdk-core, please join our community and start contributing your ideas and skills! We take notes of each [biweekly meeting](https://github.com/openimsdk/Open-IM-Server/issues/381) in [GitHub discussions](https://github.com/openimsdk/Open-IM-Server/discussions/categories/meeting), and our minutes are written in [Google Docs](https://docs.google.com/document/d/1nx8MDpuG74NASx081JcCpxPgDITNTpIIos0DS6Vr9GU/edit?usp=sharing). openim-sdk-core maintains a [public roadmap](https://github.com/openimsdk/community/tree/main/roadmaps). It gives a a high-level view of the main priorities for the project, the maturity of different features and projects, and how to influence the project direction. ## about OpenIM ### common + https://github.com/openimsdk/automation: OpenIM Automation, cicd, and actions, Robotics. + https://github.com/openimsdk/community: Community Management for OpenIM ### OpenIM **Links** Contains some common parts of the OpenIM community. + https://github.com/openimsdk/automation: OpenIM Automation, cicd, and actions, Robotics. + https://github.com/openimsdk/openim-sdk-core: The IMSDK implemented by golang can be used in IOS, Android, PC and other platforms. + https://github.com/openimsdk/openim-sdk-core: Instant messaging IM server. + https://github.com/openimsdk/community: Community Management for OpenIM. ### SDKs + [openim-sdk-core](https://github.com/openimsdk/openim-sdk-core): A cross-platform SDK implemented in golang that can be used in IOS, Android, PC, and other platforms. + [Open-IM-SDK-iOS](https://github.com/openimsdk/Open-IM-SDK-iOS): An iOS SDK generated based on openim-sdk-core, available for developers to reference. + [Open-IM-SDK-Android](https://github.com/openimsdk/Open-IM-SDK-Android): An Android SDK generated based on openim-sdk-core, available for developers to reference. + [Open-IM-SDK-Flutter](https://github.com/openimsdk/Open-IM-SDK-Flutter): A Flutter SDK generated based on Open-IM-SDK-iOS and Open-IM-SDK-Android, available for developers to reference. + [Open-IM-SDK-Uniapp](https://github.com/openimsdk/Open-IM-SDK-Uniapp): A uni-app SDK generated based on Open-IM-SDK-iOS and Open-IM-SDK-Android, available for developers to reference. ### Demos + [Open-IM-iOS-Demo](https://github.com/openimsdk/Open-IM-iOS-Demo): An iOS demo based on Open-IM-SDK-iOS, available for developers to reference. + [Open-IM-Android-Demo](https://github.com/openimsdk/Open-IM-Android-Demo): An Android demo based on Open-IM-SDK-Android, available for developers to reference. + [Open-IM-Flutter-Demo](https://github.com/openimsdk/Open-IM-Flutter-Demo): A Flutter demo based on Open-IM-SDK-Flutter, available for developers to reference. ## Used By OpenIM is used by the following companies ,let's write it down in [ADOPTER](https://github.com/openimsdk/community/blob/main/ADOPTERS.md). Please leave your use cases in the comments [here](https://github.com/openimsdk/Open-IM-Server/issues/379). ## License [openim-sdk-core](https://github.com/openimsdk/openim-sdk-core) is licensed under the Apache License, Version 2.0. See [LICENSE](https://github.com/openimsdk/openim-sdk-core/tree/main/LICENSE) for the full license text. ## Thanks to our contributors!