a2e0eed4480b4ff78643364d516125c9456d0416
[samba.git] / nsswitch / libwbclient / wbc_async.h
1 /*
2    Unix SMB/CIFS implementation.
3    Headers for the async winbind client library
4    Copyright (C) Volker Lendecke 2008
5
6      ** NOTE! The following LGPL license applies to the wbclient
7      ** library. This does NOT imply that all of Samba is released
8      ** under the LGPL
9
10    This library is free software; you can redistribute it and/or
11    modify it under the terms of the GNU Lesser General Public
12    License as published by the Free Software Foundation; either
13    version 3 of the License, or (at your option) any later version.
14
15    This library is distributed in the hope that it will be useful,
16    but WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18    Library General Public License for more details.
19
20    You should have received a copy of the GNU Lesser General Public License
21    along with this program.  If not, see <http://www.gnu.org/licenses/>.
22 */
23
24 #ifndef _WBC_ASYNC_H_
25 #define _WBC_ASYNC_H_
26
27 #include <talloc.h>
28 #include <tevent.h>
29 #include "nsswitch/libwbclient/wbclient.h"
30
31 struct wb_context;
32 struct winbindd_request;
33 struct winbindd_response;
34
35 struct tevent_req *wb_trans_send(TALLOC_CTX *mem_ctx,
36                                  struct tevent_context *ev,
37                                  struct wb_context *wb_ctx, bool need_priv,
38                                  struct winbindd_request *wb_req);
39 wbcErr wb_trans_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
40                      struct winbindd_response **presponse);
41 struct wb_context *wb_context_init(TALLOC_CTX *mem_ctx);
42
43 /* Definitions from wb_reqtrans.c */
44 wbcErr map_wbc_err_from_errno(int error);
45
46 bool tevent_req_is_wbcerr(struct tevent_req *req, wbcErr *pwbc_err);
47 wbcErr tevent_req_simple_recv_wbcerr(struct tevent_req *req);
48
49 struct tevent_req *wb_req_read_send(TALLOC_CTX *mem_ctx,
50                                     struct tevent_context *ev,
51                                     int fd, size_t max_extra_data);
52 ssize_t wb_req_read_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
53                          struct winbindd_request **preq, int *err);
54
55 struct tevent_req *wb_req_write_send(TALLOC_CTX *mem_ctx,
56                                      struct tevent_context *ev,
57                                      struct tevent_queue *queue, int fd,
58                                      struct winbindd_request *wb_req);
59 ssize_t wb_req_write_recv(struct tevent_req *req, int *err);
60
61 struct tevent_req *wb_resp_read_send(TALLOC_CTX *mem_ctx,
62                                      struct tevent_context *ev, int fd);
63 ssize_t wb_resp_read_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
64                           struct winbindd_response **presp, int *err);
65
66 struct tevent_req *wb_resp_write_send(TALLOC_CTX *mem_ctx,
67                                       struct tevent_context *ev,
68                                       struct tevent_queue *queue, int fd,
69                                       struct winbindd_response *wb_resp);
70 ssize_t wb_resp_write_recv(struct tevent_req *req, int *err);
71
72 struct tevent_req *wb_simple_trans_send(TALLOC_CTX *mem_ctx,
73                                         struct tevent_context *ev,
74                                         struct tevent_queue *queue, int fd,
75                                         struct winbindd_request *wb_req);
76 int wb_simple_trans_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
77                          struct winbindd_response **presponse, int *err);
78
79 #endif /*_WBC_ASYNC_H_*/