mirror of
				https://github.com/stefanocasazza/ULib.git
				synced 2025-10-26 19:57:22 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // ============================================================================
 | |
| //
 | |
| // = LIBRARY
 | |
| //    ULib - c++ library
 | |
| //
 | |
| // = FILENAME
 | |
| //    timestamp.h
 | |
| //
 | |
| // = AUTHOR
 | |
| //    Stefano Casazza
 | |
| //
 | |
| // ============================================================================
 | |
| 
 | |
| #ifndef U_TIMESTAMP_H
 | |
| #define U_TIMESTAMP_H 1
 | |
| 
 | |
| #include <ulib/ssl/pkcs7.h>
 | |
| 
 | |
| #include <openssl/ts.h>
 | |
| 
 | |
| /**
 | |
|  * A time-stamp token is obtained by sending the digest value of the given data to the Time-Stamp Authority (TSA).
 | |
|  * The returned time-stamp token is a signed data that contains the digest value, the identity of the TSA, and
 | |
|  * the time of stamping. This proves that the given data existed before the time of stamping.
 | |
|  *
 | |
|  * NOTE: the term time-stamp token used does NOT refer to the TSA's response to a requesting client, but the
 | |
|  * token generated by the TSA, which is present within this response. In the case of RFC 3161 [10] protocol,
 | |
|  * the time-stamp token term is referring to the timeStampToken field within the TimeStampResp element
 | |
|  * (the TSA's response returned to the requesting client)
 | |
|  */
 | |
| 
 | |
| class U_EXPORT UTimeStamp : public UPKCS7 {
 | |
| public:
 | |
| 
 | |
|    /**
 | |
|    * Constructs this object from the response of TSA service encoded string.
 | |
|    *
 | |
|    * @param string of bytes
 | |
|    */
 | |
| 
 | |
|    static TS_RESP* readTimeStampResponse(const UString& x);
 | |
| 
 | |
|    UTimeStamp(const UString& x) : UPKCS7(U_NULLPTR,U_NULLPTR)
 | |
|       {
 | |
|       U_TRACE_CTOR(0, UTimeStamp, "%V", x.rep)
 | |
| 
 | |
|       response = readTimeStampResponse(x);
 | |
| 
 | |
|       if (response) pkcs7 = (PKCS7*) TS_RESP_get_token(response);
 | |
|       }
 | |
| 
 | |
|    UTimeStamp(UString& request, const UString& TSA);
 | |
| 
 | |
|    /**
 | |
|     * Deletes this object
 | |
|     */
 | |
| 
 | |
|    ~UTimeStamp()
 | |
|       {
 | |
|       U_TRACE_DTOR(0, UTimeStamp)
 | |
| 
 | |
|       if (response)
 | |
|          {
 | |
|          pkcs7 = U_NULLPTR;
 | |
| 
 | |
|          TS_RESP_free(response);
 | |
|          }
 | |
|       }
 | |
| 
 | |
|    bool isValid() const
 | |
|       {
 | |
|       U_TRACE_NO_PARAM(0, "UTimeStamp::isValid()")
 | |
| 
 | |
|       if (response != U_NULLPTR) U_RETURN(true);
 | |
| 
 | |
|       U_RETURN(false);
 | |
|       }
 | |
| 
 | |
|    static bool isTimeStampToken(PKCS7* p7);
 | |
|    static bool isTimeStampResponse(const UString& content);
 | |
| 
 | |
|    static UString getTimeStampToken(int alg, const UString& data, const UString& url);
 | |
|    static UString createQuery(int alg, const UString& data, const char* policy, bool bnonce, bool bcert);
 | |
| 
 | |
|    // DEBUG
 | |
| 
 | |
| #if defined(U_STDCPP_ENABLE) && defined(DEBUG)
 | |
|    const char* dump(bool reset) const;
 | |
| #endif
 | |
| 
 | |
| protected:
 | |
|    TS_RESP* response;
 | |
| 
 | |
| private:
 | |
|    U_DISALLOW_COPY_AND_ASSIGN(UTimeStamp)
 | |
| };
 | |
| 
 | |
| #endif
 | 
