// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "sandbox/win/sandbox_poc/pocdll/exports.h" #include "sandbox/win/sandbox_poc/pocdll/utils.h" // This file contains the tests used to verify the security of the network. void POCDLL_API TestNetworkListen(HANDLE log) { HandleToFile handle2file; FILE *output = handle2file.Translate(log, "w"); #if DONT_WANT_INTERCEPTIONS_JUST_WANT_NETWORK // Initialize Winsock WSADATA wsa_data; int result = ::WSAStartup(MAKEWORD(2, 2), &wsa_data); if (result != NO_ERROR) { fprintf(output, "[ERROR] Cannot initialize winsock. Error%d\r\n", result); return; } // Create a SOCKET for listening for // incoming connection requests. SOCKET listen_socket; listen_socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (listen_socket == INVALID_SOCKET) { fprintf(output, "[ERROR] Failed to create socket. Error %ld\r\n", ::WSAGetLastError()); ::WSACleanup(); return; } // The sockaddr_in structure specifies the address family, // IP address, and port for the socket that is being bound. sockaddr_in service; service.sin_family = AF_INET; service.sin_addr.s_addr = inet_addr("127.0.0.1"); service.sin_port = htons(88); if (bind(listen_socket, reinterpret_cast(&service), sizeof(service)) == SOCKET_ERROR) { fprintf(output, "[BLOCKED] Bind socket on port 88. Error %ld\r\n", ::WSAGetLastError()); closesocket(listen_socket); ::WSACleanup(); return; } // Listen for incoming connection requests // on the created socket if (listen(listen_socket, SOMAXCONN) == SOCKET_ERROR) { fprintf(output, "[BLOCKED] Listen socket on port 88. Error %ld\r\n", ::WSAGetLastError()); } else { fprintf(output, "[GRANTED] Listen socket on port 88.\r\n", ::WSAGetLastError()); } ::WSACleanup(); return; #else // DONT_WANT_INTERCEPTIONS_JUST_WANT_NETWORK // Just print out that this test is not running. fprintf(output, "[ERROR] No network tests.\r\n"); #endif // DONT_WANT_INTERCEPTIONS_JUST_WANT_NETWORK }