2 Samba Unix/Linux SMB client library
4 Copyright (C) 2002 Jim McDonough (jmcd@us.ibm.com)
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 2 of the License, or
9 (at your option) any later version.
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.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #include "utils/net.h"
24 int net_common_methods_usage(int argc
, const char**argv
)
26 d_printf("Valid methods: (auto-detected if not specified)\n");
27 d_printf("\tads\t\t\t\tActive Directory (LDAP/Kerberos)\n");
28 d_printf("\trpc\t\t\t\tDCE-RPC\n");
29 d_printf("\trap\t\t\t\tRAP (older systems)\n");
34 int net_common_flags_usage(int argc
, const char **argv
)
36 d_printf("Valid targets: choose one (none defaults to localhost)\n");
37 d_printf("\t-S or --server=<server>\t\tserver name\n");
38 d_printf("\t-I or --ipaddress=<ipaddr>\taddress of target server\n");
39 d_printf("\t-w or --workgroup=<wg>\t\ttarget workgroup or domain\n");
42 d_printf("Valid miscellaneous options are:\n"); /* misc options */
43 d_printf("\t-p or --port=<port>\t\tconnection port on target\n");
44 d_printf("\t-W or --myworkgroup=<wg>\tclient workgroup\n");
45 d_printf("\t-d or --debuglevel=<level>\tdebug level (0-10)\n");
46 d_printf("\t-n or --myname=<name>\t\tclient name\n");
47 d_printf("\t-U or --user=<name>\t\tuser name\n");
48 d_printf("\t-s or --configfile=<path>\tpathname of smb.conf file\n");
49 d_printf("\t-l or --long\t\t\tDisplay full information\n");
50 d_printf("\t-V or --version\t\t\tPrint samba version information\n");
51 d_printf("\t-P or --machine-pass\t\tAuthenticate as machine account\n");
55 static int help_usage(int argc
, const char **argv
)
59 "Usage: net help <function>\n"\
61 "Valid functions are:\n"\
62 " RPC RAP ADS FILE SHARE SESSION SERVER DOMAIN PRINTQ USER GROUP VALIDATE\n"\
63 " GROUPMEMBER ADMIN SERVICE PASSWORD TIME LOOKUP GETLOCALSID SETLOCALSID\n"\
68 int net_help_user(int argc
, const char **argv
)
70 d_printf("\nnet [<method>] user [misc. options] [targets]"\
71 "\n\tList users\n\n");
72 d_printf("net [<method>] user DELETE <name> [misc. options] [targets]"\
73 "\n\tDelete specified user\n");
74 d_printf("\nnet [<method>] user INFO <name> [misc. options] [targets]"\
75 "\n\tList the domain groups of the specified user\n");
76 d_printf("\nnet [<method>] user ADD <name> [password] [-c container] "\
77 "[-F user flags] [misc. options]"\
78 " [targets]\n\tAdd specified user\n");
80 net_common_methods_usage(argc
, argv
);
81 net_common_flags_usage(argc
, argv
);
82 d_printf("\t-C or --comment=<comment>\tdescriptive comment (for add only)\n");
83 d_printf("\t-c or --container=<container>\tLDAP container, defaults to cn=Users (for add in ADS only)\n");
87 int net_help_group(int argc
, const char **argv
)
89 d_printf("net [<method>] group [misc. options] [targets]"\
90 "\n\tList user groups\n\n");
91 d_printf("net rpc group LIST [global|local|builtin]* [misc. options]"\
92 "\n\tList specific user groups\n\n");
93 d_printf("net [<method>] group DELETE <name> "\
94 "[misc. options] [targets]"\
95 "\n\tDelete specified group\n");
96 d_printf("\nnet [<method>] group ADD <name> [-C comment] [-c container]"\
97 " [misc. options] [targets]\n\tCreate specified group\n");
98 d_printf("\nnet rpc group MEMBERS <name>\n\tList Group Members\n\n");
99 net_common_methods_usage(argc
, argv
);
100 net_common_flags_usage(argc
, argv
);
101 d_printf("\t-C or --comment=<comment>\tdescriptive comment (for add only)\n");
102 d_printf("\t-c or --container=<container>\tLDAP container, defaults to cn=Users (for add in ADS only)\n");
106 int net_help_join(int argc
, const char **argv
)
108 d_printf("\nnet [<method>] join [misc. options]\n"
109 "\tjoins this server to a domain\n");
110 d_printf("Valid methods: (auto-detected if not specified)\n");
111 d_printf("\tads\t\t\t\tActive Directory (LDAP/Kerberos)\n");
112 d_printf("\trpc\t\t\t\tDCE-RPC\n");
113 net_common_flags_usage(argc
, argv
);
117 int net_help_share(int argc
, const char **argv
)
120 "\nnet [<method>] share [misc. options] [targets] \n"
121 "\tenumerates all exported resources (network shares) "
122 "on target server\n\n"
123 "net [<method>] share ADD <name=serverpath> [misc. options] [targets]"
124 "\n\tadds a share from a server (makes the export active)\n\n"
125 "net [<method>] share DELETE <sharename> [misc. options] [targets]"
126 "\n\tdeletes a share from a server (makes the export inactive)\n\n"
127 "net [<method>] share ALLOWEDUSERS [<filename>] "
128 "[misc. options] [targets]"
129 "\n\tshows a list of all shares together with all users allowed to"
130 "\n\taccess them. This needs the output of 'net usersidlist' on"
131 "\n\tstdin or in <filename>.\n"
132 "net [<method>] share MIGRATE FILES <sharename> [misc. options] [targets]"
133 "\n\tMigrates files from remote to local server\n\n"
134 "net [<method>] share MIGRATE SHARES <sharename> [misc. options] [targets]"
135 "\n\tMigrates shares from remote to local server\n\n"
136 /* "net [<method>] share MIGRATE SECURITY <sharename> [misc. options] [targets]"
137 "\n\tMigrates share-ACLs from remote to local server\n\n" */
138 "net [<method>] share MIGRATE ALL <sharename> [misc. options] [targets]"
139 "\n\tMigrates shares (including directories, files) from remote\n"
140 "\tto local server\n\n"
142 net_common_methods_usage(argc
, argv
);
143 net_common_flags_usage(argc
, argv
);
145 "\t-C or --comment=<comment>\tdescriptive comment (for add only)\n"
146 "\t-M or --maxusers=<num>\t\tmax users allowed for share\n"
147 "\t --acls\t\t\tcopies ACLs as well\n"
148 "\t --attrs\t\t\tcopies DOS Attributes as well\n"
149 "\t --timestampes\t\tpreserve timestampes while copying files\n"
150 "\t --destination\t\tmigration target server (default: localhost)\n"
151 "\t-e or --exclude\t\t\tlist of shares to be excluded from mirroring\n"
152 "\t-v or --verbose\t\t\tgive verbose output\n");
156 int net_help_file(int argc
, const char **argv
)
158 d_printf("net [<method>] file [misc. options] [targets]\n"\
159 "\tlists all open files on file server\n\n");
160 d_printf("net [<method>] file USER <username> "\
161 "[misc. options] [targets]"\
162 "\n\tlists all files opened by username on file server\n\n");
163 d_printf("net [<method>] file CLOSE <id> [misc. options] [targets]\n"\
164 "\tcloses specified file on target server\n\n");
165 d_printf("net [rap] file INFO <id> [misc. options] [targets]\n"\
166 "\tdisplays information about the specified open file\n");
168 net_common_methods_usage(argc
, argv
);
169 net_common_flags_usage(argc
, argv
);
173 int net_help_printer(int argc
, const char **argv
)
175 d_printf("net rpc printer LIST [printer] [misc. options] [targets]\n"\
176 "\tlists all printers on print-server\n\n");
177 d_printf("net rpc printer DRIVER [printer] [misc. options] [targets]\n"\
178 "\tlists all printer-drivers on print-server\n\n");
179 d_printf("net rpc printer PUBLISH action [printer] [misc. options] [targets]\n"\
180 "\tpublishes printer settings in Active Directory\n"
181 "\taction can be one of PUBLISH, UPDATE, UNPUBLISH or LIST\n\n");
182 d_printf("net rpc printer MIGRATE PRINTERS [printer] [misc. options] [targets]"\
183 "\n\tmigrates printers from remote to local server\n\n");
184 d_printf("net rpc printer MIGRATE SETTINGS [printer] [misc. options] [targets]"\
185 "\n\tmigrates printer-settings from remote to local server\n\n");
186 d_printf("net rpc printer MIGRATE DRIVERS [printer] [misc. options] [targets]"\
187 "\n\tmigrates printer-drivers from remote to local server\n\n");
188 d_printf("net rpc printer MIGRATE FORMS [printer] [misc. options] [targets]"\
189 "\n\tmigrates printer-forms from remote to local server\n\n");
190 d_printf("net rpc printer MIGRATE SECURITY [printer] [misc. options] [targets]"\
191 "\n\tmigrates printer-ACLs from remote to local server\n\n");
192 d_printf("net rpc printer MIGRATE ALL [printer] [misc. options] [targets]"\
193 "\n\tmigrates drivers, forms, queues, settings and acls from\n"\
194 "\tremote to local print-server\n\n");
195 net_common_methods_usage(argc
, argv
);
196 net_common_flags_usage(argc
, argv
);
198 "\t-v or --verbose\t\t\tgive verbose output\n"
199 "\t --destination\t\tmigration target server (default: localhost)\n");
205 int net_help_status(int argc
, const char **argv
)
207 d_printf(" net status sessions [parseable] "
208 "Show list of open sessions\n");
209 d_printf(" net status shares [parseable] "
210 "Show list of open shares\n");
214 static int net_usage(int argc
, const char **argv
)
216 d_printf(" net time\t\tto view or set time information\n"\
217 " net lookup\t\tto lookup host name or ip address\n"\
218 " net user\t\tto manage users\n"\
219 " net group\t\tto manage groups\n"\
220 " net groupmap\t\tto manage group mappings\n"\
221 " net join\t\tto join a domain\n"\
222 " net cache\t\tto operate on cache tdb file\n"\
223 " net getlocalsid [NAME]\tto get the SID for local name\n"\
224 " net setlocalsid SID\tto set the local domain SID\n"\
225 " net changesecretpw\tto change the machine password in the local secrets database only\n"\
226 " \tthis requires the -f flag as a safety barrier\n"\
227 " net status\t\tShow server status\n"\
228 " net usersidlist\tto get a list of all users with their SIDs\n"
230 " net ads <command>\tto run ADS commands\n"\
231 " net rap <command>\tto run RAP (pre-RPC) commands\n"\
232 " net rpc <command>\tto run RPC commands\n"\
234 "Type \"net help <option>\" to get more information on that option\n");
235 net_common_flags_usage(argc
, argv
);
240 handle "net help *" subcommands
242 int net_help(int argc
, const char **argv
)
244 struct functable func
[] = {
245 {"ADS", net_ads_help
},
246 {"RAP", net_rap_help
},
247 {"RPC", net_rpc_help
},
249 {"FILE", net_help_file
},
250 {"SHARE", net_help_share
},
251 {"SESSION", net_rap_session_usage
},
252 {"SERVER", net_rap_server_usage
},
253 {"DOMAIN", net_rap_domain_usage
},
254 {"PRINTQ", net_rap_printq_usage
},
255 {"USER", net_help_user
},
256 {"GROUP", net_help_group
},
257 {"GROUPMAP", net_help_groupmap
},
258 {"JOIN", net_help_join
},
259 {"VALIDATE", net_rap_validate_usage
},
260 {"GROUPMEMBER", net_rap_groupmember_usage
},
261 {"ADMIN", net_rap_admin_usage
},
262 {"SERVICE", net_rap_service_usage
},
263 {"PASSWORD", net_rap_password_usage
},
264 {"TIME", net_time_usage
},
265 {"LOOKUP", net_lookup_usage
},
266 {"USERSIDLIST", net_usersidlist_usage
},
267 #ifdef WITH_FAKE_KASERVER
268 {"AFSKEY", net_afskey_usage
},
271 {"HELP", help_usage
},
274 return net_run_function(argc
, argv
, func
, net_usage
);