Class BinaryBasedBlob
- java.lang.Object
-
- org.apache.jackrabbit.oak.plugins.value.BinaryBasedBlob
-
- All Implemented Interfaces:
Blob
public class BinaryBasedBlob extends Object implements Blob
This Blob implementation is based on an underlyingBinary
.Any error accessing the underlying binary in
getNewStream()
will be deferred to the returned input stream.
-
-
Constructor Summary
Constructors Constructor Description BinaryBasedBlob(Binary binary)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description String
getContentIdentity()
A unique identifier of the content of this value.@NotNull InputStream
getNewStream()
Delegates toBinary.getStream()
and returns an input stream the always throws anIOException
if the underlying binary failed to produce one.String
getReference()
Returns a secure reference to this blob, ornull
if such a reference is not available.long
length()
Delegates toBinary.getSize()
and returns -1 if that fails.
-
-
-
Constructor Detail
-
BinaryBasedBlob
public BinaryBasedBlob(Binary binary)
-
-
Method Detail
-
getNewStream
@NotNull public @NotNull InputStream getNewStream()
Delegates toBinary.getStream()
and returns an input stream the always throws anIOException
if the underlying binary failed to produce one.- Specified by:
getNewStream
in interfaceBlob
- Returns:
- a new stream for this blob
-
length
public long length()
Delegates toBinary.getSize()
and returns -1 if that fails.
-
getReference
public String getReference()
Description copied from interface:Blob
Returns a secure reference to this blob, ornull
if such a reference is not available.- Specified by:
getReference
in interfaceBlob
- Returns:
null
- See Also:
- OAK-834
-
getContentIdentity
public String getContentIdentity()
Description copied from interface:Blob
A unique identifier of the content of this value. Usually this is a message digest of the content (a cryptographically secure one-way hash). This allows to avoid processing large binary values multiple times.This method returns null if the identifier is unknown. The identifier may not always be available, for example if the value has not yet been saved or processed. Once an identifier is available, it will never change because values are immutable.
If two values have the same identifier, the content of the value is guaranteed to be the same. However it is not guaranteed that two values with the same content will return the same identifier.
The identifier is opaque, meaning it can have any format and size.
- Specified by:
getContentIdentity
in interfaceBlob
- Returns:
null
-
-