blob: d389ae245c2abbffe4a989827dd4d62fbb6b47db [file] [log] [blame]
//========================================================================
//
// SignatureInfo.h
//
// This file is licensed under the GPLv2 or later
//
// Copyright 2015 André Guerreiro <aguerreiro1985@gmail.com>
// Copyright 2015 André Esser <bepandre@hotmail.com>
// Copyright 2015, 2017, 2018, 2020 Albert Astals Cid <aacid@kde.org>
// Copyright 2017 Hans-Ulrich Jüttner <huj@froreich-bioscientia.de>
// Copyright 2018 Chinmoy Ranjan Pradhan <chinmoyrp65@protonmail.com>
// Copyright 2018 Oliver Sander <oliver.sander@tu-dresden.de>
// Copyright 2021 Georgiy Sgibnev <georgiy@sgibnev.com>. Work sponsored by lab50.net.
// Copyright 2021 André Guerreiro <aguerreiro1985@gmail.com>
// Copyright 2021 Marek Kasik <mkasik@redhat.com>
// Copyright 2023 g10 Code GmbH, Author: Sune Stolborg Vuorela <sune@vuorela.dk>
//
//========================================================================
#ifndef SIGNATUREINFO_H
#define SIGNATUREINFO_H
#include <memory>
#include <ctime>
#include "poppler_private_export.h"
#include "goo/GooString.h"
#include "HashAlgorithm.h"
enum SignatureValidationStatus
{
SIGNATURE_VALID,
SIGNATURE_INVALID,
SIGNATURE_DIGEST_MISMATCH,
SIGNATURE_DECODING_ERROR,
SIGNATURE_GENERIC_ERROR,
SIGNATURE_NOT_FOUND,
SIGNATURE_NOT_VERIFIED
};
enum CertificateValidationStatus
{
CERTIFICATE_TRUSTED,
CERTIFICATE_UNTRUSTED_ISSUER,
CERTIFICATE_UNKNOWN_ISSUER,
CERTIFICATE_REVOKED,
CERTIFICATE_EXPIRED,
CERTIFICATE_GENERIC_ERROR,
CERTIFICATE_NOT_VERIFIED
};
class X509CertificateInfo;
class POPPLER_PRIVATE_EXPORT SignatureInfo
{
public:
SignatureInfo() = default;
~SignatureInfo();
SignatureInfo(const SignatureInfo &) = delete;
SignatureInfo &operator=(const SignatureInfo &) = delete;
/* GETTERS */
SignatureValidationStatus getSignatureValStatus() const;
CertificateValidationStatus getCertificateValStatus() const;
std::string getSignerName() const;
std::string getSubjectDN() const;
const GooString &getLocation() const;
const GooString &getReason() const;
HashAlgorithm getHashAlgorithm() const; // Returns the used HashAlgorithm, and unknown if compiled without signature support
time_t getSigningTime() const;
bool isSubfilterSupported() const { return sig_subfilter_supported; }
const X509CertificateInfo *getCertificateInfo() const;
/* SETTERS */
void setSignatureValStatus(enum SignatureValidationStatus);
void setCertificateValStatus(enum CertificateValidationStatus);
void setSignerName(const std::string &);
void setSubjectDN(const std::string &);
void setLocation(const GooString *);
void setReason(const GooString *);
void setHashAlgorithm(HashAlgorithm);
void setSigningTime(time_t);
void setSubFilterSupport(bool isSupported) { sig_subfilter_supported = isSupported; }
void setCertificateInfo(std::unique_ptr<X509CertificateInfo>);
private:
SignatureValidationStatus sig_status = SIGNATURE_NOT_VERIFIED;
CertificateValidationStatus cert_status = CERTIFICATE_NOT_VERIFIED;
std::unique_ptr<X509CertificateInfo> cert_info;
std::string signer_name;
std::string subject_dn;
GooString location;
GooString reason;
HashAlgorithm hash_type = HashAlgorithm::Unknown;
time_t signing_time = 0;
bool sig_subfilter_supported = false;
};
#endif