io.vlingo.lattice.model.process.ProcessMessageTextAdapter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vlingo-lattice Show documentation
Show all versions of vlingo-lattice Show documentation
Tooling for reactive Domain-Driven Design projects that are highly concurrent. Includes compute grid, actor caching, spaces, cross-node cluster messaging, CQRS, and Event Sourcing support.
// Copyright © 2012-2020 VLINGO LABS. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.
package io.vlingo.lattice.model.process;
import io.vlingo.common.serialization.JsonSerialization;
import io.vlingo.symbio.BaseEntry.TextEntry;
import io.vlingo.symbio.EntryAdapter;
import io.vlingo.symbio.Metadata;
import io.vlingo.symbio.Source;
public class ProcessMessageTextAdapter implements EntryAdapter {
@Override
public ProcessMessage fromEntry(final TextEntry entry) {
try {
final SerializableProcessMessage serializedMessage = JsonSerialization.deserialized(entry.entryData(), SerializableProcessMessage.class);
final Class> sourceType = Class.forName(serializedMessage.type);
final Source> source = (Source>) JsonSerialization.deserialized(serializedMessage.source, sourceType);
return new ProcessMessage(source);
} catch (Exception e) {
throw new IllegalArgumentException("ProcessMessageTextAdapter failed because: " + e.getMessage(), e);
}
}
@Override
public TextEntry toEntry(final ProcessMessage source, final Metadata metadata) {
final SerializableProcessMessage serializedMessage = new SerializableProcessMessage(source);
final String serialization = JsonSerialization.serialized(serializedMessage);
return new TextEntry(ProcessMessage.class, 1, serialization, metadata);
}
@Override
public TextEntry toEntry(final ProcessMessage source, final String id, final Metadata metadata) {
final SerializableProcessMessage serializedMessage = new SerializableProcessMessage(source);
final String serialization = JsonSerialization.serialized(serializedMessage);
return new TextEntry(id, ProcessMessage.class, 1, serialization, metadata);
}
@Override
public TextEntry toEntry(final ProcessMessage source, final int version, final String id, final Metadata metadata) {
final SerializableProcessMessage serializedMessage = new SerializableProcessMessage(source);
final String serialization = JsonSerialization.serialized(serializedMessage);
return new TextEntry(id, ProcessMessage.class, 1, serialization, version, metadata);
}
private static final class SerializableProcessMessage {
public final String source;
public final String type;
SerializableProcessMessage(final ProcessMessage message) {
this.source = sourceToText(message.source);
this.type = message.sourceTypeName();
}
private String sourceToText(final Source> source) {
final String sourceJson = JsonSerialization.serialized(source);
return sourceJson;
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy