Package org.apache.poi.poifs.crypt
Class Decryptor
- java.lang.Object
- 
- org.apache.poi.poifs.crypt.Decryptor
 
- 
- All Implemented Interfaces:
- GenericRecord
 - Direct Known Subclasses:
- AgileDecryptor,- BinaryRC4Decryptor,- CryptoAPIDecryptor,- StandardDecryptor,- XORDecryptor
 
 public abstract class Decryptor extends Object implements GenericRecord 
- 
- 
Field SummaryFields Modifier and Type Field Description static StringDEFAULT_PASSWORDstatic StringDEFAULT_POIFS_ENTRYprotected EncryptionInfoencryptionInfo
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description abstract Decryptorcopy()protected intgetBlockSizeInBytes()InputStreamgetDataStream(InputStream stream, int size, int initialPos)Wraps a stream for decryptionabstract InputStreamgetDataStream(DirectoryNode dir)Return a stream with decrypted data.InputStreamgetDataStream(POIFSFileSystem fs)EncryptionInfogetEncryptionInfo()Map<String,Supplier<?>>getGenericProperties()static DecryptorgetInstance(EncryptionInfo info)byte[]getIntegrityHmacKey()byte[]getIntegrityHmacValue()protected intgetKeySizeInBytes()abstract longgetLength()Returns the length of the encrypted data that can be safely read withgetDataStream(org.apache.poi.poifs.filesystem.DirectoryNode).SecretKeygetSecretKey()byte[]getVerifier()CipherinitCipherForBlock(Cipher cipher, int block)Initializes a cipher object for a given block index for encryptionvoidsetChunkSize(int chunkSize)Sets the chunk size of the data stream.voidsetEncryptionInfo(EncryptionInfo encryptionInfo)protected voidsetIntegrityHmacKey(byte[] integrityHmacKey)protected voidsetIntegrityHmacValue(byte[] integrityHmacValue)protected voidsetSecretKey(SecretKey secretKey)protected voidsetVerifier(byte[] verifier)abstract booleanverifyPassword(String password)- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.poi.common.usermodel.GenericRecordgetGenericChildren, getGenericRecordType
 
- 
 
- 
- 
- 
Field Detail- 
DEFAULT_PASSWORDpublic static final String DEFAULT_PASSWORD - See Also:
- Constant Field Values
 
 - 
DEFAULT_POIFS_ENTRYpublic static final String DEFAULT_POIFS_ENTRY - See Also:
- Constant Field Values
 
 - 
encryptionInfoprotected EncryptionInfo encryptionInfo 
 
- 
 - 
Constructor Detail- 
Decryptorprotected Decryptor() 
 - 
Decryptorprotected Decryptor(Decryptor other) 
 
- 
 - 
Method Detail- 
getDataStreampublic abstract InputStream getDataStream(DirectoryNode dir) throws IOException, GeneralSecurityException Return a stream with decrypted data.Use getLength()to get the size of that data that can be safely read from the stream. Just reading to the end of the input stream is not sufficient because there are normally padding bytes that must be discarded- Parameters:
- dir- the node to read from
- Returns:
- decrypted stream
- Throws:
- IOException
- GeneralSecurityException
 
 - 
getDataStreampublic InputStream getDataStream(InputStream stream, int size, int initialPos) throws IOException, GeneralSecurityException Wraps a stream for decryptionAs we are handling streams and don't know the total length beforehand, it's the callers duty to care for the length of the entries. - Parameters:
- stream- the stream to be wrapped
- initialPos- initial/current byte position within the stream
- Returns:
- decrypted stream
- Throws:
- IOException
- GeneralSecurityException
 
 - 
setChunkSizepublic void setChunkSize(int chunkSize) Sets the chunk size of the data stream. Needs to be set before the data stream is requested. When not set, the implementation uses method specific default values- Parameters:
- chunkSize- the chunk size, i.e. the block size with the same encryption key
 
 - 
initCipherForBlockpublic Cipher initCipherForBlock(Cipher cipher, int block) throws GeneralSecurityException Initializes a cipher object for a given block index for encryption- Parameters:
- cipher- may be null, otherwise the given instance is reset to the new block index
- block- the block index, e.g. the persist/slide id (hslf)
- Returns:
- a new cipher object, if cipher was null, otherwise the reinitialized cipher
- Throws:
- GeneralSecurityException- if the cipher can't be initialized
 
 - 
verifyPasswordpublic abstract boolean verifyPassword(String password) throws GeneralSecurityException - Throws:
- GeneralSecurityException
 
 - 
getLengthpublic abstract long getLength() Returns the length of the encrypted data that can be safely read withgetDataStream(org.apache.poi.poifs.filesystem.DirectoryNode). Just reading to the end of the input stream is not sufficient because there are normally padding bytes that must be discardedThe length variable is initialized in getDataStream(org.apache.poi.poifs.filesystem.DirectoryNode), an attempt to call getLength() prior to getDataStream() will result in IllegalStateException.- Returns:
- length of the encrypted data
- Throws:
- IllegalStateException- if- getDataStream(org.apache.poi.poifs.filesystem.DirectoryNode)was not called
 
 - 
getInstancepublic static Decryptor getInstance(EncryptionInfo info) 
 - 
getDataStreampublic InputStream getDataStream(POIFSFileSystem fs) throws IOException, GeneralSecurityException - Throws:
- IOException
- GeneralSecurityException
 
 - 
getVerifierpublic byte[] getVerifier() 
 - 
getSecretKeypublic SecretKey getSecretKey() 
 - 
getIntegrityHmacKeypublic byte[] getIntegrityHmacKey() 
 - 
getIntegrityHmacValuepublic byte[] getIntegrityHmacValue() 
 - 
setSecretKeyprotected void setSecretKey(SecretKey secretKey) 
 - 
setVerifierprotected void setVerifier(byte[] verifier) 
 - 
setIntegrityHmacKeyprotected void setIntegrityHmacKey(byte[] integrityHmacKey) 
 - 
setIntegrityHmacValueprotected void setIntegrityHmacValue(byte[] integrityHmacValue) 
 - 
getBlockSizeInBytesprotected int getBlockSizeInBytes() 
 - 
getKeySizeInBytesprotected int getKeySizeInBytes() 
 - 
getEncryptionInfopublic EncryptionInfo getEncryptionInfo() 
 - 
setEncryptionInfopublic void setEncryptionInfo(EncryptionInfo encryptionInfo) 
 - 
copypublic abstract Decryptor copy() 
 - 
getGenericPropertiespublic Map<String,Supplier<?>> getGenericProperties() - Specified by:
- getGenericPropertiesin interface- GenericRecord
 
 
- 
 
-