2015-02-26 12:57:53 +01:00
/*
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 ;
2015-03-02 20:52:59 +01:00
WERROR error ;
2015-02-26 12:57:53 +01:00
struct policy_handle Cluster ;
status = dcerpc_clusapi_OpenCluster ( b , mem_ctx ,
& error ,
& Cluster ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return ntstatus_to_werror ( status ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
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 ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
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 ;
2015-03-02 20:52:59 +01:00
WERROR error ;
2015-02-26 12:57:53 +01:00
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 ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
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 ;
2015-03-02 20:52:59 +01:00
WERROR error ;
2015-02-26 12:57:53 +01:00
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 ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
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 ;
2015-03-02 20:52:59 +01:00
WERROR error ;
2015-02-26 12:57:53 +01:00
const char * lpszResourceName ;
const char * lpszDeviceName ;
uint32_t pdwMaxQuorumLogSize ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-02-26 12:57:53 +01:00
status = dcerpc_clusapi_GetQuorumResource ( b , mem_ctx ,
& lpszResourceName ,
& lpszDeviceName ,
& pdwMaxQuorumLogSize ,
& rpc_status ,
& error ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return ntstatus_to_werror ( status ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
printf ( " lpszResourceName: %s \n " , lpszResourceName ) ;
printf ( " lpszDeviceName: %s \n " , lpszDeviceName ) ;
printf ( " pdwMaxQuorumLogSize: %d \n " , pdwMaxQuorumLogSize ) ;
2015-03-02 20:52:59 +01:00
printf ( " rpc_status: %s \n " , win_errstr ( rpc_status ) ) ;
2015-02-26 12:57:53 +01:00
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 ;
2015-03-02 20:52:59 +01:00
WERROR error ;
2015-02-26 12:57:53 +01:00
uint32_t dwType = 1 ;
struct ENUM_LIST * ReturnEnum ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-02-26 12:57:53 +01:00
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 ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( error ) ) {
printf ( " error: %s \n " , win_errstr ( error ) ) ;
return error ;
2015-02-26 12:57:53 +01:00
}
2015-03-02 20:52:59 +01:00
printf ( " rpc_status: %s \n " , win_errstr ( rpc_status ) ) ;
2015-02-26 12:57:53 +01:00
return WERR_OK ;
}
2015-07-17 11:39:52 +02:00
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 ;
}
2015-02-26 12:57:53 +01:00
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 " ;
2015-03-02 20:52:59 +01:00
WERROR Status ;
2015-02-26 12:57:53 +01:00
struct policy_handle hResource ;
2015-06-25 21:23:11 +02:00
WERROR rpc_status , ignore ;
2015-02-26 12:57:53 +01:00
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 ) ;
}
2015-03-02 20:52:59 +01:00
if ( ! W_ERROR_IS_OK ( Status ) ) {
printf ( " Status: %s \n " , win_errstr ( Status ) ) ;
return Status ;
2015-02-26 12:57:53 +01:00
}
2015-03-02 20:52:59 +01:00
printf ( " rpc_status: %s \n " , win_errstr ( rpc_status ) ) ;
2015-02-26 12:57:53 +01:00
2015-06-25 21:23:11 +02:00
dcerpc_clusapi_CloseResource ( b , mem_ctx ,
& hResource ,
& ignore ) ;
2015-02-26 12:57:53 +01:00
return WERR_OK ;
}
2015-06-25 15:08:14 +02:00
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 ;
}
2015-06-25 19:19:46 +02:00
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 ;
}
2015-06-25 15:08:14 +02:00
2015-07-09 15:56:44 +02:00
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 ;
}
2016-05-09 12:07:47 +02:00
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 ;
}
2016-05-09 12:10:22 +02:00
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 ;
}
2015-07-09 15:56:44 +02:00
2015-02-26 12:57:53 +01:00
struct cmd_set clusapi_commands [ ] = {
2019-01-09 16:31:51 +01:00
{
. name = " CLUSAPI " ,
} ,
{
. name = " clusapi_open_cluster " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_open_cluster ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Open cluster " ,
2019-01-09 16:31:51 +01:00
. 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 ,
2020-01-08 17:25:13 +01:00
. description = " Get cluster name " ,
2019-01-09 16:31:51 +01:00
. 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 ,
2020-01-08 17:25:13 +01:00
. description = " Get cluster version " ,
2019-01-09 16:31:51 +01:00
. 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 ,
2020-01-08 17:25:13 +01:00
. description = " Get quorum resource " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
{
. name = " clusapi_create_enum " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_create_enum ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Create enum query " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
{
. name = " clusapi_create_enumex " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_create_enumex ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Create enumex query " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
{
. name = " clusapi_open_resource " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_open_resource ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Open cluster resource " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
{
. name = " clusapi_online_resource " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_online_resource ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Set cluster resource online " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
{
. name = " clusapi_offline_resource " ,
. returntype = RPC_RTYPE_WERROR ,
. ntfn = NULL ,
. wfn = cmd_clusapi_offline_resource ,
. table = & ndr_table_clusapi ,
. rpc_pipe = NULL ,
2020-01-08 17:25:13 +01:00
. description = " Set cluster resource offline " ,
2019-01-09 16:31:51 +01:00
. 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 ,
2020-01-08 17:25:13 +01:00
. description = " Get cluster resource state " ,
2019-01-09 16:31:51 +01:00
. 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 ,
2020-01-08 17:25:13 +01:00
. description = " Get cluster version2 " ,
2019-01-09 16:31:51 +01:00
. usage = " " ,
} ,
2016-05-09 12:07:47 +02:00
{
. 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 = " " ,
} ,
2016-05-09 12:10:22 +02:00
{
. 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 = " " ,
} ,
2019-01-09 16:31:51 +01:00
{
. name = NULL ,
} ,
2015-02-26 12:57:53 +01:00
} ;