Files
umbrix/lib/features/proxies/notifier/proxies_notifier.dart

47 lines
1.5 KiB
Dart
Raw Normal View History

2023-07-06 17:18:41 +03:30
import 'dart:async';
import 'package:fpdart/fpdart.dart';
import 'package:hiddify/data/data_providers.dart';
import 'package:hiddify/domain/clash/clash.dart';
2023-08-19 22:27:23 +03:30
import 'package:hiddify/domain/core_service_failure.dart';
2023-07-06 17:18:41 +03:30
import 'package:hiddify/features/common/clash/clash_mode.dart';
2023-08-19 22:27:23 +03:30
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
2023-07-06 17:18:41 +03:30
import 'package:hiddify/features/proxies/model/model.dart';
import 'package:hiddify/utils/utils.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';
part 'proxies_notifier.g.dart';
@Riverpod(keepAlive: true)
class ProxiesNotifier extends _$ProxiesNotifier with AppLogger {
@override
Future<List<GroupWithProxies>> build() async {
loggy.debug('building');
2023-08-19 22:27:23 +03:30
if (!await ref.watch(serviceRunningProvider.future)) {
throw const CoreServiceNotRunning();
}
2023-07-06 17:18:41 +03:30
final mode = await ref.watch(clashModeProvider.future);
2023-08-19 22:27:23 +03:30
return _clash.getProxies().flatMap(
(proxies) {
return TaskEither(
() async => right(await GroupWithProxies.fromProxies(proxies, mode)),
);
},
).getOrElse((l) {
loggy.warning("failed receiving proxies: $l");
throw l;
}).run();
2023-07-06 17:18:41 +03:30
}
2023-08-19 22:27:23 +03:30
ClashFacade get _clash => ref.read(coreFacadeProvider);
2023-07-06 17:18:41 +03:30
Future<void> changeProxy(String selectorName, String proxyName) async {
loggy.debug("changing proxy, selector: $selectorName - proxy: $proxyName ");
await _clash
.changeProxy(selectorName, proxyName)
.getOrElse((l) => throw l)
.run();
ref.invalidateSelf();
}
}