/* * tlscerts.h * * Copyright (C) 2012 - 2016 James Booth * * This file is part of Profanity. * * Profanity 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 3 of the License, or * (at your option) any later version. * * Profanity 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. * * You should have received a copy of the GNU General Public License * along with Profanity. If not, see . * * In addition, as a special exception, the copyright holders give permission to * link the code of portions of this program with the OpenSSL library under * certain conditions as described in each individual source file, and * distribute linked combinations including the two. * * You must obey the GNU General Public License in all respects for all of the * code used other than OpenSSL. If you modify file(s) with this exception, you * may extend this exception to your version of the file(s), but you are not * obligated to do so. If you do not wish to do so, delete this exception * statement from your version. If you delete this exception statement from all * source files in the program, then also delete it here. * */ #ifndef TLSCERTS_H #define TLSCERTS_H typedef struct tls_cert_t { int version; char *serialnumber; char *subjectname; char *subject_country; char *subject_state; char *subject_distinguishedname; char *subject_serialnumber; char *subject_commonname; char *subject_organisation; char *subject_organisation_unit; char *subject_email; char *issuername; char *issuer_country; char *issuer_state; char *issuer_distinguishedname; char *issuer_serialnumber; char *issuer_commonname; char *issuer_organisation; char *issuer_organisation_unit; char *issuer_email; char *notbefore; char *notafter; char *fingerprint; char *key_alg; char *signature_alg; } TLSCertificate; void tlscerts_init(void); TLSCertificate* tlscerts_new(const char *const fingerprint, int version, const char *const serialnumber, const char *const subjectname, const char *const issuername, const char *const notbefore, const char *const notafter, const char *const key_alg, const char *const signature_alg); void tlscerts_set_current(const char *const fp); char* tlscerts_get_current(void); void tlscerts_clear_current(void); gboolean tlscerts_exists(const char *const fingerprint); void tlscerts_add(TLSCertificate *cert); gboolean tlscerts_revoke(const char *const fingerprint); TLSCertificate* tlscerts_get_trusted(const char *const fingerprint); void tlscerts_free(TLSCertificate *cert); GList* tlscerts_list(void); char* tlscerts_complete(const char *const prefix); void tlscerts_reset_ac(void); void tlscerts_close(void); #endif