Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/up9cloud/flutter_libtdjson
A flutter plugin for TDLib JSON interface, ffi binding.
https://github.com/up9cloud/flutter_libtdjson
android ffi flutter flutter-plugin ios libtdjson macos tdjson tdlib telegram telegram-api
Last synced: 2 months ago
JSON representation
A flutter plugin for TDLib JSON interface, ffi binding.
- Host: GitHub
- URL: https://github.com/up9cloud/flutter_libtdjson
- Owner: up9cloud
- License: mit
- Created: 2021-07-06T08:01:11.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-06-16T05:35:07.000Z (7 months ago)
- Last Synced: 2024-06-16T06:01:00.531Z (7 months ago)
- Topics: android, ffi, flutter, flutter-plugin, ios, libtdjson, macos, tdjson, tdlib, telegram, telegram-api
- Language: Dart
- Homepage:
- Size: 267 KB
- Stars: 7
- Watchers: 4
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# flutter_libtdjson
![Build Status](https://github.com/up9cloud/flutter_libtdjson/actions/workflows/main.yml/badge.svg)
[![Pub Version](https://img.shields.io/pub/v/libtdjson)](https://pub.dev/packages/libtdjson)
[![Pub Likes](https://img.shields.io/pub/likes/libtdjson)](https://pub.dev/packages/libtdjson/score)
[![Pub Points](https://img.shields.io/pub/points/libtdjson)](https://pub.dev/packages/libtdjson/score)
[![popularity](https://img.shields.io/pub/popularity/libtdjson)](https://pub.dev/packages/libtdjson/score)A flutter plugin for [TDLib JSON interface](https://github.com/tdlib/td#using-from-other-programming-languages), ffi binding.
## Lib versions
| package | td version |
| ------- | ------------------------------------- |
| 0.2.1 | 1.8.31 (Android, iOS, macOS) |
| 0.2.0 | 1.8.30 (Android, iOS, macOS) |
| 0.1.4 | 1.8.1 (Android, iOS, macOS) |
| 0.1.3 | 1.7.9 (Android, iOS, macOS) |
| 0.1.2 | 1.7.0 (Android), latest (iOS, macOS) |## Supported architectures
Make sure you are using supported one
| Platform | Architecture | |
| ---------------- | ------------ | --- |
| Android | armeabi-v7a | ✅ |
| | arm64-v8a | ✅ |
| Android emulator | x86 | ✅ |
| | x86_64 | ✅ |
| iOS | armv7 | ❌ |
| | armv7s | ❌ |
| | arm64 | ⛔ |
| iOS simulator | i386 | ❌ |
| | x86_64 | ⛔ |
| | arm64 (M1) | ⛔ |
| macOS | i386 | ❌ |
| | x86_64 | ✅ |
| | arm64 (M1) | ✅ |## Installation
- Update `pubspec.yaml`:
```yml
dependencies:
libtdjson: ^0.2.1
```- If you want to build android, you have to add envs for github maven, see `./android/build.gradle`
```bash
export GITHUB_ACTOR=
export GITHUB_TOKEN=
```- If you want to set `tdlibParameters.database_directory` outside work dir, make sure you request the storage permission, e.q. `android/app/src/main/AndroidManifest.xml`
```xml
```- If you want to build macos, have to set network permission in `./macos/Runner/*.entitlements` files
```xml
com.apple.security.network.client
```## Dev memo
### Bump TDLib version
- Bump the td version of [android-libtdjson](https://github.com/up9cloud/android-libtdjson)
- Bump the android dependency version in `./android/build.gradle`
- Run `./example` for android```bash
cd ./example
flutter run -d emulator-5554
```- Bump the td version of [ios-libtdjson](https://github.com/up9cloud/ios-libtdjson)
- Bump the macos dependency version in `./macos/libtdjson.podspec` (s.dependency)
- Run `./example` for macos```bash
cd ./example/macos
pod update flutter_libtdjson
cd ..
flutter run -d macos
```- Bump the ios dependency version in `./ios/libtdjson.podspec`
- Run `./example` for ios simulator```bash
cd ./example/ios
pod update flutter_libtdjson
cd ..
flutter run --debug
# link .dylib to search path, e.q:
# ln -s $(pwd)/build/ios/Debug-iphonesimulator/XCFrameworkIntermediates/flutter_libtdjson/libtdjson.dylib ~/Library/Developer/CoreSimulator/Devices/FD63D560-544B-4B18-8F2F-03B093156DE2/data/Containers/Bundle/Application/004B7B3D-4665-4217-A9C7-2D2193107E80/Runner.app/Frameworks/libtdjson.dylib
# Reload with `R`
```- Bump the package version in `./pubspec.yaml`
- Add changelog for new version in `./CHANGELOG.md`
- Bump version info in `./README.md`
- Git commit (message example: `bump td to vx.x.x`)
- Git add tag (`git tag v?.?.?`, the tag version should be same as the version in pubspec.yaml)
- Push with tags (`git push && git push --tags`)
- Wait for CI task### Manually publish
- https://dart.dev/tools/pub/publishing
```bash
dart pub publish# credentials file on macos
cat ~/Library/Application\ Support/dart/pub-credentials.json
```## TODO
- [ ] ⛔ is about `iOS with dylib`. There are .dylib files in build/ios/Debug-iphonesimulator/XCFrameworkIntermediates, but still...