more logging

This commit is contained in:
Efstratios Giannopoulos 2024-05-10 14:00:40 +03:00
parent f080312a59
commit 0f8aadf6f4
1 changed files with 15 additions and 5 deletions

View File

@ -3,6 +3,7 @@ package org.opencdmp.deposit.zenodorepository.service.zenodo;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import gr.cite.tools.exception.MyApplicationException; import gr.cite.tools.exception.MyApplicationException;
import gr.cite.tools.logging.LoggerService; import gr.cite.tools.logging.LoggerService;
import gr.cite.tools.logging.MapLogEntry;
import org.opencdmp.commonmodels.models.FileEnvelopeModel; import org.opencdmp.commonmodels.models.FileEnvelopeModel;
import org.opencdmp.commonmodels.models.dmp.DmpModel; import org.opencdmp.commonmodels.models.dmp.DmpModel;
import org.opencdmp.depositbase.repository.DepositConfiguration; import org.opencdmp.depositbase.repository.DepositConfiguration;
@ -205,6 +206,9 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
try { try {
//Forth, update the new deposit's metadata //Forth, update the new deposit's metadata
String updateUrl = links.get(ZENODO_LINKS_SELF) + "?access_token=" + zenodoToken; String updateUrl = links.get(ZENODO_LINKS_SELF) + "?access_token=" + zenodoToken;
logger.debug(new MapLogEntry("Deposit New Version")
.And("url", updateUrl)
.And("body", deposit));
zenodoClient.put().uri(updateUrl) zenodoClient.put().uri(updateUrl)
.headers(httpHeaders -> { .headers(httpHeaders -> {
httpHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON)); httpHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
@ -242,6 +246,9 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
private LinkedHashMap<String, String> deposit(String zenodoToken, String zenodoUrl, WebClient zenodoClient, ZenodoDeposit deposit) { private LinkedHashMap<String, String> deposit(String zenodoToken, String zenodoUrl, WebClient zenodoClient, ZenodoDeposit deposit) {
Map<String, Object> createResponse; Map<String, Object> createResponse;
String createUrl = zenodoUrl + "deposit/depositions" + "?access_token=" + zenodoToken; String createUrl = zenodoUrl + "deposit/depositions" + "?access_token=" + zenodoToken;
logger.debug(new MapLogEntry("Deposit")
.And("url", createUrl)
.And("body", deposit));
createResponse = zenodoClient.post().uri(createUrl).headers(httpHeaders -> { createResponse = zenodoClient.post().uri(createUrl).headers(httpHeaders -> {
httpHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON)); httpHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
httpHeaders.setContentType(MediaType.APPLICATION_JSON); httpHeaders.setContentType(MediaType.APPLICATION_JSON);
@ -254,6 +261,8 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
} }
private String publish(WebClient webClient, String publishUrl){ private String publish(WebClient webClient, String publishUrl){
logger.debug(new MapLogEntry("publish")
.And("url", publishUrl));
Map<String, Object> publishResponse = webClient.post().uri(publishUrl).bodyValue("").exchangeToMono(mono -> Map<String, Object> publishResponse = webClient.post().uri(publishUrl).bodyValue("").exchangeToMono(mono ->
mono.statusCode().isError() ? mono.statusCode().isError() ?
mono.createException().flatMap(Mono::error) : mono.createException().flatMap(Mono::error) :
@ -291,6 +300,10 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
map.add(REDIRECT_URI, depositConfiguration.getRedirectUri()); map.add(REDIRECT_URI, depositConfiguration.getRedirectUri());
try { try {
logger.debug(new MapLogEntry("Get Access Token")
.And("url", depositConfiguration.getRepositoryAccessTokenUrl())
.And("body", map));
Map<String, Object> values = client.post().uri(depositConfiguration.getRepositoryAccessTokenUrl()).bodyValue(map).exchangeToMono(mono -> Map<String, Object> values = client.post().uri(depositConfiguration.getRepositoryAccessTokenUrl()).bodyValue(map).exchangeToMono(mono ->
mono.statusCode().isError() ? mono.statusCode().isError() ?
mono.createException().flatMap(Mono::error) : mono.createException().flatMap(Mono::error) :
@ -361,8 +374,7 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
private static ExchangeFilterFunction logRequest() { private static ExchangeFilterFunction logRequest() {
return ExchangeFilterFunction.ofRequestProcessor(clientRequest -> { return ExchangeFilterFunction.ofRequestProcessor(clientRequest -> {
logger.debug("Request: {} {}", clientRequest.method(), clientRequest.url()); logger.debug(new MapLogEntry("Request").And("method", clientRequest.method()).And("url", clientRequest.url()));
clientRequest.headers().forEach((name, values) -> values.forEach(value -> logger.debug("{}={}", name, value)));
return Mono.just(clientRequest); return Mono.just(clientRequest);
}); });
} }
@ -372,9 +384,7 @@ public class ZenodoDepositServiceImpl implements ZenodoDepositService {
if (response.statusCode().isError()) { if (response.statusCode().isError()) {
return response.mutate().build().bodyToMono(String.class) return response.mutate().build().bodyToMono(String.class)
.flatMap(body -> { .flatMap(body -> {
logger.error("Request: {} {}", response.request().getMethod(), response.request().getURI()); logger.error(new MapLogEntry("Response").And("method", response.request().getMethod()).And("url", response.request().getURI()).And("status", response.statusCode()).And("body", body));
response.request().getHeaders().forEach((name, values) -> values.forEach(value -> logger.error("{}={}", name, value)));
logger.error("Response: {} {}", response.statusCode(), body);
return Mono.just(response); return Mono.just(response);
}); });
} }