aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf/qpdf/Pl_SHA2.hh
blob: 9b3275f09bed25381e5aee7fe10a88577ba4c7dd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#ifndef PL_SHA2_HH
#define PL_SHA2_HH

// Bits must be a supported number of bits, currently only 256, 384, or 512.  Passing 0 as bits
// leaves the pipeline uncommitted, in which case resetBits must be called before the pipeline is
// used. If a next is provided, this pipeline sends its output to its successor unmodified.  After
// calling finish, the SHA2 checksum of the data that passed through the pipeline is available.

// This pipeline is reusable; i.e., it is safe to call write() after calling finish().  The first
// call to write() after a call to finish() initializes a new SHA2 object.  resetBits may also be
// called between finish and the next call to write.

#include <qpdf/Pipeline.hh>
#include <qpdf/QPDFCryptoImpl.hh>
#include <memory>

class Pl_SHA2: public Pipeline
{
  public:
    Pl_SHA2(int bits = 0, Pipeline* next = nullptr);
    ~Pl_SHA2() override = default;
    void write(unsigned char const*, size_t) override;
    void finish() override;
    void resetBits(int bits);
    std::string getHexDigest();
    std::string getRawDigest();

  private:
    bool in_progress;
    std::shared_ptr<QPDFCryptoImpl> crypto;
};

#endif // PL_SHA2_HH