1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
|
/*
Samba Unix/Linux SMB client library
Distributed SMB/CIFS Server Management Utility
Copyright (C) 2001 Andrew Bartlett (abartlet@samba.org)
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>. */
/*
* A function of this type is passed to the '
* run_rpc_command' wrapper. Must go before the net_proto.h
* include
*/
struct cli_state;
#include "../librpc/gen_ndr/lsa.h"
#include "intl.h"
#ifdef HAVE_LIBINTL_H
#include <libintl.h>
#endif
#if defined(HAVE_GETTEXT) && !defined(__LCLINT__)
#define _(foo) gettext(foo)
#else
#define _(foo) foo
#endif
#define MODULE_NAME "net"
struct net_context {
const char *opt_requester_name;
const char *opt_host;
const char *opt_password;
const char *opt_user_name;
bool opt_user_specified;
const char *opt_workgroup;
int opt_long_list_entries;
int opt_reboot;
int opt_force;
int opt_stdin;
int opt_port;
int opt_verbose;
int opt_maxusers;
const char *opt_comment;
const char *opt_container;
int opt_flags;
int opt_timeout;
int opt_request_timeout;
const char *opt_target_workgroup;
int opt_machine_pass;
int opt_localgroup;
int opt_domaingroup;
int do_talloc_report;
const char *opt_newntname;
int opt_rid;
int opt_acls;
int opt_attrs;
int opt_timestamps;
const char *opt_exclude;
const char *opt_destination;
int opt_testmode;
int opt_kerberos;
int opt_force_full_repl;
int opt_ccache;
int opt_single_obj_repl;
int opt_clean_old_entries;
const char *opt_db;
int opt_lock;
int opt_auto;
int opt_repair;
int opt_reg_version;
const char *opt_output;
int opt_wipe;
const char *opt_precheck;
int opt_no_dns_updates;
int opt_keep_account;
int opt_json;
int opt_continue_on_error;
int opt_recursive;
int opt_follow_symlink;
int opt_have_ip;
struct sockaddr_storage opt_dest_ip;
bool smb_encrypt;
struct libnetapi_ctx *netapi_ctx;
struct messaging_context *msg_ctx;
struct netlogon_creds_cli_context *netlogon_creds;
struct cli_credentials *creds;
struct loadparm_context *lp_ctx;
bool display_usage;
void *private_data;
};
struct net_dc_info {
bool is_dc;
bool is_pdc;
bool is_ad;
bool is_mixed_mode;
const char *netbios_domain_name;
const char *dns_domain_name;
const char *forest_name;
};
#define NET_TRANSPORT_LOCAL 0x01
#define NET_TRANSPORT_RAP 0x02
#define NET_TRANSPORT_RPC 0x04
#define NET_TRANSPORT_ADS 0x08
struct functable {
const char *funcname;
int (*fn)(struct net_context *c, int argc, const char **argv);
int valid_transports;
const char *description;
const char *usage;
};
typedef NTSTATUS (*rpc_command_fn)(struct net_context *c,
const struct dom_sid *,
const char *,
struct cli_state *cli,
struct rpc_pipe_client *,
TALLOC_CTX *,
int,
const char **);
typedef struct copy_clistate {
TALLOC_CTX *mem_ctx;
struct cli_state *cli_share_src;
struct cli_state *cli_share_dst;
char *cwd;
uint16_t attribute;
struct net_context *c;
}copy_clistate;
struct rpc_sh_ctx {
struct cli_state *cli;
struct dom_sid *domain_sid;
const char *domain_name;
const char *whoami;
const char *thiscmd;
struct rpc_sh_cmd *cmds;
struct rpc_sh_ctx *parent;
};
struct rpc_sh_cmd {
const char *name;
struct rpc_sh_cmd *(*sub)(struct net_context *c,
TALLOC_CTX *mem_ctx,
struct rpc_sh_ctx *ctx);
const struct ndr_interface_table *table;
NTSTATUS (*fn)(struct net_context *c, TALLOC_CTX *mem_ctx,
struct rpc_sh_ctx *ctx,
struct rpc_pipe_client *pipe_hnd,
int argc, const char **argv);
const char *help;
};
enum netdom_domain_t { ND_TYPE_NT4, ND_TYPE_AD };
/* INCLUDE FILES */
#include "utils/net_proto.h"
#include "utils/net_help_common.h"
/* MACROS & DEFINES */
#define NET_FLAGS_MASTER 0x00000001
#define NET_FLAGS_DMB 0x00000002
#define NET_FLAGS_LOCALHOST_DEFAULT_INSANE 0x00000004 /* Would it be insane to set 'localhost'
as the default remote host for this
operation? For example, localhost
is insane for a 'join' operation. */
#define NET_FLAGS_PDC 0x00000008 /* PDC only */
#define NET_FLAGS_ANONYMOUS 0x00000010 /* use an anonymous connection */
#define NET_FLAGS_NO_PIPE 0x00000020 /* don't open an RPC pipe */
#define NET_FLAGS_SIGN 0x00000040 /* sign RPC connection */
#define NET_FLAGS_SEAL 0x00000080 /* seal RPC connection */
#define NET_FLAGS_TCP 0x00000100 /* use ncacn_ip_tcp */
#define NET_FLAGS_EXPECT_FALLBACK 0x00000200 /* the caller will fallback */
/* net share operation modes */
#define NET_MODE_SHARE_MIGRATE 1
|