libssh  0.8.3
The SSH library
channels.h
1 /*
2  * This file is part of the SSH Library
3  *
4  * Copyright (c) 2009 by Aris Adamantiadis
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 #ifndef CHANNELS_H_
22 #define CHANNELS_H_
23 #include "libssh/priv.h"
24 
29 enum ssh_channel_request_state_e {
31  SSH_CHANNEL_REQ_STATE_NONE = 0,
33  SSH_CHANNEL_REQ_STATE_PENDING,
35  SSH_CHANNEL_REQ_STATE_ACCEPTED,
37  SSH_CHANNEL_REQ_STATE_DENIED,
39  SSH_CHANNEL_REQ_STATE_ERROR
40 };
41 
42 enum ssh_channel_state_e {
43  SSH_CHANNEL_STATE_NOT_OPEN = 0,
44  SSH_CHANNEL_STATE_OPENING,
45  SSH_CHANNEL_STATE_OPEN_DENIED,
46  SSH_CHANNEL_STATE_OPEN,
47  SSH_CHANNEL_STATE_CLOSED
48 };
49 
50 /* The channel has been closed by the remote side */
51 #define SSH_CHANNEL_FLAG_CLOSED_REMOTE 0x1
52 /* The channel has been freed by the calling program */
53 #define SSH_CHANNEL_FLAG_FREED_LOCAL 0x2
54 /* the channel has not yet been bound to a remote one */
55 #define SSH_CHANNEL_FLAG_NOT_BOUND 0x4
56 
58  ssh_session session; /* SSH_SESSION pointer */
59  uint32_t local_channel;
60  uint32_t local_window;
61  int local_eof;
62  uint32_t local_maxpacket;
63 
64  uint32_t remote_channel;
65  uint32_t remote_window;
66  int remote_eof; /* end of file received */
67  uint32_t remote_maxpacket;
68  enum ssh_channel_state_e state;
69  int delayed_close;
70  int flags;
71  ssh_buffer stdout_buffer;
72  ssh_buffer stderr_buffer;
73  void *userarg;
74  int exit_status;
75  enum ssh_channel_request_state_e request_state;
76  struct ssh_list *callbacks; /* list of ssh_channel_callbacks */
77 
78  /* counters */
79  ssh_counter counter;
80 };
81 
82 SSH_PACKET_CALLBACK(ssh_packet_channel_open_conf);
83 SSH_PACKET_CALLBACK(ssh_packet_channel_open_fail);
84 SSH_PACKET_CALLBACK(ssh_packet_channel_success);
85 SSH_PACKET_CALLBACK(ssh_packet_channel_failure);
86 SSH_PACKET_CALLBACK(ssh_request_success);
87 SSH_PACKET_CALLBACK(ssh_request_denied);
88 
89 SSH_PACKET_CALLBACK(channel_rcv_change_window);
90 SSH_PACKET_CALLBACK(channel_rcv_eof);
91 SSH_PACKET_CALLBACK(channel_rcv_close);
92 SSH_PACKET_CALLBACK(channel_rcv_request);
93 SSH_PACKET_CALLBACK(channel_rcv_data);
94 
96 int channel_default_bufferize(ssh_channel channel, void *data, int len,
97  int is_stderr);
98 int ssh_channel_flush(ssh_channel channel);
99 uint32_t ssh_channel_new_id(ssh_session session);
100 ssh_channel ssh_channel_from_local(ssh_session session, uint32_t id);
101 void ssh_channel_do_free(ssh_channel channel);
102 
103 #endif /* CHANNELS_H_ */
Definition: channels.h:57
Definition: session.h:102
Definition: misc.h:38
ssh_channel ssh_channel_new(ssh_session session)
Allocate a new channel.
Definition: channels.c:79
#define SSH_PACKET_CALLBACK(name)
This macro declares a packet callback handler.
Definition: callbacks.h:527
Definition: buffer.c:47
Definition: libssh.h:108