TLS: Support rehandshake upon SIGHUP.
[libpwmd.git] / src / tls.h
blob691101c7a4e63ba7e212634c56e818581848bf06
1 /*
2 Copyright (C) 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015,
3 2016
4 Ben Kibbey <bjk@luxsci.net>
6 This file is part of pwmd.
8 Pwmd is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 2 of the License, or
11 (at your option) any later version.
13 Pwmd is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with Pwmd. If not, see <http://www.gnu.org/licenses/>.
21 #ifndef TLS_H
22 #define TLS_H
24 #include <gnutls/gnutls.h>
25 #include <errno.h>
27 struct tls_s
29 gnutls_session_t ses;
30 char *fp;
31 int nl;
32 int rehandshake;
35 struct client_s;
36 struct tls_s *tls_init_client (int fd, int timeout, const char *prio);
37 void tls_log (int level, const char *msg);
38 void tls_audit_log (gnutls_session_t, const char *);
39 ssize_t tls_read_hook (assuan_context_t ctx, assuan_fd_t fd, void *data,
40 size_t len);
41 ssize_t tls_write_hook (assuan_context_t ctx, assuan_fd_t fd,
42 const void *data, size_t len);
43 void tls_deinit_params ();
44 gpg_error_t tls_init_params ();
45 gpg_error_t tls_validate_access (struct client_s *client, const char *filename);
46 void tls_rehandshake ();
48 #endif