| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| #ifndef GUAC_COMMON_SSH_H |
| #define GUAC_COMMON_SSH_H |
| |
| #include "guac_ssh_user.h" |
| |
| #include <guacamole/client.h> |
| #include <libssh2.h> |
| |
| /** |
| * An SSH session, backed by libssh2 and associated with a particular |
| * Guacamole client. |
| */ |
| typedef struct guac_common_ssh_session { |
| |
| /** |
| * The Guacamole client using this SSH session. |
| */ |
| guac_client* client; |
| |
| /** |
| * The user that will be authenticating via SSH. |
| */ |
| guac_common_ssh_user* user; |
| |
| /** |
| * The underlying SSH session from libssh2. |
| */ |
| LIBSSH2_SESSION* session; |
| |
| /** |
| * The file descriptor of the socket being used for the SSH connection. |
| */ |
| int fd; |
| |
| } guac_common_ssh_session; |
| |
| /** |
| * Initializes the underlying SSH and encryption libraries used by Guacamole. |
| * This function must be called before any other guac_common_ssh_*() functions |
| * are called. |
| * |
| * @param client |
| * The Guacamole client that will be using SSH. |
| * |
| * @return |
| * Zero if initialization, or non-zero if an error occurs. |
| */ |
| int guac_common_ssh_init(guac_client* client); |
| |
| /** |
| * Cleans up the underlying SSH and encryption libraries used by Guacamole. |
| * This function must be called once no other guac_common_ssh_*() functions |
| * will be used. |
| */ |
| void guac_common_ssh_uninit(); |
| |
| /** |
| * Connects to the SSH server running at the given hostname and port, and |
| * authenticates as the given user. If an error occurs while connecting or |
| * authenticating, the Guacamole client will automatically and fatally abort. |
| * The user object provided must eventually be explicitly destroyed, but should |
| * not be destroyed until this session is destroyed, assuming the session is |
| * successfully created. |
| * |
| * @param client |
| * The Guacamole client that will be using SSH. |
| * |
| * @param hostname |
| * The hostname of the SSH server to connect to. |
| * |
| * @param port |
| * The port to connect to on the given hostname. |
| * |
| * @param user |
| * The user to authenticate as, once connected. |
| * |
| * @return |
| * A new SSH session if the connection and authentication succeed, or NULL |
| * if the connection or authentication were not successful. |
| */ |
| guac_common_ssh_session* guac_common_ssh_create_session(guac_client* client, |
| const char* hostname, const char* port, guac_common_ssh_user* user); |
| |
| /** |
| * Disconnects and destroys the given SSH session, freeing all associated |
| * resources. Any associated user must be explicitly destroyed, and will not |
| * be destroyed automatically. |
| * |
| * @param session |
| * The SSH session to destroy. |
| */ |
| void guac_common_ssh_destroy_session(guac_common_ssh_session* session); |
| |
| #endif |
| |