Função AddAccessAllowedObjectAce (securitybaseapi.h)
A função AddAccessAllowedObjectAce adiciona uma ACE ( entrada de controle de acesso ) permitida pelo acesso ao final de uma DACL (lista de controle de acesso discricionário ). A nova ACE pode conceder acesso a um objeto ou a um conjunto de propriedades ou propriedade em um objeto . Você também pode usar AddAccessAllowedObjectAce para adicionar uma ACE que somente um tipo especificado de objeto filho pode herdar.
Sintaxe
BOOL AddAccessAllowedObjectAce(
[in, out] PACL pAcl,
[in] DWORD dwAceRevision,
[in] DWORD AceFlags,
[in] DWORD AccessMask,
[in, optional] GUID *ObjectTypeGuid,
[in, optional] GUID *InheritedObjectTypeGuid,
[in] PSID pSid
);
Parâmetros
[in, out] pAcl
Um ponteiro para uma DACL. A função AddAccessAllowedObjectAce adiciona uma ACE com permissão de acesso ao final desta DACL. A ACE está na forma de uma estrutura ACCESS_ALLOWED_OBJECT_ACE .
[in] dwAceRevision
Especifica o nível de revisão da DACL que está sendo modificada. Esse valor deve ser ACL_REVISION_DS. Se o nível de revisão da DACL for inferior a ACL_REVISION_DS, a função o alterará para ACL_REVISION_DS.
[in] AceFlags
Um conjunto de sinalizadores de bits que controlam a herança da ACE. A função define esses sinalizadores no membro AceFlags da estrutura ACE_HEADER do novo ACE. Esse parâmetro pode ser uma combinação dos seguintes valores.
Valor | Significado |
---|---|
|
A ACE é herdada por objetos de contêiner. |
|
A ACE não se aplica ao objeto ao qual a ACL ( lista de controle de acesso ) é atribuída, mas pode ser herdada por objetos filho. |
|
Indica uma ACE herdada. Esse sinalizador permite que operações que alterem a segurança em uma árvore de objetos modifiquem ACEs herdadas, sem alterar ACEs que foram aplicadas diretamente ao objeto. |
|
Os bits OBJECT_INHERIT_ACE e CONTAINER_INHERIT_ACE não são propagados para uma ACE herdada. |
|
O ACE é herdado por objetos não pertencentes a contêineres. |
[in] AccessMask
Um conjunto de sinalizadores de bits que usam o formato ACCESS_MASK . Esses sinalizadores especificam os direitos de acesso que o novo ACE permite para o SID ( identificador de segurança ) especificado.
[in, optional] ObjectTypeGuid
Um ponteiro para uma estrutura GUID que identifica o tipo de objeto, conjunto de propriedades ou propriedade protegido pelo novo ACE. Se esse parâmetro for NULL, o novo ACE protegerá o objeto ao qual a DACL é atribuída.
[in, optional] InheritedObjectTypeGuid
Um ponteiro para uma estrutura GUID que identifica o tipo de objeto que pode herdar o novo ACE. Se esse parâmetro não for NULL, somente o tipo de objeto especificado poderá herdar o ACE. Se FOR NULL, qualquer tipo de objeto filho poderá herdar o ACE. Em ambos os casos, a herança também é controlada pelo valor do parâmetro AceFlags , bem como por qualquer proteção contra herança colocada nos objetos filho.
[in] pSid
Um ponteiro para um SID que identifica a sessão de usuário, grupo ou logon à qual a nova ACE permite o acesso.
Valor retornado
Se a função for bem-sucedida, o valor retornado será diferente de zero.
Se a função falhar, o valor retornado será zero. Para obter informações de erro estendidas, chame GetLastError. Veja a seguir os possíveis valores de erro.
Código de retorno | Descrição |
---|---|
|
A nova ACE não se encaixa na ACL. Um buffer de ACL maior é necessário. |
|
A ACL especificada não está formada corretamente. |
|
O parâmetro AceFlags não é válido. |
|
O SID especificado não é estruturalmente válido. |
|
A revisão especificada não é conhecida ou é incompatível com a da ACL. |
|
O ACE foi adicionado com êxito. |
Comentários
Se ObjectTypeGuid e InheritedObjectTypeGuid forem NULL, use a função AddAccessAllowedAceEx em vez de AddAccessAllowedObjectAce. Isso é sugerido porque um ACCESS_ALLOWED_ACE é menor e mais eficiente do que um ACCESS_ALLOWED_OBJECT_ACE.
O chamador deve garantir que as ACEs sejam adicionadas à DACL na ordem correta. Para obter mais informações, consulte Ordem das ACEs em uma DACL.
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 | securitybaseapi.h (inclua Windows.h) |
Biblioteca | Advapi32.lib |
DLL | Advapi32.dll |