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

io.micronaut.serde.Decoder Maven / Gradle / Ivy

Go to download

Enables serialization/deserialization in Micronaut applications using build time information

There is a newer version: 2.12.0
Show newest version
/*
 * Copyright 2017-2021 original authors
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.micronaut.serde;

import io.micronaut.core.annotation.NonNull;
import io.micronaut.core.annotation.Nullable;
import io.micronaut.core.type.Argument;
import io.micronaut.json.tree.JsonNode;
import io.micronaut.serde.util.BinaryCodecUtil;

import java.io.IOException;
import java.math.BigDecimal;
import java.math.BigInteger;

/**
 * Core interface for decoding values from a serialized format such as JSON.
 *
 * @since 1.0.0
 */
public interface Decoder extends AutoCloseable {
    /**
     * Start decoding an array.
     * @param type The array type
     * @return The array decoder
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    Decoder decodeArray(Argument type) throws IOException;

    /**
     * Start decoding an array.
     * @return The array decoder
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    default Decoder decodeArray() throws IOException {
        return decodeArray(Argument.OBJECT_ARGUMENT);
    }

    /**
     * @return Returns {@code true} if another array value is available.
     * @throws IOException If an unrecoverable error occurs
     */
    boolean hasNextArrayValue() throws IOException;

    /**
     * Decodes an object.
     * @param type The type, never {@code null}
     * @return The object decoder
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    Decoder decodeObject(@NonNull Argument type) throws IOException;

    /**
     * Decodes an object.
     * @return The object decoder
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    default Decoder decodeObject() throws IOException {
        return decodeObject(Argument.OBJECT_ARGUMENT);
    }

    /**
     * Decodes a key, if there are no more keys to decode returns {@code null}.
     * @return The key or {@code null} if there aren't any more keys
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    String decodeKey() throws IOException;

    /**
     * Decodes a string.
     * @return The string, never {@code null}
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    String decodeString() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeString()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default String decodeStringNullable() throws IOException {
        return decodeNull() ? null : decodeString();
    }

    /**
     * Decodes a boolean.
     * @return The boolean
     * @throws IOException If an unrecoverable error occurs
     */
    boolean decodeBoolean() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeBoolean()}.
     *
     * @return The boolean
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Boolean decodeBooleanNullable() throws IOException {
        return decodeNull() ? null : decodeBoolean();
    }

    /**
     * Decodes a byte.
     * @return The byte
     * @throws IOException If an unrecoverable error occurs
     */
    byte decodeByte() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeByte()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Byte decodeByteNullable() throws IOException {
        return decodeNull() ? null : decodeByte();
    }

    /**
     * Decodes a short.
     * @return The short
     * @throws IOException If an unrecoverable error occurs
     */
    short decodeShort() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeShort()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Short decodeShortNullable() throws IOException {
        return decodeNull() ? null : decodeShort();
    }

    /**
     * Decodes a char.
     * @return The char
     * @throws IOException If an unrecoverable error occurs
     */
    char decodeChar() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeChar()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Character decodeCharNullable() throws IOException {
        return decodeNull() ? null : decodeChar();
    }

    /**
     * Decodes a number.
     * @return The number
     * @throws IOException If an unrecoverable error occurs
     * @since 2.9.0
     */
    default Number decodeNumber() throws IOException {
        return decodeBigDecimal();
    }

    /**
     * Equivalent to {@code decodeNull() ? null : decodeNumber()}.
     *
     * @return The number
     * @throws IOException If an unrecoverable error occurs
     * @since 2.9.0
     */
    @Nullable
    default Number decodeNumberNullable() throws IOException {
        return decodeNull() ? null : decodeNumber();
    }

    /**
     * Decodes a int.
     * @return The int
     * @throws IOException If an unrecoverable error occurs
     */
    int decodeInt() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeInt()}.
     *
     * @return The int
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Integer decodeIntNullable() throws IOException {
        return decodeNull() ? null : decodeInt();
    }

    /**
     * Decodes a long.
     * @return The long
     * @throws IOException If an unrecoverable error occurs
     */
    long decodeLong() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeLong()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Long decodeLongNullable() throws IOException {
        return decodeNull() ? null : decodeLong();
    }

    /**
     * Decodes a float.
     * @return The float
     * @throws IOException If an unrecoverable error occurs
     */
    float decodeFloat() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeFloat()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Float decodeFloatNullable() throws IOException {
        return decodeNull() ? null : decodeFloat();
    }

    /**
     * Decodes a double.
     * @return The double
     * @throws IOException If an unrecoverable error occurs
     */
    double decodeDouble() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeDouble()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default Double decodeDoubleNullable() throws IOException {
        return decodeNull() ? null : decodeDouble();
    }

    /**
     * Decodes a BigInteger.
     * @return The BigInteger, never {@code null}
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    BigInteger decodeBigInteger() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeBigInteger()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default BigInteger decodeBigIntegerNullable() throws IOException {
        return decodeNull() ? null : decodeBigInteger();
    }

    /**
     * Decodes a BigDecimal.
     * @return The BigDecimal, never {@code null}
     * @throws IOException If an unrecoverable error occurs
     */
    @NonNull
    BigDecimal decodeBigDecimal() throws IOException;

    /**
     * Equivalent to {@code decodeNull() ? null : decodeBigDecimal()}.
     *
     * @return The value
     * @throws IOException If an unrecoverable error occurs
     */
    @Nullable
    default BigDecimal decodeBigDecimalNullable() throws IOException {
        return decodeNull() ? null : decodeBigDecimal();
    }

    /**
     * Decode binary data from this stream. Binary data can be serialized in multiple different
     * ways that differ by format.
     *
     * 
    *
  • An array of numbers must be supported by all implementations, for compatibility. * This is also the default implementation.
  • *
  • A base64 string. This is convenient for text-based formats like json, and is * supported by jackson.
  • *
  • A format-specific type, for binary formats such as bson.
  • *
  • Other format specific behavior. Oracle JDBC Json will parse strings as hex, for * example.
  • *
* * Implementations must support the array shape, but the other shapes are optional. * * @return The decoded byte array * @since 2.1 */ default byte @NonNull [] decodeBinary() throws IOException { return BinaryCodecUtil.decodeFromArray(this); } /** * Equivalent to {@code decodeNull() ? null : decodeBinary()}. * * @return The value * @throws IOException If an unrecoverable error occurs * @since 2.1 */ default byte @Nullable [] decodeBinaryNullable() throws IOException { return decodeNull() ? null : decodeBinary(); } /** * Attempt to decode a null value. Returns {@code false} if this value is not null, and another method should be * used for decoding. Returns {@code true} if this value was null, and the cursor has been advanced to the next * value. * @throws IOException If an unrecoverable error occurs * @return Returns {@code true} if the value was {@code null} */ boolean decodeNull() throws IOException; /** * Decodes the current state into an arbitrary object. * *

The following should be decoded by this method:

* *
    *
  • Object types will be decoded into a {@link java.util.Map}
  • *
  • Array types will be decoded into a {@link java.util.List}
  • *
  • JSON primitive types into the equivalent Java wrapper type
  • *
* * * @return The decoded object * @throws IOException If an unrecoverable error occurs */ @Nullable Object decodeArbitrary() throws IOException; /** * Decodes the current state into a {@link JsonNode}. * * @return The decoded node * @throws IOException If an unrecoverable error occurs */ @NonNull JsonNode decodeNode() throws IOException; /** * Buffer the whole subtree of this value and return it as a new {@link Decoder}. The returned {@link Decoder} can * be used independently to this {@link Decoder}. This means actual parsing of the subtree can be delayed. *

* The returned {@link Decoder} should behave identically to this {@link Decoder}. This means that for example * {@code decoder.decodeDouble()} should be equivalent to {@code decoder.decodeBuffer().decodeDouble()}. * * @return An independent decoder that visits this subtree. * @throws IOException If an unrecoverable error occurs */ Decoder decodeBuffer() throws IOException; /** * Skips the current value. * @throws IOException If an unrecoverable error occurs */ void skipValue() throws IOException; /** * @throws IllegalStateException If there are still elements left to consume * @throws IOException If an unrecoverable error occurs */ default void finishStructure() throws IOException { finishStructure(false); } /** * @param consumeLeftElements True to consume left elements * @throws IllegalStateException If there are still elements left to consume and consumeLeftElements is false * @throws IOException If an unrecoverable error occurs */ void finishStructure(boolean consumeLeftElements) throws IOException; /** * Finalize the current structure. Equivalent to calling {@link #finishStructure()}. * @throws IOException If an unrecoverable error occurs */ @Override default void close() throws IOException { finishStructure(); } /** * Creates an exception for the given message. * @param message The message, never {@code null} * @param invalidValue The invalid value. Can be {@code null}. * @return The exception, never {@code null} */ @NonNull IOException createDeserializationException(@NonNull String message, @Nullable Object invalidValue); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy