ha/service-mgmt/sm/src/sm_service_group_standby_state.c
Erich Cordoba c8735e882a Remove version from sm folder
The sm component had the 1.0.0 version in the folder name, this
change removes that version and updates the centos_pkg_dirs.

Story: 2006623
Task: 36827

Depends-On: https://review.opendev.org/#/c/685128/
Change-Id: I6725d1f961c2a82275da5fabbff8e89a8dd6f245
Signed-off-by: Erich Cordoba <erich.cordoba.malibran@intel.com>
2019-09-26 14:11:31 -05:00

183 lines
6.4 KiB
C

//
// Copyright (c) 2014 Wind River Systems, Inc.
//
// SPDX-License-Identifier: Apache-2.0
//
#include "sm_service_group_standby_state.h"
#include <stdio.h>
#include "sm_types.h"
#include "sm_debug.h"
#include "sm_service_group_notification.h"
#include "sm_service_group_fsm.h"
#include "sm_service_group_go_active.h"
#include "sm_service_group_go_standby.h"
#include "sm_service_group_audit.h"
// ****************************************************************************
// Service Group Standby State - Entry
// ===================================
SmErrorT sm_service_group_standby_state_entry(
SmServiceGroupT* service_group )
{
SmErrorT error;
error = sm_service_group_notification_notify(
service_group, SM_SERVICE_GROUP_NOTIFICATION_STANDBY );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to send service group (%s) notification, error=%s",
service_group->name, sm_error_str( error ) );
return( error );
}
error = sm_service_group_go_standby( service_group );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to go-standby on service group (%s), error=%s",
service_group->name, sm_error_str( error ) );
return( error );
}
return( SM_OKAY );
}
// ****************************************************************************
// ****************************************************************************
// Service Group Standby State - Exit
// ==================================
SmErrorT sm_service_group_standby_state_exit(
SmServiceGroupT* service_group )
{
SmErrorT error;
error = sm_service_group_notification_abort( service_group );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to abort service group (%s) notification, error=%s",
service_group->name, sm_error_str( error ) );
return( error );
}
return( SM_OKAY );
}
// ****************************************************************************
// ****************************************************************************
// Service Group Standby State - Transition
// ========================================
SmErrorT sm_service_group_standby_state_transition(
SmServiceGroupT* service_group, SmServiceGroupStateT from_state )
{
return( SM_OKAY );
}
// ****************************************************************************
// ****************************************************************************
// Service Group Standby State - Event Handler
// ===========================================
SmErrorT sm_service_group_standby_state_event_handler(
SmServiceGroupT* service_group, SmServiceGroupEventT event,
void* event_data[] )
{
char* service_name = NULL;
SmServiceStateT service_state;
SmServiceGroupStateT state;
SmErrorT error;
error = sm_service_group_fsm_get_next_state( service_group->name,
event, &state );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to determine next state for service group (%s), "
"error=%s", service_group->name, sm_error_str( error ) );
return( error );
}
switch( event )
{
case SM_SERVICE_GROUP_EVENT_GO_ACTIVE:
case SM_SERVICE_GROUP_EVENT_DISABLE:
error = sm_service_group_fsm_set_state( service_group->name,
state );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to set service group (%s) state (%s), "
"error=%s.", service_group->name,
sm_service_group_state_str( state ),
sm_error_str( error ) );
return( error );
}
break;
case SM_SERVICE_GROUP_EVENT_GO_STANDBY:
case SM_SERVICE_GROUP_EVENT_NOTIFICATION_SUCCESS:
case SM_SERVICE_GROUP_EVENT_NOTIFICATION_FAILED:
case SM_SERVICE_GROUP_EVENT_NOTIFICATION_TIMEOUT:
// Ignore.
break;
case SM_SERVICE_GROUP_EVENT_SERVICE_SCN:
service_name = (char *)
event_data[SM_SERVICE_GROUP_EVENT_DATA_SERVICE_NAME];
service_state = *(SmServiceStateT *)
event_data[SM_SERVICE_GROUP_EVENT_DATA_SERVICE_STATE];
DPRINTFD( "Service group (%s) service (%s) state (%s) received.",
service_group->name, service_name,
sm_service_state_str( service_state ) );
case SM_SERVICE_GROUP_EVENT_AUDIT:
error = sm_service_group_audit_status( service_group );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to audit service group (%s), error=%s.",
service_group->name, sm_error_str( error ) );
return( error );
}
break;
case SM_SERVICE_GROUP_EVENT_SHUTDOWN:
error = sm_service_group_fsm_set_state( service_group->name,
SM_SERVICE_GROUP_STATE_SHUTDOWN );
if( SM_OKAY != error )
{
DPRINTFE( "Failed to set service group (%s) state (%s), "
"error=%s.", service_group->name,
sm_service_group_state_str(
SM_SERVICE_GROUP_STATE_SHUTDOWN ),
sm_error_str( error ) );
return( error );
}
break;
default:
DPRINTFI( "Service group (%s) ignoring event (%s).",
service_group->name,
sm_service_group_event_str( event ) );
break;
}
return( SM_OKAY );
}
// ****************************************************************************
// ****************************************************************************
// Service Group Standby State - Initialize
// ========================================
SmErrorT sm_service_group_standby_state_initialize( void )
{
return( SM_OKAY );
}
// ****************************************************************************
// ****************************************************************************
// Service Group Standby State - Finalize
// ======================================
SmErrorT sm_service_group_standby_state_finalize( void )
{
return( SM_OKAY );
}
// ****************************************************************************