aboutsummaryrefslogtreecommitdiff
path: root/socket-sucker.c
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2012-08-30 08:12:48 +0000
committerTarmac <Unknown>2012-08-30 08:12:48 +0000
commit357bbd20197f7708ee8a6961f7cb1ed2669d5f1a (patch)
tree68008a85702e841141662d78ae3d51a44c38179f /socket-sucker.c
parent94a390dfea5dca700af213639e1071d72c2123a5 (diff)
parentff6a857303006d1e9e2c920c39cf3a1bca30871f (diff)
downloadlightdm-remote-session-freerdp2-357bbd20197f7708ee8a6961f7cb1ed2669d5f1a.tar.gz
lightdm-remote-session-freerdp2-357bbd20197f7708ee8a6961f7cb1ed2669d5f1a.tar.bz2
lightdm-remote-session-freerdp2-357bbd20197f7708ee8a6961f7cb1ed2669d5f1a.zip
Checking return values and enabling PIE to increase security. Fixes: https://bugs.launchpad.net/bugs/1039636. Approved by Albert Astals Cid, jenkins.
Diffstat (limited to 'socket-sucker.c')
-rw-r--r--socket-sucker.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/socket-sucker.c b/socket-sucker.c
index 7a1e82f..35424a6 100644
--- a/socket-sucker.c
+++ b/socket-sucker.c
@@ -41,7 +41,12 @@ main (int argc, char * argv[])
}
serv_addr.sun_family = AF_UNIX;
- snprintf(serv_addr.sun_path, sizeof(serv_addr.sun_path), "%s/%s", home, ".freerdp-socket");
+
+ int printsize = snprintf(serv_addr.sun_path, sizeof(serv_addr.sun_path) - 1, "%s/%s", home, ".freerdp-socket");
+ if (printsize > sizeof(serv_addr.sun_path) - 1 || printsize < 0) {
+ return -1;
+ }
+
servlen = strlen(serv_addr.sun_path) + sizeof(serv_addr.sun_family);
if ((socket_fd = socket(AF_UNIX, SOCK_STREAM, 0)) < 0) {
@@ -57,11 +62,14 @@ main (int argc, char * argv[])
int out = 0;
in = read(socket_fd, buffer, BUFFER_SIZE);
- out = write(1, buffer, in);
+
+ if (in > 0) {
+ out = write(1, buffer, in);
+ }
close(socket_fd);
- if (in == 0) {
+ if (in > 0 && out > 0) {
return 0;
} else {
return -1;