/* * Copyright (C) 2007 Martin Willi * Copyright (C) 2015 Andreas Steffen * HSR Hochschule fuer Technik Rapperswil * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. See . * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ #include "certificate.h" #include #include ENUM(certificate_type_names, CERT_ANY, CERT_GPG, "ANY", "X509", "X509_CRL", "OCSP_REQUEST", "OCSP_RESPONSE", "X509_AC", "PUBKEY", "PKCS10_REQUEST", "PGP", ); ENUM(cert_validation_names, VALIDATION_GOOD, VALIDATION_REVOKED, "GOOD", "SKIPPED", "STALE", "FAILED", "ON_HOLD", "REVOKED", ); /** * See header */ bool certificate_is_newer(certificate_t *this, certificate_t *other) { time_t this_update, that_update; char *type = "certificate"; bool newer; if (this->get_type(this) == CERT_X509_CRL) { type = "crl"; } this->get_validity(this, NULL, &this_update, NULL); other->get_validity(other, NULL, &that_update, NULL); newer = this_update > that_update; DBG1(DBG_LIB, " %s from %T is %s - existing %s from %T %s", type, &this_update, FALSE, newer ? "newer" : "not newer", type, &that_update, FALSE, newer ? "replaced" : "retained"); return newer; }