r23779: Change from v2 or later to v3 or later.
[jra/samba/.git] / source3 / utils / net.h
index 5e65ca0d4cdfbf17956b885c9468fd30f670ee2e..f3a43700d5b20907296d32da3af197be476004ff 100644 (file)
@@ -5,7 +5,7 @@
 
    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 2 of the License, or
+   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,
    along with this program; if not, write to the Free Software
    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
 
-#include "utils/net_proto.h"
-#define NET_FLAGS_MASTER 1
-#define NET_FLAGS_DMB 2
+/* 
+ * A function of this type is passed to the '
+ * run_rpc_command' wrapper.  Must go before the net_proto.h 
+ * include
+ */
+
+typedef NTSTATUS (*rpc_command_fn)(const DOM_SID *,
+                               const char *, 
+                               struct cli_state *cli,
+                               struct rpc_pipe_client *,
+                               TALLOC_CTX *,
+                               int,
+                               const char **);
 
-/* Would it be insane to set 'localhost' as the default
-   remote host for this operation? 
+typedef struct copy_clistate {
+       TALLOC_CTX *mem_ctx;
+       struct cli_state *cli_share_src;
+       struct cli_state *cli_share_dst;
+       char *cwd;
+       uint16 attribute;
+}copy_clistate;
 
-   For example, localhost is insane for a 'join' operation.
-*/
-#define NET_FLAGS_LOCALHOST_DEFAULT_INSANE 4 
+struct rpc_sh_ctx {
+       struct cli_state *cli;
 
-/* We want to find the PDC only */
-#define NET_FLAGS_PDC 8 
+       DOM_SID *domain_sid;
+       char *domain_name;
 
-/* We want an anonymous connection */
-#define NET_FLAGS_ANONYMOUS 16 
+       const char *whoami;
+       const char *thiscmd;
+       struct rpc_sh_cmd *cmds;
+       struct rpc_sh_ctx *parent;
+};
 
-/* don't open an RPC pipe */
-#define NET_FLAGS_NO_PIPE 32
+struct rpc_sh_cmd {
+       const char *name;
+       struct rpc_sh_cmd *(*sub)(TALLOC_CTX *mem_ctx,
+                                 struct rpc_sh_ctx *ctx);
+       int pipe_idx;
+       NTSTATUS (*fn)(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 "libmsrpc.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 */
+
+/* net share operation modes */
+#define NET_MODE_SHARE_MIGRATE 1
 
 extern int opt_maxusers;
 extern const char *opt_comment;
@@ -67,9 +114,23 @@ extern int opt_attrs;
 extern int opt_timestamps;
 extern const char *opt_exclude;
 extern const char *opt_destination;
+extern BOOL opt_testmode;
 
 extern BOOL opt_have_ip;
 extern struct in_addr opt_dest_ip;
 
 extern const char *share_type[];
 
+/* Structure for mapping accounts to groups */
+/* Array element is the group rid */
+typedef struct _groupmap {
+       uint32 rid;
+       uint32 gidNumber;
+       fstring sambaSID;
+       fstring group_dn;
+} GROUPMAP;
+
+typedef struct _accountmap {
+       uint32 rid;
+       fstring cn;
+} ACCOUNTMAP;