refactor: 重构供应商文件类型枚举及相关服务
feat: 为多个服务添加缓存支持 fix: 修复WebSocket任务管理和远程调用异常处理 refactor: 重命名CompanyVendorFileType为VendorFileType refactor: 优化项目成本导入任务实现 fix: 修复ContractTabSkinBase中的空指针问题 refactor: 统一WebSocket客户端任务调用接口
This commit is contained in:
@@ -7,6 +7,7 @@ import lombok.Getter;
|
||||
import org.springframework.beans.BeanUtils;
|
||||
|
||||
import java.beans.PropertyDescriptor;
|
||||
import java.util.Locale;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
import java.util.logging.Level;
|
||||
@@ -24,15 +25,12 @@ public class WebSocketClientSession {
|
||||
}
|
||||
|
||||
public void close() {
|
||||
webSocketService.closeSession(this);
|
||||
}
|
||||
|
||||
public void submitTask(WebSocketClientTasker tasker, Object... args) throws JsonProcessingException {
|
||||
public void submitTask(WebSocketClientTasker tasker, Locale locale, Object... args) throws JsonProcessingException {
|
||||
this.tasker = tasker;
|
||||
// 将 tasker.getTaskName() 和 args 合并到一个数组参数中
|
||||
Object[] mergedArgs = new Object[args.length + 1];
|
||||
mergedArgs[0] = tasker.getTaskName();
|
||||
System.arraycopy(args, 0, mergedArgs, 1, args.length);
|
||||
send("createTask", mergedArgs);
|
||||
send("createTask", tasker.getTaskName(), locale.toLanguageTag(), args);
|
||||
}
|
||||
|
||||
public void send(String type, Object... args) throws JsonProcessingException {
|
||||
@@ -49,31 +47,17 @@ public class WebSocketClientSession {
|
||||
String type = node.get("type").asText();
|
||||
JsonNode args = node.get(WebSocketConstant.ARGUMENTS_FIELD_NAME);
|
||||
if (type.equals("message")) {
|
||||
String message = args.get(1).asText();
|
||||
String level = args.get(0).asText();
|
||||
updateMessage(java.util.logging.Level.parse(level), message);
|
||||
handleAsMessage(args);
|
||||
} else if (type.equals("title")) {
|
||||
String message = args.get(0).asText();
|
||||
tasker.updateTitle(message);
|
||||
handleAsTitle(args);
|
||||
} else if (type.equals("property")) {
|
||||
String name = args.get(0).asText();
|
||||
Object value = args.get(1);
|
||||
try {
|
||||
PropertyDescriptor descriptor = BeanUtils.getPropertyDescriptor(tasker.getClass(), name);
|
||||
System.out.println("descriptor = " + descriptor);
|
||||
System.out.println("descriptor.getPropertyType() = " + descriptor.getPropertyType());
|
||||
Object object = webSocketService.getObjectMapper().convertValue(value, descriptor.getPropertyType());
|
||||
System.out.println("object = " + object);
|
||||
System.out.println("descriptor.getWriteMethod() = " + descriptor.getWriteMethod());
|
||||
System.out.println("descriptor.getWriteMethod().getParameterTypes() = " + descriptor.getWriteMethod().getParameterTypes());
|
||||
descriptor.getWriteMethod().invoke(tasker, object);
|
||||
} catch (Exception e) {
|
||||
tasker.updateMessage(java.util.logging.Level.SEVERE, "属性设置失败: " + name + " = " + value);
|
||||
}
|
||||
handleAsProperty(args);
|
||||
} else if (type.equals("progress")) {
|
||||
long current = args.get(0).asLong();
|
||||
long total = args.get(1).asLong();
|
||||
tasker.updateProgress(current, total);
|
||||
handleAsProgress(args);
|
||||
} else if (type.equals("start")) {
|
||||
handleAsStart(args);
|
||||
} else if (type.equals("done")) {
|
||||
handleAsDone(args);
|
||||
} else {
|
||||
tasker.updateMessage(java.util.logging.Level.INFO, "未知的消息类型: " + node.toString());
|
||||
}
|
||||
@@ -82,6 +66,49 @@ public class WebSocketClientSession {
|
||||
}
|
||||
}
|
||||
|
||||
private void handleAsDone(JsonNode args) {
|
||||
tasker.updateMessage(java.util.logging.Level.INFO, "任务完成");
|
||||
close();
|
||||
}
|
||||
|
||||
private void handleAsStart(JsonNode args) {
|
||||
tasker.updateMessage(java.util.logging.Level.INFO, "任务开始");
|
||||
}
|
||||
|
||||
private void handleAsProgress(JsonNode args) {
|
||||
long current = args.get(0).asLong();
|
||||
long total = args.get(1).asLong();
|
||||
tasker.updateProgress(current, total);
|
||||
}
|
||||
|
||||
private void handleAsProperty(JsonNode args) {
|
||||
String name = args.get(0).asText();
|
||||
Object value = args.get(1);
|
||||
try {
|
||||
PropertyDescriptor descriptor = BeanUtils.getPropertyDescriptor(tasker.getClass(), name);
|
||||
System.out.println("descriptor = " + descriptor);
|
||||
System.out.println("descriptor.getPropertyType() = " + descriptor.getPropertyType());
|
||||
Object object = webSocketService.getObjectMapper().convertValue(value, descriptor.getPropertyType());
|
||||
System.out.println("object = " + object);
|
||||
System.out.println("descriptor.getWriteMethod() = " + descriptor.getWriteMethod());
|
||||
System.out.println("descriptor.getWriteMethod().getParameterTypes() = " + descriptor.getWriteMethod().getParameterTypes());
|
||||
descriptor.getWriteMethod().invoke(tasker, object);
|
||||
} catch (Exception e) {
|
||||
tasker.updateMessage(java.util.logging.Level.SEVERE, "属性设置失败: " + name + " = " + value);
|
||||
}
|
||||
}
|
||||
|
||||
private void handleAsTitle(JsonNode args) {
|
||||
String message = args.get(0).asText();
|
||||
tasker.updateTitle(message);
|
||||
}
|
||||
|
||||
private void handleAsMessage(JsonNode args) {
|
||||
String level = args.get(0).asText();
|
||||
String message = args.get(1).asText();
|
||||
updateMessage(java.util.logging.Level.parse(level), message);
|
||||
}
|
||||
|
||||
public void updateMessage(Level level, String message) {
|
||||
tasker.updateMessage(level, message);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user