Greenbone Vulnerability Management Libraries 22.35.9
serverutils.c File Reference

GnuTLS based functions for server communication. More...

#include "serverutils.h"
#include "../base/hosts.h"
#include <arpa/inet.h>
#include <errno.h>
#include <fcntl.h>
#include <gcrypt.h>
#include <glib.h>
#include <gnutls/x509.h>
#include <netdb.h>
#include <signal.h>
#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <unistd.h>
Include dependency graph for serverutils.c:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define _GNU_SOURCE
#define G_LOG_DOMAIN   "libgvm util"
 GLib logging domain.

Functions

static int server_attach_internal (int socket, gnutls_session_t *session, const char *host, int port)
 Attach a socket to a session, and shake hands with the peer.
static int server_new_internal (unsigned int end_type, const char *priority, const gchar *ca_cert_file, const gchar *cert_file, const gchar *key_file, gnutls_session_t *server_session, gnutls_certificate_credentials_t *server_credentials)
 Make a session for connecting to a server.
static int close_unix (gvm_connection_t *client_connection)
 Close UNIX socket connection.
void gvm_connection_free (gvm_connection_t *client_connection)
 Free connection.
int gvm_server_verify (gnutls_session_t session)
 Verify certificate.
int load_gnutls_file (const char *file, gnutls_datum_t *loaded_file)
 Loads a file's data into gnutls_datum_t struct.
void unload_gnutls_file (gnutls_datum_t *data)
 Unloads a gnutls_datum_t struct's data.
static void set_cert_pub_mem (const char *data)
 Save cert_pub_mem with public certificate.
static void set_cert_priv_mem (const char *data)
 Save cert_priv_mem with private certificate.
static const char * get_cert_priv_mem ()
 Get private certificate from cert_priv_mem.
static const char * get_cert_pub_mem ()
 Get public certificate from cert_pub_mem.
static int client_cert_callback (gnutls_session_t session, const gnutls_datum_t *req_ca_rdn, int nreqs, const gnutls_pk_algorithm_t *sign_algos, int sign_algos_length, gnutls_retr2_st *st)
 Callback function to be called in order to retrieve the certificate to be used in the handshake.
int gvm_server_open_verify (gnutls_session_t *session, const char *host, int port, const char *ca_mem, const char *pub_mem, const char *priv_mem, int verify)
 Connect to the server using a given host, port and cert.
int gvm_server_open_with_cert (gnutls_session_t *session, const char *host, int port, const char *ca_mem, const char *pub_mem, const char *priv_mem)
 Connect to the server using a given host, port and cert.
int gvm_server_open (gnutls_session_t *session, const char *host, int port)
 Connect to the server using a given host and port.
int gvm_server_close (int socket, gnutls_session_t session)
 Close a server connection and its socket.
void gvm_connection_close (gvm_connection_t *connection)
 Close a server connection and its socket.
int gvm_server_attach (int socket, gnutls_session_t *session)
 Attach a socket to a session, and shake hands with the peer.
static int gvm_server_vsendf_internal (gnutls_session_t *session, const char *fmt, va_list ap, int quiet)
 Send a string to the server.
static int unix_vsendf_internal (int socket, const char *fmt, va_list ap, int quiet)
 Send a string to the server.
static int gvm_connection_vsendf_internal (gvm_connection_t *connection, const char *fmt, va_list ap, int quiet)
 Send a string to the connection.
int gvm_server_vsendf (gnutls_session_t *session, const char *fmt, va_list ap)
 Send a string to the server.
int gvm_socket_vsendf (int socket, const char *fmt, va_list ap)
 Send a string to the server.
static int gvm_connection_vsendf (gvm_connection_t *connection, const char *fmt, va_list ap)
 Send a string to the server.
static int gvm_server_vsendf_quiet (gnutls_session_t *session, const char *fmt, va_list ap)
 Send a string to the server, refraining from logging besides warnings.
static int gvm_connection_vsendf_quiet (gvm_connection_t *connection, const char *fmt, va_list ap)
 Send a string to the server, refraining from logging besides warnings.
int gvm_server_sendf (gnutls_session_t *session, const char *format,...)
 Format and send a string to the server.
int gvm_connection_sendf (gvm_connection_t *connection, const char *format,...)
 Format and send a string to the server.
static int gvm_server_sendf_quiet (gnutls_session_t *session, const char *format,...)
 Format and send a string to the server.
static int gvm_connection_sendf_quiet (gvm_connection_t *connection, const char *format,...)
 Format and send a string to the server.
int gvm_server_sendf_xml (gnutls_session_t *session, const char *format,...)
 Format and send an XML string to the server.
int gvm_connection_sendf_xml (gvm_connection_t *connection, const char *format,...)
 Format and send an XML string to the server.
int gvm_server_sendf_xml_quiet (gnutls_session_t *session, const char *format,...)
 Format and send an XML string to the server.
int gvm_connection_sendf_xml_quiet (gvm_connection_t *connection, const char *format,...)
 Format and send an XML string to the server.
static int server_new_gnutls_init (gnutls_certificate_credentials_t *server_credentials)
 Initialize a server session.
static int server_new_gnutls_set (unsigned int end_type, const char *priority, gnutls_session_t *server_session, gnutls_certificate_credentials_t *server_credentials)
 Set the server credentials.
int gvm_server_new (unsigned int end_type, gchar *ca_cert_file, gchar *cert_file, gchar *key_file, gnutls_session_t *server_session, gnutls_certificate_credentials_t *server_credentials)
 Make a session for connecting to a server.
int gvm_server_new_mem (unsigned int end_type, const char *ca_cert, const char *pub_key, const char *priv_key, gnutls_session_t *session, gnutls_certificate_credentials_t *credentials)
 Make a session for connecting to a server, with certificates stored in memory.
int set_gnutls_dhparams (gnutls_certificate_credentials_t creds, const char *dhparams_file)
 Set a gnutls session's Diffie-Hellman parameters.
int gvm_server_free (int server_socket, gnutls_session_t server_session, gnutls_certificate_credentials_t server_credentials)
 Cleanup a server session.

Variables

static char * cert_pub_mem = NULL
static char * cert_priv_mem = NULL

Detailed Description

GnuTLS based functions for server communication.

This library supplies low-level communication functions for communication with a server over GnuTLS.

Definition in file serverutils.c.

Macro Definition Documentation

◆ _GNU_SOURCE

#define _GNU_SOURCE

Definition at line 14 of file serverutils.c.

◆ G_LOG_DOMAIN

#define G_LOG_DOMAIN   "libgvm util"

GLib logging domain.

Definition at line 38 of file serverutils.c.

Function Documentation

◆ client_cert_callback()

int client_cert_callback ( gnutls_session_t session,
const gnutls_datum_t * req_ca_rdn,
int nreqs,
const gnutls_pk_algorithm_t * sign_algos,
int sign_algos_length,
gnutls_retr2_st * st )
static

Callback function to be called in order to retrieve the certificate to be used in the handshake.

Parameters
[in]sessionPointer to GNUTLS session. Not in used. Can be NULL.
[in]req_ca_rdnContains a list with the CA names that the server considers trusted. Not in used. Can be NULL.
[in]nreqsNumber of CA requested. Not in used. Can be NULL.
[in]sign_algoscontains a list with server's acceptable public key algorithms. Not in used. Can be NULL.
[in]sign_algos_lengthAlgos list length. Not in used. Can be NULL.
[out]stShould contain the certificates and private keys
Returns
0 on success, non-null otherwise.

Definition at line 261 of file serverutils.c.

265{
266 int ret;
267 gnutls_datum_t data;
268 static gnutls_x509_crt_t crt;
269 static gnutls_x509_privkey_t key;
270
271 (void) session;
272 (void) req_ca_rdn;
273 (void) nreqs;
274 (void) sign_algos;
275 (void) sign_algos_length;
276 data.data = (unsigned char *) g_strdup (get_cert_pub_mem ());
277 data.size = strlen (get_cert_pub_mem ());
278 gnutls_x509_crt_init (&crt);
279 ret = gnutls_x509_crt_import (crt, &data, GNUTLS_X509_FMT_PEM);
280 g_free (data.data);
281 if (ret)
282 return ret;
283 st->cert.x509 = &crt;
284 st->cert_type = GNUTLS_CRT_X509;
285 st->ncerts = 1;
286
287 data.data = (unsigned char *) g_strdup (get_cert_priv_mem ());
288 data.size = strlen (get_cert_priv_mem ());
289 gnutls_x509_privkey_init (&key);
290 ret = gnutls_x509_privkey_import (key, &data, GNUTLS_X509_FMT_PEM);
291 g_free (data.data);
292 if (ret)
293 return ret;
294 st->key.x509 = key;
295 st->key_type = GNUTLS_PRIVKEY_X509;
296 return 0;
297}
static const char * get_cert_pub_mem()
Get public certificate from cert_pub_mem.
static const char * get_cert_priv_mem()
Get private certificate from cert_priv_mem.

References get_cert_priv_mem(), and get_cert_pub_mem().

Referenced by gvm_server_open_verify().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ close_unix()

int close_unix ( gvm_connection_t * client_connection)
static

Close UNIX socket connection.

Parameters
[in]client_connectionClient connection.
Returns
0 success, -1 error.

Definition at line 57 of file serverutils.c.

58{
59 /* Turn off blocking. */
60 if (fcntl (client_connection->socket, F_SETFL, O_NONBLOCK) == -1)
61 {
62 g_warning ("%s: failed to set server socket flag: %s\n", __func__,
63 strerror (errno));
64 return -1;
65 }
66
67 if (shutdown (client_connection->socket, SHUT_RDWR) == -1)
68 {
69 if (errno == ENOTCONN)
70 return 0;
71 g_warning ("%s: failed to shutdown server socket: %s\n", __func__,
72 strerror (errno));
73 return -1;
74 }
75
76 if (close (client_connection->socket) == -1)
77 {
78 g_warning ("%s: failed to close server socket: %s\n", __func__,
79 strerror (errno));
80 return -1;
81 }
82
83 return 0;
84}
int socket
Socket.
Definition serverutils.h:32

References gvm_connection_t::socket.

Referenced by gvm_connection_free().

Here is the caller graph for this function:

◆ get_cert_priv_mem()

const char * get_cert_priv_mem ( )
static

Get private certificate from cert_priv_mem.

Returns
The DER or PEM encoded certificate.

Definition at line 229 of file serverutils.c.

230{
231 return cert_priv_mem;
232}
static char * cert_priv_mem

References cert_priv_mem.

Referenced by client_cert_callback().

Here is the caller graph for this function:

◆ get_cert_pub_mem()

const char * get_cert_pub_mem ( )
static

Get public certificate from cert_pub_mem.

Returns
The DER or PEM encoded certificate.

Definition at line 240 of file serverutils.c.

241{
242 return cert_pub_mem;
243}
static char * cert_pub_mem

References cert_pub_mem.

Referenced by client_cert_callback().

Here is the caller graph for this function:

◆ gvm_connection_close()

void gvm_connection_close ( gvm_connection_t * connection)

Close a server connection and its socket.

Parameters
[in]connectionConnection.

Definition at line 504 of file serverutils.c.

505{
506 gvm_connection_free (connection);
507}
void gvm_connection_free(gvm_connection_t *client_connection)
Free connection.
Definition serverutils.c:92

References gvm_connection_free().

Here is the call graph for this function:

◆ gvm_connection_free()

void gvm_connection_free ( gvm_connection_t * client_connection)

Free connection.

Parameters
[in]client_connectionConnection.

Definition at line 92 of file serverutils.c.

93{
94 if (client_connection->tls)
95 gvm_server_free (client_connection->socket, client_connection->session,
96 client_connection->credentials);
97 else
98 close_unix (client_connection);
99}
static int close_unix(gvm_connection_t *client_connection)
Close UNIX socket connection.
Definition serverutils.c:57
int gvm_server_free(int server_socket, gnutls_session_t server_session, gnutls_certificate_credentials_t server_credentials)
Cleanup a server session.
int tls
Whether uses TCP-TLS (vs UNIX socket).
Definition serverutils.h:31
gnutls_certificate_credentials_t credentials
Credentials.
Definition serverutils.h:34
gnutls_session_t session
Session.
Definition serverutils.h:33

References close_unix(), gvm_connection_t::credentials, gvm_server_free(), gvm_connection_t::session, gvm_connection_t::socket, and gvm_connection_t::tls.

Referenced by gvm_connection_close().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_sendf()

int gvm_connection_sendf ( gvm_connection_t * connection,
const char * format,
... )

Format and send a string to the server.

Parameters
[in]connectionConnection.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 823 of file serverutils.c.

824{
825 va_list ap;
826 int rc;
827
828 va_start (ap, format);
829 rc = gvm_connection_vsendf (connection, format, ap);
830 va_end (ap);
831 return rc;
832}
static int gvm_connection_vsendf(gvm_connection_t *connection, const char *fmt, va_list ap)
Send a string to the server.

References gvm_connection_vsendf().

Referenced by gmp_ping_c(), gmp_resume_task_report_c(), gmp_start_task_ext_c(), gmp_start_task_report_c(), gmp_stop_task_c(), gvm_connection_sendf_xml(), and gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_sendf_quiet()

int gvm_connection_sendf_quiet ( gvm_connection_t * connection,
const char * format,
... )
static

Format and send a string to the server.

Parameters
[in]connectionConnection.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 863 of file serverutils.c.

865{
866 va_list ap;
867 int rc;
868
869 va_start (ap, format);
870 rc = gvm_connection_vsendf_quiet (connection, format, ap);
871 va_end (ap);
872 return rc;
873}
static int gvm_connection_vsendf_quiet(gvm_connection_t *connection, const char *fmt, va_list ap)
Send a string to the server, refraining from logging besides warnings.

References gvm_connection_vsendf_quiet().

Referenced by gvm_connection_sendf_xml_quiet().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_sendf_xml()

int gvm_connection_sendf_xml ( gvm_connection_t * connection,
const char * format,
... )

Format and send an XML string to the server.

Escape XML in string and character args.

Parameters
[in]connectionConnection.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 911 of file serverutils.c.

912{
913 va_list ap;
914 gchar *msg;
915 int rc;
916
917 va_start (ap, format);
918 msg = g_markup_vprintf_escaped (format, ap);
919 rc = gvm_connection_sendf (connection, "%s", msg);
920 g_free (msg);
921 va_end (ap);
922 return rc;
923}
int gvm_connection_sendf(gvm_connection_t *connection, const char *format,...)
Format and send a string to the server.

References gvm_connection_sendf().

Referenced by gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_sendf_xml_quiet()

int gvm_connection_sendf_xml_quiet ( gvm_connection_t * connection,
const char * format,
... )

Format and send an XML string to the server.

Escape XML in string and character args.

Quiet version, only logs warnings.

Parameters
[in]connectionConnection.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 965 of file serverutils.c.

967{
968 va_list ap;
969 gchar *msg;
970 int rc;
971
972 va_start (ap, format);
973 msg = g_markup_vprintf_escaped (format, ap);
974 rc = gvm_connection_sendf_quiet (connection, "%s", msg);
975 g_free (msg);
976 va_end (ap);
977 return rc;
978}
static int gvm_connection_sendf_quiet(gvm_connection_t *connection, const char *format,...)
Format and send a string to the server.

References gvm_connection_sendf_quiet().

Referenced by gmp_authenticate_info_ext_c(), and gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_vsendf()

int gvm_connection_vsendf ( gvm_connection_t * connection,
const char * fmt,
va_list ap )
static

Send a string to the server.

Parameters
[in]connectionConnection.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 757 of file serverutils.c.

759{
760 return gvm_connection_vsendf_internal (connection, fmt, ap, 0);
761}
static int gvm_connection_vsendf_internal(gvm_connection_t *connection, const char *fmt, va_list ap, int quiet)
Send a string to the connection.

References gvm_connection_vsendf_internal().

Referenced by gvm_connection_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_vsendf_internal()

int gvm_connection_vsendf_internal ( gvm_connection_t * connection,
const char * fmt,
va_list ap,
int quiet )
static

Send a string to the connection.

Parameters
[in]connectionConnection.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
[in]quietWhether to log debug and info messages. Useful for hiding passwords.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 709 of file serverutils.c.

711{
712 if (connection->tls)
713 return gvm_server_vsendf_internal (&connection->session, fmt, ap, quiet);
714 return unix_vsendf_internal (connection->socket, fmt, ap, quiet);
715}
static int unix_vsendf_internal(int socket, const char *fmt, va_list ap, int quiet)
Send a string to the server.
static int gvm_server_vsendf_internal(gnutls_session_t *session, const char *fmt, va_list ap, int quiet)
Send a string to the server.

References gvm_server_vsendf_internal(), gvm_connection_t::session, gvm_connection_t::socket, gvm_connection_t::tls, and unix_vsendf_internal().

Referenced by gvm_connection_vsendf(), and gvm_connection_vsendf_quiet().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_connection_vsendf_quiet()

int gvm_connection_vsendf_quiet ( gvm_connection_t * connection,
const char * fmt,
va_list ap )
static

Send a string to the server, refraining from logging besides warnings.

Parameters
[in]connectionConnection.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 788 of file serverutils.c.

790{
791 return gvm_connection_vsendf_internal (connection, fmt, ap, 1);
792}

References gvm_connection_vsendf_internal().

Referenced by gvm_connection_sendf_quiet().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_attach()

int gvm_server_attach ( int socket,
gnutls_session_t * session )

Attach a socket to a session, and shake hands with the peer.

Parameters
[in]socketSocket.
[in]sessionPointer to GNUTLS session. FIXME: Why is this a pointer to a session?
Returns
0 on success, -1 on error.

Definition at line 569 of file serverutils.c.

570{
571 int ret;
572
573 ret = server_attach_internal (socket, session, NULL, 0);
574 return ret ? -1 : 0;
575}
static int server_attach_internal(int, gnutls_session_t *, const char *, int)
Attach a socket to a session, and shake hands with the peer.

References server_attach_internal().

Here is the call graph for this function:

◆ gvm_server_close()

int gvm_server_close ( int socket,
gnutls_session_t session )

Close a server connection and its socket.

Parameters
[in]socketSocket connected to server.
[in]sessionGNUTLS session with server.
Returns
0 on success, -1 on error.

Definition at line 493 of file serverutils.c.

494{
495 return gvm_server_free (socket, session, NULL);
496}

References gvm_server_free().

Referenced by osp_connection_close().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_free()

int gvm_server_free ( int server_socket,
gnutls_session_t server_session,
gnutls_certificate_credentials_t server_credentials )

Cleanup a server session.

This shuts down the TLS session, closes the socket and releases the TLS resources.

Parameters
[in]server_socketThe socket connected to the server.
[in]server_sessionThe session with the server.
[in]server_credentialsCredentials or NULL.
Returns
0 success, -1 error.

Definition at line 1271 of file serverutils.c.

1273{
1274 /* Turn off blocking. */
1275 // FIX get flags first
1276 if (fcntl (server_socket, F_SETFL, O_NONBLOCK) == -1)
1277 {
1278 g_warning ("%s: failed to set server socket flag: %s\n", __func__,
1279 strerror (errno));
1280 return -1;
1281 }
1282
1283 while (1)
1284 {
1285 int ret = gnutls_bye (server_session, GNUTLS_SHUT_WR);
1286 if (ret == GNUTLS_E_AGAIN || ret == GNUTLS_E_INTERRUPTED)
1287 {
1288 continue;
1289 }
1290 if (ret)
1291 {
1292 g_debug (" Failed to gnutls_bye: %s\n",
1293 gnutls_strerror ((int) ret));
1294 /* Carry on successfully anyway, as this often fails, perhaps
1295 * because the server is closing the connection first. */
1296 break;
1297 }
1298 break;
1299 }
1300
1301 /* The former separate code in gvm_server_close and here
1302 differed in the order the TLS session and socket was closed. The
1303 way we do it here seems to be the right thing but for full
1304 backward compatibility we do it for calls from
1305 gvm_server_close in the old way. We can distinguish the two
1306 modes by the existence of server_credentials. */
1307 if (server_credentials)
1308 {
1309 if (close (server_socket) == -1)
1310 {
1311 g_warning ("%s: failed to close server socket: %s\n", __func__,
1312 strerror (errno));
1313 return -1;
1314 }
1315 gnutls_deinit (server_session);
1316 gnutls_certificate_free_credentials (server_credentials);
1317 }
1318 else
1319 {
1320 gnutls_deinit (server_session);
1321 close (server_socket);
1322 }
1323
1324 gnutls_global_deinit ();
1325
1326 return 0;
1327}

Referenced by gvm_connection_free(), gvm_server_close(), and gvm_server_sendf().

Here is the caller graph for this function:

◆ gvm_server_new()

int gvm_server_new ( unsigned int end_type,
gchar * ca_cert_file,
gchar * cert_file,
gchar * key_file,
gnutls_session_t * server_session,
gnutls_certificate_credentials_t * server_credentials )

Make a session for connecting to a server.

Parameters
[in]end_typeConnection end type (GNUTLS_SERVER or GNUTLS_CLIENT).
[in]ca_cert_fileCertificate authority file.
[in]cert_fileCertificate file.
[in]key_fileKey file.
[out]server_sessionThe session with the server.
[out]server_credentialsServer credentials.
Returns
0 on success, -1 on error.

Definition at line 1144 of file serverutils.c.

1147{
1148 return server_new_internal (end_type, NULL, ca_cert_file, cert_file, key_file,
1149 server_session, server_credentials);
1150}
static int server_new_internal(unsigned int, const char *, const gchar *, const gchar *, const gchar *, gnutls_session_t *, gnutls_certificate_credentials_t *)
Make a session for connecting to a server.

References server_new_internal().

Referenced by gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_new_mem()

int gvm_server_new_mem ( unsigned int end_type,
const char * ca_cert,
const char * pub_key,
const char * priv_key,
gnutls_session_t * session,
gnutls_certificate_credentials_t * credentials )

Make a session for connecting to a server, with certificates stored in memory.

Parameters
[in]end_typeConnection end type: GNUTLS_SERVER or GNUTLS_CLIENT.
[in]ca_certCertificate authority public key.
[in]pub_keyPublic key.
[in]priv_keyPrivate key.
[out]sessionThe session with the server.
[out]credentialsServer credentials.
Returns
0 on success, -1 on error.

Definition at line 1166 of file serverutils.c.

1170{
1171 if (server_new_gnutls_init (credentials))
1172 return -1;
1173
1174 if (pub_key && priv_key)
1175 {
1176 int ret;
1177 gnutls_datum_t pub, priv;
1178
1179 pub.data = (void *) pub_key;
1180 pub.size = strlen (pub_key);
1181 priv.data = (void *) priv_key;
1182 priv.size = strlen (priv_key);
1183
1184 ret = gnutls_certificate_set_x509_key_mem (*credentials, &pub, &priv,
1185 GNUTLS_X509_FMT_PEM);
1186 if (ret < 0)
1187 {
1188 g_warning ("%s: %s\n", __func__, gnutls_strerror (ret));
1189 return -1;
1190 }
1191 }
1192
1193 if (ca_cert)
1194 {
1195 int ret;
1196 gnutls_datum_t data;
1197
1198 data.data = (void *) ca_cert;
1199 data.size = strlen (ca_cert);
1200 ret = gnutls_certificate_set_x509_trust_mem (*credentials, &data,
1201 GNUTLS_X509_FMT_PEM);
1202 if (ret < 0)
1203 {
1204 g_warning ("%s: %s\n", __func__, gnutls_strerror (ret));
1205 gnutls_certificate_free_credentials (*credentials);
1206 return -1;
1207 }
1208 }
1209
1210 if (server_new_gnutls_set (end_type, NULL, session, credentials))
1211 {
1212 gnutls_certificate_free_credentials (*credentials);
1213 return -1;
1214 }
1215
1216 return 0;
1217}
static int server_new_gnutls_init(gnutls_certificate_credentials_t *server_credentials)
Initialize a server session.
static int server_new_gnutls_set(unsigned int end_type, const char *priority, gnutls_session_t *server_session, gnutls_certificate_credentials_t *server_credentials)
Set the server credentials.

References server_new_gnutls_init(), and server_new_gnutls_set().

Referenced by gvm_server_open_verify(), and gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_open()

int gvm_server_open ( gnutls_session_t * session,
const char * host,
int port )

Connect to the server using a given host and port.

Parameters
[in]sessionPointer to GNUTLS session.
[in]hostHost to connect to.
[in]portPort to connect to.
Returns
0 on success, -1 on error.

Definition at line 479 of file serverutils.c.

480{
481 return gvm_server_open_with_cert (session, host, port, NULL, NULL, NULL);
482}
int gvm_server_open_with_cert(gnutls_session_t *session, const char *host, int port, const char *ca_mem, const char *pub_mem, const char *priv_mem)
Connect to the server using a given host, port and cert.

References gvm_server_open_with_cert().

Here is the call graph for this function:

◆ gvm_server_open_verify()

int gvm_server_open_verify ( gnutls_session_t * session,
const char * host,
int port,
const char * ca_mem,
const char * pub_mem,
const char * priv_mem,
int verify )

Connect to the server using a given host, port and cert.

Parameters
[in]sessionPointer to GNUTLS session.
[in]hostHost to connect to.
[in]portPort to connect to.
[in]ca_memCA cert.
[in]pub_memPublic key.
[in]priv_memPrivate key.
[in]verifyWhether to verify.
Returns
0 on success, -1 on error.
Warning
On success we are leaking the credentials. We can't free them because the session only makes a shallow copy.

Definition at line 313 of file serverutils.c.

316{
317 int ret;
318 int server_socket;
319 struct addrinfo address_hints;
320 struct addrinfo *addresses, *address;
321 gchar *port_string;
322 int host_type;
323
324 gnutls_certificate_credentials_t credentials;
325
326 /* Ensure that host and port have sane values. */
327 if (port < 1 || port > 65535)
328 {
329 g_warning ("Failed to create client TLS session. "
330 "Invalid port %d",
331 port);
332 return -1;
333 }
337 {
338 g_warning ("Failed to create client TLS session. Invalid host %s", host);
339 return -1;
340 }
341
344
345 if (gvm_server_new_mem (GNUTLS_CLIENT, ca_mem, pub_mem, priv_mem, session,
346 &credentials))
347 {
348 g_warning ("Failed to create client TLS session.");
349 return -1;
350 }
351
352 if (ca_mem && pub_mem && priv_mem)
353 {
354 set_cert_pub_mem (pub_mem);
355 set_cert_priv_mem (priv_mem);
356
357 gnutls_certificate_set_retrieve_function (credentials,
359 }
360
361 /* Create the port string. */
362
363 port_string = g_strdup_printf ("%i", port);
364
365 /* Get all possible addresses. */
366
367 memset (&address_hints, 0, sizeof (address_hints));
368 address_hints.ai_family = AF_UNSPEC; /* IPv4 or IPv6. */
369 address_hints.ai_socktype = SOCK_STREAM;
370 address_hints.ai_protocol = 0;
371
372 if (getaddrinfo (host, port_string, &address_hints, &addresses))
373 {
374 g_free (port_string);
375 g_warning ("Failed to get server addresses for %s: %s", host,
376 gai_strerror (errno));
377 gnutls_deinit (*session);
378 gnutls_certificate_free_credentials (credentials);
379 return -1;
380 }
381 g_free (port_string);
382
383 /* Try to connect to each address in turn. */
384
385 for (address = addresses; address; address = address->ai_next)
386 {
387 /* Make server socket. */
388
389 if (address->ai_family == AF_INET6)
390 server_socket = socket (PF_INET6, SOCK_STREAM, 0);
391 else
392 server_socket = socket (PF_INET, SOCK_STREAM, 0);
393 if (server_socket == -1)
394 {
395 g_warning ("Failed to create server socket");
396 freeaddrinfo (addresses);
397 gnutls_deinit (*session);
398 gnutls_certificate_free_credentials (credentials);
399 return -1;
400 }
401
402 /* Connect to server. */
403
404 if (connect (server_socket, address->ai_addr, address->ai_addrlen) == -1)
405 {
406 close (server_socket);
407 continue;
408 }
409 break;
410 }
411
412 freeaddrinfo (addresses);
413
414 if (address == NULL)
415 {
416 g_warning ("Failed to connect to server");
417 gnutls_deinit (*session);
418 gnutls_certificate_free_credentials (credentials);
419 return -1;
420 }
421
422 g_debug (" Connected to server '%s' port %d.", host, port);
423
424 /* Complete setup of server session. */
425 ret = server_attach_internal (server_socket, session, host, port);
426 if (ret)
427 {
428 if (ret == -2)
429 {
430 close (server_socket);
431 gnutls_deinit (*session);
432 gnutls_certificate_free_credentials (credentials);
433 }
434 close (server_socket);
435 return -1;
436 }
437 if (verify && gvm_server_verify (*session))
438 {
439 close (server_socket);
440 return -1;
441 }
442
443 return server_socket;
444}
int gvm_get_host_type(const gchar *str_stripped)
Determines the host type in a buffer.
Definition hosts.c:813
host_type
Definition hosts.h:34
@ HOST_TYPE_NAME
Definition hosts.h:35
@ HOST_TYPE_IPV6
Definition hosts.h:40
@ HOST_TYPE_IPV4
Definition hosts.h:36
static void set_cert_priv_mem(const char *data)
Save cert_priv_mem with private certificate.
static int client_cert_callback(gnutls_session_t session, const gnutls_datum_t *req_ca_rdn, int nreqs, const gnutls_pk_algorithm_t *sign_algos, int sign_algos_length, gnutls_retr2_st *st)
Callback function to be called in order to retrieve the certificate to be used in the handshake.
int gvm_server_new_mem(unsigned int end_type, const char *ca_cert, const char *pub_key, const char *priv_key, gnutls_session_t *session, gnutls_certificate_credentials_t *credentials)
Make a session for connecting to a server, with certificates stored in memory.
int gvm_server_verify(gnutls_session_t session)
Verify certificate.
static void set_cert_pub_mem(const char *data)
Save cert_pub_mem with public certificate.

References client_cert_callback(), gvm_get_host_type(), gvm_server_new_mem(), gvm_server_verify(), HOST_TYPE_IPV4, HOST_TYPE_IPV6, HOST_TYPE_NAME, server_attach_internal(), set_cert_priv_mem(), and set_cert_pub_mem().

Referenced by gvm_server_open_with_cert().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_open_with_cert()

int gvm_server_open_with_cert ( gnutls_session_t * session,
const char * host,
int port,
const char * ca_mem,
const char * pub_mem,
const char * priv_mem )

Connect to the server using a given host, port and cert.

Verify if all cert args are given.

Parameters
[in]sessionPointer to GNUTLS session.
[in]hostHost to connect to.
[in]portPort to connect to.
[in]ca_memCA cert.
[in]pub_memPublic key.
[in]priv_memPrivate key.
Returns
0 on success, -1 on error.

Definition at line 461 of file serverutils.c.

464{
465 return gvm_server_open_verify (session, host, port, ca_mem, pub_mem, priv_mem,
466 ca_mem && pub_mem && priv_mem);
467}
int gvm_server_open_verify(gnutls_session_t *session, const char *host, int port, const char *ca_mem, const char *pub_mem, const char *priv_mem, int verify)
Connect to the server using a given host, port and cert.

References gvm_server_open_verify().

Referenced by gvm_server_open(), and osp_send_command().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_sendf()

int gvm_server_sendf ( gnutls_session_t * session,
const char * format,
... )

Format and send a string to the server.

Parameters
[in]sessionPointer to GNUTLS session.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 803 of file serverutils.c.

804{
805 va_list ap;
806 int rc;
807
808 va_start (ap, format);
809 rc = gvm_server_vsendf (session, format, ap);
810 va_end (ap);
811 return rc;
812}
int gvm_server_vsendf(gnutls_session_t *session, const char *fmt, va_list ap)
Send a string to the server.

References gvm_server_vsendf().

Referenced by gmp_create_lsc_credential_ext(), gmp_create_target_ext(), gmp_create_task_ext(), gmp_delete_config_ext(), gmp_delete_lsc_credential_ext(), gmp_delete_port_list_ext(), gmp_delete_report(), gmp_delete_target_ext(), gmp_delete_task(), gmp_delete_task_ext(), gmp_get_report_ext(), gmp_get_system_reports(), gmp_get_system_reports_ext(), gmp_get_targets(), gmp_get_task_ext(), gmp_get_tasks(), gmp_get_tasks_ext(), gmp_modify_task_file(), gmp_ping(), gmp_resume_task_report(), gmp_start_task_report(), gmp_stop_task(), and gvm_server_sendf_xml().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_sendf_quiet()

int gvm_server_sendf_quiet ( gnutls_session_t * session,
const char * format,
... )
static

Format and send a string to the server.

Parameters
[in]sessionPointer to GNUTLS session.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 843 of file serverutils.c.

844{
845 va_list ap;
846 int rc;
847
848 va_start (ap, format);
849 rc = gvm_server_vsendf_quiet (session, format, ap);
850 va_end (ap);
851 return rc;
852}
static int gvm_server_vsendf_quiet(gnutls_session_t *session, const char *fmt, va_list ap)
Send a string to the server, refraining from logging besides warnings.

References gvm_server_vsendf_quiet().

Referenced by gvm_server_sendf_xml_quiet().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_sendf_xml()

int gvm_server_sendf_xml ( gnutls_session_t * session,
const char * format,
... )

Format and send an XML string to the server.

Escape XML in string and character args.

Parameters
[in]sessionPointer to GNUTLS session.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 886 of file serverutils.c.

887{
888 va_list ap;
889 gchar *msg;
890 int rc;
891
892 va_start (ap, format);
893 msg = g_markup_vprintf_escaped (format, ap);
894 rc = gvm_server_sendf (session, "%s", msg);
895 g_free (msg);
896 va_end (ap);
897 return rc;
898}
int gvm_server_sendf(gnutls_session_t *session, const char *format,...)
Format and send a string to the server.

References gvm_server_sendf().

Referenced by gmp_create_lsc_credential(), gmp_create_lsc_credential_key(), gmp_create_task(), and gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_sendf_xml_quiet()

int gvm_server_sendf_xml_quiet ( gnutls_session_t * session,
const char * format,
... )

Format and send an XML string to the server.

Escape XML in string and character args.

Quiet version, only logs warnings.

Parameters
[in]sessionPointer to GNUTLS session.
[in]formatprintf-style format string for message.
Returns
0 on success, -1 on error.

Definition at line 938 of file serverutils.c.

939{
940 va_list ap;
941 gchar *msg;
942 int rc;
943
944 va_start (ap, format);
945 msg = g_markup_vprintf_escaped (format, ap);
946 rc = gvm_server_sendf_quiet (session, "%s", msg);
947 g_free (msg);
948 va_end (ap);
949 return rc;
950}
static int gvm_server_sendf_quiet(gnutls_session_t *session, const char *format,...)
Format and send a string to the server.

References gvm_server_sendf_quiet().

Referenced by gmp_authenticate(), gmp_authenticate_info_ext(), gmp_create_lsc_credential(), and gvm_server_sendf().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_verify()

int gvm_server_verify ( gnutls_session_t session)

Verify certificate.

Parameters
[in]sessionPointer to GNUTLS session.
Returns
0 on success, 1 on failure, -1 on error.

Definition at line 111 of file serverutils.c.

112{
113 unsigned int status;
114 int ret;
115
116 ret = gnutls_certificate_verify_peers2 (session, &status);
117 if (ret < 0)
118 {
119 g_warning ("%s: failed to verify peers: %s", __func__,
120 gnutls_strerror (ret));
121 return -1;
122 }
123
124 if (status & GNUTLS_CERT_INVALID)
125 g_warning ("%s: the certificate is not trusted", __func__);
126
127 if (status & GNUTLS_CERT_SIGNER_NOT_CA)
128 g_warning ("%s: the certificate's issuer is not a CA", __func__);
129
130 if (status & GNUTLS_CERT_INSECURE_ALGORITHM)
131 g_warning ("%s: the certificate was signed using an insecure algorithm",
132 __func__);
133
134 if (status & GNUTLS_CERT_SIGNER_NOT_FOUND)
135 g_warning ("%s: the certificate hasn't got a known issuer", __func__);
136
137 if (status & GNUTLS_CERT_REVOKED)
138 g_warning ("%s: the certificate has been revoked", __func__);
139
140 if (status & GNUTLS_CERT_EXPIRED)
141 g_warning ("%s: the certificate has expired", __func__);
142
143 if (status & GNUTLS_CERT_NOT_ACTIVATED)
144 g_warning ("%s: the certificate is not yet activated", __func__);
145
146 if (status)
147 return 1;
148
149 return 0;
150}

Referenced by gvm_server_open_verify().

Here is the caller graph for this function:

◆ gvm_server_vsendf()

int gvm_server_vsendf ( gnutls_session_t * session,
const char * fmt,
va_list ap )

Send a string to the server.

Parameters
[in]sessionPointer to GNUTLS session.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 727 of file serverutils.c.

728{
729 return gvm_server_vsendf_internal (session, fmt, ap, 0);
730}

References gvm_server_vsendf_internal().

Referenced by gvm_server_sendf(), gvm_server_sendf(), osp_send_command(), and osp_send_command_str().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_server_vsendf_internal()

int gvm_server_vsendf_internal ( gnutls_session_t * session,
const char * fmt,
va_list ap,
int quiet )
static

Send a string to the server.

Parameters
[in]sessionPointer to GNUTLS session.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
[in]quietWhether to log debug and info messages. Useful for hiding passwords.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 589 of file serverutils.c.

591{
592 char *sref, *string;
593 int rc = 0, left;
594
595 left = vasprintf (&string, fmt, ap);
596 if (left == -1)
597 string = NULL;
598
599 sref = string;
600 while (left > 0)
601 {
602 ssize_t count;
603
604 if (quiet == 0)
605 g_debug (" send %d from %.*s[...]", left, left < 30 ? left : 30,
606 string);
607 count = gnutls_record_send (*session, string, left);
608 if (count < 0)
609 {
610 if (count == GNUTLS_E_INTERRUPTED)
611 /* Interrupted, try write again. */
612 continue;
613 if (count == GNUTLS_E_REHANDSHAKE)
614 {
615 /* \todo Rehandshake. */
616 if (quiet == 0)
617 g_message (" %s rehandshake", __func__);
618 continue;
619 }
620 g_warning ("Failed to write to server: %s", gnutls_strerror (count));
621 rc = -1;
622 goto out;
623 }
624 if (count == 0)
625 {
626 /* Server closed connection. */
627 if (quiet == 0)
628 g_debug ("= server closed");
629 rc = 1;
630 goto out;
631 }
632 if (quiet == 0)
633 g_debug ("=> %.*s", (int) count, string);
634 string += count;
635 left -= count;
636 }
637 if (quiet == 0)
638 g_debug ("=> done");
639
640out:
641 g_free (sref);
642 return rc;
643}

Referenced by gvm_connection_vsendf_internal(), gvm_server_vsendf(), and gvm_server_vsendf_quiet().

Here is the caller graph for this function:

◆ gvm_server_vsendf_quiet()

int gvm_server_vsendf_quiet ( gnutls_session_t * session,
const char * fmt,
va_list ap )
static

Send a string to the server, refraining from logging besides warnings.

Parameters
[in]sessionPointer to GNUTLS session.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 773 of file serverutils.c.

774{
775 return gvm_server_vsendf_internal (session, fmt, ap, 1);
776}

References gvm_server_vsendf_internal().

Referenced by gvm_server_sendf_quiet().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ gvm_socket_vsendf()

int gvm_socket_vsendf ( int socket,
const char * fmt,
va_list ap )

Send a string to the server.

Parameters
[in]socketSocket to send string through.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 742 of file serverutils.c.

743{
744 return unix_vsendf_internal (socket, fmt, ap, 0);
745}

References unix_vsendf_internal().

Referenced by gvm_server_sendf(), osp_send_command(), and osp_send_command_str().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ load_gnutls_file()

int load_gnutls_file ( const char * file,
gnutls_datum_t * loaded_file )

Loads a file's data into gnutls_datum_t struct.

Parameters
[in]fileFile to load.
[out]loaded_fileDestination to load file into.
Returns
0 if success, -1 if error.

Definition at line 161 of file serverutils.c.

162{
163 FILE *f = NULL;
164 int64_t filelen;
165 void *ptr;
166
167 if (!(f = fopen (file, "r")) || fseek (f, 0, SEEK_END) != 0
168 || (filelen = ftell (f)) < 0 || fseek (f, 0, SEEK_SET) != 0
169 || !(ptr = g_malloc0 ((size_t) filelen))
170 || fread (ptr, 1, (size_t) filelen, f) < (size_t) filelen)
171 {
172 if (f)
173 fclose (f);
174 return -1;
175 }
176
177 loaded_file->data = ptr;
178 loaded_file->size = filelen;
179 fclose (f);
180 return 0;
181}

Referenced by gvm_server_session_free(), and set_gnutls_dhparams().

Here is the caller graph for this function:

◆ server_attach_internal()

int server_attach_internal ( int socket,
gnutls_session_t * session,
const char * host,
int port )
static

Attach a socket to a session, and shake hands with the peer.

Parameters
[in]socketSocket.
[in]sessionPointer to GNUTLS session.
[in]hostNULL or the name of the host for diagnostics
[in]portPort number for diagnostics; only used if host is not NULL
Returns
0 on success, -1 on general error, -2 if the TLS handshake failed.

Definition at line 521 of file serverutils.c.

523{
524 unsigned int retries;
525
526 gnutls_transport_set_ptr (*session,
527 (gnutls_transport_ptr_t) GSIZE_TO_POINTER (socket));
528
529 retries = 0;
530 while (1)
531 {
532 int ret = gnutls_handshake (*session);
533 if (ret >= 0)
534 break;
535 if (ret == GNUTLS_E_AGAIN || ret == GNUTLS_E_INTERRUPTED)
536 {
537 if (retries > 10)
538 usleep (MIN ((retries - 10) * 10000, 5000000));
539 retries++;
540 continue;
541 }
542 if (host)
543 g_debug ("Failed to shake hands with server '%s' port %d: %s", host,
544 port, gnutls_strerror (ret));
545 else
546 g_debug ("Failed to shake hands with peer: %s", gnutls_strerror (ret));
547 if (shutdown (socket, SHUT_RDWR) == -1)
548 g_debug ("Failed to shutdown server socket");
549 return -2;
550 }
551 if (host)
552 g_debug (" Shook hands with server '%s' port %d.", host, port);
553 else
554 g_debug (" Shook hands with peer.");
555
556 return 0;
557}

Referenced by gvm_server_attach(), and gvm_server_open_verify().

Here is the caller graph for this function:

◆ server_new_gnutls_init()

int server_new_gnutls_init ( gnutls_certificate_credentials_t * server_credentials)
static

Initialize a server session.

Parameters
[in]server_credentialsCredentials to be allocated.
Returns
0 on success, -1 on error.

Definition at line 988 of file serverutils.c.

989{
990 /* Turn off use of /dev/random, as this can block. */
991 gcry_control (GCRYCTL_ENABLE_QUICK_RANDOM, 0);
992
993 /* Initialize security library. */
994 if (gnutls_global_init ())
995 {
996 g_warning ("Failed to initialize GNUTLS.");
997 return -1;
998 }
999 /* Setup server session. */
1000 if (gnutls_certificate_allocate_credentials (server_credentials))
1001 {
1002 g_warning ("%s: failed to allocate server credentials\n", __func__);
1003 return -1;
1004 }
1005 return 0;
1006}

Referenced by gvm_server_new_mem(), and server_new_internal().

Here is the caller graph for this function:

◆ server_new_gnutls_set()

int server_new_gnutls_set ( unsigned int end_type,
const char * priority,
gnutls_session_t * server_session,
gnutls_certificate_credentials_t * server_credentials )
static

Set the server credentials.

Parameters
[in]end_typeConnection end type.
[in]priorityTLS priority to be set. If no one is given, NORMAL is default.
[in]server_sessionGNUTLS session.
[in]server_credentialsCredentials to be set.
Returns
0 on success, -1 on error.

Definition at line 1020 of file serverutils.c.

1023{
1024 int err;
1025
1026 if (gnutls_init (server_session, end_type))
1027 {
1028 g_warning ("%s: failed to initialise server session\n", __func__);
1029 return -1;
1030 }
1031
1032 /* Depending on gnutls version different priority strings are
1033 possible. At least from 3.0 this is an option:
1034 "NONE:+VERS-TLS1.0:+CIPHER-ALL:+COMP-ALL:+RSA:+DHE-RSA:+DHE-DSS:+MAC-ALL"
1035 But in fact this function is only for internal
1036 purposes, not for scanning abilities. So, the conservative "NORMAL"
1037 is chosen.
1038 */
1039
1040 err = gnutls_priority_set_direct (*server_session,
1041 priority ? priority : "NORMAL", NULL);
1042 if (err)
1043 {
1044 g_warning ("%s: failed to set tls priorities: %s\n", __func__,
1045 gnutls_strerror (err));
1046 gnutls_deinit (*server_session);
1047 return -1;
1048 }
1049
1050 if (gnutls_credentials_set (*server_session, GNUTLS_CRD_CERTIFICATE,
1051 *server_credentials))
1052 {
1053 g_warning ("%s: failed to set server credentials\n", __func__);
1054 gnutls_deinit (*server_session);
1055 return -1;
1056 }
1057
1058 if (end_type == GNUTLS_SERVER)
1059 gnutls_certificate_server_set_request (*server_session,
1060 GNUTLS_CERT_REQUEST);
1061 return 0;
1062}

Referenced by Ensure(), gvm_server_new_mem(), main(), and server_new_internal().

Here is the caller graph for this function:

◆ server_new_internal()

int server_new_internal ( unsigned int end_type,
const char * priority,
const gchar * ca_cert_file,
const gchar * cert_file,
const gchar * key_file,
gnutls_session_t * server_session,
gnutls_certificate_credentials_t * server_credentials )
static

Make a session for connecting to a server.

Parameters
[in]end_typeConnection end type (GNUTLS_SERVER or GNUTLS_CLIENT).
[in]priorityCustom priority string or NULL.
[in]ca_cert_fileCertificate authority file.
[in]cert_fileCertificate file.
[in]key_fileKey file.
[out]server_sessionThe session with the server.
[out]server_credentialsServer credentials.
Returns
0 on success, -1 on error.

Definition at line 1079 of file serverutils.c.

1083{
1084 if (server_new_gnutls_init (server_credentials))
1085 return -1;
1086
1087 if (cert_file && key_file)
1088 {
1089 int ret;
1090
1091 ret = gnutls_certificate_set_x509_key_file (
1092 *server_credentials, cert_file, key_file, GNUTLS_X509_FMT_PEM);
1093 if (ret < 0)
1094 {
1095 g_warning ("%s: failed to set credentials key file: %s\n", __func__,
1096 gnutls_strerror (ret));
1097 g_warning ("%s: cert file: %s\n", __func__, cert_file);
1098 g_warning ("%s: key file : %s\n", __func__, key_file);
1099 gnutls_certificate_free_credentials (*server_credentials);
1100 return -1;
1101 }
1102 }
1103
1104 if (ca_cert_file)
1105 {
1106 int ret;
1107
1108 ret = gnutls_certificate_set_x509_trust_file (
1109 *server_credentials, ca_cert_file, GNUTLS_X509_FMT_PEM);
1110 if (ret < 0)
1111 {
1112 g_warning ("%s: failed to set credentials trust file: %s\n", __func__,
1113 gnutls_strerror (ret));
1114 g_warning ("%s: trust file: %s\n", __func__, ca_cert_file);
1115 gnutls_certificate_free_credentials (*server_credentials);
1116 return -1;
1117 }
1118 }
1119
1120 if (server_new_gnutls_set (end_type, priority, server_session,
1121 server_credentials))
1122 {
1123 gnutls_certificate_free_credentials (*server_credentials);
1124 return -1;
1125 }
1126
1127 return 0;
1128}

References server_new_gnutls_init(), and server_new_gnutls_set().

Referenced by gvm_server_new().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ set_cert_priv_mem()

void set_cert_priv_mem ( const char * data)
static

Save cert_priv_mem with private certificate.

Parameters
[in]dataThe DER or PEM encoded certificate.

Definition at line 216 of file serverutils.c.

217{
218 if (cert_priv_mem)
219 g_free (cert_priv_mem);
220 cert_priv_mem = g_strdup (data);
221}

References cert_priv_mem.

Referenced by gvm_server_open_verify().

Here is the caller graph for this function:

◆ set_cert_pub_mem()

void set_cert_pub_mem ( const char * data)
static

Save cert_pub_mem with public certificate.

Parameters
[in]dataThe DER or PEM encoded certificate.

Definition at line 204 of file serverutils.c.

205{
206 g_free (cert_pub_mem);
207 cert_pub_mem = g_strdup (data);
208}

References cert_pub_mem.

Referenced by gvm_server_open_verify().

Here is the caller graph for this function:

◆ set_gnutls_dhparams()

int set_gnutls_dhparams ( gnutls_certificate_credentials_t creds,
const char * dhparams_file )

Set a gnutls session's Diffie-Hellman parameters.

Parameters
[in]credsGnuTLS credentials.
[in]dhparams_filePath to PEM file containing the DH parameters.
Returns
0 on success, -1 on error.

Definition at line 1228 of file serverutils.c.

1230{
1231 int ret;
1232 gnutls_datum_t data;
1233
1234 if (!creds || !dhparams_file)
1235 return -1;
1236
1237 if (load_gnutls_file (dhparams_file, &data))
1238 return -1;
1239
1240/* Disable false positive warning about potential leak of memory */
1241#ifndef __clang_analyzer__
1242
1243 gnutls_dh_params_t params = g_malloc0 (sizeof (gnutls_dh_params_t));
1244 ret = gnutls_dh_params_import_pkcs3 (params, &data, GNUTLS_X509_FMT_PEM);
1245 unload_gnutls_file (&data);
1246 if (ret)
1247 {
1248 g_free (params);
1249 return -1;
1250 }
1251 else
1252 gnutls_certificate_set_dh_params (creds, params);
1253 return 0;
1254
1255#endif
1256}
int load_gnutls_file(const char *file, gnutls_datum_t *loaded_file)
Loads a file's data into gnutls_datum_t struct.
void unload_gnutls_file(gnutls_datum_t *data)
Unloads a gnutls_datum_t struct's data.

References load_gnutls_file(), and unload_gnutls_file().

Referenced by gvm_server_session_free().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ unix_vsendf_internal()

int unix_vsendf_internal ( int socket,
const char * fmt,
va_list ap,
int quiet )
static

Send a string to the server.

Parameters
[in]socketSocket.
[in]fmtFormat of string to send.
[in]apArgs for fmt.
[in]quietWhether to log debug and info messages. Useful for hiding passwords.
Returns
0 on success, 1 if server closed connection, -1 on error.

Definition at line 657 of file serverutils.c.

658{
659 char *string_start, *string;
660 int rc = 0, left;
661
662 left = vasprintf (&string, fmt, ap);
663 if (left == -1)
664 string = NULL;
665
666 string_start = string;
667 while (left > 0)
668 {
669 ssize_t count;
670
671 if (quiet == 0)
672 g_debug (" send %d from %.*s[...]", left, left < 30 ? left : 30,
673 string);
674 count = write (socket, string, left);
675 if (count < 0)
676 {
677 if (errno == EINTR || errno == EAGAIN)
678 continue;
679 g_warning ("Failed to write to server: %s", strerror (errno));
680 rc = -1;
681 goto out;
682 }
683 if (quiet == 0)
684 g_debug ("=> %.*s", (int) count, string);
685
686 string += count;
687 left -= count;
688 }
689 if (quiet == 0)
690 g_debug ("=> done");
691
692out:
693 g_free (string_start);
694 return rc;
695}

Referenced by gvm_connection_vsendf_internal(), and gvm_socket_vsendf().

Here is the caller graph for this function:

◆ unload_gnutls_file()

void unload_gnutls_file ( gnutls_datum_t * data)

Unloads a gnutls_datum_t struct's data.

Parameters
[in]dataPointer to gnutls_datum_t struct to be unloaded.

Definition at line 189 of file serverutils.c.

190{
191 if (data)
192 g_free (data->data);
193}

Referenced by gvm_server_session_free(), and set_gnutls_dhparams().

Here is the caller graph for this function:

Variable Documentation

◆ cert_priv_mem

char* cert_priv_mem = NULL
static

Definition at line 196 of file serverutils.c.

Referenced by get_cert_priv_mem(), and set_cert_priv_mem().

◆ cert_pub_mem

char* cert_pub_mem = NULL
static

Definition at line 195 of file serverutils.c.

Referenced by get_cert_pub_mem(), and set_cert_pub_mem().