mirror of
https://github.com/PowerShell/Win32-OpenSSH.git
synced 2025-10-24 17:24:01 +02:00
Removed more unsupported code in sshd.exe
This commit is contained in:
parent
c346800d8c
commit
31c7448e63
@ -7,4 +7,8 @@
|
|||||||
#define WIFSIGNALED(w) (!WIFEXITED(w) && !WIFSTOPPED(w))
|
#define WIFSIGNALED(w) (!WIFEXITED(w) && !WIFSTOPPED(w))
|
||||||
#define WEXITSTATUS(w) (int)(WIFEXITED(w) ? ((_W_INT(w) >> 8) & 0377) : -1)
|
#define WEXITSTATUS(w) (int)(WIFEXITED(w) ? ((_W_INT(w) >> 8) & 0377) : -1)
|
||||||
#define WTERMSIG(w) (int)(WIFSIGNALED(w) ? (_W_INT(w) & 0177) : -1)
|
#define WTERMSIG(w) (int)(WIFSIGNALED(w) ? (_W_INT(w) & 0177) : -1)
|
||||||
|
|
||||||
|
/* wait pid options */
|
||||||
|
#define WNOHANG 1
|
||||||
|
|
||||||
pid_t waitpid(pid_t pid, int *status, int options);
|
pid_t waitpid(pid_t pid, int *status, int options);
|
76
ssh.c
76
ssh.c
@ -118,9 +118,6 @@
|
|||||||
|
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
extern HANDLE proxy_command_handle;
|
|
||||||
extern DWORD proxy_command_pid;
|
|
||||||
|
|
||||||
char dotsshdir[MAX_PATH];
|
char dotsshdir[MAX_PATH];
|
||||||
|
|
||||||
#endif /* WIN32_FIXME */
|
#endif /* WIN32_FIXME */
|
||||||
@ -249,49 +246,6 @@ tilde_expand_paths(char **paths, u_int num_paths)
|
|||||||
|
|
||||||
#ifdef WIN32_FIXME
|
#ifdef WIN32_FIXME
|
||||||
|
|
||||||
/*
|
|
||||||
* This function send CTRL_BREAK_EVENT (equivalent of SIGINT) to
|
|
||||||
* child proxy process.
|
|
||||||
*
|
|
||||||
* If process still alive terminates it.
|
|
||||||
*/
|
|
||||||
|
|
||||||
static void CleanUpProxyProcess()
|
|
||||||
{
|
|
||||||
if (proxy_command_handle)
|
|
||||||
{
|
|
||||||
if (GenerateConsoleCtrlEvent(CTRL_BREAK_EVENT, proxy_command_pid) == FALSE)
|
|
||||||
{
|
|
||||||
debug("ERROR. Cannot send exit signal to childs (%u).",
|
|
||||||
(unsigned int) GetLastError());
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Try wait up to 100 ms until proxy process finished.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (WaitForSingleObject(proxy_command_handle, 100) == WAIT_TIMEOUT)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* If still not closed, kill proxy process.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (TerminateProcess(proxy_command_handle, 1) == TRUE)
|
|
||||||
{
|
|
||||||
debug("Process %u terminated.", (unsigned int) proxy_command_pid);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
debug("ERROR. Cannot terminate proxy process (pid = %u).",
|
|
||||||
(unsigned int) proxy_command_pid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
CloseHandle(proxy_command_handle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
extern Buffer stdin_buffer; /* Buffer for stdin data. */
|
|
||||||
/*
|
/*
|
||||||
* This function handles exit signal.
|
* This function handles exit signal.
|
||||||
*/
|
*/
|
||||||
@ -325,10 +279,6 @@ BOOL WINAPI CtrlHandlerRoutine(DWORD dwCtrlType)
|
|||||||
|
|
||||||
debug("Exit signal received...");
|
debug("Exit signal received...");
|
||||||
|
|
||||||
CleanUpProxyProcess();
|
|
||||||
|
|
||||||
UninitMitKerberos();
|
|
||||||
|
|
||||||
cleanup_exit(0);
|
cleanup_exit(0);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -1473,10 +1423,8 @@ main(int ac, char **av)
|
|||||||
options.num_system_hostfiles);
|
options.num_system_hostfiles);
|
||||||
tilde_expand_paths(options.user_hostfiles, options.num_user_hostfiles);
|
tilde_expand_paths(options.user_hostfiles, options.num_user_hostfiles);
|
||||||
|
|
||||||
#ifndef WIN32_FIXME
|
|
||||||
signal(SIGPIPE, SIG_IGN); /* ignore SIGPIPE early */
|
signal(SIGPIPE, SIG_IGN); /* ignore SIGPIPE early */
|
||||||
signal(SIGCHLD, main_sigchld_handler);
|
signal(SIGCHLD, main_sigchld_handler);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Log into the remote system. Never returns if the login fails. */
|
/* Log into the remote system. Never returns if the login fails. */
|
||||||
ssh_login(&sensitive_data, host, (struct sockaddr *)&hostaddr,
|
ssh_login(&sensitive_data, host, (struct sockaddr *)&hostaddr,
|
||||||
@ -1533,20 +1481,14 @@ main(int ac, char **av)
|
|||||||
* Windows specific Cleanup.
|
* Windows specific Cleanup.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef WIN32_FIXME
|
#ifdef WIN32_FIXME
|
||||||
|
|
||||||
if (tty_flag)
|
if (tty_flag)
|
||||||
ConUnInitWithRestore(); // restore terminal to previous settings if it was a tty session
|
ConUnInitWithRestore(); // restore terminal to previous settings if it was a tty session
|
||||||
|
#endif
|
||||||
CleanUpProxyProcess();
|
|
||||||
|
|
||||||
UninitMitKerberos();
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
/* Kill ProxyCommand if it is running. */
|
/* Kill ProxyCommand if it is running. */
|
||||||
ssh_kill_proxy_command();
|
ssh_kill_proxy_command();
|
||||||
#endif
|
|
||||||
|
|
||||||
return exit_status;
|
return exit_status;
|
||||||
}
|
}
|
||||||
@ -1554,7 +1496,7 @@ main(int ac, char **av)
|
|||||||
static void
|
static void
|
||||||
control_persist_detach(void)
|
control_persist_detach(void)
|
||||||
{
|
{
|
||||||
#ifndef WIN32_FIXME
|
#ifndef WIN32_FIXME//R
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
int devnull;
|
int devnull;
|
||||||
|
|
||||||
@ -1595,6 +1537,8 @@ control_persist_detach(void)
|
|||||||
}
|
}
|
||||||
daemon(1, 1);
|
daemon(1, 1);
|
||||||
setproctitle("%s [mux]", options.control_path);
|
setproctitle("%s [mux]", options.control_path);
|
||||||
|
#else
|
||||||
|
fatal("not supported in Windows");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2037,13 +1981,6 @@ ssh_session2_open(void)
|
|||||||
window >>= 1;
|
window >>= 1;
|
||||||
packetmax >>= 1;
|
packetmax >>= 1;
|
||||||
}
|
}
|
||||||
#ifdef WIN32_FIXME
|
|
||||||
else {
|
|
||||||
// make stdio duplicated ports of above binary mode so no CRLF xlate
|
|
||||||
//_setmode(sfd_to_fd(in), O_BINARY);
|
|
||||||
//_setmode(sfd_to_fd(out), O_BINARY);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
c = channel_new(
|
c = channel_new(
|
||||||
"session", SSH_CHANNEL_OPENING, in, out, err,
|
"session", SSH_CHANNEL_OPENING, in, out, err,
|
||||||
@ -2250,7 +2187,6 @@ load_public_identity_files(void)
|
|||||||
free(pwdir);
|
free(pwdir);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef WIN32_FIXME
|
|
||||||
static void
|
static void
|
||||||
main_sigchld_handler(int sig)
|
main_sigchld_handler(int sig)
|
||||||
{
|
{
|
||||||
@ -2265,6 +2201,6 @@ main_sigchld_handler(int sig)
|
|||||||
signal(sig, main_sigchld_handler);
|
signal(sig, main_sigchld_handler);
|
||||||
errno = save_errno;
|
errno = save_errno;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -74,14 +74,10 @@ static int matching_host_key_dns = 0;
|
|||||||
|
|
||||||
#ifdef WIN32_FIXME
|
#ifdef WIN32_FIXME
|
||||||
#define FAIL(X) if (X) goto fail
|
#define FAIL(X) if (X) goto fail
|
||||||
|
|
||||||
HANDLE proxy_command_handle = NULL;
|
|
||||||
DWORD proxy_command_pid = 0;
|
|
||||||
|
|
||||||
#else
|
|
||||||
static pid_t proxy_command_pid = 0;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static pid_t proxy_command_pid = 0;
|
||||||
|
|
||||||
/* import */
|
/* import */
|
||||||
extern Options options;
|
extern Options options;
|
||||||
extern char *__progname;
|
extern char *__progname;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user