source: vendor/3.6.0/source4/lib/socket/socket.h

Last change on this file was 740, checked in by Silvan Scherrer, 13 years ago

Samba Server: update vendor to 3.6.0

File size: 8.5 KB
Line 
1/*
2 Unix SMB/CIFS implementation.
3 Socket functions
4 Copyright (C) Stefan Metzmacher 2004
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
10
11 This program 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
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
18*/
19
20#ifndef _SAMBA_SOCKET_H
21#define _SAMBA_SOCKET_H
22
23struct tevent_context;
24struct tevent_fd;
25struct socket_context;
26
27enum socket_type {
28 SOCKET_TYPE_STREAM,
29 SOCKET_TYPE_DGRAM
30};
31
32struct socket_address {
33 const char *family;
34 char *addr;
35 int port;
36 struct sockaddr *sockaddr;
37 size_t sockaddrlen;
38};
39
40struct socket_ops {
41 const char *name;
42
43 NTSTATUS (*fn_init)(struct socket_context *sock);
44
45 /* client ops */
46 NTSTATUS (*fn_connect)(struct socket_context *sock,
47 const struct socket_address *my_address,
48 const struct socket_address *server_address,
49 uint32_t flags);
50
51 /* complete a non-blocking connect */
52 NTSTATUS (*fn_connect_complete)(struct socket_context *sock,
53 uint32_t flags);
54
55 /* server ops */
56 NTSTATUS (*fn_listen)(struct socket_context *sock,
57 const struct socket_address *my_address,
58 int queue_size, uint32_t flags);
59 NTSTATUS (*fn_accept)(struct socket_context *sock,
60 struct socket_context **new_sock);
61
62 /* general ops */
63 NTSTATUS (*fn_recv)(struct socket_context *sock, void *buf,
64 size_t wantlen, size_t *nread);
65 NTSTATUS (*fn_send)(struct socket_context *sock,
66 const DATA_BLOB *blob, size_t *sendlen);
67
68 NTSTATUS (*fn_sendto)(struct socket_context *sock,
69 const DATA_BLOB *blob, size_t *sendlen,
70 const struct socket_address *dest_addr);
71 NTSTATUS (*fn_recvfrom)(struct socket_context *sock,
72 void *buf, size_t wantlen, size_t *nread,
73 TALLOC_CTX *addr_ctx, struct socket_address **src_addr);
74 NTSTATUS (*fn_pending)(struct socket_context *sock, size_t *npending);
75
76 void (*fn_close)(struct socket_context *sock);
77
78 NTSTATUS (*fn_set_option)(struct socket_context *sock, const char *option, const char *val);
79
80 char *(*fn_get_peer_name)(struct socket_context *sock, TALLOC_CTX *mem_ctx);
81 struct socket_address *(*fn_get_peer_addr)(struct socket_context *sock, TALLOC_CTX *mem_ctx);
82 struct socket_address *(*fn_get_my_addr)(struct socket_context *sock, TALLOC_CTX *mem_ctx);
83
84 int (*fn_get_fd)(struct socket_context *sock);
85};
86
87enum socket_state {
88 SOCKET_STATE_UNDEFINED,
89
90 SOCKET_STATE_CLIENT_START,
91 SOCKET_STATE_CLIENT_CONNECTED,
92 SOCKET_STATE_CLIENT_STARTTLS,
93 SOCKET_STATE_CLIENT_ERROR,
94
95 SOCKET_STATE_SERVER_LISTEN,
96 SOCKET_STATE_SERVER_CONNECTED,
97 SOCKET_STATE_SERVER_STARTTLS,
98 SOCKET_STATE_SERVER_ERROR
99};
100
101#define SOCKET_FLAG_BLOCK 0x00000001
102#define SOCKET_FLAG_PEEK 0x00000002
103#define SOCKET_FLAG_TESTNONBLOCK 0x00000004
104#define SOCKET_FLAG_ENCRYPT 0x00000008 /* This socket
105 * implementation requires
106 * that re-sends be
107 * consistant, because it
108 * is encrypting data.
109 * This modifies the
110 * TESTNONBLOCK case */
111#define SOCKET_FLAG_NOCLOSE 0x00000010 /* don't auto-close on free */
112
113
114struct socket_context {
115 enum socket_type type;
116 enum socket_state state;
117 uint32_t flags;
118
119 int fd;
120
121 void *private_data;
122 const struct socket_ops *ops;
123 const char *backend_name;
124
125 /* specific to the ip backend */
126 int family;
127};
128
129struct resolve_context;
130struct tsocket_address;
131
132/* prototypes */
133NTSTATUS socket_create_with_ops(TALLOC_CTX *mem_ctx, const struct socket_ops *ops,
134 struct socket_context **new_sock,
135 enum socket_type type, uint32_t flags);
136NTSTATUS socket_create(const char *name, enum socket_type type,
137 struct socket_context **new_sock, uint32_t flags);
138NTSTATUS socket_connect(struct socket_context *sock,
139 const struct socket_address *my_address,
140 const struct socket_address *server_address,
141 uint32_t flags);
142NTSTATUS socket_connect_complete(struct socket_context *sock, uint32_t flags);
143NTSTATUS socket_listen(struct socket_context *sock,
144 const struct socket_address *my_address,
145 int queue_size, uint32_t flags);
146NTSTATUS socket_accept(struct socket_context *sock, struct socket_context **new_sock);
147NTSTATUS socket_recv(struct socket_context *sock, void *buf,
148 size_t wantlen, size_t *nread);
149NTSTATUS socket_recvfrom(struct socket_context *sock, void *buf,
150 size_t wantlen, size_t *nread,
151 TALLOC_CTX *addr_ctx, struct socket_address **src_addr);
152NTSTATUS socket_send(struct socket_context *sock,
153 const DATA_BLOB *blob, size_t *sendlen);
154NTSTATUS socket_sendto(struct socket_context *sock,
155 const DATA_BLOB *blob, size_t *sendlen,
156 const struct socket_address *dest_addr);
157NTSTATUS socket_pending(struct socket_context *sock, size_t *npending);
158NTSTATUS socket_set_option(struct socket_context *sock, const char *option, const char *val);
159char *socket_get_peer_name(struct socket_context *sock, TALLOC_CTX *mem_ctx);
160struct socket_address *socket_get_peer_addr(struct socket_context *sock, TALLOC_CTX *mem_ctx);
161struct socket_address *socket_get_my_addr(struct socket_context *sock, TALLOC_CTX *mem_ctx);
162struct tsocket_address *socket_address_to_tsocket_address(TALLOC_CTX *mem_ctx,
163 const struct socket_address *a);
164struct socket_address *tsocket_address_to_socket_address(TALLOC_CTX *mem_ctx,
165 const struct tsocket_address *a);
166struct tsocket_address *socket_get_remote_addr(struct socket_context *sock, TALLOC_CTX *mem_ctx);
167struct tsocket_address *socket_get_local_addr(struct socket_context *sock, TALLOC_CTX *mem_ctx);
168int socket_get_fd(struct socket_context *sock);
169NTSTATUS socket_dup(struct socket_context *sock);
170struct socket_address *socket_address_from_strings(TALLOC_CTX *mem_ctx,
171 const char *type,
172 const char *host,
173 int port);
174struct socket_address *socket_address_from_sockaddr(TALLOC_CTX *mem_ctx,
175 struct sockaddr *sockaddr,
176 size_t addrlen);
177_PUBLIC_ void socket_address_set_port(struct socket_address *a,
178 uint16_t port);
179struct socket_address *socket_address_copy(TALLOC_CTX *mem_ctx,
180 const struct socket_address *oaddr);
181const struct socket_ops *socket_getops_byname(const char *name, enum socket_type type);
182bool allow_access(TALLOC_CTX *mem_ctx,
183 const char **deny_list, const char **allow_list,
184 const char *cname, const char *caddr);
185bool socket_check_access(struct socket_context *sock,
186 const char *service_name,
187 const char **allow_list, const char **deny_list);
188
189struct composite_context *socket_connect_send(struct socket_context *sock,
190 struct socket_address *my_address,
191 struct socket_address *server_address,
192 uint32_t flags,
193 struct tevent_context *event_ctx);
194NTSTATUS socket_connect_recv(struct composite_context *ctx);
195NTSTATUS socket_connect_ev(struct socket_context *sock,
196 struct socket_address *my_address,
197 struct socket_address *server_address,
198 uint32_t flags,
199 struct tevent_context *ev);
200
201struct composite_context *socket_connect_multi_send(TALLOC_CTX *mem_ctx,
202 const char *server_address,
203 int num_server_ports,
204 uint16_t *server_ports,
205 struct resolve_context *resolve_ctx,
206 struct tevent_context *event_ctx);
207NTSTATUS socket_connect_multi_recv(struct composite_context *ctx,
208 TALLOC_CTX *mem_ctx,
209 struct socket_context **result,
210 uint16_t *port);
211NTSTATUS socket_connect_multi(TALLOC_CTX *mem_ctx, const char *server_address,
212 int num_server_ports, uint16_t *server_ports,
213 struct resolve_context *resolve_ctx,
214 struct tevent_context *event_ctx,
215 struct socket_context **result,
216 uint16_t *port);
217void set_socket_options(int fd, const char *options);
218void socket_set_flags(struct socket_context *sock, unsigned flags);
219
220void socket_tevent_fd_close_fn(struct tevent_context *ev,
221 struct tevent_fd *fde,
222 int fd,
223 void *private_data);
224
225extern bool testnonblock;
226
227#endif /* _SAMBA_SOCKET_H */
Note: See TracBrowser for help on using the repository browser.