diff -r 000000000000 -r 3da2a79470a7 testexecmgmt/ucc/Source/Uccs.v2/ServiceStubs/HostExecute/CHostExecuteStub.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/testexecmgmt/ucc/Source/Uccs.v2/ServiceStubs/HostExecute/CHostExecuteStub.cpp Mon Mar 08 15:04:18 2010 +0800 @@ -0,0 +1,250 @@ +/* +* Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: +* System Includes +* +*/ + + + + +#include + + +/******************************************************************************* + * + * Local Includes + * + ******************************************************************************/ +#include "strncpynt.h" +#include "CHostExecuteStub.h" +#include "CCHostexecute.h" +#include "../../Core/UCCS_ServiceValues.h" +#include "../../Core/UCCS_ErrorCodes.h" + + +/******************************************************************************* + * + * Definitions + * + ******************************************************************************/ + +/******************************************************************************* + * + * Macro Functions + * + ******************************************************************************/ + +/******************************************************************************* + * + * Constructor / Destructor + * + ******************************************************************************/ +CHostExecuteStub::CHostExecuteStub() +{ + iClientHostExecute = new CCHostexecute(); + assert( iClientHostExecute != NULL ); +} + + +CHostExecuteStub::~CHostExecuteStub() +{ + delete iClientHostExecute; +} + + +/******************************************************************************* + * + * Startup / Shutdown + * + ******************************************************************************/ +int CHostExecuteStub::StartUccsService( char *aHostName, int *aErrorCode, int *aUnused ) +{ + int client_stub_error; + + // check params + assert( aHostName != NULL ); + assert( aErrorCode != NULL ); + *aErrorCode = 0; + + // connect to the remote service + client_stub_error = iClientHostExecute->Connect( aHostName ); + + // return the result + return client_stub_error; +} + + +int CHostExecuteStub::StopUccsService( int *aErrorCode, int *aUnused ) +{ + int client_stub_error; + + // check params + assert( aErrorCode != NULL ); + *aErrorCode = 0; + + // shutdown the stub -- force it to close + client_stub_error = iClientHostExecute->Disconnect(); + + // done + return client_stub_error; +} + + +/******************************************************************************* + * + * IssueCommand + * + ******************************************************************************/ +CDataRecord* CHostExecuteStub::IssueCommand( CDataRecord* aRequest ) +{ + int i, err, client_stub_error, method_id = -1; + char *tmp_string; + CDataRecord *request_reply; + + TStartupInfo sarg_startup_info; + int rv_integer, sarg_integer; + TExecuteRequest sarg_execute_request; + TExecuteResult rv_execute_result; + TComponentList rv_component_list; + + // check params + assert( aRequest != NULL ); + + // create a standard reply + request_reply = CreateBaseReply( aRequest ); + assert( request_reply != NULL ); + + // get and check the method_id + err = request_reply->GetFieldAsInt( "METHODID", &method_id ); + if( method_id == -1 ) { + UpdateCompletionCode( request_reply, ERR_INVALID_METHOD ); + return request_reply; + } + + // now dispatch and call the appropriate method + switch( method_id ) { + + // ss_startuprpcservice + case 1: + + // extract the parameters + sarg_startup_info.iEmpty = 0; + + // make the call and update the return value + client_stub_error = iClientHostExecute->ss_startuprpcservice( sarg_startup_info, &rv_integer ); + UpdateCompletionCode( request_reply, client_stub_error ); + if( client_stub_error != ERR_NONE ) { + break; + } + + // set any return information + request_reply->NewField( "RESULT", rv_integer ); + break; + + // sc_shutdownrpcservice + case 2: + + // extract the parameters + GETINTEGERARGUMENT( "FORCE", &sarg_integer, 1, 1, aRequest, request_reply ); + + // make the call and update the return value + client_stub_error = iClientHostExecute->sc_shutdownrpcservice( sarg_integer, &rv_integer ); + UpdateCompletionCode( request_reply, client_stub_error ); + if( client_stub_error != ERR_NONE ) { + break; + } + + // set the return values + request_reply->NewField( "RESULT", rv_integer ); + break; + + // list_devices + case 30: + + // make the call and update the return value + client_stub_error = iClientHostExecute->list_devices( &rv_component_list ); + UpdateCompletionCode( request_reply, client_stub_error ); + if( client_stub_error != ERR_NONE ) { + break; + } + + // set the return values + request_reply->NewField( "PROCESSCOUNT", rv_component_list.TComponentList_len ); + for( i = 0; i < rv_component_list.TComponentList_len; i++ ) { + AddIteratedIntegerFieldName( "PID", i, (rv_component_list.TComponentList_val)[i], request_reply ); + } + break; + + // st_executecommand + case 3: + + // extract the parameters + GETSTRINGARGUMENT( "COMMAND", &tmp_string, 1, 0, aRequest, request_reply ); + STRNCPY_NULL_TERMINATE( sarg_execute_request.iCommandLine, tmp_string, MAXCOMMANDLINE ); + GETINTEGERARGUMENT( "TIMEOUT", &(sarg_execute_request.iTimeout), 2, 0, aRequest, request_reply ); + GETINTEGERARGUMENT( "GETSTDOUT", &(sarg_execute_request.iRecordStandardOut), 3, 1, aRequest, request_reply ); + GETINTEGERARGUMENT( "GETSTDERR", &(sarg_execute_request.iRecordStandartError), 4, 1, aRequest, request_reply ); + + // make the call and update the return value + client_stub_error = iClientHostExecute->st_executecommand( sarg_execute_request, &rv_execute_result ); + UpdateCompletionCode( request_reply, client_stub_error ); + if( client_stub_error != ERR_NONE ) { + break; + } + + // extract the parameters + request_reply->NewField( "RESULT", rv_execute_result.iResult ); + request_reply->NewField( "RESULT_DETAIL", rv_execute_result.iErrorCode ); + request_reply->NewField( "RESULT_SYSTEM_ERROR", rv_execute_result.iErrorDetail ); + request_reply->NewField( "PROCESS_EXIT_REASON", rv_execute_result.iProcessExitReason ); + request_reply->NewField( "PROCESS_EXIT_DETAIL", rv_execute_result.iProcessExitDetail ); + request_reply->NewField( "STANDARD_OUTPUT_LENGTH", rv_execute_result.iStandardOut.TVarData_len ); + request_reply->NewField( "STANDARD_OUTPUT", rv_execute_result.iStandardOut.TVarData_val ); + request_reply->NewField( "STANDARD_ERROR_LENGTH", rv_execute_result.iStandardError.TVarData_len ); + request_reply->NewField( "STANDARD_ERROR", rv_execute_result.iStandardError.TVarData_val ); + break; + + // Any other method id results in an invalid method id result + default: + UpdateCompletionCode( request_reply, ERR_INVALID_METHOD ); + break; + } + + // everything should be handled above + return request_reply; +} + + +/******************************************************************************* + * + * GetStatus() + * + ******************************************************************************/ +int CHostExecuteStub::GetStatus() +{ + assert( !"GetStatus() - is not implemented" ); + return -1; +} + + +/******************************************************************************* + * + * GetLastRPCError() + * + ******************************************************************************/ +char *CHostExecuteStub::GetLastRPCError( int *aIntError ) +{ + return iClientHostExecute->GetLastRPCError( aIntError ); +}