task_repository.dart 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. import 'package:electronic_assistant/base/app_base_request.dart';
  2. import 'package:electronic_assistant/data/api/atmob_api.dart';
  3. import 'package:electronic_assistant/data/api/response/talk_query_response.dart';
  4. import 'package:electronic_assistant/data/bean/talks.dart';
  5. import 'package:electronic_assistant/utils/async_util.dart';
  6. import 'package:electronic_assistant/utils/cancel_future.dart';
  7. import 'package:flutter/cupertino.dart';
  8. import '../../utils/http_handler.dart';
  9. import '../api/request/talk_query_request.dart';
  10. import '../api/response/tasks_running_response.dart';
  11. import '../consts/error_code.dart';
  12. class TaskRepository {
  13. final Set<String> electronicTasks = {};
  14. final Set<String> _recordSuccessTalkIds = {};
  15. CancelableFuture? _taskStatusCheckFuture;
  16. TaskRepository._();
  17. void stopTask() {
  18. _taskStatusCheckFuture?.cancel();
  19. }
  20. void addTask(String taskId) {
  21. electronicTasks.add(taskId);
  22. _startTaskStatusCheck();
  23. }
  24. void startUnfinishedTask() {
  25. debugPrint('开始获取未完成任务==');
  26. AsyncUtil.retryWithExponentialBackoff(() => _tasksRunning(), 10, (error) {
  27. if (error is ServerErrorException) {
  28. return error.code != ErrorCode.ERROR_CODE_NO_LOGIN;
  29. }
  30. return true;
  31. }).then((data) {
  32. List<String>? list = data.taskIds;
  33. debugPrint('获取未完成任务成功-${list?.length}');
  34. electronicTasks.clear();
  35. if (list != null) {
  36. electronicTasks.addAll(list);
  37. }
  38. _startTaskStatusCheck();
  39. }).catchError((error) {
  40. debugPrint('获取未完成任务失败');
  41. });
  42. }
  43. void _startTaskStatusCheck() {
  44. if (electronicTasks.isEmpty) {
  45. return;
  46. }
  47. debugPrint('开始检查任务状态');
  48. if (_taskStatusCheckFuture != null) {
  49. _taskStatusCheckFuture?.cancel();
  50. }
  51. _taskStatusCheckFuture = AsyncUtil.retryWhen(
  52. () => _checkAllTaskStatusFinished(), 0, const Duration(seconds: 3),
  53. (error) {
  54. if (error is ServerErrorException) {
  55. return error.code != ErrorCode.ERROR_CODE_NO_LOGIN;
  56. }
  57. return true;
  58. });
  59. }
  60. Future<void> _checkAllTaskStatusFinished() {
  61. String taskIds = electronicTasks.join(',');
  62. return atmobApi
  63. .talkQuery(TalkQueryRequest(taskIds))
  64. .then(HttpHandler.handle(false))
  65. .then((response) => _dealTaskStatus(response));
  66. }
  67. Future<void> _dealTaskStatus(TalkQueryResponse response) {
  68. response.talks?.forEach((element) {
  69. if (element.status == TalkStatus.analysing ||
  70. element.status == TalkStatus.waitAnalysis) {
  71. //TODO 刷新生成中的bean类数据
  72. } else if (element.status == TalkStatus.analysisSuccess ||
  73. element.status == TalkStatus.analysisFail) {
  74. electronicTasks.remove(element.taskId);
  75. if (!_recordSuccessTalkIds.contains(element.id)) {
  76. _recordSuccessTalkIds.add(element.id);
  77. _notifyGenerationStatus(element);
  78. }
  79. }
  80. });
  81. return Future.value();
  82. }
  83. void _notifyGenerationStatus(TalkBean element) {
  84. if (element.status == TalkStatus.analysisSuccess) {
  85. debugPrint('生成成功-${element.id}');
  86. } else if (element.status == TalkStatus.analysisFail) {
  87. debugPrint('生成失败-${element.id}');
  88. }
  89. }
  90. Future<TasksRunningResponse> _tasksRunning() {
  91. return atmobApi
  92. .tasksRunning(AppBaseRequest())
  93. .then(HttpHandler.handle(true));
  94. }
  95. }
  96. final taskRepository = TaskRepository._();