Lire en anglais

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.

C#
[System.Flags]
public enum SemaphoreRights
C#
[System.Flags]
[System.Security.SecurityCritical]
public enum SemaphoreRights
C#
[System.Flags]
[System.Runtime.InteropServices.ComVisible(false)]
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 .

Note

Cet exemple n’attache pas l’objet de sécurité à un Semaphore objet ; voir SemaphoreSecurity, Semaphore.GetAccessControl méthode et Semaphore.SetAccessControl.

C#
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
 */

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 à

Produit Versions
.NET Core 1.0, Core 1.1
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
Windows Desktop 3.0, 3.1, 5, 6, 7

Voir aussi