diff --git a/build.gradle b/build.gradle index 14ae0015..36ae3def 100644 --- a/build.gradle +++ b/build.gradle @@ -20,7 +20,7 @@ ext { versions = [ awaitility : '4.2.0', commonsLang : '3.12.0', - conductor : '3.9.28-orkes', + conductor : '3.9.24-orkes', jackson : '2.11.4!!', junit : '5.9.0', slf4j : '1.7.36', @@ -47,7 +47,9 @@ dependencies { api ("io.orkes.conductor:conductor-common:${versions.conductor}") api ("io.orkes.conductor:conductor-grpc:${versions.conductor}") - api ("io.orkes.conductor:conductor-java-sdk:${versions.conductor}") + api ("io.orkes.conductor:conductor-java-sdk:${versions.conductor}") { + exclude group: 'com.netflix.conductor' + } implementation 'javax.annotation:javax.annotation-api:1.3.2' implementation "com.fasterxml.jackson.jaxrs:jackson-jaxrs-json-provider:${versions.jackson}" @@ -98,7 +100,6 @@ dependencies { implementation "org.apache.logging.log4j:log4j-slf4j-impl:${versions.log4j}!!" implementation "org.apache.logging.log4j:log4j-jul:${versions.log4j}!!" implementation "org.apache.logging.log4j:log4j-web:${versions.log4j}!!" - //implementation "org.apache.logging.log4j:log4j-to-slf4j:${versions.log4j}!!" //spring implementation "org.springframework:spring-context:5.3.24" diff --git a/gradle.properties b/gradle.properties index e997a9af..077fe085 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1 +1 @@ -version=2.0.0 \ No newline at end of file +version=2.0.9 \ No newline at end of file diff --git a/src/main/java/io/orkes/conductor/client/EventClient.java b/src/main/java/io/orkes/conductor/client/EventClient.java index a7772b52..02a12b5a 100644 --- a/src/main/java/io/orkes/conductor/client/EventClient.java +++ b/src/main/java/io/orkes/conductor/client/EventClient.java @@ -14,8 +14,11 @@ +import java.util.List; import java.util.Map; +import com.netflix.conductor.common.metadata.events.EventHandler; + import io.orkes.conductor.client.model.event.QueueConfiguration; public abstract class EventClient extends com.netflix.conductor.client.http.EventClient { @@ -24,4 +27,9 @@ public abstract class EventClient extends com.netflix.conductor.client.http.Even public abstract void deleteQueueConfig(QueueConfiguration queueConfiguration); public abstract void putQueueConfig(QueueConfiguration queueConfiguration) throws Exception; + + public abstract List getEventHandlers(); + + public abstract void handleIncomingEvent(Map payload); + } diff --git a/src/main/java/io/orkes/conductor/client/WorkflowClient.java b/src/main/java/io/orkes/conductor/client/WorkflowClient.java index cd07e1e9..0c79e19c 100644 --- a/src/main/java/io/orkes/conductor/client/WorkflowClient.java +++ b/src/main/java/io/orkes/conductor/client/WorkflowClient.java @@ -26,6 +26,7 @@ import com.netflix.conductor.common.run.WorkflowTestRequest; import io.orkes.conductor.client.http.ApiException; +import io.orkes.conductor.client.model.WorkflowStateUpdate; import io.orkes.conductor.client.model.WorkflowStatus; import io.orkes.conductor.common.model.WorkflowRun; @@ -93,4 +94,18 @@ public abstract Map> getWorkflowsByNamesAndCorrelationIds public abstract Workflow updateVariables(String workflowId, Map variables); public abstract void upgradeRunningWorkflow(String workflowId, UpgradeWorkflowRequest body); + + /** + * + * Update a runningw workflow by updating its variables or one of the scheduled task identified by task reference name + * @param workflowId Id of the workflow to be updated + * @param waitUntilTaskRefNames List of task reference names to wait for. The api call will wait for ANY of these tasks to be availble in workflow. + * @param waitForSeconds Maximum time to wait for. If the workflow does not complete or reach one of the tasks listed in waitUntilTaskRefNames by this time, + * the call will return with the current status of the workflow + * @param updateRequest Payload for updating state of workflow. + * + * @return + */ + public abstract WorkflowRun updateWorkflow(String workflowId, List waitUntilTaskRefNames, Integer waitForSeconds, + WorkflowStateUpdate updateRequest); } diff --git a/src/main/java/io/orkes/conductor/client/http/OrkesEventClient.java b/src/main/java/io/orkes/conductor/client/http/OrkesEventClient.java index 926792ca..265987ba 100644 --- a/src/main/java/io/orkes/conductor/client/http/OrkesEventClient.java +++ b/src/main/java/io/orkes/conductor/client/http/OrkesEventClient.java @@ -67,6 +67,16 @@ public List getEventHandlers(String event, boolean activeOnly) { return eventResourceApi.getEventHandlersForEvent(event, activeOnly); } + @Override + public List getEventHandlers() { + return eventResourceApi.getEventHandlers(); + } + + @Override + public void handleIncomingEvent(Map payload) { + eventResourceApi.handleIncomingEvent(payload); + } + @Override public void unregisterEventHandler(String name) { eventResourceApi.removeEventHandlerStatus(name); diff --git a/src/main/java/io/orkes/conductor/client/http/OrkesWorkflowClient.java b/src/main/java/io/orkes/conductor/client/http/OrkesWorkflowClient.java index 1ad9667a..f6f64794 100644 --- a/src/main/java/io/orkes/conductor/client/http/OrkesWorkflowClient.java +++ b/src/main/java/io/orkes/conductor/client/http/OrkesWorkflowClient.java @@ -34,6 +34,7 @@ import io.orkes.conductor.client.http.api.WorkflowBulkResourceApi; import io.orkes.conductor.client.http.api.WorkflowResourceApi; import io.orkes.conductor.client.model.CorrelationIdsSearchRequest; +import io.orkes.conductor.client.model.WorkflowStateUpdate; import io.orkes.conductor.client.model.WorkflowStatus; import io.orkes.conductor.common.model.WorkflowRun; @@ -346,6 +347,15 @@ public void upgradeRunningWorkflow(String workflowId, UpgradeWorkflowRequest upg httpClient.upgradeRunningWorkflow(upgradeWorkflowRequest, workflowId); } + @Override + public WorkflowRun updateWorkflow(String workflowId, List waitUntilTaskRefNames, Integer waitForSeconds, WorkflowStateUpdate updateRequest) { + String joinedReferenceNames = ""; + if (waitUntilTaskRefNames != null) { + joinedReferenceNames = String.join(",", waitUntilTaskRefNames); + } + return httpClient.updateWorkflowState(updateRequest, UUID.randomUUID().toString(), workflowId, joinedReferenceNames, waitForSeconds); + } + @Override public void close() { shutdown(); diff --git a/src/main/java/io/orkes/conductor/client/http/api/EventResourceApi.java b/src/main/java/io/orkes/conductor/client/http/api/EventResourceApi.java index 1219e916..57e387c4 100644 --- a/src/main/java/io/orkes/conductor/client/http/api/EventResourceApi.java +++ b/src/main/java/io/orkes/conductor/client/http/api/EventResourceApi.java @@ -22,7 +22,12 @@ import com.netflix.conductor.common.metadata.events.EventHandler; import io.orkes.conductor.client.ApiClient; -import io.orkes.conductor.client.http.*; +import io.orkes.conductor.client.http.ApiException; +import io.orkes.conductor.client.http.ApiResponse; +import io.orkes.conductor.client.http.Configuration; +import io.orkes.conductor.client.http.Pair; +import io.orkes.conductor.client.http.ProgressRequestBody; +import io.orkes.conductor.client.http.ProgressResponseBody; import com.fasterxml.jackson.core.type.TypeReference; @@ -48,8 +53,8 @@ public void setApiClient(ApiClient apiClient) { /** * Build call for addEventHandler * - * @param eventHandler (required) - * @param progressListener Progress listener + * @param eventHandler (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -103,7 +108,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "POST", @@ -137,7 +142,7 @@ private com.squareup.okhttp.Call addEventHandlerValidateBeforeCall( * * @param eventHandler (required) * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public void addEventHandler(EventHandler eventHandler) throws ApiException { addEventHandlerWithHttpInfo(eventHandler); @@ -149,7 +154,7 @@ public void addEventHandler(EventHandler eventHandler) throws ApiException { * @param eventHandler (required) * @return ApiResponse<Void> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse addEventHandlerWithHttpInfo(EventHandler eventHandler) throws ApiException { @@ -160,9 +165,9 @@ private ApiResponse addEventHandlerWithHttpInfo(EventHandler eventHandler) /** * Build call for deleteQueueConfig * - * @param queueType (required) - * @param queueName (required) - * @param progressListener Progress listener + * @param queueType (required) + * @param queueName (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -224,7 +229,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "DELETE", @@ -267,7 +272,7 @@ private com.squareup.okhttp.Call deleteQueueConfigValidateBeforeCall( * @param queueName (required) * @return Object * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public Object deleteQueueConfig(String queueType, String queueName) throws ApiException { ApiResponse resp = deleteQueueConfigWithHttpInfo(queueType, queueName); @@ -281,20 +286,21 @@ public Object deleteQueueConfig(String queueType, String queueName) throws ApiEx * @param queueName (required) * @return ApiResponse<Object> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse deleteQueueConfigWithHttpInfo(String queueType, String queueName) throws ApiException { com.squareup.okhttp.Call call = deleteQueueConfigValidateBeforeCall(queueType, queueName, null, null); - Type localVarReturnType = new TypeReference() {}.getType(); + Type localVarReturnType = new TypeReference() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for getEventHandlers * - * @param progressListener Progress listener + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -347,7 +353,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "GET", @@ -375,7 +381,7 @@ private com.squareup.okhttp.Call getEventHandlersValidateBeforeCall( * * @return List<EventHandler> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public List getEventHandlers() throws ApiException { ApiResponse> resp = getEventHandlersWithHttpInfo(); @@ -387,20 +393,21 @@ public List getEventHandlers() throws ApiException { * * @return ApiResponse<List<EventHandler>> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse> getEventHandlersWithHttpInfo() throws ApiException { com.squareup.okhttp.Call call = getEventHandlersValidateBeforeCall(null, null); - Type localVarReturnType = new TypeReference>() {}.getType(); + Type localVarReturnType = new TypeReference>() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for getEventHandlersForEvent * - * @param event (required) - * @param activeOnly (optional, default to true) - * @param progressListener Progress listener + * @param event (required) + * @param activeOnly (optional, default to true) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -460,7 +467,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "GET", @@ -494,11 +501,11 @@ private com.squareup.okhttp.Call getEventHandlersForEventValidateBeforeCall( /** * Get event handlers for a given event * - * @param event (required) + * @param event (required) * @param activeOnly (optional, default to true) * @return List<EventHandler> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public List getEventHandlersForEvent(String event, Boolean activeOnly) throws ApiException { @@ -510,26 +517,27 @@ public List getEventHandlersForEvent(String event, Boolean activeO /** * Get event handlers for a given event * - * @param event (required) + * @param event (required) * @param activeOnly (optional, default to true) * @return ApiResponse<List<EventHandler>> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse> getEventHandlersForEventWithHttpInfo( String event, Boolean activeOnly) throws ApiException { com.squareup.okhttp.Call call = getEventHandlersForEventValidateBeforeCall(event, activeOnly, null, null); - Type localVarReturnType = new TypeReference>() {}.getType(); + Type localVarReturnType = new TypeReference>() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for getQueueConfig * - * @param queueType (required) - * @param queueName (required) - * @param progressListener Progress listener + * @param queueType (required) + * @param queueName (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -591,7 +599,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "GET", @@ -633,7 +641,7 @@ private com.squareup.okhttp.Call getQueueConfigValidateBeforeCall( * @param queueName (required) * @return Object * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public Map getQueueConfig(String queueType, String queueName) throws ApiException { ApiResponse> resp = getQueueConfigWithHttpInfo(queueType, queueName); @@ -647,20 +655,21 @@ public Map getQueueConfig(String queueType, String queueName) th * @param queueName (required) * @return ApiResponse<Object> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse> getQueueConfigWithHttpInfo(String queueType, String queueName) throws ApiException { com.squareup.okhttp.Call call = getQueueConfigValidateBeforeCall(queueType, queueName, null, null); - Type localVarReturnType = new TypeReference>() {}.getType(); + Type localVarReturnType = new TypeReference>() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for getQueueNames * - * @param progressListener Progress listener + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -713,7 +722,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "GET", @@ -741,7 +750,7 @@ private com.squareup.okhttp.Call getQueueNamesValidateBeforeCall( * * @return Object * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public Object getQueueNames() throws ApiException { ApiResponse resp = getQueueNamesWithHttpInfo(); @@ -753,21 +762,22 @@ public Object getQueueNames() throws ApiException { * * @return ApiResponse<Object> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse getQueueNamesWithHttpInfo() throws ApiException { com.squareup.okhttp.Call call = getQueueNamesValidateBeforeCall(null, null); - Type localVarReturnType = new TypeReference() {}.getType(); + Type localVarReturnType = new TypeReference() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for putQueueConfig * - * @param body (required) - * @param queueType (required) - * @param queueName (required) - * @param progressListener Progress listener + * @param body (required) + * @param queueType (required) + * @param queueName (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -829,7 +839,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "PUT", @@ -874,12 +884,12 @@ private com.squareup.okhttp.Call putQueueConfigValidateBeforeCall( /** * Create or update queue config by name * - * @param body (required) + * @param body (required) * @param queueType (required) * @param queueName (required) * @return Object * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public Object putQueueConfig(String body, String queueType, String queueName) throws ApiException { @@ -890,26 +900,27 @@ public Object putQueueConfig(String body, String queueType, String queueName) /** * Create or update queue config by name * - * @param body (required) + * @param body (required) * @param queueType (required) * @param queueName (required) * @return ApiResponse<Object> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse putQueueConfigWithHttpInfo( String body, String queueType, String queueName) throws ApiException { com.squareup.okhttp.Call call = putQueueConfigValidateBeforeCall(body, queueType, queueName, null, null); - Type localVarReturnType = new TypeReference() {}.getType(); + Type localVarReturnType = new TypeReference() { + }.getType(); return apiClient.execute(call, localVarReturnType); } /** * Build call for removeEventHandlerStatus * - * @param name (required) - * @param progressListener Progress listener + * @param name (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -967,7 +978,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "DELETE", @@ -1001,7 +1012,7 @@ private com.squareup.okhttp.Call removeEventHandlerStatusValidateBeforeCall( * * @param name (required) * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public void removeEventHandlerStatus(String name) throws ApiException { removeEventHandlerStatusWithHttpInfo(name); @@ -1013,7 +1024,7 @@ public void removeEventHandlerStatus(String name) throws ApiException { * @param name (required) * @return ApiResponse<Void> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse removeEventHandlerStatusWithHttpInfo(String name) throws ApiException { @@ -1025,8 +1036,8 @@ private ApiResponse removeEventHandlerStatusWithHttpInfo(String name) /** * Build call for updateEventHandler * - * @param eventHandler (required) - * @param progressListener Progress listener + * @param eventHandler (required) + * @param progressListener Progress listener * @param progressRequestListener Progress request listener * @return Call to execute * @throws ApiException If fail to serialize the request body object @@ -1080,7 +1091,7 @@ public com.squareup.okhttp.Response intercept( }); } - String[] localVarAuthNames = new String[] {"api_key"}; + String[] localVarAuthNames = new String[]{"api_key"}; return apiClient.buildCall( localVarPath, "PUT", @@ -1114,19 +1125,25 @@ private com.squareup.okhttp.Call updateEventHandlerValidateBeforeCall( * * @param eventHandler (required) * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ public void updateEventHandler(EventHandler eventHandler) throws ApiException { updateEventHandlerWithHttpInfo(eventHandler); } + + public void handleIncomingEvent(Map payload) { + handleIncomingEventWithHttpInfo(payload); + } + + /** * Update an existing event handler. * * @param eventHandler (required) * @return ApiResponse<Void> * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the - * response body + * response body */ private ApiResponse updateEventHandlerWithHttpInfo(EventHandler eventHandler) throws ApiException { @@ -1134,4 +1151,73 @@ private ApiResponse updateEventHandlerWithHttpInfo(EventHandler eventHandl updateEventHandlerValidateBeforeCall(eventHandler, null, null); return apiClient.execute(call); } + + private ApiResponse handleIncomingEventWithHttpInfo(Map payload) + throws ApiException { + com.squareup.okhttp.Call call = handleIncomingEventValidateBeforeCall(payload, null, null); + return apiClient.execute(call); + } + + private com.squareup.okhttp.Call handleIncomingEventValidateBeforeCall( + Map payload, + final ProgressResponseBody.ProgressListener progressListener, + final ProgressRequestBody.ProgressRequestListener progressRequestListener) throws ApiException { + Object localVarPostBody = payload; + + // create path and map variables + String localVarPath = "/event/handleIncomingEvent"; + + List localVarQueryParams = new ArrayList(); + List localVarCollectionQueryParams = new ArrayList(); + + Map localVarHeaderParams = new HashMap(); + + Map localVarFormParams = new HashMap(); + + final String[] localVarAccepts = {}; + + final String localVarAccept = apiClient.selectHeaderAccept(localVarAccepts); + if (localVarAccept != null) localVarHeaderParams.put("Accept", localVarAccept); + + final String[] localVarContentTypes = {"application/json"}; + final String localVarContentType = apiClient.selectHeaderContentType(localVarContentTypes); + localVarHeaderParams.put("Content-Type", localVarContentType); + + if (progressListener != null) { + apiClient + .getHttpClient() + .networkInterceptors() + .add( + new com.squareup.okhttp.Interceptor() { + @Override + public com.squareup.okhttp.Response intercept( + com.squareup.okhttp.Interceptor.Chain chain) + throws IOException { + com.squareup.okhttp.Response originalResponse = + chain.proceed(chain.request()); + return originalResponse + .newBuilder() + .body( + new ProgressResponseBody( + originalResponse.body(), + progressListener)) + .build(); + } + }); + } + + String[] localVarAuthNames = new String[] {"api_key"}; + return apiClient.buildCall( + localVarPath, + "POST", + localVarQueryParams, + localVarCollectionQueryParams, + localVarPostBody, + localVarHeaderParams, + localVarFormParams, + localVarAuthNames, + progressRequestListener); + } + + } diff --git a/src/main/java/io/orkes/conductor/client/http/api/WorkflowResourceApi.java b/src/main/java/io/orkes/conductor/client/http/api/WorkflowResourceApi.java index 104a10c5..30bad469 100644 --- a/src/main/java/io/orkes/conductor/client/http/api/WorkflowResourceApi.java +++ b/src/main/java/io/orkes/conductor/client/http/api/WorkflowResourceApi.java @@ -29,6 +29,7 @@ import io.orkes.conductor.common.model.WorkflowRun; import com.fasterxml.jackson.core.type.TypeReference; +import com.google.common.reflect.TypeToken; import com.squareup.okhttp.Call; public class WorkflowResourceApi { @@ -3923,4 +3924,106 @@ public com.squareup.okhttp.Response intercept(com.squareup.okhttp.Interceptor.Ch return apiClient.buildCall(localVarPath, "POST", localVarQueryParams, localVarCollectionQueryParams, localVarPostBody, localVarHeaderParams, localVarFormParams, localVarAuthNames, progressRequestListener); } + + + /** + * Update workflow and task status + * Updates the workflow variables, tasks and triggers evaluation. + * @param updateRequest (required) + * @param requestId (required) + * @param workflowId (required) + * @param waitUntilTaskRef (optional) + * @param waitForSeconds (optional, default to 10) + * @return WorkflowRun + * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the response body + */ + public WorkflowRun updateWorkflowState(WorkflowStateUpdate updateRequest, String requestId, String workflowId, String waitUntilTaskRef, Integer waitForSeconds) throws ApiException { + ApiResponse resp = updateWorkflowAndTaskStateWithHttpInfo(updateRequest, requestId, workflowId, waitUntilTaskRef, waitForSeconds); + return resp.getData(); + } + + /** + * Update workflow and task status + * Updates the workflow variables, tasks and triggers evaluation. + * @param body (required) + * @param requestId (required) + * @param workflowId (required) + * @param waitUntilTaskRef (optional) + * @param waitForSeconds (optional, default to 10) + * @return ApiResponse<WorkflowRun> + * @throws ApiException If fail to call the API, e.g. server error or cannot deserialize the response body + */ + public ApiResponse updateWorkflowAndTaskStateWithHttpInfo(WorkflowStateUpdate body, String requestId, String workflowId, String waitUntilTaskRef, Integer waitForSeconds) throws ApiException { + com.squareup.okhttp.Call call = updateWorkflowAndTaskStateValidateBeforeCall(body, requestId, workflowId, waitUntilTaskRef, waitForSeconds, null, null); + Type localVarReturnType = new TypeToken(){}.getType(); + return apiClient.execute(call, localVarReturnType); + } + + + public com.squareup.okhttp.Call updateWorkflowAndTaskStateCall(WorkflowStateUpdate body, String requestId, String workflowId, String waitUntilTaskRef, Integer waitForSeconds, final ProgressResponseBody.ProgressListener progressListener, final ProgressRequestBody.ProgressRequestListener progressRequestListener) throws ApiException { + Object localVarPostBody = body; + + // create path and map variables + String localVarPath = "/workflow/{workflowId}/state" + .replaceAll("\\{" + "workflowId" + "\\}", apiClient.escapeString(workflowId.toString())); + + List localVarQueryParams = new ArrayList(); + List localVarCollectionQueryParams = new ArrayList(); + if (requestId != null) + localVarQueryParams.addAll(apiClient.parameterToPair("requestId", requestId)); + if (waitUntilTaskRef != null) + localVarQueryParams.addAll(apiClient.parameterToPair("waitUntilTaskRef", waitUntilTaskRef)); + if (waitForSeconds != null) + localVarQueryParams.addAll(apiClient.parameterToPair("waitForSeconds", waitForSeconds)); + + Map localVarHeaderParams = new HashMap(); + + Map localVarFormParams = new HashMap(); + + final String[] localVarAccepts = { + "*/*" + }; + final String localVarAccept = apiClient.selectHeaderAccept(localVarAccepts); + if (localVarAccept != null) localVarHeaderParams.put("Accept", localVarAccept); + + final String[] localVarContentTypes = { + "application/json" + }; + final String localVarContentType = apiClient.selectHeaderContentType(localVarContentTypes); + localVarHeaderParams.put("Content-Type", localVarContentType); + + if(progressListener != null) { + apiClient.getHttpClient().networkInterceptors().add(new com.squareup.okhttp.Interceptor() { + @Override + public com.squareup.okhttp.Response intercept(com.squareup.okhttp.Interceptor.Chain chain) throws IOException { + com.squareup.okhttp.Response originalResponse = chain.proceed(chain.request()); + return originalResponse.newBuilder() + .body(new ProgressResponseBody(originalResponse.body(), progressListener)) + .build(); + } + }); + } + + String[] localVarAuthNames = new String[] { "api_key" }; + return apiClient.buildCall(localVarPath, "POST", localVarQueryParams, localVarCollectionQueryParams, localVarPostBody, localVarHeaderParams, localVarFormParams, localVarAuthNames, progressRequestListener); + } + + @SuppressWarnings("rawtypes") + private com.squareup.okhttp.Call updateWorkflowAndTaskStateValidateBeforeCall(WorkflowStateUpdate body, String requestId, String workflowId, String waitUntilTaskRef, Integer waitForSeconds, final ProgressResponseBody.ProgressListener progressListener, final ProgressRequestBody.ProgressRequestListener progressRequestListener) throws ApiException { + // verify the required parameter 'body' is set + if (body == null) { + throw new ApiException("Missing the required parameter 'body' when calling updateWorkflowAndTaskState(Async)"); + } + // verify the required parameter 'requestId' is set + if (requestId == null) { + throw new ApiException("Missing the required parameter 'requestId' when calling updateWorkflowAndTaskState(Async)"); + } + // verify the required parameter 'workflowId' is set + if (workflowId == null) { + throw new ApiException("Missing the required parameter 'workflowId' when calling updateWorkflowAndTaskState(Async)"); + } + + com.squareup.okhttp.Call call = updateWorkflowAndTaskStateCall(body, requestId, workflowId, waitUntilTaskRef, waitForSeconds, progressListener, progressRequestListener); + return call; + } } diff --git a/src/main/java/io/orkes/conductor/client/model/WorkflowStateUpdate.java b/src/main/java/io/orkes/conductor/client/model/WorkflowStateUpdate.java new file mode 100644 index 00000000..f374a35f --- /dev/null +++ b/src/main/java/io/orkes/conductor/client/model/WorkflowStateUpdate.java @@ -0,0 +1,26 @@ +/* + * Copyright 2024 Orkes, Inc. + *

+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

+ * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on + * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the + * specific language governing permissions and limitations under the License. + */ +package io.orkes.conductor.client.model; + +import java.util.Map; + +import com.netflix.conductor.common.metadata.tasks.TaskResult; + +import lombok.Data; + +@Data +public class WorkflowStateUpdate { + private String taskReferenceName; + private Map variables; + private TaskResult taskResult; +} diff --git a/src/test/java/io/orkes/conductor/client/api/AuthorizationClientTests.java b/src/test/java/io/orkes/conductor/client/api/AuthorizationClientTests.java index 3e511ebe..f120b010 100644 --- a/src/test/java/io/orkes/conductor/client/api/AuthorizationClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/AuthorizationClientTests.java @@ -255,7 +255,7 @@ void testMethods() { } } assertTrue(found); -// authorizationClient.getPermissions("", Commons.GROUP_ID); + authorizationClient.getPermissions("APPLICATION", applicationId); assertEquals(authorizationClient.getApplication(applicationId).getId(), applicationId); assertTrue( authorizationClient @@ -325,7 +325,6 @@ AuthorizationRequest getAuthorizationRequest() { private List getTagObject() { TagObject tagObject = new TagObject(); - tagObject.setType(null); tagObject.setKey("department"); tagObject.setValue("accounts"); return List.of(tagObject); diff --git a/src/test/java/io/orkes/conductor/client/api/EventClientTests.java b/src/test/java/io/orkes/conductor/client/api/EventClientTests.java index 897e9138..fb061c21 100644 --- a/src/test/java/io/orkes/conductor/client/api/EventClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/EventClientTests.java @@ -13,10 +13,7 @@ package io.orkes.conductor.client.api; import java.util.List; -import java.util.Map; -import org.apache.kafka.clients.consumer.ConsumerConfig; -import org.apache.kafka.clients.producer.ProducerConfig; import org.junit.jupiter.api.Test; import com.netflix.conductor.common.metadata.events.EventHandler; @@ -25,17 +22,10 @@ import io.orkes.conductor.client.EventClient; import io.orkes.conductor.client.http.ApiException; -import io.orkes.conductor.client.model.event.QueueConfiguration; -import io.orkes.conductor.client.model.event.QueueWorkerConfiguration; -import io.orkes.conductor.client.model.event.kafka.KafkaConfiguration; -import io.orkes.conductor.client.model.event.kafka.KafkaConsumer; -import io.orkes.conductor.client.model.event.kafka.KafkaProducer; import io.orkes.conductor.client.util.Commons; -import static org.junit.Assert.assertThrows; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertIterableEquals; -import static org.junit.jupiter.api.Assertions.assertTrue; public class EventClientTests extends ClientTest { private static final String EVENT_NAME = "test_sdk_java_event_name"; @@ -73,39 +63,9 @@ void testEventHandler() { assertIterableEquals(List.of(), eventClient.getEventHandlers(EVENT, false)); } - @Test - void testKafkaQueueConfiguration() throws Exception { - QueueConfiguration queueConfiguration = getQueueConfiguration(); - eventClient.deleteQueueConfig(queueConfiguration); - assertThrows( - ApiException.class, - () -> { - eventClient.getQueueConfig(queueConfiguration); - }); - eventClient.putQueueConfig(queueConfiguration); - Map configurationResponse = eventClient.getQueueConfig(queueConfiguration); - assertTrue(configurationResponse.containsKey("consumer")); - assertTrue(configurationResponse.containsKey("producer")); - eventClient.deleteQueueConfig(queueConfiguration); - } - QueueConfiguration getQueueConfiguration() throws Exception { - return new KafkaConfiguration(KAFKA_QUEUE_TOPIC_NAME) - .withConsumer(getKafkaConsumer()) - .withProducer(getKafkaProducer()); - } - QueueWorkerConfiguration getKafkaConsumer() throws Exception { - return new KafkaConsumer(KAFKA_BOOTSTRAP_SERVERS_CONFIG) - // 1 second, instead of default 2 seconds - .withConfiguration(ConsumerConfig.HEARTBEAT_INTERVAL_MS_CONFIG, "1000"); - } - QueueWorkerConfiguration getKafkaProducer() throws Exception { - return new KafkaProducer(KAFKA_BOOTSTRAP_SERVERS_CONFIG) - // send messages in chunks of 1024 bytes, instead of default every new data - .withConfiguration(ProducerConfig.BATCH_SIZE_CONFIG, "1024"); - } EventHandler getEventHandler() { EventHandler eventHandler = new EventHandler(); diff --git a/src/test/java/io/orkes/conductor/client/api/MetadataClientTests.java b/src/test/java/io/orkes/conductor/client/api/MetadataClientTests.java index f58830af..529174dd 100644 --- a/src/test/java/io/orkes/conductor/client/api/MetadataClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/MetadataClientTests.java @@ -29,11 +29,12 @@ import static org.junit.jupiter.api.Assertions.*; +@SuppressWarnings("unchecked") public class MetadataClientTests extends ClientTest { private final MetadataClient metadataClient; public MetadataClientTests() { - metadataClient = super.orkesClients.getMetadataClient(); + metadataClient = orkesClients.getMetadataClient(); ((OrkesMetadataClient) metadataClient).withReadTimeout(45000); } @@ -50,7 +51,7 @@ void taskDefinition() { metadataClient.registerTaskDefs(List.of(taskDef)); metadataClient.updateTaskDef(taskDef); TaskDef receivedTaskDef = metadataClient.getTaskDef(Commons.TASK_NAME); - assertTrue(taskDef.getName().equals(receivedTaskDef.getName())); + assertEquals(taskDef.getName(), receivedTaskDef.getName()); } @Test @@ -72,7 +73,7 @@ void workflow() { .getWorkflowDefWithMetadata(Commons.WORKFLOW_NAME, Commons.WORKFLOW_VERSION); WorkflowDef receivedWorkflowDef = metadataClient.getWorkflowDef(Commons.WORKFLOW_NAME, Commons.WORKFLOW_VERSION); - assertTrue(receivedWorkflowDef.getName().equals(Commons.WORKFLOW_NAME)); + assertEquals(receivedWorkflowDef.getName(), Commons.WORKFLOW_NAME); assertEquals(receivedWorkflowDef.getVersion(), Commons.WORKFLOW_VERSION); } @@ -91,7 +92,7 @@ void tagTask() throws Exception { metadataClient.setTaskTags(List.of(tagObject), Commons.TASK_NAME); assertNotNull( TestUtil.retryMethodCall( - () -> metadataClient.getTags())); + metadataClient::getTags)); List tags = (List) TestUtil.retryMethodCall( () -> metadataClient.getTaskTags(Commons.TASK_NAME)); assertIterableEquals(List.of(tagObject), tags); diff --git a/src/test/java/io/orkes/conductor/client/api/SchedulerClientTests.java b/src/test/java/io/orkes/conductor/client/api/SchedulerClientTests.java index fc863f9a..14f832a8 100644 --- a/src/test/java/io/orkes/conductor/client/api/SchedulerClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/SchedulerClientTests.java @@ -12,16 +12,16 @@ */ package io.orkes.conductor.client.api; -import io.orkes.conductor.client.model.TagObject; +import java.util.List; + import org.junit.jupiter.api.Test; import io.orkes.conductor.client.SchedulerClient; import io.orkes.conductor.client.model.SaveScheduleRequest; +import io.orkes.conductor.client.model.TagObject; import io.orkes.conductor.client.model.WorkflowSchedule; import io.orkes.conductor.client.util.Commons; -import java.util.List; - import static org.junit.jupiter.api.Assertions.*; public class SchedulerClientTests extends ClientTest { @@ -31,20 +31,19 @@ public class SchedulerClientTests extends ClientTest { private final SchedulerClient schedulerClient; public SchedulerClientTests() { - schedulerClient = super.orkesClients.getSchedulerClient(); + schedulerClient = orkesClients.getSchedulerClient(); } @Test void testMethods() { schedulerClient.deleteSchedule(NAME); - List existingTags = schedulerClient.getSchedulerTags(NAME); - schedulerClient.deleteSchedulerTags(existingTags, NAME); assertTrue(schedulerClient.getNextFewSchedules(CRON_EXPRESSION, 0L, 0L, 0).isEmpty()); schedulerClient.saveSchedule(getSaveScheduleRequest()); assertEquals(1, schedulerClient.getAllSchedules(Commons.WORKFLOW_NAME).size()); WorkflowSchedule workflowSchedule = schedulerClient.getSchedule(NAME); assertEquals(NAME, workflowSchedule.getName()); assertEquals(CRON_EXPRESSION, workflowSchedule.getCronExpression()); + assertFalse(schedulerClient.searchV22(0, 10, "ASC", "*", "").getResults().isEmpty()); schedulerClient.setSchedulerTags(getTagObject(), NAME); assertEquals(getTagObject(), schedulerClient.getSchedulerTags(NAME)); schedulerClient.deleteSchedulerTags(getTagObject(), NAME); @@ -74,7 +73,6 @@ SaveScheduleRequest getSaveScheduleRequest() { private List getTagObject() { TagObject tagObject = new TagObject(); - tagObject.setType(null); tagObject.setKey("department"); tagObject.setValue("accounts"); return List.of(tagObject); diff --git a/src/test/java/io/orkes/conductor/client/api/SecretClientTests.java b/src/test/java/io/orkes/conductor/client/api/SecretClientTests.java index 9da0c2ac..9864745e 100644 --- a/src/test/java/io/orkes/conductor/client/api/SecretClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/SecretClientTests.java @@ -45,9 +45,6 @@ void testMethods() { secretClient.putSecret(SECRET_NAME, SECRET_KEY); secretClient.setSecretTags(List.of(getTagObject()), SECRET_KEY); List tags = secretClient.getSecretTags(SECRET_KEY); - secretClient.deleteSecretTags(tags, SECRET_KEY); - secretClient.putSecret(SECRET_NAME, SECRET_KEY); - secretClient.setSecretTags(List.of(getTagObject()), SECRET_KEY); assertEquals(tags.size(), 1); assertEquals(tags.get(0), getTagObject()); secretClient.deleteSecretTags(List.of(getTagObject()), SECRET_KEY); @@ -61,7 +58,6 @@ void testMethods() { private TagObject getTagObject() { TagObject tagObject = new TagObject(); - tagObject.setType(null); tagObject.setKey("department"); tagObject.setValue("accounts"); return tagObject; diff --git a/src/test/java/io/orkes/conductor/client/api/TaskClientTests.java b/src/test/java/io/orkes/conductor/client/api/TaskClientTests.java index a1b91f98..7dbc09a7 100644 --- a/src/test/java/io/orkes/conductor/client/api/TaskClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/TaskClientTests.java @@ -85,6 +85,8 @@ public void testUpdateByRefName() { Workflow workflow = workflowClient.getWorkflow(workflowId, true); assertNotNull(workflow); + System.out.println("Running test for workflow: " + workflowId); + int maxLoop = 10; int count = 0; while (!workflow.getStatus().isTerminal() && count < maxLoop) { @@ -130,8 +132,7 @@ public void testUpdateByRefNameSync() { for (String referenceName : runningTasks) { System.out.println("Updating " + referenceName); try { - workflow = taskClient.updateTaskSync(workflowId, referenceName, TaskResult.Status.COMPLETED, - new TaskOutput()); + workflow = taskClient.updateTaskSync(workflowId, referenceName, TaskResult.Status.COMPLETED, new TaskOutput()); System.out.println("Workflow: " + workflow); } catch (ApiException apiException) { // 404 == task was updated already and there are no pending tasks diff --git a/src/test/java/io/orkes/conductor/client/api/WorkflowClientTests.java b/src/test/java/io/orkes/conductor/client/api/WorkflowClientTests.java index 18c402e8..b793c5f5 100644 --- a/src/test/java/io/orkes/conductor/client/api/WorkflowClientTests.java +++ b/src/test/java/io/orkes/conductor/client/api/WorkflowClientTests.java @@ -87,14 +87,13 @@ public void testSearchByCorrelationIds() { } } // Let's give couple of seconds for indexing to complete - Uninterruptibles.sleepUninterruptibly(2, TimeUnit.SECONDS); - Map> result = workflowClient.getWorkflowsByNamesAndCorrelationIds(correlationIds, - workflowNames.stream().collect(Collectors.toList()), true, false); + Uninterruptibles.sleepUninterruptibly(10, TimeUnit.SECONDS); + Map> result = workflowClient.getWorkflowsByNamesAndCorrelationIds(correlationIds, new ArrayList<>(workflowNames), true, false); assertNotNull(result); assertEquals(correlationIds.size(), result.size()); for (String correlationId : correlationIds) { assertEquals(5, result.get(correlationId).size()); - Set ids = result.get(correlationId).stream().map(wf -> wf.getWorkflowId()) + Set ids = result.get(correlationId).stream().map(Workflow::getWorkflowId) .collect(Collectors.toSet()); assertEquals(correlationIdToWorkflows.get(correlationId), ids); } diff --git a/src/test/java/io/orkes/conductor/client/api/WorkflowStateUpdateTests.java b/src/test/java/io/orkes/conductor/client/api/WorkflowStateUpdateTests.java new file mode 100644 index 00000000..1505179f --- /dev/null +++ b/src/test/java/io/orkes/conductor/client/api/WorkflowStateUpdateTests.java @@ -0,0 +1,99 @@ +/* + * Copyright 2024 Orkes, Inc. + *

+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

+ * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on + * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the + * specific language governing permissions and limitations under the License. + */ +package io.orkes.conductor.client.api; + +import java.util.List; +import java.util.Map; +import java.util.Set; +import java.util.concurrent.TimeUnit; +import java.util.stream.Collectors; + +import org.junit.jupiter.api.BeforeAll; +import org.junit.jupiter.api.Test; + +import com.netflix.conductor.common.metadata.tasks.Task; +import com.netflix.conductor.common.metadata.tasks.TaskResult; +import com.netflix.conductor.common.metadata.workflow.StartWorkflowRequest; +import com.netflix.conductor.common.run.Workflow; + +import io.orkes.conductor.client.WorkflowClient; +import io.orkes.conductor.client.model.WorkflowStateUpdate; +import io.orkes.conductor.common.model.WorkflowRun; + +import lombok.SneakyThrows; + +import static org.junit.Assert.assertEquals; + +public class WorkflowStateUpdateTests extends ClientTest { + + private static WorkflowClient workflowClient; + + @BeforeAll + public static void init() { + workflowClient = orkesClients.getWorkflowClient(); + } + + @SneakyThrows + public String startWorkflow() { + StartWorkflowRequest startWorkflowRequest = new StartWorkflowRequest(); + startWorkflowRequest.setName("sync_task_variable_updates"); + startWorkflowRequest.setVersion(1); + var run = workflowClient.executeWorkflow(startWorkflowRequest, "wait_task_ref"); + return run.get(10, TimeUnit.SECONDS) + .getWorkflowId(); + } + + @Test + public void test() { + String workflowId = startWorkflow(); + System.out.println(workflowId); + + TaskResult taskResult = new TaskResult(); + taskResult.setOutputData(Map.of("a", "b")); + + WorkflowStateUpdate request = new WorkflowStateUpdate(); + request.setTaskReferenceName("wait_task_ref"); + request.setTaskResult(taskResult); + + request.setVariables(Map.of("case", "case1")); + + WorkflowRun workflowRun = workflowClient.updateWorkflow(workflowId, List.of("wait_task_ref_1", "wait_task_ref_2"), 10, request); + + System.out.println(workflowRun); + System.out.println(workflowRun.getStatus()); + System.out.println(workflowRun.getTasks() + .stream() + .map(task -> task.getReferenceTaskName() + ":" + task.getStatus()) + .collect(Collectors.toList())); + + request = new WorkflowStateUpdate(); + request.setTaskReferenceName("wait_task_ref_2"); + request.setTaskResult(taskResult); + workflowRun = workflowClient.updateWorkflow(workflowId, List.of(), 10, request); + + assertEquals(Workflow.WorkflowStatus.COMPLETED, workflowRun.getStatus()); + Set allTaskStatus = workflowRun.getTasks() + .stream() + .map(t -> t.getStatus()) + .collect(Collectors.toSet()); + assertEquals(1, allTaskStatus.size()); + assertEquals(Task.Status.COMPLETED, allTaskStatus.iterator().next()); + + System.out.println(workflowRun.getStatus()); + System.out.println(workflowRun.getTasks() + .stream() + .map(task -> task.getReferenceTaskName() + ":" + task.getStatus()) + .collect(Collectors.toList())); + + } +} diff --git a/src/test/java/io/orkes/conductor/client/util/ApiUtil.java b/src/test/java/io/orkes/conductor/client/util/ApiUtil.java index 9148c215..91f2da93 100644 --- a/src/test/java/io/orkes/conductor/client/util/ApiUtil.java +++ b/src/test/java/io/orkes/conductor/client/util/ApiUtil.java @@ -22,14 +22,6 @@ public class ApiUtil { private static final String ENV_KEY_ID = "SDK_INTEGRATION_TESTS_SERVER_KEY_ID"; private static final String ENV_SECRET = "SDK_INTEGRATION_TESTS_SERVER_KEY_SECRET"; - public static final String USER1_APP_ID = "USER1_APPLICATION_ID"; - - public static final String USER2_APP_ID = "USER2_APPLICATION_ID"; - public static final String USER1_KEY_ID = "USER1_KEY_ID"; - private static final String USER1_SECRET = "USER1_SECRET"; - public static final String USER2_KEY_ID = "USER2_KEY_ID"; - private static final String USER2_SECRET = "USER2_SECRET"; - public static OrkesClients getOrkesClient() { final ApiClient apiClient = getApiClientWithCredentials(); apiClient.setReadTimeout(10_000); @@ -50,34 +42,6 @@ public static ApiClient getApiClientWithCredentials() { return apiClient; } - public static ApiClient getUser1Client() { - String basePath = getBasePath(); - assertNotNull(basePath, ENV_ROOT_URI + " env not set"); - String keyId = getEnv(USER1_KEY_ID); - assertNotNull(keyId, USER1_KEY_ID + " env not set"); - String keySecret = getEnv(USER1_SECRET); - assertNotNull(keySecret, USER1_SECRET + " env not set"); - ApiClient apiClient = new ApiClient(basePath, keyId, keySecret); - apiClient.setWriteTimeout(30_000); - apiClient.setReadTimeout(30_000); - apiClient.setConnectTimeout(30_000); - return apiClient; - } - - public static ApiClient getUser2Client() { - String basePath = getBasePath(); - assertNotNull(basePath, ENV_ROOT_URI + " env not set"); - String keyId = getEnv(USER2_KEY_ID); - assertNotNull(keyId, USER2_KEY_ID + " env not set"); - String keySecret = getEnv(USER2_SECRET); - assertNotNull(keySecret, USER2_SECRET + " env not set"); - ApiClient apiClient = new ApiClient(basePath, keyId, keySecret); - apiClient.setWriteTimeout(30_000); - apiClient.setReadTimeout(30_000); - apiClient.setConnectTimeout(30_000); - return apiClient; - } - public static String getBasePath() { return getEnv(ENV_ROOT_URI); }