-
Notifications
You must be signed in to change notification settings - Fork 89
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #287 from scalecube/feature/issue-283-cluster-code…
…c-artifact WIP: Issue 283 - cluster codec artifact
- Loading branch information
Showing
40 changed files
with
727 additions
and
216 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
33 changes: 33 additions & 0 deletions
33
cluster-api/src/main/java/io/scalecube/cluster/metadata/JdkMetadataCodec.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
package io.scalecube.cluster.metadata; | ||
|
||
import java.io.ByteArrayInputStream; | ||
import java.io.ByteArrayOutputStream; | ||
import java.io.ObjectInputStream; | ||
import java.io.ObjectOutputStream; | ||
import java.nio.ByteBuffer; | ||
import reactor.core.Exceptions; | ||
|
||
public class JdkMetadataCodec implements MetadataCodec { | ||
|
||
@Override | ||
public Object deserialize(ByteBuffer buffer) { | ||
byte[] bytes = buffer.array(); | ||
try (ObjectInputStream is = new ObjectInputStream(new ByteArrayInputStream(bytes))) { | ||
return is.readObject(); | ||
} catch (Exception e) { | ||
throw Exceptions.propagate(e); | ||
} | ||
} | ||
|
||
@Override | ||
public ByteBuffer serialize(Object metadata) { | ||
ByteArrayOutputStream baos = new ByteArrayOutputStream(); | ||
try (ObjectOutputStream os = new ObjectOutputStream(baos)) { | ||
os.writeObject(metadata); | ||
os.flush(); | ||
return ByteBuffer.wrap(baos.toByteArray()); | ||
} catch (Exception e) { | ||
throw Exceptions.propagate(e); | ||
} | ||
} | ||
} |
28 changes: 28 additions & 0 deletions
28
cluster-api/src/main/java/io/scalecube/cluster/metadata/MetadataCodec.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
package io.scalecube.cluster.metadata; | ||
|
||
import io.scalecube.utils.ServiceLoaderUtil; | ||
import java.nio.ByteBuffer; | ||
|
||
/** Contains methods for metadata serializing/deserializing logic. */ | ||
public interface MetadataCodec { | ||
|
||
MetadataCodec INSTANCE = | ||
ServiceLoaderUtil.findFirst(MetadataCodec.class).orElseGet(JdkMetadataCodec::new); | ||
|
||
/** | ||
* Deserializes metadata from buffer. | ||
* | ||
* @param buffer metadata buffer; if {@code buffer} is empty then returned result shall be null. | ||
* @return metadata object from metadata buffer or null | ||
*/ | ||
Object deserialize(ByteBuffer buffer); | ||
|
||
/** | ||
* Serializes given metadata into buffer. | ||
* | ||
* @param metadata metadata object (optional); if {@code metadata} is null then returned result | ||
* may be null or empty buffer. | ||
* @return buffer or null | ||
*/ | ||
ByteBuffer serialize(Object metadata); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
36 changes: 0 additions & 36 deletions
36
cluster-testlib/src/main/java/io/scalecube/cluster/metadata/SimpleMapMetadataCodec.java
This file was deleted.
Oops, something went wrong.
33 changes: 0 additions & 33 deletions
33
cluster-testlib/src/main/java/io/scalecube/cluster/transport/JacksonMessageCodec.java
This file was deleted.
Oops, something went wrong.
1 change: 0 additions & 1 deletion
1
...estlib/src/main/resources/META-INF/services/io.scalecube.cluster.metadata.MetadataDecoder
This file was deleted.
Oops, something went wrong.
1 change: 0 additions & 1 deletion
1
...estlib/src/main/resources/META-INF/services/io.scalecube.cluster.metadata.MetadataEncoder
This file was deleted.
Oops, something went wrong.
1 change: 0 additions & 1 deletion
1
...tlib/src/main/resources/META-INF/services/io.scalecube.cluster.transport.api.MessageCodec
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.