123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- import 'dart:async';
- import 'dart:typed_data';
- import 'package:dartz/dartz.dart';
- import 'package:flowy_infra/flowy_logger.dart';
- import 'package:flowy_sdk/dispatch/dispatch.dart';
- import 'package:flowy_sdk/protobuf/flowy-observable/subject.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-user/user_profile.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/app_create.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/errors.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/observable.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/workspace_create.pb.dart';
- import 'package:flowy_sdk/protobuf/flowy-workspace/workspace_query.pb.dart';
- import 'package:flowy_sdk/rust_stream.dart';
- import 'package:app_flowy/workspace/domain/i_workspace.dart';
- import 'helper.dart';
- class WorkspaceRepo {
- UserProfile user;
- String workspaceId;
- WorkspaceRepo({
- required this.user,
- required this.workspaceId,
- });
- Future<Either<App, WorkspaceError>> createApp(String appName, String desc) {
- final request = CreateAppRequest.create()
- ..name = appName
- ..workspaceId = workspaceId
- ..desc = desc;
- return WorkspaceEventCreateApp(request).send();
- }
- Future<Either<Workspace, WorkspaceError>> getWorkspace() {
- final request = QueryWorkspaceRequest.create()..workspaceId = workspaceId;
- return WorkspaceEventReadWorkspaces(request).send().then((result) {
- return result.fold(
- (workspaces) {
- assert(workspaces.items.length == 1);
- if (workspaces.items.isEmpty) {
- return right(WorkspaceError.create()..msg = "Workspace not found");
- } else {
- return left(workspaces.items[0]);
- }
- },
- (error) => right(error),
- );
- });
- }
- Future<Either<List<App>, WorkspaceError>> getApps() {
- final request = QueryWorkspaceRequest.create()..workspaceId = workspaceId;
- return WorkspaceEventReadWorkspaceApps(request).send().then((result) {
- return result.fold(
- (apps) => left(apps.items),
- (error) => right(error),
- );
- });
- }
- }
- class WorkspaceWatchRepo {
- StreamSubscription<ObservableSubject>? _subscription;
- WorkspaceCreateAppCallback? _createApp;
- WorkspaceDeleteAppCallback? _deleteApp;
- WorkspaceUpdatedCallback? _update;
- late WorkspaceObservableParser _extractor;
- final UserProfile user;
- final String workspaceId;
- WorkspaceWatchRepo({
- required this.user,
- required this.workspaceId,
- });
- void startWatching({
- WorkspaceCreateAppCallback? createApp,
- WorkspaceDeleteAppCallback? deleteApp,
- WorkspaceUpdatedCallback? update,
- }) {
- _createApp = createApp;
- _deleteApp = deleteApp;
- _update = update;
- _extractor = WorkspaceObservableParser(
- id: workspaceId,
- callback: (ty, result) {
- _handleObservableType(ty, result);
- },
- );
- _subscription =
- RustStreamReceiver.listen((observable) => _extractor.parse(observable));
- }
- void _handleObservableType(
- WorkspaceObservable ty, Either<Uint8List, WorkspaceError> result) {
- switch (ty) {
- case WorkspaceObservable.WorkspaceUpdated:
- if (_update != null) {
- result.fold(
- (payload) {
- final workspace = Workspace.fromBuffer(payload);
- _update!(workspace.name, workspace.desc);
- },
- (error) => Log.error(error),
- );
- }
- break;
- case WorkspaceObservable.WorkspaceCreateApp:
- if (_createApp != null) {
- result.fold(
- (payload) => _createApp!(
- left(RepeatedApp.fromBuffer(payload).items),
- ),
- (error) => _createApp!(right(error)),
- );
- }
- break;
- case WorkspaceObservable.WorkspaceDeleteApp:
- if (_deleteApp != null) {
- result.fold(
- (payload) => _deleteApp!(
- left(RepeatedApp.fromBuffer(payload).items),
- ),
- (error) => _deleteApp!(right(error)),
- );
- }
- break;
- default:
- break;
- }
- }
- Future<void> close() async {
- await _subscription?.cancel();
- }
- }
|