package com.banesco.infraestructure.helpers; import java.util.logging.Level; import java.util.logging.Logger; import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.DeserializationFeature; import com.fasterxml.jackson.databind.ObjectMapper; public class JsonHelper { private static final Logger logger = Logger.getLogger(JsonHelper.class.getName()); public static final ObjectMapper MAPPER = new ObjectMapper(); static { MAPPER.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); } /** * Convierte un objeto Java en una cadena JSON. * * @param object El objeto a convertir en JSON. * @return La cadena JSON resultante o null si ocurre un error. * @throws JsonProcessingException si hay algún error al convertir el objeto * a JSON */ public static String getJsonFromObject(Object object) { if (object == null) { return "null"; } try { return MAPPER.writeValueAsString(object); } catch (JsonProcessingException e) { logger.log(Level.SEVERE, "Error al convertir objeto a JSON: {0}", e.getMessage()); return null; } } /** * Convierte una cadena JSON en un objeto Java de la clase especificada. * * @param json La cadena JSON a convertir. * @param className La clase del objeto Java resultante. * @param El tipo del objeto resultante. * @return El objeto Java resultante, o null si ocurre un error o la cadena * JSON está vacía. * @throws JsonProcessingException Si ocurre un error al procesar JSON. * @throws IllegalArgumentException Si alguno de los argumentos no es * válido. */ public static T getObjectFromJson(String json, Class className) { if (json == null || json.isEmpty()) { return null; } try { return MAPPER.readValue(json, className); } catch (JsonProcessingException | IllegalArgumentException e) { logger.log(Level.WARNING, "Error al convertir JSON a objeto: {0}", e.getMessage()); return null; } } }