mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-08-04 06:50:23 +00:00

* chore: bump version 0.8.8 * feat: add bloc observer * chore: update comment * chore: update comment
87 lines
2.4 KiB
Dart
87 lines
2.4 KiB
Dart
import 'dart:async';
|
|
import 'dart:convert';
|
|
import 'dart:ffi';
|
|
import 'dart:io';
|
|
import 'dart:isolate';
|
|
|
|
import 'package:appflowy_backend/log.dart';
|
|
import 'package:appflowy_backend/rust_stream.dart';
|
|
import 'package:ffi/ffi.dart';
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'ffi.dart' as ffi;
|
|
|
|
export 'package:async/async.dart';
|
|
|
|
enum ExceptionType {
|
|
AppearanceSettingsIsEmpty,
|
|
}
|
|
|
|
class FlowySDKException implements Exception {
|
|
ExceptionType type;
|
|
FlowySDKException(this.type);
|
|
}
|
|
|
|
class FlowySDK {
|
|
static const MethodChannel _channel = MethodChannel('appflowy_backend');
|
|
static Future<String> get platformVersion async {
|
|
final String version = await _channel.invokeMethod('getPlatformVersion');
|
|
return version;
|
|
}
|
|
|
|
FlowySDK();
|
|
|
|
Future<void> dispose() async {}
|
|
|
|
Future<void> init(String configuration) async {
|
|
ffi.set_stream_port(RustStreamReceiver.shared.port);
|
|
ffi.store_dart_post_cobject(NativeApi.postCObject);
|
|
|
|
// On iOS, VSCode can't print logs from Rust, so we need to use a different method to print logs.
|
|
// So we use a shared port to receive logs from Rust and print them using the logger. In release mode, we don't print logs.
|
|
if (Platform.isIOS && kDebugMode) {
|
|
ffi.set_log_stream_port(RustLogStreamReceiver.logShared.port);
|
|
}
|
|
|
|
// final completer = Completer<Uint8List>();
|
|
// // Create a SendPort that accepts only one message.
|
|
// final sendPort = singleCompletePort(completer);
|
|
|
|
final code = ffi.init_sdk(0, configuration.toNativeUtf8());
|
|
if (code != 0) {
|
|
throw Exception('Failed to initialize the SDK');
|
|
}
|
|
// return completer.future;
|
|
}
|
|
}
|
|
|
|
class RustLogStreamReceiver {
|
|
static RustLogStreamReceiver logShared = RustLogStreamReceiver._internal();
|
|
late RawReceivePort _ffiPort;
|
|
late StreamController<Uint8List> _streamController;
|
|
late StreamSubscription<Uint8List> _subscription;
|
|
int get port => _ffiPort.sendPort.nativePort;
|
|
|
|
RustLogStreamReceiver._internal() {
|
|
_ffiPort = RawReceivePort();
|
|
_streamController = StreamController();
|
|
_ffiPort.handler = _streamController.add;
|
|
|
|
_subscription = _streamController.stream.listen((data) {
|
|
String decodedString = utf8.decode(data);
|
|
Log.info(decodedString);
|
|
});
|
|
}
|
|
|
|
factory RustLogStreamReceiver() {
|
|
return logShared;
|
|
}
|
|
|
|
Future<void> dispose() async {
|
|
await _streamController.close();
|
|
await _subscription.cancel();
|
|
_ffiPort.close();
|
|
}
|
|
}
|