Função GetInheritanceSourceA (aclapi.h)

Não há suporte para esta versão dessa função. Há suporte para a versão de caractere largo dessa função, GetInheritanceSourceW.

Sintaxe

DWORD GetInheritanceSourceA(
  [in]           LPSTR                 pObjectName,
  [in]           SE_OBJECT_TYPE        ObjectType,
  [in]           SECURITY_INFORMATION  SecurityInfo,
  [in]           BOOL                  Container,
  [in, optional] GUID                  **pObjectClassGuids,
  [in]           DWORD                 GuidCount,
  [in]           PACL                  pAcl,
  [in, optional] PFN_OBJECT_MGR_FUNCTS pfnArray,
  [in]           PGENERIC_MAPPING      pGenericMapping,
  [out]          PINHERITED_FROMA      pInheritArray
);

Parâmetros

[in] pObjectName

Um ponteiro para o nome do objeto que usa a ACL a ser verificada.

[in] ObjectType

O tipo de objeto indicado por pObjectName. Os valores possíveis são SE_FILE_OBJECT, SE_REGISTRY_KEY, SE_DS_OBJECT e SE_DS_OBJECT_ALL.

[in] SecurityInfo

O tipo de ACL usado com o objeto . Os valores possíveis são DACL_SECURITY_INFORMATION ou SACL_SECURITY_INFORMATION.

[in] Container

TRUE se o objeto for um objeto container ou FALSE se o objeto for um objeto folha. Observe que o único objeto folha é SE_FILE_OBJECT.

[in, optional] pObjectClassGuids

Lista opcional de GUIDs que identificam os tipos de objeto ou nomes associados a pObjectName. Isso poderá ser NULL se o gerenciador de objetos der suporte apenas a uma classe de objeto ou não tiver nenhum GUID associado à classe de objeto.

[in] GuidCount

Número de GUIDs apontados por pObjectClassGuids.

[in] pAcl

A ACL do objeto.

[in, optional] pfnArray

Reservado. Defina esse parâmetro como NULL.

[in] pGenericMapping

O mapeamento de direitos genéricos para direitos específicos para o objeto .

[out] pInheritArray

Um ponteiro para uma matriz de estruturas INHERITED_FROM que a função GetInheritanceSource preenche com as informações de herança. O chamador deve alocar memória suficiente para uma entrada para cada ACE na ACL.

Retornar valor

Se a função for bem-sucedida, a função retornará ERROR_SUCCESS.

Se a função falhar, ela retornará um código de erro diferente de zero definido em WinError.h.

Comentários

A função GetInheritanceSource aloca memória para os nomes retornados na estrutura INHERITED_FROM . Quando a função terminar de usar essa memória, o programa de chamada deverá liberá-la chamando FreeInheritedFromArray. Observe que o chamador deve fornecer memória para a própria matriz. Se o chamador alocou a memória, o chamador deverá liberar essa memória depois de chamar FreeInheritedFromArray.

Essa função não lida com condições de corrida. Se o thread chamar essa função no momento aproximado em que outro thread alterar o descritor de segurança do objeto, essa função poderá falhar.

Observação

O cabeçalho aclapi.h define GetInheritanceSource como um alias que seleciona automaticamente a versão ANSI ou Unicode dessa função com base na definição da constante de pré-processador UNICODE. Misturar o uso do alias neutro de codificação com código que não seja neutro em codificação pode levar a incompatibilidades que resultam em erros de compilação ou de runtime. Para obter mais informações, consulte Convenções para protótipos de função.

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows XP [somente aplicativos da área de trabalho]
Servidor mínimo com suporte Windows Server 2003 [somente aplicativos da área de trabalho]
Plataforma de Destino Windows
Cabeçalho aclapi.h
Biblioteca Advapi32.lib
DLL Advapi32.dll

Confira também

FreeInheritedFromArray