Skip to content

Commit

Permalink
Minor refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
nviennot committed Nov 10, 2019
1 parent bfa3c10 commit 7e02dba
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 19 deletions.
38 changes: 20 additions & 18 deletions tmate-ssh-client.c
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,6 @@ static void on_ssh_auth_server_complete(struct tmate_ssh_client *connected_clien
if (client == connected_client)
continue;

assert(!client->has_encoder);
kill_ssh_client(client, NULL);
}
}
Expand Down Expand Up @@ -177,7 +176,9 @@ static void tune_socket_opts(int fd)
#define SSO(level, optname, val) ({ \
int _flag = val; \
if (setsockopt(fd, level, optname, &(_flag), sizeof(int)) < 0) { \
tmate_info("setsockopt(" #level ", " #optname ", %d) failed", val); \
/* If the connection has been closed, we'll get EINVAL */ \
if (errno != EINVAL) \
tmate_info("setsockopt(" #level ", " #optname ", %d) failed %s", val, strerror(errno)); \
} \
})

Expand Down Expand Up @@ -249,23 +250,11 @@ static void init_conn_fd(struct tmate_ssh_client *client)

static void on_ssh_client_event(struct tmate_ssh_client *client)
{
char *identity;
ssh_key pubkey;
enum ssh_keytypes_e key_type;
unsigned char *hash;
ssize_t hash_len;
char *hash_str;
const char *server_hash_str;
int match;

int verbosity = SSH_LOG_NOLOG + log_get_level();
int port = options_get_number(global_options, "tmate-server-port");

ssh_session session = client->session;
ssh_channel channel = client->channel;

switch (client->state) {
case SSH_INIT:
case SSH_INIT: {
client->session = session = ssh_new();
if (!session) {
tmate_fatal("cannot ssh_new()");
Expand All @@ -274,13 +263,17 @@ static void on_ssh_client_event(struct tmate_ssh_client *client)

ssh_set_callbacks(session, &client->ssh_callbacks);

int verbosity = SSH_LOG_NOLOG + log_get_level();
int port = options_get_number(global_options, "tmate-server-port");

ssh_set_blocking(session, 0);
ssh_options_set(session, SSH_OPTIONS_HOST, client->server_ip);
ssh_options_set(session, SSH_OPTIONS_LOG_VERBOSITY, &verbosity);
ssh_options_set(session, SSH_OPTIONS_PORT, &port);
ssh_options_set(session, SSH_OPTIONS_USER, "tmate");
ssh_options_set(session, SSH_OPTIONS_COMPRESSION, "yes");

char *identity;
if ((identity = get_identity())) {
/*
* FIXME libssh will continue with the next set of
Expand All @@ -295,7 +288,8 @@ static void on_ssh_client_event(struct tmate_ssh_client *client)
}

client->state = SSH_CONNECT;
// fall through
}
// fall through

case SSH_CONNECT:
switch (ssh_connect(session)) {
Expand All @@ -314,7 +308,15 @@ static void on_ssh_client_event(struct tmate_ssh_client *client)
}
// fall through

case SSH_AUTH_SERVER:
case SSH_AUTH_SERVER: {
ssh_key pubkey;
enum ssh_keytypes_e key_type;
unsigned char *hash;
ssize_t hash_len;
char *hash_str;
const char *server_hash_str;
int match;

#if LIBSSH_VERSION_INT >= SSH_VERSION_INT(0, 9, 0)
if (ssh_get_server_publickey(session, &pubkey) < 0)
tmate_fatal("ssh_get_server_publickey");
Expand Down Expand Up @@ -379,6 +381,7 @@ static void on_ssh_client_event(struct tmate_ssh_client *client)
on_ssh_auth_server_complete(client);

client->state = SSH_AUTH_CLIENT_NONE;
}
// fall through

case SSH_AUTH_CLIENT_NONE:
Expand Down Expand Up @@ -573,7 +576,6 @@ struct tmate_ssh_client *tmate_ssh_client_alloc(struct tmate_session *session,
client->state = SSH_NONE;
client->session = NULL;
client->channel = NULL;
client->has_encoder = 0;

return client;
}
1 change: 0 additions & 1 deletion tmate.h
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,6 @@ struct tmate_ssh_client {

char *server_ip;

int has_encoder;
int state;

/*
Expand Down

0 comments on commit 7e02dba

Please sign in to comment.