Condividi tramite


EventWaitHandleRights Enumerazione

Definizione

Specifica i diritti per il controllo di accesso che possono essere applicati agli oggetti eventi di sistema denominati.

Questa enumerazione supporta una combinazione bit per bit dei rispettivi valori dei membri.

public enum class EventWaitHandleRights
[System.Flags]
public enum EventWaitHandleRights
[System.Flags]
[System.Security.SecurityCritical]
public enum EventWaitHandleRights
[<System.Flags>]
type EventWaitHandleRights = 
[<System.Flags>]
[<System.Security.SecurityCritical>]
type EventWaitHandleRights = 
Public Enum EventWaitHandleRights
Ereditarietà
EventWaitHandleRights
Attributi

Campi

ChangePermissions 262144

Diritto per modificare le regole di sicurezza e controllo associate a un evento denominato.

Delete 65536

Diritto per eliminare un evento denominato.

FullControl 2031619

Diritto per esercitare il controllo completo su un evento denominato e modificarne le regole di accesso e di controllo.

Modify 2

Diritto per impostare o ripristinare lo stato segnalato di un evento denominato.

ReadPermissions 131072

Diritto per aprire e copiare le regole di accesso e di controllo di un evento denominato.

Synchronize 1048576

Diritto per restare in attesa di un evento denominato.

TakeOwnership 524288

Diritto per modificare il proprietario di un evento denominato.

Esempio

Nell'esempio di codice seguente viene illustrato l'uso dei valori durante la creazione e EventWaitHandleAccessRule l'uso di EventWaitHandleRights oggetti. L'esempio crea un EventWaitHandleSecurity oggetto, aggiunge regole che consentono e negano vari diritti per l'utente corrente e visualizzano la coppia risultante di regole. L'esempio consente quindi nuovi diritti per l'utente corrente e visualizza il risultato, che mostra che i nuovi diritti vengono uniti alla regola esistente AccessControlType.Allow .

Nota

In questo esempio non viene collegato l'oggetto di sicurezza a un EventWaitHandle oggetto; vedere EventWaitHandleSecurity, EventWaitHandle.GetAccessControl metodo e EventWaitHandle.SetAccessControl.

using System;
using System.Threading;
using System.Security.AccessControl;
using System.Security.Principal;

public class Example
{
    public static void Main()
    {
        // Create a string representing the current user.
        string user = Environment.UserDomainName + "\\" + 
            Environment.UserName;

        // Create a security object that grants no access.
        EventWaitHandleSecurity mSec = new EventWaitHandleSecurity();

        // Add a rule that grants the current user the 
        // right to wait on or signal the event.
        EventWaitHandleAccessRule rule = new EventWaitHandleAccessRule(user, 
            EventWaitHandleRights.Synchronize | EventWaitHandleRights.Modify, 
            AccessControlType.Allow);
        mSec.AddAccessRule(rule);

        // Add a rule that denies the current user the 
        // right to change permissions on the event.
        rule = new EventWaitHandleAccessRule(user, 
            EventWaitHandleRights.ChangePermissions, 
            AccessControlType.Deny);
        mSec.AddAccessRule(rule);

        // Display the rules in the security object.
        ShowSecurity(mSec);

        // Add a rule that allows the current user the 
        // right to read permissions on the event. This rule
        // is merged with the existing Allow rule.
        rule = new EventWaitHandleAccessRule(user, 
            EventWaitHandleRights.ReadPermissions, 
            AccessControlType.Allow);
        mSec.AddAccessRule(rule);

        ShowSecurity(mSec);
    }

    private static void ShowSecurity(EventWaitHandleSecurity security)
    {
        Console.WriteLine("\r\nCurrent access rules:\r\n");

        foreach(EventWaitHandleAccessRule ar in 
            security.GetAccessRules(true, true, typeof(NTAccount)))
        {
            Console.WriteLine("        User: {0}", ar.IdentityReference);
            Console.WriteLine("        Type: {0}", ar.AccessControlType);
            Console.WriteLine("      Rights: {0}", ar.EventWaitHandleRights);
            Console.WriteLine();
        }
    }
}

/*This code example produces output similar to following:

Current access rules:

        User: TestDomain\TestUser
        Type: Deny
      Rights: ChangePermissions

        User: TestDomain\TestUser
        Type: Allow
      Rights: Modify, Synchronize


Current access rules:

        User: TestDomain\TestUser
        Type: Deny
      Rights: ChangePermissions

        User: TestDomain\TestUser
        Type: Allow
      Rights: Modify, ReadPermissions, Synchronize
 */
Imports System.Threading
Imports System.Security.AccessControl
Imports System.Security.Principal

Public Class Example

    Public Shared Sub Main()

        ' Create a string representing the current user.
        Dim user As String = Environment.UserDomainName _ 
            & "\" & Environment.UserName

        ' Create a security object that grants no access.
        Dim mSec As New EventWaitHandleSecurity()

        ' Add a rule that grants the current user the 
        ' right to wait on or signal the event.
        Dim rule As New EventWaitHandleAccessRule(user, _
            EventWaitHandleRights.Synchronize _
            Or EventWaitHandleRights.Modify, _
            AccessControlType.Allow)
        mSec.AddAccessRule(rule)

        ' Add a rule that denies the current user the 
        ' right to change permissions on the event.
        rule = New EventWaitHandleAccessRule(user, _
            EventWaitHandleRights.ChangePermissions, _
            AccessControlType.Deny)
        mSec.AddAccessRule(rule)

        ' Display the rules in the security object.
        ShowSecurity(mSec)

        ' Add a rule that allows the current user the 
        ' right to read permissions on the event. This rule
        ' is merged with the existing Allow rule.
        rule = New EventWaitHandleAccessRule(user, _
            EventWaitHandleRights.ReadPermissions, _
            AccessControlType.Allow)
        mSec.AddAccessRule(rule)

        ShowSecurity(mSec)

    End Sub 

    Private Shared Sub ShowSecurity(ByVal security As EventWaitHandleSecurity)
        Console.WriteLine(vbCrLf & "Current access rules:" & vbCrLf)

        For Each ar As EventWaitHandleAccessRule In _
            security.GetAccessRules(True, True, GetType(NTAccount))

            Console.WriteLine("        User: {0}", ar.IdentityReference)
            Console.WriteLine("        Type: {0}", ar.AccessControlType)
            Console.WriteLine("      Rights: {0}", ar.EventWaitHandleRights)
            Console.WriteLine()
        Next

    End Sub
End Class 

'This code example produces output similar to following:
'
'Current access rules:
'
'        User: TestDomain\TestUser
'        Type: Deny
'      Rights: ChangePermissions
'
'        User: TestDomain\TestUser
'        Type: Allow
'      Rights: Modify, Synchronize
'
'
'Current access rules:
'
'        User: TestDomain\TestUser
'        Type: Deny
'      Rights: ChangePermissions
'
'        User: TestDomain\TestUser
'        Type: Allow
'      Rights: Modify, ReadPermissions, Synchronize

Commenti

Usare l'enumerazione EventWaitHandleRights per specificare i diritti di controllo di accesso quando si creano EventWaitHandleAccessRule oggetti. Per applicare i diritti di accesso a un evento di sistema denominato, aggiungere EventWaitHandleAccessRule prima oggetti a un EventWaitHandleSecurity oggetto, quindi collegare l'oggetto EventWaitHandleSecurity all'evento di sistema denominato usando il costruttore o il EventWaitHandle.EventWaitHandle(Boolean, EventResetMode, String, Boolean, EventWaitHandleSecurity)EventWaitHandle.SetAccessControl metodo .

Si applica a

Vedi anche