mirror of
https://github.com/samba-team/samba.git
synced 2024-12-24 21:34:56 +03:00
acc149c427
- ported two rpc back from TNG (WINREG: shutdown and abort shutdown)
- some optimizations and changed some DEBUG statement in loadparm.c
- changed rpcclient a bit moved from non reentrant next_token_nr to next_token
- in cmd_reg.c not sure if getopt will work ok on all platforms only setting optind=0
(This used to be commit fd54412ce9
)
333 lines
7.3 KiB
C
333 lines
7.3 KiB
C
/*
|
|
Unix SMB/Netbios implementation.
|
|
Version 2.2
|
|
RPC pipe client
|
|
|
|
Copyright (C) Tim Potter 2000
|
|
|
|
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
|
|
(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, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
#include "includes.h"
|
|
|
|
extern int DEBUGLEVEL;
|
|
extern pstring server;
|
|
|
|
/* Check DFS is supported by the remote server */
|
|
|
|
static uint32 cmd_dfs_exist(struct cli_state *cli, int argc, char **argv)
|
|
{
|
|
TALLOC_CTX *mem_ctx;
|
|
BOOL dfs_exists;
|
|
uint32 result;
|
|
|
|
if (argc != 1) {
|
|
printf("Usage: %s\n", argv[0]);
|
|
return 0;
|
|
}
|
|
|
|
if (!(mem_ctx = talloc_init())) {
|
|
DEBUG(0,("cmd_dfs_exist: talloc_init failed\n"));
|
|
return NT_STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/* Initialise RPC connection */
|
|
|
|
if (!cli_nt_session_open (cli, PIPE_NETDFS)) {
|
|
DEBUG(0, ("Could not initialize netdfs pipe!\n"));
|
|
result = NT_STATUS_UNSUCCESSFUL;
|
|
goto done;
|
|
}
|
|
|
|
result = cli_dfs_exist(cli, mem_ctx, &dfs_exists);
|
|
|
|
if (result == NT_STATUS_NOPROBLEMO)
|
|
printf("dfs is %spresent\n", dfs_exists ? "" : "not ");
|
|
|
|
cli_nt_session_close(cli);
|
|
|
|
done:
|
|
talloc_destroy(mem_ctx);
|
|
return result;
|
|
}
|
|
|
|
static uint32 cmd_dfs_add(struct cli_state *cli, int argc, char **argv)
|
|
{
|
|
TALLOC_CTX *mem_ctx;
|
|
uint32 result;
|
|
char *entrypath, *servername, *sharename, *comment;
|
|
uint32 flags = 0;
|
|
|
|
if (argc != 5) {
|
|
printf("Usage: %s entrypath servername sharename comment\n",
|
|
argv[0]);
|
|
return 0;
|
|
}
|
|
|
|
entrypath = argv[1];
|
|
servername = argv[2];
|
|
sharename = argv[3];
|
|
comment = argv[4];
|
|
|
|
if (!(mem_ctx = talloc_init())) {
|
|
DEBUG(0,("cmd_dfs_add: talloc_init failed\n"));
|
|
return NT_STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/* Initialise RPC connection */
|
|
|
|
if (!cli_nt_session_open (cli, PIPE_NETDFS)) {
|
|
DEBUG(0, ("Could not initialize netdfs pipe!\n"));
|
|
result = NT_STATUS_UNSUCCESSFUL;
|
|
goto done;
|
|
}
|
|
|
|
result = cli_dfs_add(cli, mem_ctx, entrypath, servername,
|
|
sharename, comment, flags);
|
|
|
|
cli_nt_session_close(cli);
|
|
|
|
done:
|
|
talloc_destroy(mem_ctx);
|
|
return result;
|
|
}
|
|
|
|
static uint32 cmd_dfs_remove(struct cli_state *cli, int argc, char **argv)
|
|
{
|
|
TALLOC_CTX *mem_ctx;
|
|
uint32 result;
|
|
char *entrypath, *servername, *sharename;
|
|
|
|
if (argc != 4) {
|
|
printf("Usage: %s entrypath servername sharename\n", argv[0]);
|
|
return 0;
|
|
}
|
|
|
|
entrypath = argv[1];
|
|
servername = argv[2];
|
|
sharename = argv[3];
|
|
|
|
if (!(mem_ctx = talloc_init())) {
|
|
DEBUG(0,("cmd_dfs_remove: talloc_init failed\n"));
|
|
return NT_STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/* Initialise RPC connection */
|
|
|
|
if (!cli_nt_session_open (cli, PIPE_NETDFS)) {
|
|
DEBUG(0, ("Could not initialize netdfs pipe!\n"));
|
|
result = NT_STATUS_UNSUCCESSFUL;
|
|
goto done;
|
|
}
|
|
|
|
result = cli_dfs_remove(cli, mem_ctx, entrypath, servername,
|
|
sharename);
|
|
|
|
cli_nt_session_close(cli);
|
|
|
|
done:
|
|
talloc_destroy(mem_ctx);
|
|
return result;
|
|
}
|
|
|
|
/* Display a DFS_INFO_1 structure */
|
|
|
|
static void display_dfs_info_1(DFS_INFO_1 *info1)
|
|
{
|
|
fstring temp;
|
|
|
|
unistr2_to_ascii(temp, &info1->entrypath, sizeof(temp) - 1);
|
|
printf("entrypath: %s\n", temp);
|
|
}
|
|
|
|
/* Display a DFS_INFO_2 structure */
|
|
|
|
static void display_dfs_info_2(DFS_INFO_2 *info2)
|
|
{
|
|
fstring temp;
|
|
|
|
unistr2_to_ascii(temp, &info2->entrypath, sizeof(temp) - 1);
|
|
printf("entrypath: %s\n", temp);
|
|
|
|
unistr2_to_ascii(temp, &info2->comment, sizeof(temp) - 1);
|
|
printf("\tcomment: %s\n", temp);
|
|
|
|
printf("\tstate: %d\n", info2->state);
|
|
printf("\tnum_storages: %d\n", info2->num_storages);
|
|
}
|
|
|
|
/* Display a DFS_INFO_3 structure */
|
|
|
|
static void display_dfs_info_3(DFS_INFO_3 *info3)
|
|
{
|
|
fstring temp;
|
|
int i;
|
|
|
|
unistr2_to_ascii(temp, &info3->entrypath, sizeof(temp) - 1);
|
|
printf("entrypath: %s\n", temp);
|
|
|
|
unistr2_to_ascii(temp, &info3->comment, sizeof(temp) - 1);
|
|
printf("\tcomment: %s\n", temp);
|
|
|
|
printf("\tstate: %d\n", info3->state);
|
|
printf("\tnum_storages: %d\n", info3->num_storages);
|
|
|
|
for (i = 0; i < info3->num_storages; i++) {
|
|
DFS_STORAGE_INFO *dsi = &info3->storages[i];
|
|
|
|
unistr2_to_ascii(temp, &dsi->servername, sizeof(temp) - 1);
|
|
printf("\t\tstorage[%d] servername: %s\n", i, temp);
|
|
|
|
unistr2_to_ascii(temp, &dsi->sharename, sizeof(temp) - 1);
|
|
printf("\t\tstorage[%d] sharename: %s\n", i, temp);
|
|
}
|
|
}
|
|
|
|
/* Display a DFS_INFO_CTR structure */
|
|
|
|
static void display_dfs_info_ctr(DFS_INFO_CTR *ctr)
|
|
{
|
|
int i;
|
|
|
|
for (i = 0; i < ctr->num_entries; i++) {
|
|
switch (ctr->switch_value) {
|
|
case 0x01:
|
|
display_dfs_info_1(&ctr->dfs.info1[i]);
|
|
break;
|
|
case 0x02:
|
|
display_dfs_info_2(&ctr->dfs.info2[i]);
|
|
break;
|
|
case 0x03:
|
|
display_dfs_info_3(&ctr->dfs.info3[i]);
|
|
break;
|
|
default:
|
|
printf("unsupported info level %d\n",
|
|
ctr->switch_value);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Enumerate dfs shares */
|
|
|
|
static uint32 cmd_dfs_enum(struct cli_state *cli, int argc, char **argv)
|
|
{
|
|
TALLOC_CTX *mem_ctx;
|
|
DFS_INFO_CTR ctr;
|
|
uint32 result, info_level = 1;
|
|
|
|
if (argc > 2) {
|
|
printf("Usage: %s [info_level]\n", argv[0]);
|
|
return 0;
|
|
}
|
|
|
|
if (argc == 2)
|
|
info_level = atoi(argv[1]);
|
|
|
|
if (!(mem_ctx = talloc_init())) {
|
|
DEBUG(0,("cmd_dfs_enum: talloc_init failed\n"));
|
|
return NT_STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/* Initialise RPC connection */
|
|
|
|
if (!cli_nt_session_open (cli, PIPE_NETDFS)) {
|
|
DEBUG(0, ("Could not initialize netdfs pipe!\n"));
|
|
result = NT_STATUS_UNSUCCESSFUL;
|
|
goto done;
|
|
}
|
|
|
|
/* Call RPC function */
|
|
|
|
if ((result = cli_dfs_enum(cli, mem_ctx, info_level, &ctr))
|
|
== NT_STATUS_NOPROBLEMO) {
|
|
|
|
/* Print results */
|
|
display_dfs_info_ctr(&ctr);
|
|
}
|
|
|
|
cli_nt_session_close(cli);
|
|
|
|
done:
|
|
talloc_destroy(mem_ctx);
|
|
return result;
|
|
}
|
|
|
|
static uint32 cmd_dfs_getinfo(struct cli_state *cli, int argc, char **argv)
|
|
{
|
|
TALLOC_CTX *mem_ctx;
|
|
uint32 result;
|
|
char *entrypath, *servername, *sharename;
|
|
uint32 info_level = 1;
|
|
DFS_INFO_CTR ctr;
|
|
|
|
if (argc < 4 || argc > 5) {
|
|
printf("Usage: %s entrypath servername sharename [info_level]\n", argv[0]);
|
|
return 0;
|
|
}
|
|
|
|
entrypath = argv[1];
|
|
servername = argv[2];
|
|
sharename = argv[3];
|
|
|
|
if (argc == 5)
|
|
info_level = atoi(argv[4]);
|
|
|
|
if (!(mem_ctx = talloc_init())) {
|
|
DEBUG(0,("cmd_dfs_getinfo: talloc_init failed\n"));
|
|
return NT_STATUS_UNSUCCESSFUL;
|
|
}
|
|
|
|
/* Initialise RPC connection */
|
|
|
|
if (!cli_nt_session_open (cli, PIPE_NETDFS)) {
|
|
DEBUG(0, ("Could not initialize netdfs pipe!\n"));
|
|
result = NT_STATUS_UNSUCCESSFUL;
|
|
goto done;
|
|
}
|
|
|
|
/* Call RPC function */
|
|
|
|
if ((result = cli_dfs_get_info(cli, mem_ctx, entrypath, servername,
|
|
sharename, info_level, &ctr))
|
|
== NT_STATUS_NOPROBLEMO) {
|
|
|
|
/* Print results */
|
|
|
|
display_dfs_info_ctr(&ctr);
|
|
}
|
|
|
|
cli_nt_session_close(cli);
|
|
|
|
done:
|
|
talloc_destroy(mem_ctx);
|
|
return result;
|
|
}
|
|
|
|
/* List of commands exported by this module */
|
|
|
|
struct cmd_set dfs_commands[] = {
|
|
|
|
{ "DFS" },
|
|
|
|
{ "dfsexist", cmd_dfs_exist, "Query DFS support", "" },
|
|
{ "dfsadd", cmd_dfs_add, "Add a DFS share", "" },
|
|
{ "dfsremove", cmd_dfs_remove, "Remove a DFS share", "" },
|
|
{ "dfsgetinfo", cmd_dfs_getinfo, "Query DFS share info", "" },
|
|
{ "dfsenum", cmd_dfs_enum, "Enumerate dfs shares", "" },
|
|
|
|
{ NULL }
|
|
};
|