Search in sources :

Example 6 with BeanInner

use of sqlite.kripton58.BeanInner in project kripton by xcesco.

the class BeanBeanBindMap method serializeOnJacksonAsString.

@Override
public int serializeOnJacksonAsString(BeanBean object, JsonGenerator jacksonSerializer) throws Exception {
    jacksonSerializer.writeStartObject();
    int fieldCount = 0;
    // Serialized Field:
    // field id (mapped with "id")
    jacksonSerializer.writeStringField("id", PrimitiveUtils.writeLong(object.id));
    // field value (mapped with "value")
    if (object.value != null) {
        fieldCount++;
        int n = object.value.length;
        BeanInner item;
        // write wrapper tag
        jacksonSerializer.writeFieldName("value");
        if (n > 0) {
            jacksonSerializer.writeStartArray();
            for (int i = 0; i < n; i++) {
                item = object.value[i];
                if (item == null) {
                    jacksonSerializer.writeString("null");
                } else {
                    if (beanInnerBindMap.serializeOnJacksonAsString(item, jacksonSerializer) == 0) {
                        jacksonSerializer.writeNullField("value");
                    }
                }
            }
            jacksonSerializer.writeEndArray();
        } else {
            jacksonSerializer.writeString("");
        }
    }
    // field value2 (mapped with "value2")
    if (object.value2 != null) {
        fieldCount++;
        int n = object.value2.length;
        BeanInner item;
        // write wrapper tag
        jacksonSerializer.writeFieldName("value2");
        if (n > 0) {
            jacksonSerializer.writeStartArray();
            for (int i = 0; i < n; i++) {
                item = object.value2[i];
                if (item == null) {
                    jacksonSerializer.writeString("null");
                } else {
                    if (beanInnerBindMap.serializeOnJacksonAsString(item, jacksonSerializer) == 0) {
                        jacksonSerializer.writeNullField("value2");
                    }
                }
            }
            jacksonSerializer.writeEndArray();
        } else {
            jacksonSerializer.writeString("");
        }
    }
    jacksonSerializer.writeEndObject();
    return fieldCount;
}
Also used : BeanInner(sqlite.kripton58.BeanInner)

Example 7 with BeanInner

use of sqlite.kripton58.BeanInner in project kripton by xcesco.

the class BeanBeanBindMap method parseOnJackson.

/**
 * parse with jackson
 */
@Override
public BeanBean parseOnJackson(JsonParser jacksonParser) throws Exception {
    BeanBean instance = new BeanBean();
    String fieldName;
    if (jacksonParser.currentToken() == null) {
        jacksonParser.nextToken();
    }
    if (jacksonParser.currentToken() != JsonToken.START_OBJECT) {
        jacksonParser.skipChildren();
        return instance;
    }
    while (jacksonParser.nextToken() != JsonToken.END_OBJECT) {
        fieldName = jacksonParser.getCurrentName();
        jacksonParser.nextToken();
        // Parse fields:
        switch(fieldName) {
            case "id":
                // field id (mapped with "id")
                instance.id = jacksonParser.getLongValue();
                break;
            case "value":
                // field value (mapped with "value")
                if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
                    ArrayList<BeanInner> collection = new ArrayList<>();
                    BeanInner item = null;
                    while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
                        if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
                            item = null;
                        } else {
                            item = beanInnerBindMap.parseOnJackson(jacksonParser);
                        }
                        collection.add(item);
                    }
                    instance.value = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
                }
                break;
            case "value2":
                // field value2 (mapped with "value2")
                if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
                    ArrayList<BeanInner> collection = new ArrayList<>();
                    BeanInner item = null;
                    while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
                        if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
                            item = null;
                        } else {
                            item = beanInnerBindMap.parseOnJackson(jacksonParser);
                        }
                        collection.add(item);
                    }
                    instance.value2 = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
                }
                break;
            default:
                jacksonParser.skipChildren();
                break;
        }
    }
    return instance;
}
Also used : BeanInner(sqlite.kripton58.BeanInner) ArrayList(java.util.ArrayList)

Example 8 with BeanInner

use of sqlite.kripton58.BeanInner in project kripton by xcesco.

the class BeanBeanTable method serializeValue.

/**
 * for attribute value serialization
 */
public static byte[] serializeValue(BeanInner[] value) {
    if (value == null) {
        return null;
    }
    KriptonJsonContext context = KriptonBinder.jsonBind();
    try (KriptonByteArrayOutputStream stream = new KriptonByteArrayOutputStream();
        JacksonWrapperSerializer wrapper = context.createSerializer(stream)) {
        JsonGenerator jacksonSerializer = wrapper.jacksonGenerator;
        jacksonSerializer.writeStartObject();
        int fieldCount = 0;
        if (value != null) {
            fieldCount++;
            int n = value.length;
            BeanInner item;
            // write wrapper tag
            jacksonSerializer.writeFieldName("element");
            jacksonSerializer.writeStartArray();
            for (int i = 0; i < n; i++) {
                item = value[i];
                if (item == null) {
                    jacksonSerializer.writeNull();
                } else {
                    beanInnerBindMap.serializeOnJackson(item, jacksonSerializer);
                }
            }
            jacksonSerializer.writeEndArray();
        }
        jacksonSerializer.writeEndObject();
        jacksonSerializer.flush();
        return stream.toByteArray();
    } catch (Exception e) {
        throw (new KriptonRuntimeException(e.getMessage()));
    }
}
Also used : BeanInner(sqlite.kripton58.BeanInner) JsonGenerator(com.fasterxml.jackson.core.JsonGenerator) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException) KriptonByteArrayOutputStream(com.abubusoft.kripton.common.KriptonByteArrayOutputStream) KriptonJsonContext(com.abubusoft.kripton.KriptonJsonContext) JacksonWrapperSerializer(com.abubusoft.kripton.persistence.JacksonWrapperSerializer) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException)

Example 9 with BeanInner

use of sqlite.kripton58.BeanInner in project kripton by xcesco.

the class BeanBeanTable method parseValue.

/**
 * for attribute value parsing
 */
public static BeanInner[] parseValue(byte[] input) {
    if (input == null) {
        return null;
    }
    KriptonJsonContext context = KriptonBinder.jsonBind();
    try (JacksonWrapperParser wrapper = context.createParser(input)) {
        JsonParser jacksonParser = wrapper.jacksonParser;
        // START_OBJECT
        jacksonParser.nextToken();
        // value of "element"
        jacksonParser.nextValue();
        BeanInner[] result = null;
        if (jacksonParser.currentToken() == JsonToken.START_ARRAY) {
            ArrayList<BeanInner> collection = new ArrayList<>();
            BeanInner item = null;
            while (jacksonParser.nextToken() != JsonToken.END_ARRAY) {
                if (jacksonParser.currentToken() == JsonToken.VALUE_NULL) {
                    item = null;
                } else {
                    item = beanInnerBindMap.parseOnJackson(jacksonParser);
                }
                collection.add(item);
            }
            result = CollectionUtils.asArray(collection, new BeanInner[collection.size()]);
        }
        return result;
    } catch (Exception e) {
        throw (new KriptonRuntimeException(e.getMessage()));
    }
}
Also used : BeanInner(sqlite.kripton58.BeanInner) ArrayList(java.util.ArrayList) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException) KriptonJsonContext(com.abubusoft.kripton.KriptonJsonContext) JacksonWrapperParser(com.abubusoft.kripton.persistence.JacksonWrapperParser) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException) JsonParser(com.fasterxml.jackson.core.JsonParser)

Example 10 with BeanInner

use of sqlite.kripton58.BeanInner in project kripton by xcesco.

the class BeanBeanTable method serializeValue2.

/**
 * for attribute value2 serialization
 */
public static byte[] serializeValue2(BeanInner[] value) {
    if (value == null) {
        return null;
    }
    KriptonJsonContext context = KriptonBinder.jsonBind();
    try (KriptonByteArrayOutputStream stream = new KriptonByteArrayOutputStream();
        JacksonWrapperSerializer wrapper = context.createSerializer(stream)) {
        JsonGenerator jacksonSerializer = wrapper.jacksonGenerator;
        jacksonSerializer.writeStartObject();
        int fieldCount = 0;
        if (value != null) {
            fieldCount++;
            int n = value.length;
            BeanInner item;
            // write wrapper tag
            jacksonSerializer.writeFieldName("element");
            jacksonSerializer.writeStartArray();
            for (int i = 0; i < n; i++) {
                item = value[i];
                if (item == null) {
                    jacksonSerializer.writeNull();
                } else {
                    beanInnerBindMap.serializeOnJackson(item, jacksonSerializer);
                }
            }
            jacksonSerializer.writeEndArray();
        }
        jacksonSerializer.writeEndObject();
        jacksonSerializer.flush();
        return stream.toByteArray();
    } catch (Exception e) {
        throw (new KriptonRuntimeException(e.getMessage()));
    }
}
Also used : BeanInner(sqlite.kripton58.BeanInner) JsonGenerator(com.fasterxml.jackson.core.JsonGenerator) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException) KriptonByteArrayOutputStream(com.abubusoft.kripton.common.KriptonByteArrayOutputStream) KriptonJsonContext(com.abubusoft.kripton.KriptonJsonContext) JacksonWrapperSerializer(com.abubusoft.kripton.persistence.JacksonWrapperSerializer) KriptonRuntimeException(com.abubusoft.kripton.exception.KriptonRuntimeException)

Aggregations

BeanInner (sqlite.kripton58.BeanInner)33 KriptonJsonContext (com.abubusoft.kripton.KriptonJsonContext)18 KriptonRuntimeException (com.abubusoft.kripton.exception.KriptonRuntimeException)18 ArrayList (java.util.ArrayList)14 KriptonByteArrayOutputStream (com.abubusoft.kripton.common.KriptonByteArrayOutputStream)9 JacksonWrapperParser (com.abubusoft.kripton.persistence.JacksonWrapperParser)9 JacksonWrapperSerializer (com.abubusoft.kripton.persistence.JacksonWrapperSerializer)9 JsonGenerator (com.fasterxml.jackson.core.JsonGenerator)9 JsonParser (com.fasterxml.jackson.core.JsonParser)9 LinkedList (java.util.LinkedList)3