task_repository.dart 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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/data/repositories/account_repository.dart';
  6. import 'package:electronic_assistant/data/repositories/agenda_repository.dart';
  7. import 'package:electronic_assistant/data/repositories/talk_repository.dart';
  8. import 'package:electronic_assistant/utils/async_util.dart';
  9. import 'package:electronic_assistant/utils/cancel_future.dart';
  10. import 'package:flutter/cupertino.dart';
  11. import '../../dialog/analyse_status_dialog.dart';
  12. import '../../module/talk/view.dart';
  13. import '../../utils/http_handler.dart';
  14. import '../api/request/talk_query_request.dart';
  15. import '../api/response/tasks_running_response.dart';
  16. import '../consts/error_code.dart';
  17. class TaskRepository {
  18. final Set<String> electronicTasks = {};
  19. final Set<String> _recordSuccessTalkIds = {};
  20. CancelableFuture? _taskStatusCheckFuture;
  21. TaskRepository._();
  22. void stopTask() {
  23. _taskStatusCheckFuture?.cancel();
  24. }
  25. void addTask(String taskId) {
  26. electronicTasks.add(taskId);
  27. _startTaskStatusCheck();
  28. }
  29. void startUnfinishedTask() {
  30. debugPrint('开始获取未完成任务==');
  31. AsyncUtil.retryWithExponentialBackoff(() => _tasksRunning(), 10, (error) {
  32. if (error is ServerErrorException) {
  33. return error.code != ErrorCode.errorCodeNoLogin;
  34. }
  35. return true;
  36. }).then((data) {
  37. List<String>? list = data.taskIds;
  38. debugPrint('获取未完成任务成功-${list?.length}');
  39. electronicTasks.clear();
  40. if (list != null) {
  41. electronicTasks.addAll(list);
  42. }
  43. _startTaskStatusCheck();
  44. }).catchError((error) {
  45. debugPrint('获取未完成任务失败');
  46. });
  47. }
  48. void _startTaskStatusCheck() {
  49. if (electronicTasks.isEmpty) {
  50. return;
  51. }
  52. debugPrint('开始检查任务状态');
  53. if (_taskStatusCheckFuture != null) {
  54. _taskStatusCheckFuture?.cancel();
  55. }
  56. _taskStatusCheckFuture = AsyncUtil.retryWhen(
  57. () => _checkAllTaskStatusFinished(), 0, const Duration(seconds: 3),
  58. (error) {
  59. if (error is ServerErrorException) {
  60. return error.code != ErrorCode.errorCodeNoLogin;
  61. }
  62. return true;
  63. });
  64. }
  65. Future<void> _checkAllTaskStatusFinished() {
  66. String taskIds = electronicTasks.join(',');
  67. return atmobApi
  68. .talkQuery(TalkQueryRequest(taskIds))
  69. .then(HttpHandler.handle(true))
  70. .then((response) => _dealTaskStatus(response))
  71. .then((data) {
  72. if (electronicTasks.isEmpty) {
  73. return;
  74. } else {
  75. throw Exception('task not finished');
  76. }
  77. });
  78. }
  79. Future<void> _dealTaskStatus(TalkQueryResponse response) {
  80. response.talks?.forEach((element) {
  81. if (element.status.value == TalkStatus.analysing ||
  82. element.status.value == TalkStatus.waitAnalysis) {
  83. talkRepository.renovateTalkData(element);
  84. } else if (element.status.value == TalkStatus.analysisSuccess ||
  85. element.status.value == TalkStatus.analysisFail) {
  86. electronicTasks.remove(element.taskId);
  87. if (!_recordSuccessTalkIds.contains(element.id)) {
  88. _recordSuccessTalkIds.add(element.id);
  89. _notifyGenerationStatus(element);
  90. }
  91. }
  92. });
  93. return Future.value();
  94. }
  95. void _notifyGenerationStatus(TalkBean element) {
  96. talkRepository.renovateTalkData(element);
  97. if (element.status.value == TalkStatus.analysisSuccess) {
  98. debugPrint('生成成功-${element.id}');
  99. showAnalyseSuccessDialog(onViewClick: () {
  100. TalkPage.start(element);
  101. });
  102. accountRepository.refreshUserInfo();
  103. agendaRepository.requestHomeAgendaData();
  104. } else if (element.status.value == TalkStatus.analysisFail) {
  105. debugPrint('生成失败-${element.id}');
  106. // ToastUtil.showToast('生成失败');
  107. }
  108. }
  109. Future<TasksRunningResponse> _tasksRunning() {
  110. return atmobApi
  111. .tasksRunning(AppBaseRequest())
  112. .then(HttpHandler.handle(true));
  113. }
  114. }
  115. final taskRepository = TaskRepository._();