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

io.zeebe.logstreams.snapshot.SerializableWrapper Maven / Gradle / Ivy

There is a newer version: 0.16.4
Show newest version
/*
 * Copyright © 2017 camunda services GmbH ([email protected])
 *
 * 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
 *
 *     http://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.zeebe.logstreams.snapshot;

import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.io.Serializable;

import io.zeebe.logstreams.spi.SnapshotSupport;

/**
 * Wraps a {@link Serializable} object providing {@link SnapshotSupport} to be used in a StreamProcessor.
 *

* NOTE: obviously all the known caveats around java serialization apply to this class. * Or on other words: do not use this outside of demo applications. * * @param the type of the wrapped {@link Serializable}. */ public class SerializableWrapper implements SnapshotSupport { protected T object; public SerializableWrapper(T object) { this.object = object; } public T getObject() { return object; } @Override public long writeSnapshot(OutputStream outputStream) throws Exception { final ObjectOutputStream oos = new ObjectOutputStream(outputStream); oos.writeObject(object); oos.flush(); return -1; } @Override @SuppressWarnings("unchecked") public void recoverFromSnapshot(InputStream inputStream) throws Exception { final ObjectInputStream ois = new ObjectInputStream(inputStream); object = (T) ois.readObject(); } @Override public void reset() { // do nothing } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy