From 5cd8a02f873c11939288aeae717e04a05732d159 Mon Sep 17 00:00:00 2001 From: Jay Chung Date: Mon, 19 Dec 2022 16:06:41 +0800 Subject: [PATCH] [fix] Remove tenant arg in workflow definition (#13212) current tenant in workflow only work when the first time user do not exist, when user change the tenant in workflow but tenant exist, it will be ignore, so we try to remove it from workflow, and in #40 we try to create both user and tenant vis cli instead of auto create --- .../dolphinscheduler/api/python/PythonGateway.java | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/dolphinscheduler-api/src/main/java/org/apache/dolphinscheduler/api/python/PythonGateway.java b/dolphinscheduler-api/src/main/java/org/apache/dolphinscheduler/api/python/PythonGateway.java index 3b189169b9..cbada02e42 100644 --- a/dolphinscheduler-api/src/main/java/org/apache/dolphinscheduler/api/python/PythonGateway.java +++ b/dolphinscheduler-api/src/main/java/org/apache/dolphinscheduler/api/python/PythonGateway.java @@ -226,7 +226,6 @@ public class PythonGateway { * @param timeout timeout for workflow working, if running time longer than timeout, * task will mark as fail * @param workerGroup run task in which worker group - * @param tenantCode tenantCode * @param taskRelationJson relation json for nodes * @param taskDefinitionJson taskDefinitionJson * @param otherParamsJson otherParamsJson handle other params @@ -242,13 +241,16 @@ public class PythonGateway { int warningGroupId, int timeout, String workerGroup, - String tenantCode, int releaseState, String taskRelationJson, String taskDefinitionJson, String otherParamsJson, String executionType) { User user = usersService.queryUser(userName); + if (user.getTenantCode() == null) { + throw new RuntimeException("Can not create or update workflow for user who not related to any tenant."); + } + Project project = projectMapper.queryByName(projectName); long projectCode = project.getCode(); @@ -263,12 +265,12 @@ public class PythonGateway { ReleaseState.OFFLINE); processDefinitionService.updateProcessDefinition(user, projectCode, name, processDefinitionCode, description, globalParams, - null, timeout, tenantCode, taskRelationJson, taskDefinitionJson, otherParamsJson, + null, timeout, user.getTenantCode(), taskRelationJson, taskDefinitionJson, otherParamsJson, executionTypeEnum); } else { Map result = processDefinitionService.createProcessDefinition(user, projectCode, name, description, globalParams, - null, timeout, tenantCode, taskRelationJson, taskDefinitionJson, otherParamsJson, + null, timeout, user.getTenantCode(), taskRelationJson, taskDefinitionJson, otherParamsJson, executionTypeEnum); processDefinition = (ProcessDefinition) result.get(Constants.DATA_LIST); processDefinitionCode = processDefinition.getCode();