All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sentrysoftware.metricshub.agent.deserialization.AttributesDeserializer Maven / Gradle / Ivy

package org.sentrysoftware.metricshub.agent.deserialization;

/*-
 * ╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲
 * MetricsHub Agent
 * ჻჻჻჻჻჻
 * Copyright 2023 - 2024 Sentry Software
 * ჻჻჻჻჻჻
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see .
 * ╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱╲╱
 */

import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.DeserializationContext;
import com.fasterxml.jackson.databind.JsonDeserializer;
import java.io.IOException;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.stream.Collectors;
import org.sentrysoftware.metricshub.engine.common.helpers.StringHelper;

/**
 * AttributesDeserializer is a custom JSON deserializer for converting JSON attributes into a {@link Map} format.
 * It parses a JSON object, deserializes its attributes, and converts them into a map where keys are strings and values are stringified representations.
 */
public class AttributesDeserializer extends JsonDeserializer> {

	/**
	 * Deserialize JSON attributes into a {@link Map} format.
	 *
	 * @param parser  JSON parser.
	 * @param context Deserialization context.
	 * @return A map representing the deserialized attributes.
	 * @throws IOException If an I/O error occurs during deserialization.
	 */
	@Override
	public Map deserialize(JsonParser parser, DeserializationContext context) throws IOException {
		if (parser == null) {
			return new HashMap<>();
		}

		final Map deserializedAttributes = parser.readValueAs(new TypeReference>() {});

		return deserializedAttributes
			.entrySet()
			.stream()
			.collect(
				Collectors.toMap(
					Map.Entry::getKey,
					value -> StringHelper.stringify(value.getValue()),
					(oldValue, newValue) -> oldValue,
					LinkedHashMap::new
				)
			);
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy