Skip to content

Commit

Permalink
Merge pull request #65 from europeana/EA-3842-exception-handling-and_…
Browse files Browse the repository at this point in the history
…logging

do not write credentials to logs
  • Loading branch information
gsergiu authored Jun 14, 2024
2 parents d78543c + d68c633 commit 824e4cd
Showing 1 changed file with 59 additions and 51 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -61,16 +61,16 @@ public class ETranslationTranslationService extends AbstractTranslationService {
public ETranslationTranslationService(String etranslationServiceBaseUrl, String domain,
String translationApiBaseUrl, int maxWaitMillisec, String username, String password,
RedisMessageListenerContainer redisMessageListenerContainer) throws TranslationException {
if (!FAKE_BASE_URL_FOR_TESTING.equals(etranslationServiceBaseUrl)) {
validateETranslConfigParams(etranslationServiceBaseUrl, domain, translationApiBaseUrl,
maxWaitMillisec, username, password);
if (!FAKE_BASE_URL_FOR_TESTING.equals(santizeETranslationRequestBody(etranslationServiceBaseUrl))) {
validateETranslConfigParams(santizeETranslationRequestBody(etranslationServiceBaseUrl), santizeETranslationRequestBody(domain), santizeETranslationRequestBody(translationApiBaseUrl),
maxWaitMillisec, santizeETranslationRequestBody(username), santizeETranslationRequestBody(password));
}
this.baseUrl = etranslationServiceBaseUrl;
this.translationApiBaseUrl = translationApiBaseUrl;
this.domain = domain;
this.baseUrl = santizeETranslationRequestBody(etranslationServiceBaseUrl);
this.translationApiBaseUrl = santizeETranslationRequestBody(translationApiBaseUrl);
this.domain = santizeETranslationRequestBody(domain);
this.maxWaitMillisec = maxWaitMillisec;
this.credentialUsername = username;
this.credentialPwd = password;
this.credentialUsername = santizeETranslationRequestBody(username);
this.credentialPwd = santizeETranslationRequestBody(password);
this.redisMessageListenerContainer = redisMessageListenerContainer;
}

Expand All @@ -86,22 +86,22 @@ private void validateETranslConfigParams(String etranslationServiceBaseUrl, Stri
String translationApiBaseUrl, int maxWaitMillisec, String username, String password)
throws TranslationException {
List<String> missingParams = new ArrayList<>(6);
if (StringUtils.isBlank(etranslationServiceBaseUrl)) {
if (StringUtils.isBlank(santizeETranslationRequestBody(etranslationServiceBaseUrl))) {
missingParams.add("baseUrl");
}
if (StringUtils.isBlank(domain)) {
if (StringUtils.isBlank(santizeETranslationRequestBody(domain))) {
missingParams.add("domain");
}
if (StringUtils.isBlank(translationApiBaseUrl)) {
if (StringUtils.isBlank(santizeETranslationRequestBody(translationApiBaseUrl))) {
missingParams.add("translationApiBaseUrl");
}
if (maxWaitMillisec <= 0) {
missingParams.add("maxWaitMillisec (must be >0)");
}
if (StringUtils.isBlank(username)) {
if (StringUtils.isBlank(santizeETranslationRequestBody(username))) {
missingParams.add("username");
}
if (StringUtils.isBlank(password)) {
if (StringUtils.isBlank(santizeETranslationRequestBody(password))) {
missingParams.add("password");
}

Expand All @@ -114,7 +114,7 @@ private void validateETranslConfigParams(String etranslationServiceBaseUrl, Stri
@Override
public void translate(List<TranslationObj> translationObjs) throws TranslationException {
String sourceLang = translationObjs.get(0).getSourceLang();
if (sourceLang == null) {
if (santizeETranslationRequestBody(sourceLang) == null) {
throw new TranslationException(
"The source language cannot be null for the eTranslation service.");
}
Expand All @@ -129,27 +129,27 @@ public void translate(List<TranslationObj> translationObjs) throws TranslationEx
* using the external reference from the eTransl callback.
*/
// create external reference for eTransl service
String eTranslExtRef = TranslationUtils.generateRedisKey(eTranslJointStr,
String eTranslExtRef = TranslationUtils.generateRedisKey(santizeETranslationRequestBody(eTranslJointStr),
translationObjs.get(0).getSourceLang(), translationObjs.get(0).getTargetLang(), "et:");

try {
//create request body
String body =
createTranslationRequestBody(eTranslJointStr, translationObjs.get(0).getSourceLang(),
translationObjs.get(0).getTargetLang(), eTranslExtRef);
createTranslationRequestBody(santizeETranslationRequestBody(eTranslJointStr), translationObjs.get(0).getSourceLang(),
translationObjs.get(0).getTargetLang(), santizeETranslationRequestBody(eTranslExtRef));

// register redis channel
redisMessageListenerAdapter = registerRedisChannel(eTranslExtRef, eTranslJointStr.length());
redisMessageListenerAdapter = registerRedisChannel(santizeETranslationRequestBody(eTranslExtRef), santizeETranslationRequestBody(eTranslJointStr).length());

//send the eTransl request, if not fake url
if (!FAKE_BASE_URL_FOR_TESTING.equals(baseUrl)) {
sendTranslationRequest(body);
sendTranslationRequest(santizeETranslationRequestBody(body));
}
// create a redis message listener obj, and wait on that obj until it get notified from the
// redis publisher
// createRedisMessageListenerAndWaitForResults(translationObjs, eTranslExtRef,
// eTranslJointStr.length());
readTranslationResponseFromRedis(redisMessageListenerAdapter, translationObjs, eTranslExtRef, eTranslJointStr.length());
readTranslationResponseFromRedis(redisMessageListenerAdapter, translationObjs, santizeETranslationRequestBody(eTranslExtRef), santizeETranslationRequestBody(eTranslJointStr).length());

} catch (JSONException | UnsupportedEncodingException e) {
throw new TranslationException(
Expand Down Expand Up @@ -180,7 +180,7 @@ private void readTranslationResponseFromRedis(MessageListenerAdapter redisMessag
String response =
readMessageFromChannel(redisMessageListenerAdapter);

if (response == null) {
if (santizeETranslationRequestBody(response) == null) {
throw new TranslationException(
"No response received from external eTranslation Service within expected interval of seconds: "
+ toSeconds(maxWaitMillisec),
Expand All @@ -189,16 +189,16 @@ private void readTranslationResponseFromRedis(MessageListenerAdapter redisMessag

// message received, populate the translations
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("Received message from redis message listener is: {}", response);
LOGGER.debug("Received message from redis message listener is: {}", santizeETranslationRequestBody(response));
}

if (response.contains(ETranslationTranslationService.ERROR_CALLBACK_MARKUP)) {
if (santizeETranslationRequestBody(response).contains(ETranslationTranslationService.ERROR_CALLBACK_MARKUP)) {
// eTtransl error callback received
throw new TranslationException(response, HttpStatus.SC_UNPROCESSABLE_ENTITY);
throw new TranslationException(santizeETranslationRequestBody(response), HttpStatus.SC_UNPROCESSABLE_ENTITY);
}

// fill translations into the provided translation list
fillTranslationsFromRemoteResponse(translationObjs, response, isSnippetLimitExceeded(textSize));
fillTranslationsFromRemoteResponse(translationObjs, santizeETranslationRequestBody(response), isSnippetLimitExceeded(textSize));
}

private int toSeconds(int maxWaitMillisec) {
Expand Down Expand Up @@ -262,16 +262,16 @@ private MessageListenerAdapter registerRedisChannel(String eTranslExtRef, int te
MessageListenerAdapter redisMessageListenerAdapter =
new MessageListenerAdapter(new RedisMessageListener(requestAsDocument));
redisMessageListenerContainer.addMessageListener(redisMessageListenerAdapter,
ChannelTopic.of(eTranslExtRef));
ChannelTopic.of(santizeETranslationRequestBody(eTranslExtRef)));
return redisMessageListenerAdapter;
}

private void fillTranslationsFromRemoteResponse(List<TranslationObj> translationObjs,
String response, boolean responseAsDocument) throws TranslationException {
if (responseAsDocument) {
fillTranslationsFromDocumentTranslationResponse(translationObjs, response);
fillTranslationsFromDocumentTranslationResponse(translationObjs, santizeETranslationRequestBody(response));
} else {
fillTranslationsFromTextSnippetTranslationResponse(translationObjs, response);
fillTranslationsFromTextSnippetTranslationResponse(translationObjs, santizeETranslationRequestBody(response));
}
}

Expand All @@ -288,8 +288,8 @@ private void fillTranslationsFromRemoteResponse(List<TranslationObj> translation
private void fillTranslationsFromDocumentTranslationResponse(List<TranslationObj> translationObjs,
String response) throws TranslationException {
// first base64 decode
String respBase64Decoded = new String(Base64.decodeBase64(response), StandardCharsets.UTF_8);
fillTranslationsFromTextSnippetTranslationResponse(translationObjs, respBase64Decoded);
String respBase64Decoded = new String(Base64.decodeBase64(santizeETranslationRequestBody(response)), StandardCharsets.UTF_8);
fillTranslationsFromTextSnippetTranslationResponse(translationObjs, santizeETranslationRequestBody(respBase64Decoded));
}

/**
Expand All @@ -304,7 +304,7 @@ private void fillTranslationsFromDocumentTranslationResponse(List<TranslationObj

private void fillTranslationsFromTextSnippetTranslationResponse(
List<TranslationObj> translationObjs, String response) throws TranslationException {
String[] translations = response.split(MARKUP_DELIMITER_WITHOUT_NEWLINE);
String[] translations = santizeETranslationRequestBody(response).split(MARKUP_DELIMITER_WITHOUT_NEWLINE);
if (translations.length != translationObjs.size()) {
throw new TranslationException(
"The eTranslation response and the input texts have different size.");
Expand Down Expand Up @@ -338,10 +338,10 @@ private String generateJointStringForTranslation(List<TranslationObj> translatio

private String createTranslationRequestBody(String text, String sourceLang, String targetLang,
String externalReference) throws JSONException {
if (isSnippetLimitExceeded(text.length())) {
return createTranslationBodyWithDocument(text, sourceLang, targetLang, externalReference);
if (isSnippetLimitExceeded(santizeETranslationRequestBody(text).length())) {
return createTranslationBodyWithDocument(santizeETranslationRequestBody(text), santizeETranslationRequestBody(sourceLang), santizeETranslationRequestBody(targetLang), santizeETranslationRequestBody(externalReference));
} else {
return createTranslationBodyWithTextSnippet(text, sourceLang, targetLang, externalReference);
return createTranslationBodyWithTextSnippet(santizeETranslationRequestBody(text), santizeETranslationRequestBody(sourceLang), santizeETranslationRequestBody(targetLang), santizeETranslationRequestBody(externalReference));
}
}

Expand All @@ -360,19 +360,19 @@ private String createTranslationBodyWithTextSnippet(String text, String sourceLa
JSONObject jsonBody = new JSONObject().put("priority", 0)
.put("requesterCallback", getTranslatioCallbackUrl())
.put("errorCallback", getTranslationErrorCallbackUrl())
.put("externalReference", externalReference)
.put("externalReference", santizeETranslationRequestBody(externalReference))
.put("callerInformation",
new JSONObject().put("application", credentialUsername).put("username",
credentialUsername))
.put("sourceLanguage", sourceLang.toUpperCase(Locale.ENGLISH))
.put("targetLanguages", new JSONArray().put(0, targetLang.toUpperCase(Locale.ENGLISH)))
.put("sourceLanguage", santizeETranslationRequestBody(sourceLang).toUpperCase(Locale.ENGLISH))
.put("targetLanguages", new JSONArray().put(0, santizeETranslationRequestBody(targetLang).toUpperCase(Locale.ENGLISH)))
.put("domain", domain)
// .put("destinations",
// new JSONObject().put("httpDestinations", new JSONArray().put(0,
// "http://<prod_server_ip>/enrichment-web")))
// .put("documentToTranslateBase64", new JSONObject().put("format",
// fileFormat).put("content", base64content));
.put("textToTranslate", text);
.put("textToTranslate", santizeETranslationRequestBody(text));

return jsonBody.toString();
}
Expand All @@ -391,23 +391,23 @@ private String createTranslationBodyWithTextSnippet(String text, String sourceLa
*/
private String createTranslationBodyWithDocument(String text, String sourceLang,
String targetLang, String externalReference) throws JSONException {
String base64EncodedText = Base64.encodeBase64String(text.getBytes(StandardCharsets.UTF_8));
String base64EncodedText = Base64.encodeBase64String(santizeETranslationRequestBody(text).getBytes(StandardCharsets.UTF_8));
JSONObject jsonBody = new JSONObject().put("priority", 0)
// .put("requesterCallback", getTranslatioCallbackUrl())
// .put("errorCallback", getTranslationErrorCallbackUrl())
.put("externalReference", externalReference)
.put("externalReference", santizeETranslationRequestBody(externalReference))
.put("callerInformation",
new JSONObject().put("application", credentialUsername).put("username",
credentialUsername))
.put("sourceLanguage", sourceLang.toUpperCase(Locale.ENGLISH))
.put("targetLanguages", new JSONArray().put(0, targetLang.toUpperCase(Locale.ENGLISH)))
.put("sourceLanguage", santizeETranslationRequestBody(sourceLang).toUpperCase(Locale.ENGLISH))
.put("targetLanguages", new JSONArray().put(0, santizeETranslationRequestBody(targetLang).toUpperCase(Locale.ENGLISH)))
.put("domain", domain)
.put("destinations",
new JSONObject().put("httpDestinations",
new JSONArray().put(0, getTranslatioCallbackUrl())))
// .put("textToTranslate", text);
.put("documentToTranslateBase64",
new JSONObject().put("content", base64EncodedText).put("format", "txt"));
new JSONObject().put("content", santizeETranslationRequestBody(base64EncodedText)).put("format", "txt"));
return jsonBody.toString();
}

Expand All @@ -418,7 +418,7 @@ private long sendTranslationRequest(String content) throws TranslationException,
CloseableHttpClient httpClient =
HttpClientBuilder.create().setDefaultCredentialsProvider(credsProvider).build();
HttpPost request = new HttpPost(baseUrl);
StringEntity body = new StringEntity(content, "UTF-8");
StringEntity body = new StringEntity(santizeETranslationRequestBody(content), "UTF-8");
request.addHeader("content-type", "application/json");
request.setEntity(body);

Expand All @@ -429,30 +429,38 @@ private long sendTranslationRequest(String content) throws TranslationException,
if (HttpStatus.SC_OK != respStatusLine.getStatusCode()) {
throw new TranslationException(
"The translation request could not be successfully registered. ETranslation response: "
+ respStatusLine.getStatusCode() + ", response body: " + respBody);
+ respStatusLine.getStatusCode() + ", response body: " + santizeETranslationRequestBody(respBody));
}

long requestNumber;
try {
requestNumber = Long.parseLong(respBody);
requestNumber = Long.parseLong(santizeETranslationRequestBody(respBody));
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("eTranslation request sent with the request-id: {} and body: {}.",
requestNumber, content);
requestNumber, santizeETranslationRequestBody(content));
}
if (requestNumber < 0) {
throw wrapETranslationErrorResponse(respBody);
throw wrapETranslationErrorResponse(santizeETranslationRequestBody(respBody));
}
} catch (NumberFormatException e) {
throw wrapETranslationErrorResponse(respBody);
throw wrapETranslationErrorResponse(santizeETranslationRequestBody(respBody));
}

return requestNumber;
}

private String santizeETranslationRequestBody(String content) {
if(content != null) {
content.replaceAll(credentialPwd, "*****");
content.replaceAll(credentialUsername, "*****");
}
return content;
}

TranslationException wrapETranslationErrorResponse(String respBody) {
return new TranslationException(
"The translation request could not be successfully registered. ETranslation error response: "
+ respBody);
+ santizeETranslationRequestBody(respBody));
}

@Override
Expand All @@ -462,7 +470,7 @@ public String getServiceId() {

@Override
public void setServiceId(String serviceId) {
this.serviceId = serviceId;
this.serviceId = santizeETranslationRequestBody(serviceId);
}

@Override
Expand Down

0 comments on commit 824e4cd

Please sign in to comment.