1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
--- src/scanner.c.orig 2016-11-10 09:58:06 UTC
+++ src/scanner.c
@@ -33,6 +33,7 @@
#include <assert.h>
#include <unistd.h>
#include <sys/types.h>
+#include <sys/socket.h>
#include <sys/time.h>
#include <sys/stat.h>
#include <sys/un.h>
@@ -586,7 +587,6 @@ int
openvas_scanner_connect_unix ()
{
struct sockaddr_un addr;
- int len;
openvas_scanner_socket = socket (AF_UNIX, SOCK_STREAM, 0);
if (openvas_scanner_socket == -1)
@@ -596,10 +596,12 @@ openvas_scanner_connect_unix ()
return -1;
}
+ memset(&addr, 0, sizeof(struct sockaddr_un));
+
addr.sun_family = AF_UNIX;
- strncpy (addr.sun_path, openvas_scanner_unix_path, 108);
- len = strlen (addr.sun_path) + sizeof (addr.sun_family);
- if (connect (openvas_scanner_socket, (struct sockaddr *) &addr, len) == -1)
+ strlcpy(addr.sun_path, openvas_scanner_unix_path, sizeof(addr.sun_path));
+
+ if (connect (openvas_scanner_socket, (struct sockaddr *) &addr, SUN_LEN(&addr)) == -1)
{
g_warning ("%s: Failed to connect to scanner (%s): %s\n", __FUNCTION__,
openvas_scanner_unix_path, strerror (errno));
|