1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-22 22:04:08 +03:00

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

754 lines
18 KiB
C
Raw Normal View History

/*
Unix SMB/CIFS implementation.
RPC pipe client
Copyright (C) Günther Deschner 2015
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/>.
*/
#include "includes.h"
#include "rpcclient.h"
#include "../librpc/gen_ndr/ndr_clusapi_c.h"
static WERROR cmd_clusapi_open_cluster(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
struct policy_handle Cluster;
status = dcerpc_clusapi_OpenCluster(b, mem_ctx,
&error,
&Cluster);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("successfully opened cluster\n");
status = dcerpc_clusapi_CloseCluster(b, mem_ctx,
&Cluster,
&error);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("successfully closed cluster\n");
return WERR_OK;
}
static WERROR cmd_clusapi_get_cluster_name(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
const char *ClusterName;
const char *NodeName;
status = dcerpc_clusapi_GetClusterName(b, mem_ctx,
&ClusterName,
&NodeName,
&error);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("ClusterName: %s\n", ClusterName);
printf("NodeName: %s\n", NodeName);
return WERR_OK;
}
static WERROR cmd_clusapi_get_cluster_version(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
uint16_t lpwMajorVersion;
uint16_t lpwMinorVersion;
uint16_t lpwBuildNumber;
const char *lpszVendorId;
const char *lpszCSDVersion;
status = dcerpc_clusapi_GetClusterVersion(b, mem_ctx,
&lpwMajorVersion,
&lpwMinorVersion,
&lpwBuildNumber,
&lpszVendorId,
&lpszCSDVersion,
&error);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("lpwMajorVersion: %d\n", lpwMajorVersion);
printf("lpwMinorVersion: %d\n", lpwMinorVersion);
printf("lpwBuildNumber: %d\n", lpwBuildNumber);
printf("lpszVendorId: %s\n", lpszVendorId);
printf("lpszCSDVersion: %s\n", lpszCSDVersion);
return WERR_OK;
}
static WERROR cmd_clusapi_get_quorum_resource(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
const char *lpszResourceName;
const char *lpszDeviceName;
uint32_t pdwMaxQuorumLogSize;
WERROR rpc_status;
status = dcerpc_clusapi_GetQuorumResource(b, mem_ctx,
&lpszResourceName,
&lpszDeviceName,
&pdwMaxQuorumLogSize,
&rpc_status,
&error);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("lpszResourceName: %s\n", lpszResourceName);
printf("lpszDeviceName: %s\n", lpszDeviceName);
printf("pdwMaxQuorumLogSize: %d\n", pdwMaxQuorumLogSize);
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_create_enum(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
uint32_t dwType = 1;
struct ENUM_LIST *ReturnEnum;
WERROR rpc_status;
if (argc >= 2) {
sscanf(argv[1],"%x",&dwType);
}
status = dcerpc_clusapi_CreateEnum(b, mem_ctx,
dwType,
&ReturnEnum,
&rpc_status,
&error);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_create_enumex(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
WERROR error;
uint32_t dwType = 1;
struct ENUM_LIST *ReturnIdEnum;
struct ENUM_LIST *ReturnNameEnum;
WERROR rpc_status, ignore;
struct policy_handle Cluster;
status = dcerpc_clusapi_OpenCluster(b, mem_ctx,
&error,
&Cluster);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
if (argc >= 2) {
sscanf(argv[1],"%x",&dwType);
}
status = dcerpc_clusapi_CreateEnumEx(b, mem_ctx,
Cluster,
dwType,
0,
&ReturnIdEnum,
&ReturnNameEnum,
&rpc_status,
&error);
dcerpc_clusapi_CloseCluster(b, mem_ctx,
&Cluster,
&ignore);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(error)) {
printf("error: %s\n", win_errstr(error));
return error;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_open_resource(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszResourceName = "Cluster Name";
WERROR Status;
struct policy_handle hResource;
WERROR rpc_status, ignore;
if (argc >= 2) {
lpszResourceName = argv[1];
}
status = dcerpc_clusapi_OpenResource(b, mem_ctx,
lpszResourceName,
&Status,
&rpc_status,
&hResource);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
dcerpc_clusapi_CloseResource(b, mem_ctx,
&hResource,
&ignore);
return WERR_OK;
}
static WERROR cmd_clusapi_online_resource(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszResourceName = "Cluster Name";
WERROR Status;
struct policy_handle hResource;
WERROR rpc_status, ignore;
if (argc >= 2) {
lpszResourceName = argv[1];
}
status = dcerpc_clusapi_OpenResource(b, mem_ctx,
lpszResourceName,
&Status,
&rpc_status,
&hResource);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
status = dcerpc_clusapi_OnlineResource(b, mem_ctx,
hResource,
&Status,
&rpc_status);
dcerpc_clusapi_CloseResource(b, mem_ctx,
&hResource,
&ignore);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_offline_resource(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszResourceName = "Cluster Name";
WERROR Status;
struct policy_handle hResource;
WERROR rpc_status, ignore;
if (argc >= 2) {
lpszResourceName = argv[1];
}
status = dcerpc_clusapi_OpenResource(b, mem_ctx,
lpszResourceName,
&Status,
&rpc_status,
&hResource);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
status = dcerpc_clusapi_OfflineResource(b, mem_ctx,
hResource,
&Status,
&rpc_status);
dcerpc_clusapi_CloseResource(b, mem_ctx,
&hResource,
&ignore);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_get_resource_state(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszResourceName = "Cluster Name";
WERROR Status;
struct policy_handle hResource;
WERROR rpc_status;
enum clusapi_ClusterResourceState State;
const char *NodeName;
const char *GroupName;
WERROR result, ignore;
if (argc >= 2) {
lpszResourceName = argv[1];
}
status = dcerpc_clusapi_OpenResource(b, mem_ctx,
lpszResourceName,
&Status,
&rpc_status,
&hResource);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
status = dcerpc_clusapi_GetResourceState(b, mem_ctx,
hResource,
&State,
&NodeName,
&GroupName,
&rpc_status,
&result);
dcerpc_clusapi_CloseResource(b, mem_ctx,
&hResource,
&ignore);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Status: %s\n", win_errstr(Status));
return Status;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_get_cluster_version2(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
uint16_t lpwMajorVersion;
uint16_t lpwMinorVersion;
uint16_t lpwBuildNumber;
const char *lpszVendorId;
const char *lpszCSDVersion;
struct CLUSTER_OPERATIONAL_VERSION_INFO *ppClusterOpVerInfo;
WERROR rpc_status;
WERROR result;
status = dcerpc_clusapi_GetClusterVersion2(b, mem_ctx,
&lpwMajorVersion,
&lpwMinorVersion,
&lpwBuildNumber,
&lpszVendorId,
&lpszCSDVersion,
&ppClusterOpVerInfo,
&rpc_status,
&result);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(result)) {
printf("result: %s\n", win_errstr(result));
return result;
}
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_pause_node(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszNodeName = "CTDB_NODE_0";
WERROR Status;
struct policy_handle hNode;
WERROR rpc_status;
WERROR result, ignore;
if (argc >= 2) {
lpszNodeName = argv[1];
}
status = dcerpc_clusapi_OpenNode(b, mem_ctx,
lpszNodeName,
&Status,
&rpc_status,
&hNode);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Failed to open node %s\n", lpszNodeName);
printf("Status: %s\n", win_errstr(Status));
return Status;
}
status = dcerpc_clusapi_PauseNode(b, mem_ctx,
hNode,
&rpc_status,
&result);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(result)) {
printf("Failed to pause node %s\n", lpszNodeName);
printf("Status: %s\n", win_errstr(result));
return result;
}
dcerpc_clusapi_CloseNode(b, mem_ctx,
&hNode,
&ignore);
printf("Cluster node %s has been paused\n", lpszNodeName);
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
static WERROR cmd_clusapi_resume_node(struct rpc_pipe_client *cli,
TALLOC_CTX *mem_ctx,
int argc,
const char **argv)
{
struct dcerpc_binding_handle *b = cli->binding_handle;
NTSTATUS status;
const char *lpszNodeName = "CTDB_NODE_0";
WERROR Status;
struct policy_handle hNode;
WERROR rpc_status;
WERROR result, ignore;
if (argc >= 2) {
lpszNodeName = argv[1];
}
status = dcerpc_clusapi_OpenNode(b, mem_ctx,
lpszNodeName,
&Status,
&rpc_status,
&hNode);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(Status)) {
printf("Failed to open node %s\n", lpszNodeName);
printf("Status: %s\n", win_errstr(Status));
return Status;
}
status = dcerpc_clusapi_ResumeNode(b, mem_ctx,
hNode,
&rpc_status,
&result);
if (!NT_STATUS_IS_OK(status)) {
return ntstatus_to_werror(status);
}
if (!W_ERROR_IS_OK(result)) {
printf("Failed to resume node %s\n", lpszNodeName);
printf("Status: %s\n", win_errstr(result));
return result;
}
dcerpc_clusapi_CloseNode(b, mem_ctx,
&hNode,
&ignore);
printf("Cluster node %s has been resumed\n", lpszNodeName);
printf("rpc_status: %s\n", win_errstr(rpc_status));
return WERR_OK;
}
struct cmd_set clusapi_commands[] = {
{
.name = "CLUSAPI",
},
{
.name = "clusapi_open_cluster",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_open_cluster,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Open cluster",
.usage = "",
},
{
.name = "clusapi_get_cluster_name",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_get_cluster_name,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Get cluster name",
.usage = "",
},
{
.name = "clusapi_get_cluster_version",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_get_cluster_version,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Get cluster version",
.usage = "",
},
{
.name = "clusapi_get_quorum_resource",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_get_quorum_resource,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Get quorum resource",
.usage = "",
},
{
.name = "clusapi_create_enum",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_create_enum,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Create enum query",
.usage = "",
},
{
.name = "clusapi_create_enumex",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_create_enumex,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Create enumex query",
.usage = "",
},
{
.name = "clusapi_open_resource",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_open_resource,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Open cluster resource",
.usage = "",
},
{
.name = "clusapi_online_resource",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_online_resource,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Set cluster resource online",
.usage = "",
},
{
.name = "clusapi_offline_resource",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_offline_resource,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Set cluster resource offline",
.usage = "",
},
{
.name = "clusapi_get_resource_state",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_get_resource_state,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Get cluster resource state",
.usage = "",
},
{
.name = "clusapi_get_cluster_version2",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_get_cluster_version2,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Get cluster version2",
.usage = "",
},
{
.name = "clusapi_pause_node",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_pause_node,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Pause cluster node",
.usage = "",
},
{
.name = "clusapi_resume_node",
.returntype = RPC_RTYPE_WERROR,
.ntfn = NULL,
.wfn = cmd_clusapi_resume_node,
.table = &ndr_table_clusapi,
.rpc_pipe = NULL,
.description = "Resume cluster node",
.usage = "",
},
{
.name = NULL,
},
};