From 341c4aa93978a724f0773d4bccc01661da2a903a Mon Sep 17 00:00:00 2001
From: Kateryna Novak <93556224+kateryna-novak@users.noreply.github.com>
Date: Sat, 19 Oct 2024 07:30:53 +0300
Subject: [PATCH] Fix for the issue 75 (#76)
---
.../H.Formatters.Inferno.csproj | 1 +
.../PipeServerExtensions.cs | 10 +++++++-
.../PipeServerExtensions.cs | 23 +++++++++++++++----
.../H.Pipes/Factories/PipeServerFactory.cs | 22 +++++++++++++++++-
src/libs/H.Pipes/IO/PipeStreamWriter.cs | 2 +-
5 files changed, 51 insertions(+), 7 deletions(-)
diff --git a/src/libs/H.Formatters.Inferno/H.Formatters.Inferno.csproj b/src/libs/H.Formatters.Inferno/H.Formatters.Inferno.csproj
index d56338c..e8c07b0 100644
--- a/src/libs/H.Formatters.Inferno/H.Formatters.Inferno.csproj
+++ b/src/libs/H.Formatters.Inferno/H.Formatters.Inferno.csproj
@@ -29,6 +29,7 @@
+
diff --git a/src/libs/H.Formatters.Inferno/PipeServerExtensions.cs b/src/libs/H.Formatters.Inferno/PipeServerExtensions.cs
index a43794c..39b2b79 100644
--- a/src/libs/H.Formatters.Inferno/PipeServerExtensions.cs
+++ b/src/libs/H.Formatters.Inferno/PipeServerExtensions.cs
@@ -1,5 +1,7 @@
using System.Diagnostics;
+using System.IO.Pipes;
using H.Pipes;
+using H.Pipes.AccessControl;
using H.Pipes.Extensions;
namespace H.Formatters;
@@ -19,7 +21,8 @@ public static class PipeServerExtensions
[System.Runtime.Versioning.SupportedOSPlatform("windows")]
public static void EnableEncryption(
this IPipeServer server,
- Action? exceptionAction = null)
+ Action? exceptionAction = null,
+ PipeSecurity? pipeSecurity = null)
{
server = server ?? throw new ArgumentNullException(nameof(server));
server.ClientConnected += async (_, args) =>
@@ -31,6 +34,11 @@ public static void EnableEncryption(
var pipeName = $"{args.Connection.PipeName}_Inferno";
var server = new SingleConnectionPipeServer(pipeName, args.Connection.Formatter);
+
+ if (pipeSecurity != null)
+ {
+ server.SetPipeSecurity(pipeSecurity);
+ }
server.ExceptionOccurred += (_, args) =>
{
Debug.WriteLine($"{nameof(EnableEncryption)} server returns exception: {args.Exception}");
diff --git a/src/libs/H.Pipes.AccessControl/PipeServerExtensions.cs b/src/libs/H.Pipes.AccessControl/PipeServerExtensions.cs
index fcee94b..ea03031 100644
--- a/src/libs/H.Pipes.AccessControl/PipeServerExtensions.cs
+++ b/src/libs/H.Pipes.AccessControl/PipeServerExtensions.cs
@@ -11,7 +11,7 @@ public static class PipeServerExtensions
{
///
/// Sets 's for each that will be created by
- /// Overrides
+ /// Overrides and
///
///
///
@@ -22,8 +22,9 @@ public static void SetPipeSecurity(this IPipeServer server, PipeSecurity p
{
server = server ?? throw new ArgumentNullException(nameof(server));
pipeSecurity = pipeSecurity ?? throw new ArgumentNullException(nameof(pipeSecurity));
-
- server.CreatePipeStreamFunc = pipeName => NamedPipeServerStreamConstructors.New(
+#if NET6_0_OR_GREATER
+ server.CreatePipeStreamFunc = pipeName =>
+ NamedPipeServerStreamAcl.Create(
pipeName: pipeName,
direction: PipeDirection.InOut,
maxNumberOfServerInstances: 1,
@@ -31,7 +32,21 @@ public static void SetPipeSecurity(this IPipeServer server, PipeSecurity p
options: PipeOptions.Asynchronous | PipeOptions.WriteThrough,
inBufferSize: 0,
outBufferSize: 0,
- pipeSecurity: pipeSecurity);
+ pipeSecurity);
+
+ //server.c
+#else
+ server.CreatePipeStreamFunc = pipeName =>
+ NamedPipeServerStreamConstructors.New(
+ pipeName: pipeName,
+ direction: PipeDirection.InOut,
+ maxNumberOfServerInstances: 1,
+ transmissionMode: PipeTransmissionMode.Byte,
+ options: PipeOptions.Asynchronous | PipeOptions.WriteThrough,
+ inBufferSize: 0,
+ outBufferSize: 0,
+ pipeSecurity: pipeSecurity);
+#endif
}
///
diff --git a/src/libs/H.Pipes/Factories/PipeServerFactory.cs b/src/libs/H.Pipes/Factories/PipeServerFactory.cs
index 252afe4..3e94157 100644
--- a/src/libs/H.Pipes/Factories/PipeServerFactory.cs
+++ b/src/libs/H.Pipes/Factories/PipeServerFactory.cs
@@ -1,4 +1,6 @@
using System.IO.Pipes;
+using System.Security.AccessControl;
+using System.Security.Principal;
namespace H.Pipes.Factories;
@@ -44,7 +46,23 @@ public static async Task CreateAndWaitAsync(string pipeNa
///
public static NamedPipeServerStream Create(string pipeName)
{
- return new NamedPipeServerStream(
+#if NET6_0_OR_GREATER
+
+#pragma warning disable CA1416
+ return NamedPipeServerStreamAcl.Create(
+ pipeName: pipeName,
+ direction: PipeDirection.InOut,
+ maxNumberOfServerInstances: 1,
+ transmissionMode: PipeTransmissionMode.Byte,
+ options: PipeOptions.Asynchronous | PipeOptions.WriteThrough,
+ inBufferSize: 0,
+ outBufferSize: 0,
+ null,
+ HandleInheritability.None,
+ (PipeAccessRights)0);
+#pragma warning restore CA1416
+#else
+ return new NamedPipeServerStream(
pipeName: pipeName,
direction: PipeDirection.InOut,
maxNumberOfServerInstances: 1,
@@ -52,5 +70,7 @@ public static NamedPipeServerStream Create(string pipeName)
options: PipeOptions.Asynchronous | PipeOptions.WriteThrough,
inBufferSize: 0,
outBufferSize: 0);
+#endif
+
}
}
diff --git a/src/libs/H.Pipes/IO/PipeStreamWriter.cs b/src/libs/H.Pipes/IO/PipeStreamWriter.cs
index 33c2dbb..e880c0c 100644
--- a/src/libs/H.Pipes/IO/PipeStreamWriter.cs
+++ b/src/libs/H.Pipes/IO/PipeStreamWriter.cs
@@ -20,7 +20,7 @@ public sealed class PipeStreamWriter : IDisposable
/// Gets the underlying PipeStream object.
///
private PipeStream BaseStream { get; }
- private SemaphoreSlim SemaphoreSlim { get; } = new SemaphoreSlim(1, 1);
+ private SemaphoreSlim SemaphoreSlim { get; } = new(1, 1);
#endregion