Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nuomi1/nbus
NBus is a sharing and signin library for Chinese Social Application, such as WeChat, QQ and Weibo. NBus also supports system's sharing and Sign in with Apple.
https://github.com/nuomi1/nbus
apple oauth qq share wechat weibo
Last synced: 3 months ago
JSON representation
NBus is a sharing and signin library for Chinese Social Application, such as WeChat, QQ and Weibo. NBus also supports system's sharing and Sign in with Apple.
- Host: GitHub
- URL: https://github.com/nuomi1/nbus
- Owner: nuomi1
- License: mit
- Created: 2020-07-10T11:56:20.000Z (over 4 years ago)
- Default Branch: develop
- Last Pushed: 2022-05-23T13:11:59.000Z (over 2 years ago)
- Last Synced: 2024-10-08T09:19:10.206Z (4 months ago)
- Topics: apple, oauth, qq, share, wechat, weibo
- Language: Swift
- Homepage:
- Size: 6.16 MB
- Stars: 29
- Watchers: 3
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NBus
[![CI Status](https://img.shields.io/github/workflow/status/nuomi1/NBus/Swift)](https://github.com/nuomi1/NBus)
[![Version](https://img.shields.io/cocoapods/v/NBus)](https://cocoapods.org/pods/NBus)
[![License](https://img.shields.io/cocoapods/l/NBus)](https://cocoapods.org/pods/NBus)
[![Platform](https://img.shields.io/cocoapods/p/NBus)](https://cocoapods.org/pods/NBus)## Introduction
NBus is a sharing and signin library for Chinese Social Application, such as WeChat, QQ and Weibo.
NBus also supports system's sharing and Sign in with Apple.## Feature
### Share
| Handler | Text | Image | Audio | Video | WebPage | File | MiniProgram |
| ---------------- | :--: | :---: | :---: | :---: | :-----: | :--: | :---------: |
| QQHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ |
| QQSDKHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ |
| WechatHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ |
| WechatSDKHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ |
| WeiboHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ❌ | ❌ |
| WeiboSDKHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ❌ | ❌ |
| SystemHandler | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ✔️ | ❌ |### Oauth
| Handler | Oauth |
| ---------------- | :---: |
| QQHandler | ✔️ |
| QQSDKHandler | ✔️ |
| WechatHandler | ✔️ |
| WechatSDKHandler | ✔️ |
| WeiboHandler | ✔️ |
| WeiboSDKHandler | ✔️ |
| SystemHandler | ✔️ |### Launch
| Handler | MiniProgram |
| ---------------- | :---------: |
| QQHandler | ✔️ |
| QQSDKHandler | ✔️ |
| WechatHandler | ✔️ |
| WechatSDKHandler | ✔️ |
| WeiboHandler | ❌ |
| WeiboSDKHandler | ❌ |
| SystemHandler | ❌ |> - ✔️ - Support
> - ⭕ - Experimental support
> - ❌ - NOT support## Requirements
- Swift 5.0
- iOS 10.0
- [QQ 8.1.3 - 20190830](https://wiki.connect.qq.com/universal-links%E9%80%82%E9%85%8Dfaq)
- [Wechat 7.0.7 - 20190917](https://developers.weixin.qq.com/doc/oplatform/Mobile_App/Access_Guide/iOS.html)
- [Weibo ~ 20201017](https://github.com/sinaweibosdk/weibo_ios_sdk)## Usage
1. Edit `LSApplicationQueriesSchemes` in `Info.plist`.
```xml
mqq
mqqopensdkapiV2
mqqopensdklaunchminiapp
mqqopensdkminiapp
mqqopensdknopasteboard
weixin
weixinULAPI
sinaweibo
weibosdk
weibosdk3.3```
2. Edit `CFBundleURLTypes` in `Info.plist`.
```xml
CFBundleTypeRole
Editor
CFBundleURLName
CFBundleURLSchemes
tencent123456
CFBundleTypeRole
Editor
CFBundleURLName
CFBundleURLSchemes
wx123456
CFBundleTypeRole
Editor
CFBundleURLName
CFBundleURLSchemes
wb123456
```
3. Edit `com.apple.developer.associated-domains` in `TARGET.entitlements`.
```xml
applinks:www.example.com
```
4. Register handler(s) before using NBus.
```swift
func application(
_ application: UIApplication,
didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
) -> Bool {
let qqHandler = QQHandler(
appID: "tencent123456",
universalLink: URL(string: "https://www.example.com/qq_conn/123456/")!
)Bus.shared.handlers = [qqHandler]
}
``````swift
func application(
_ app: UIApplication,
open url: URL,
options: [UIApplication.OpenURLOptionsKey: Any] = [:]
) -> Bool {
Bus.shared.openURL(url)
}
``````swift
func application(
_ application: UIApplication,
continue userActivity: NSUserActivity,
restorationHandler: @escaping ([UIUserActivityRestoring]?) -> Void
) -> Bool {
Bus.shared.openUserActivity(userActivity)
}
```5. Share message using NBus.
```swift
let message = Messages.text(text: "NBus")
let endpoint = Endpoints.QQ.friendBus.shared.share(message: message, to: endpoint) { result in
switch result {
case .success:
print("Success")
case let .failure(error):
print(error)
}
}
```6. Oauth using NBus.
```swift
let platform = Platforms.qqBus.shared.oauth(with: platform) { result in
switch result {
case let .success(parameters):
let accessToken = parameters[Bus.OauthInfoKeys.QQ.accessToken]
let expirationDate = parameters[Bus.OauthInfoKeys.QQ.expirationDate]
let openID = = parameters[Bus.OauthInfoKeys.QQ.openID]print(accessToken, expirationDate, openID)
case let .failure(error):
print(error)
}
}
```7. Launch Mini Program using NBus.
```swift
let program = Messages.miniProgram(
miniProgramID: "123456",
path: "/example",
link: URL(string: "https://www.example.com")!,
miniProgramType: .release,
title: "NBus",
description: "NBus",
thumbnail: UIImage(named: "example")?.jpegData(compressionQuality: 1)
)let platform = Platforms.qq
Bus.shared.launch(program: program, with: platform) { result in
switch result {
case .success:
print("Success") // Never happen
case let .failure(error):
print(error)
}
}
```## Example
To run the example project, clone the repo, edit the `Example/NBus/Config.xcconfig` file, and run `bundle install && bundle exec fastlane setup && open Example/NBus.xcworkspace` from the Example directory first.
## Installation
### CocoaPods
You can use `NBus` directly which is including all SDK bridging handlers.
```ruby
pod "NBus" # default subspecs "SDKHandlers"
```or all open source handlers.
```ruby
pod "NBus/BusHandlers"
```or what you like.
```ruby
pod "NBus/QQSDKHandler"
pod "NBus/QQHandler"pod "NBus/WechatSDKHandler"
pod "NBus/WechatHandler"pod "NBus/WeiboSDKHandler"
pod "NBus/WeiboHandler"pod "NBus/SystemHandler"
```even those SDKs.
```ruby
pod "NBusQQSDK"pod "NBusWechatSDK"
pod "NBusWeiboSDK"
```## WARNING
1. `WeiboSDK.bundle` must saved in App's root path.
## Author
nuomi1, [[email protected]](mailto:[email protected])
## Related articles
- [NBus 的由来](https://blog.nuomi1.com/archives/2020/09/nbus-comes-from.html)
- [NBus 之 QQHandler](https://blog.nuomi1.com/archives/2021/01/nbus-qqhandler.html)
- [NBus 之 QQSDKHandler](https://blog.nuomi1.com/archives/2020/12/nbus-qqsdkhandler.html)
- [NBus 之 SystemHandler](https://blog.nuomi1.com/archives/2020/12/nbus-systemhandler.html)
- [NBus 之 WechatHandler](https://blog.nuomi1.com/archives/2021/01/nbus-wechathandler.html)
- [NBus 之 WechatSDKHandler](https://blog.nuomi1.com/archives/2020/12/nbus-wechatsdkhandler.html)
- [NBus 之 WeiboHandler](https://blog.nuomi1.com/archives/2021/01/nbus-weibohandler.html)
- [NBus 之 WeiboSDKHandler](https://blog.nuomi1.com/archives/2020/12/nbus-weibosdkhandler.html)## Thanks
- [MonkeyKing](https://github.com/nixzhu/MonkeyKing)
- [LQThirdParty](https://github.com/LQi2009/LQThirdParty)## License
NBus is available under the MIT license. See the LICENSE file for more info.