Partager via


SemaphoreRights Énumération

Définition

Spécifie les droits de contrôle d'accès qui peuvent s'appliquer aux objets d'un sémaphore système nommé.

Cette énumération prend en charge une combinaison au niveau du bit de ses valeurs membres.

public enum class SemaphoreRights
[System.Flags]
public enum SemaphoreRights
[System.Flags]
[System.Security.SecurityCritical]
public enum SemaphoreRights
[System.Flags]
[System.Runtime.InteropServices.ComVisible(false)]
public enum SemaphoreRights
[<System.Flags>]
type SemaphoreRights = 
[<System.Flags>]
[<System.Security.SecurityCritical>]
type SemaphoreRights = 
[<System.Flags>]
[<System.Runtime.InteropServices.ComVisible(false)>]
type SemaphoreRights = 
Public Enum SemaphoreRights
Héritage
SemaphoreRights
Attributs

Champs

ChangePermissions 262144

Droit de modifier les règles de sécurité et d'audit associées à un sémaphore nommé.

Delete 65536

Droit de supprimer un sémaphore nommé.

FullControl 2031619

Droit d'exercer un contrôle total sur un sémaphore nommé et d'en modifier les règles d'accès et d'audit.

Modify 2

Droit de libérer un sémaphore nommé.

ReadPermissions 131072

Droit d'ouvrir et de copier les règles d'accès et d'audit pour un sémaphore nommé.

Synchronize 1048576

Droit de servir un sémaphore nommé.

TakeOwnership 524288

Droit de modifier le propriétaire d'un sémaphore nommé.

Exemples

L’exemple de code suivant illustre l’utilisation de valeurs lors de la création et de l’utilisation SemaphoreAccessRule d’objetsSemaphoreRights. L’exemple crée un SemaphoreSecurity objet, ajoute des règles qui autorisent et refusent différents droits pour l’utilisateur actuel et affichent la paire de règles résultante. L’exemple autorise ensuite les nouveaux droits pour l’utilisateur actuel et affiche le résultat, montrant que les nouveaux droits sont fusionnés avec la règle existante AccessControlType.Allow .

Notes

Cet exemple n’attache pas l’objet de sécurité à un Semaphore objet ; voir SemaphoreSecurity, Semaphore.GetAccessControl méthode et Semaphore.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.
        SemaphoreSecurity mSec = new SemaphoreSecurity();

        // Add a rule that grants the current user the 
        // right to enter or release the semaphore.
        SemaphoreAccessRule rule = new SemaphoreAccessRule(user, 
            SemaphoreRights.Synchronize | SemaphoreRights.Modify, 
            AccessControlType.Allow);
        mSec.AddAccessRule(rule);

        // Add a rule that denies the current user the 
        // right to change permissions on the semaphore.
        rule = new SemaphoreAccessRule(user, 
            SemaphoreRights.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 semaphore. This rule
        // is merged with the existing Allow rule.
        rule = new SemaphoreAccessRule(user, 
            SemaphoreRights.ReadPermissions, 
            AccessControlType.Allow);
        mSec.AddAccessRule(rule);

        ShowSecurity(mSec);
    }

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

        foreach(SemaphoreAccessRule 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.SemaphoreRights);
            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 SemaphoreSecurity()

        ' Add a rule that grants the current user the 
        ' right to enter or release the semaphore.
        Dim rule As New SemaphoreAccessRule(user, _
            SemaphoreRights.Synchronize _
            Or SemaphoreRights.Modify, _
            AccessControlType.Allow)
        mSec.AddAccessRule(rule)

        ' Add a rule that denies the current user the 
        ' right to change permissions on the semaphore.
        rule = New SemaphoreAccessRule(user, _
            SemaphoreRights.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 semaphore. This 
        ' rule is merged with the existing Allow rule.
        rule = New SemaphoreAccessRule(user, _
            SemaphoreRights.ReadPermissions, _
            AccessControlType.Allow)
        mSec.AddAccessRule(rule)

        ShowSecurity(mSec)

    End Sub 

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

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

            Console.WriteLine("        User: {0}", ar.IdentityReference)
            Console.WriteLine("        Type: {0}", ar.AccessControlType)
            Console.WriteLine("      Rights: {0}", ar.SemaphoreRights)
            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

Remarques

Utilisez l’énumération SemaphoreRights pour spécifier les droits de contrôle d’accès lorsque vous créez SemaphoreSecurity des objets. Pour appliquer des droits d’accès à un sémaphore système nommé, utilisez SemaphoreSecurity des objets avec le Semaphore.Semaphore(Int32, Int32, String, Boolean, SemaphoreSecurity) constructeur et la Semaphore.SetAccessControl méthode.

Pour connaître les valeurs numériques des droits d’accès Windows sous-jacents, consultez Synchronisation des droits d’accès et de sécurité des objets (Windows).

S’applique à

Voir aussi