123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- import 'dart:async';
- import 'package:appflowy_backend/protobuf/flowy-user/protobuf.dart';
- import 'package:dartz/dartz.dart';
- import 'package:appflowy_backend/dispatch/dispatch.dart';
- import 'package:appflowy_backend/protobuf/flowy-error/errors.pb.dart';
- import 'package:appflowy_backend/protobuf/flowy-folder2/workspace.pb.dart';
- import 'package:fixnum/fixnum.dart';
- class UserBackendService {
- UserBackendService({
- required this.userId,
- });
- final Int64 userId;
- static Future<Either<FlowyError, UserProfilePB>>
- getCurrentUserProfile() async {
- final result = await UserEventGetUserProfile().send();
- return result.swap();
- }
- Future<Either<Unit, FlowyError>> updateUserProfile({
- String? name,
- String? password,
- String? email,
- String? iconUrl,
- String? openAIKey,
- }) {
- final payload = UpdateUserProfilePayloadPB.create()..id = userId;
- if (name != null) {
- payload.name = name;
- }
- if (password != null) {
- payload.password = password;
- }
- if (email != null) {
- payload.email = email;
- }
- if (iconUrl != null) {
- payload.iconUrl = iconUrl;
- }
- if (openAIKey != null) {
- payload.openaiKey = openAIKey;
- }
- return UserEventUpdateUserProfile(payload).send();
- }
- Future<Either<Unit, FlowyError>> deleteWorkspace({
- required String workspaceId,
- }) {
- throw UnimplementedError();
- }
- Future<Either<Unit, FlowyError>> signOut() {
- return UserEventSignOut().send();
- }
- Future<Either<Unit, FlowyError>> initUser() async {
- return UserEventInitUser().send();
- }
- Future<Either<List<WorkspacePB>, FlowyError>> getWorkspaces() {
- final request = WorkspaceIdPB.create();
- return FolderEventReadAllWorkspaces(request).send().then((result) {
- return result.fold(
- (workspaces) => left(workspaces.items),
- (error) => right(error),
- );
- });
- }
- Future<Either<WorkspacePB, FlowyError>> openWorkspace(String workspaceId) {
- final request = WorkspaceIdPB.create()..value = workspaceId;
- return FolderEventOpenWorkspace(request).send().then((result) {
- return result.fold(
- (workspace) => left(workspace),
- (error) => right(error),
- );
- });
- }
- Future<Either<WorkspacePB, FlowyError>> createWorkspace(
- String name,
- String desc,
- ) {
- final request = CreateWorkspacePayloadPB.create()
- ..name = name
- ..desc = desc;
- return FolderEventCreateWorkspace(request).send().then((result) {
- return result.fold(
- (workspace) => left(workspace),
- (error) => right(error),
- );
- });
- }
- }
|