nc-photos/lib/bloc/app_password_exchange.dart

89 lines
2.4 KiB
Dart
Raw Normal View History

2021-04-10 06:28:12 +02:00
import 'package:bloc/bloc.dart';
import 'package:flutter/foundation.dart';
import 'package:logging/logging.dart';
import 'package:nc_photos/account.dart';
import 'package:nc_photos/api/api_util.dart' as api_util;
2021-05-06 06:57:20 +02:00
import 'package:nc_photos/exception.dart';
2021-04-10 06:28:12 +02:00
abstract class AppPasswordExchangeBlocEvent {
const AppPasswordExchangeBlocEvent();
}
class AppPasswordExchangeBlocConnect extends AppPasswordExchangeBlocEvent {
const AppPasswordExchangeBlocConnect(this.account);
@override
toString() {
return "$runtimeType {"
"account: $account, "
"}";
}
final Account account;
}
abstract class AppPasswordExchangeBlocState {
const AppPasswordExchangeBlocState();
}
class AppPasswordExchangeBlocInit extends AppPasswordExchangeBlocState {
const AppPasswordExchangeBlocInit();
}
class AppPasswordExchangeBlocSuccess extends AppPasswordExchangeBlocState {
const AppPasswordExchangeBlocSuccess(this.password);
@override
toString() {
return "$runtimeType {"
"password: ${kDebugMode ? password : '***'}, "
"}";
}
final String password;
}
class AppPasswordExchangeBlocFailure extends AppPasswordExchangeBlocState {
const AppPasswordExchangeBlocFailure(this.exception);
@override
toString() {
return "$runtimeType {"
"exception: $exception, "
"}";
}
final exception;
}
class AppPasswordExchangeBloc
extends Bloc<AppPasswordExchangeBlocEvent, AppPasswordExchangeBlocState> {
AppPasswordExchangeBloc() : super(AppPasswordExchangeBlocInit());
@override
mapEventToState(AppPasswordExchangeBlocEvent event) async* {
_log.info("[mapEventToState] $event");
if (event is AppPasswordExchangeBlocConnect) {
yield* _exchangePassword(event.account);
}
}
Stream<AppPasswordExchangeBlocState> _exchangePassword(
Account account) async* {
try {
final appPwd = await api_util.exchangePassword(account);
yield AppPasswordExchangeBlocSuccess(appPwd);
2021-05-06 06:57:20 +02:00
} on InvalidBaseUrlException catch (e) {
_log.warning("[_exchangePassword] Invalid base url");
yield AppPasswordExchangeBlocFailure(e);
2021-04-10 06:28:12 +02:00
} catch (e, stacktrace) {
2021-04-27 22:06:16 +02:00
_log.shout("[_exchangePassword] Failed while exchanging password", e,
2021-04-10 06:28:12 +02:00
stacktrace);
yield AppPasswordExchangeBlocFailure(e);
}
}
static final _log =
Logger("bloc.app_password_exchange.AppPasswordExchangeBloc");
}