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

fr.cenotelie.commons.utils.json.JsonDeserializer Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2017 Association Cénotélie (cenotelie.fr)
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser 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 Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General
 * Public License along with this program.
 * If not, see .
 ******************************************************************************/

package fr.cenotelie.commons.utils.json;

import fr.cenotelie.commons.utils.TextUtils;
import fr.cenotelie.hime.redist.ASTNode;

import java.util.ArrayList;
import java.util.List;

/**
 * Represents a de-serializer of Json-serialized data
 *
 * @author Laurent Wouters
 */
public class JsonDeserializer {
    /**
     * The default de-serializer
     */
    public static final JsonDeserializer DEFAULT = new JsonDeserializer();

    /**
     * De-serializes an object parameters or result related to a request
     *
     * @param definition The serialized parameters
     * @param context    The de-serialization context
     * @return The de-serialized object
     */
    public Object deserialize(ASTNode definition, Object context) {
        if (definition == null)
            return null;
        switch (definition.getSymbol().getID()) {
            case JsonParser.ID.array: {
                List value = new ArrayList<>();
                for (ASTNode child : definition.getChildren()) {
                    value.add(deserialize(child, context));
                }
                return value;
            }
            case JsonParser.ID.object: {
                return deserializeObject(definition, context);
            }
            case JsonLexer.ID.LITERAL_NULL: {
                return null;
            }
            case JsonLexer.ID.LITERAL_FALSE: {
                return false;
            }
            case JsonLexer.ID.LITERAL_TRUE: {
                return true;
            }
            case JsonLexer.ID.LITERAL_INTEGER: {
                return Integer.parseInt(definition.getValue());
            }
            case JsonLexer.ID.LITERAL_DECIMAL: {
                return Double.parseDouble(definition.getValue());
            }
            case JsonLexer.ID.LITERAL_DOUBLE: {
                return Double.parseDouble(definition.getValue());
            }
            case JsonLexer.ID.LITERAL_STRING: {
                String value = TextUtils.unescape(definition.getValue());
                return value.substring(1, value.length() - 1);
            }
        }
        return null;
    }

    /**
     * De-serializes an object related to a request
     *
     * @param definition The serialized parameters
     * @param context    The de-serialization context
     * @return The de-serialized object
     */
    public Object deserializeObject(ASTNode definition, Object context) {
        // fallback to mapping the properties
        SerializedUnknown result = new SerializedUnknown();
        for (ASTNode memberNode : definition.getChildren()) {
            String memberName = TextUtils.unescape(memberNode.getChildren().get(0).getValue());
            memberName = memberName.substring(1, memberName.length() - 1);
            ASTNode memberValue = memberNode.getChildren().get(1);
            result.addProperty(memberName, deserialize(memberValue, context));
        }
        return result;
    }
}