diff --git a/authentication/esignet-integration-impl/src/main/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImpl.java b/authentication/esignet-integration-impl/src/main/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImpl.java index 3a06bf6e3c2..8eb043021c4 100644 --- a/authentication/esignet-integration-impl/src/main/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImpl.java +++ b/authentication/esignet-integration-impl/src/main/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImpl.java @@ -1,5 +1,6 @@ package io.mosip.authentication.esignet.integration.service; +import io.mosip.kernel.core.exception.ExceptionUtils; import org.json.JSONException; import org.json.JSONObject; import org.springframework.beans.factory.annotation.Autowired; @@ -47,17 +48,20 @@ public class IdaAuditPluginImpl implements AuditPlugin { @Value("${mosip.esignet.authenticator.ida.audit-manager-url}") private String auditManagerUrl; + @Value("${mosip.audit.description.max-length:2048}") + private Integer auditDescriptionMaxLength; + @Override public void logAudit(Action action, ActionStatus status, AuditDTO audit, Throwable t) { - audit(null, action, status, audit); + audit(null, action, status, audit,t); } @Override public void logAudit(String username, Action action, ActionStatus status, AuditDTO audit, Throwable t) { - audit(username, action, status, audit); + audit(username, action, status, audit,t); } - private void audit(String username, Action action, ActionStatus status, AuditDTO audit) { + private void audit(String username, Action action, ActionStatus status, AuditDTO audit, Throwable t) { try { String authToken = authTransactionHelper.getAuthToken(); @@ -78,7 +82,11 @@ private void audit(String username, Action action, ActionStatus status, AuditDTO auditRequest.setCreatedBy(this.getClass().getSimpleName()); auditRequest.setModuleName(action.getModule()); auditRequest.setModuleId(action.getModule()); - auditRequest.setDescription(getAuditDescription(audit)); + String auditDescription = t != null ? ExceptionUtils.getStackTrace(t) : getAuditDescription(audit); + if (auditDescription != null && auditDescription.length() > auditDescriptionMaxLength) { + auditDescription = auditDescription.substring(0, auditDescriptionMaxLength); + } + auditRequest.setDescription(auditDescription); auditRequest.setId(audit.getTransactionId()); request.setRequest(auditRequest); diff --git a/authentication/esignet-integration-impl/src/test/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImplTest.java b/authentication/esignet-integration-impl/src/test/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImplTest.java index ceda8fd7c41..9dc267df614 100644 --- a/authentication/esignet-integration-impl/src/test/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImplTest.java +++ b/authentication/esignet-integration-impl/src/test/java/io/mosip/authentication/esignet/integration/service/IdaAuditPluginImplTest.java @@ -95,11 +95,6 @@ public void logAudit_WithValidStatus_ThenPass() throws Exception { new ParameterizedTypeReference() { }; Mockito.when(authTransactionHelper.getAuthToken()).thenReturn("authToken"); - Mockito.when(objectMapper.writeValueAsString(any())).thenReturn("requestBody"); - Mockito.when(restTemplate.exchange( - Mockito.any(RequestEntity.class), - Mockito.eq(responseType) - )).thenReturn(responseEntity); try { idaAuditPlugin.logAudit(username,action, status, auditDTO, null); Assert.assertTrue(true); @@ -120,11 +115,6 @@ public void logAudit_WithUnauthorizedStatus_ThenPass() throws Exception { new ParameterizedTypeReference() { }; Mockito.when(authTransactionHelper.getAuthToken()).thenReturn("authToken"); - Mockito.when(objectMapper.writeValueAsString(any())).thenReturn("requestBody"); - Mockito.when(restTemplate.exchange( - Mockito.any(RequestEntity.class), - Mockito.eq(responseType) - )).thenReturn(responseEntity); try { idaAuditPlugin.logAudit(username,action, status, auditDTO, null); Assert.assertTrue(true); @@ -145,11 +135,6 @@ public void logAudit_WithForbiddenStatus_ThenPass() throws Exception { new ParameterizedTypeReference() { }; Mockito.when(authTransactionHelper.getAuthToken()).thenReturn("authToken"); - Mockito.when(objectMapper.writeValueAsString(any())).thenReturn("requestBody"); - Mockito.when(restTemplate.exchange( - Mockito.any(RequestEntity.class), - Mockito.eq(responseType) - )).thenReturn(responseEntity); try { idaAuditPlugin.logAudit(username,action, status, auditDTO, null); Assert.assertTrue(true);