X-Git-Url: http://tinc-vpn.org/git/browse?p=fides;a=blobdiff_plain;f=lib%2Fcertificate.h;h=02775225b04a5400e341a781d818b20267871801;hp=2a605ea77df66a0a47ed5c3cd998a8ca192b7c62;hb=fa1153b4c3237d897a871331f0f9c0f8d30ca5a1;hpb=8f104b8742166c41e395375c1e740d7af6224699 diff --git a/lib/certificate.h b/lib/certificate.h index 2a605ea..0277522 100644 --- a/lib/certificate.h +++ b/lib/certificate.h @@ -18,11 +18,13 @@ #ifndef __FIDES_CERTIFICATE_H__ #define __FIDES_CERTIFICATE_H__ -#include #include #include "publickey.h" #include "privatekey.h" +#ifdef __cplusplus +#include + namespace Fides { class Certificate { friend class Manager; @@ -43,4 +45,22 @@ namespace Fides { }; } +extern "C" { +typedef Fides::Certificate fides_certificate; +#else +typedef struct fides_certificate fides_certificate; +#endif + +extern fides_certificate *fides_certificate_new(const fides_publickey *pub, struct timeval timestamp, const char *statement, const char *signature); +extern fides_certificate *fides_certificate_new_priv(const fides_privatekey *priv, struct timeval timestamp, const char *statement); +extern void fides_certificate_free(fides_certificate *c); + +extern char *fides_certificate_to_string(fides_certificate *c); +extern char *fides_certificate_fingerprint(fides_certificate *c, unsigned int bits); +extern bool fides_certificate_validate(fides_certificate *c); + +#ifdef __cplusplus +} +#endif + #endif