Package com.itextpdf.text.pdf.security
Class TSAClientBouncyCastle
java.lang.Object
com.itextpdf.text.pdf.security.TSAClientBouncyCastle
- All Implemented Interfaces:
TSAClient
Time Stamp Authority Client interface implementation using Bouncy Castle
org.bouncycastle.tsp package.
Created by Aiken Sam, 2006-11-15, refactored by Martin Brunecky, 07/15/2007 for ease of subclassing.
- Since:
- 2.1.6
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringThe default value for the hash algorithmstatic final intThe default value for the hash algorithmprotected StringHash algorithmprivate static final LoggerThe Logger instance.protected intEstimate of the received time stamp tokenprotected TSAInfoBouncyCastleAn interface that allows you to inspect the timestamp info.protected StringTSA passwordprivate StringTSA request policyprotected StringURL of the Time Stamp Authorityprotected StringTSA Username -
Constructor Summary
ConstructorsConstructorDescriptionCreates an instance of a TSAClient that will use BouncyCastle.TSAClientBouncyCastle(String url, String username, String password) Creates an instance of a TSAClient that will use BouncyCastle.TSAClientBouncyCastle(String url, String username, String password, int tokSzEstimate, String digestAlgorithm) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionGets the MessageDigest to digest the data imprintbyte[]getTimeStampToken(byte[] imprint) Get RFC 3161 timeStampToken.intGet the token size estimate.protected byte[]getTSAResponse(byte[] requestBytes) Get timestamp token - communications layervoidsetTSAInfo(TSAInfoBouncyCastle tsaInfo) voidsetTSAReqPolicy(String tsaReqPolicy)
-
Field Details
-
LOGGER
The Logger instance. -
tsaURL
URL of the Time Stamp Authority -
tsaUsername
TSA Username -
tsaPassword
TSA password -
tsaInfo
An interface that allows you to inspect the timestamp info. -
DEFAULTTOKENSIZE
public static final int DEFAULTTOKENSIZEThe default value for the hash algorithm- See Also:
-
tokenSizeEstimate
protected int tokenSizeEstimateEstimate of the received time stamp token -
DEFAULTHASHALGORITHM
The default value for the hash algorithm- See Also:
-
digestAlgorithm
Hash algorithm -
tsaReqPolicy
TSA request policy
-
-
Constructor Details
-
TSAClientBouncyCastle
Creates an instance of a TSAClient that will use BouncyCastle.- Parameters:
url- String - Time Stamp Authority URL (i.e. "http://tsatest1.digistamp.com/TSA")
-
TSAClientBouncyCastle
Creates an instance of a TSAClient that will use BouncyCastle.- Parameters:
url- String - Time Stamp Authority URL (i.e. "http://tsatest1.digistamp.com/TSA")username- String - user(account) namepassword- String - password
-
TSAClientBouncyCastle
public TSAClientBouncyCastle(String url, String username, String password, int tokSzEstimate, String digestAlgorithm) Constructor. Note the token size estimate is updated by each call, as the token size is not likely to change (as long as we call the same TSA using the same imprint length).- Parameters:
url- String - Time Stamp Authority URL (i.e. "http://tsatest1.digistamp.com/TSA")username- String - user(account) namepassword- String - passwordtokSzEstimate- int - estimated size of received time stamp token (DER encoded)
-
-
Method Details
-
setTSAInfo
- Parameters:
tsaInfo- the tsaInfo to set
-
getTokenSizeEstimate
public int getTokenSizeEstimate()Get the token size estimate. Returned value reflects the result of the last succesfull call, padded- Specified by:
getTokenSizeEstimatein interfaceTSAClient- Returns:
- an estimate of the token size
-
getTSAReqPolicy
-
setTSAReqPolicy
-
getMessageDigest
Gets the MessageDigest to digest the data imprint- Specified by:
getMessageDigestin interfaceTSAClient- Returns:
- the digest algorithm name
- Throws:
GeneralSecurityException
-
getTimeStampToken
public byte[] getTimeStampToken(byte[] imprint) throws IOException, org.bouncycastle.tsp.TSPException Get RFC 3161 timeStampToken. Method may return null indicating that timestamp should be skipped.- Specified by:
getTimeStampTokenin interfaceTSAClient- Parameters:
imprint- data imprint to be time-stamped- Returns:
- encoded, TSA signed data of the timeStampToken
- Throws:
IOExceptionorg.bouncycastle.tsp.TSPException
-
getTSAResponse
Get timestamp token - communications layer- Returns:
- - byte[] - TSA response, raw bytes (RFC 3161 encoded)
- Throws:
IOException
-