Add copy-on-write support.
[pwmd.git] / src / tls.h
blob5980712222d76ba83c80e327a42b7ac2e74d8e96
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 int tls_fd;
36 int tls6_fd;
38 struct client_s;
39 int tls_start_stop (int term);
40 struct tls_s *tls_init_client (int fd, int timeout, const char *prio);
41 void tls_log (int level, const char *msg);
42 void tls_audit_log (gnutls_session_t, const char *);
43 ssize_t tls_read_hook (assuan_context_t ctx, assuan_fd_t fd, void *data,
44 size_t len);
45 ssize_t tls_write_hook (assuan_context_t ctx, assuan_fd_t fd,
46 const void *data, size_t len);
47 void tls_deinit_params ();
48 gpg_error_t tls_validate_access (struct client_s *client, const char *filename);
49 void tls_rehandshake ();
51 #endif