2 Unix SMB/CIFS implementation.
4 SMB composite request interfaces
6 Copyright (C) Andrew Tridgell 2005
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
23 this defines the structures associated with "composite"
24 requests. Composite requests are libcli requests that are internally
25 implemented as multiple libcli/raw/ calls, but can be treated as a
26 single call via these composite calls. The composite calls are
27 particularly designed to be used in async applications
30 #include "libcli/raw/signing.h"
31 #include "libcli/raw/libcliraw.h"
32 #include "libcli/smb2/smb2.h"
36 a composite open/read(s)/close request that loads a whole file
37 into memory. Used as a demo of the composite system.
39 struct smb_composite_loadfile
{
49 struct smb_composite_fetchfile
{
51 const char *dest_host
;
53 const char *called_name
;
55 const char *service_type
;
56 const char *socket_options
;
57 struct cli_credentials
*credentials
;
58 const char *workgroup
;
60 struct smbcli_options options
;
61 struct smbcli_session_options session_options
;
62 struct resolve_context
*resolve_ctx
;
63 struct smb_iconv_convenience
*iconv_convenience
;
64 struct gensec_settings
*gensec_settings
;
73 a composite open/write(s)/close request that saves a whole file from
74 memory. Used as a demo of the composite system.
76 struct smb_composite_savefile
{
86 a composite request for a full connection to a remote server. Includes
88 - socket establishment
91 - session setup (if credentials are not NULL)
92 - tree connect (if service is not NULL)
94 struct smb_composite_connect
{
96 const char *dest_host
;
97 const char **dest_ports
;
98 const char *socket_options
;
99 const char *called_name
;
101 const char *service_type
;
102 struct cli_credentials
*credentials
;
103 bool fallback_to_anonymous
;
104 const char *workgroup
;
105 struct smbcli_options options
;
106 struct smbcli_session_options session_options
;
107 struct smb_iconv_convenience
*iconv_convenience
;
108 struct gensec_settings
*gensec_settings
;
111 struct smbcli_tree
*tree
;
112 bool anonymous_fallback_done
;
118 generic session setup interface that takes care of which
119 session setup varient to use
121 struct smb_composite_sesssetup
{
124 uint32_t capabilities
;
125 struct cli_credentials
*credentials
;
126 const char *workgroup
;
127 struct gensec_settings
*gensec_settings
;
135 query file system info
137 struct smb_composite_fsinfo
{
139 const char *dest_host
;
140 const char **dest_ports
;
141 const char *socket_options
;
142 const char *called_name
;
144 const char *service_type
;
145 struct cli_credentials
*credentials
;
146 const char *workgroup
;
147 enum smb_fsinfo_level level
;
148 struct smb_iconv_convenience
*iconv_convenience
;
149 struct gensec_settings
*gensec_settings
;
153 union smb_fsinfo
*fsinfo
;
158 composite call for appending new acl to the file's security descriptor and get
162 struct smb_composite_appendacl
{
166 const struct security_descriptor
*sd
;
170 struct security_descriptor
*sd
;
175 a composite API to fire connect() calls to multiple targets, picking the
179 struct smb_composite_connectmulti
{
182 const char **hostnames
;
183 const char **addresses
;
184 int *ports
; /* Either NULL for lp_smb_ports() per
185 * destination or a list of explicit ports */
188 struct smbcli_socket
*socket
;
192 struct smbcli_session
;
193 struct resolve_context
;
195 #include "libcli/smb_composite/proto.h"