Implementando SceSvcAttachmentConfig
A função SceSvcAttachmentConfig deve recuperar informações do banco de dados de segurança e, em seguida, usar essas informações para configurar o serviço.
Ao implementar sceSvcAttachmentConfig, você pode recuperar todas as informações e, em seguida, configurar o serviço ou recuperar e configurar o serviço em etapas. O algoritmo a seguir recupera todas as informações e configura o serviço.
Para implementar SceSvcAttachmentConfig
- Defina as variáveis necessárias para recuperar informações e retornar códigos.
- Chame a função de retorno de chamada pfQueryInfo na estrutura de retorno de chamada para recuperar informações de configuração do banco de dados de segurança.
- Configure o sistema com as informações retornadas.
- Chame a função de retorno de chamada pfFreeInfo na estrutura de retorno de chamada para liberar a memória usada para obter informações retornadas.
- Se houver alguma mensagem que a extensão deseja adicionar ao arquivo de log de análise, chame a função de retorno de chamada pfLogInfo na estrutura de retorno de chamada.
- Retornar os códigos SCESTATUS apropriados.
O exemplo a seguir mostra uma possível implementação de SceSvcAttachmentConfig. Observe que, neste exemplo, a função ProcessConfigurationLine define a configuração do serviço. A implementação dessa função não é mostrada.
SCESTATUS WINAPI SceSvcAttachmentConfig (
IN PSCESVC_CALLBACK_INFO pSceCbInfo
)
{
////////////////////////////////////////////////////
// Define variables.
////////////////////////////////////////////////////
PSCESVC_CONFIGURATION_INFO pConfigInfo = NULL;
SCESTATUS retCode;
SCE_ENUMERATION_CONTEXT EnumContext = 0;
if ( pSceCbInfo == NULL ||
pSceCbInfo->sceHandle == NULL ||
pSceCbInfo->pfQueryInfo == NULL ||
pSceCbInfo->pfSetInfo == NULL ||
pSceCbInfo->pfFreeInfo == NULL )
{
return(SCESTATUS_INVALID_PARAMETER);
}
////////////////////////////////////////////////////
// Retrieve configuration information and configure
// system.
////////////////////////////////////////////////////
do
{
retCode = (*(pSceCbInfo->pfQueryInfo))( pSceCbInfo->sceHandle,
SceSvcConfigurationInfo,
NULL,
FALSE,
(PVOID *)&pConfigInfo,
&EnumContext
);
if (retCode == SCESTATUS_SUCCESS && pConfigInfo != NULL)
{
ULONG i:
//////////////////////////////////////////////////
// Configure system.
/////////////////////////////////////////////////
for(i = 0; < pConfigInfo->Count; i++)
{
if(pConfigInfo->Line[i].Key == NULL)
continue;
ProcessConfigurationLine(pConfigInfo->Line[i]);
}
//////////////////////////////////////////////////
// Free data returned.
/////////////////////////////////////////////////
(*(pSceCbInfo->pfFreeInfo)) ((PVOPID)pConfigInfo);
pConfigInfo = NULL;
}
} while (retCode == SCESTATUS_SUCCESS && CountReturned > 0);
////////////////////////////////////////////////////
// Add code for other return codes if retCode is
// not SCESTATUS_SUCCESS.
///////////////////////////////////////////////////
return retCode;
}