aboutsummaryrefslogtreecommitdiff
path: root/lib/VNLib.Plugins.Extensions.Data/src/Storage
diff options
context:
space:
mode:
authorLibravatar vnugent <public@vaughnnugent.com>2023-08-29 11:18:36 -0400
committerLibravatar vnugent <public@vaughnnugent.com>2023-08-29 11:18:36 -0400
commitbf01b244f3bf2aa3c236fb86c0d75c261f54b334 (patch)
treeaddccd2a34dfbb319d4dcdf8dcaef664a5fb7d4d /lib/VNLib.Plugins.Extensions.Data/src/Storage
parentc68c7762ce9023af8b65ce58adee167fc9788ee1 (diff)
integrate simple fs in utils
Diffstat (limited to 'lib/VNLib.Plugins.Extensions.Data/src/Storage')
-rw-r--r--lib/VNLib.Plugins.Extensions.Data/src/Storage/FsExtensions.cs72
-rw-r--r--lib/VNLib.Plugins.Extensions.Data/src/Storage/ISimpleFilesystem.cs72
2 files changed, 0 insertions, 144 deletions
diff --git a/lib/VNLib.Plugins.Extensions.Data/src/Storage/FsExtensions.cs b/lib/VNLib.Plugins.Extensions.Data/src/Storage/FsExtensions.cs
deleted file mode 100644
index 8f5c099..0000000
--- a/lib/VNLib.Plugins.Extensions.Data/src/Storage/FsExtensions.cs
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
-* Copyright (c) 2023 Vaughn Nugent
-*
-* Library: VNLib
-* Package: VNLib.Plugins.Extensions.Data
-* File: FsExtensions.cs
-*
-* FsExtensions.cs is part of VNLib.Plugins.Extensions.Data which is part
-* of the larger VNLib collection of libraries and utilities.
-*
-* VNLib.Plugins.Extensions.Data is free software: you can redistribute it and/or modify
-* it under the terms of the GNU Affero General Public License as
-* published by the Free Software Foundation, either version 3 of the
-* License, or (at your option) any later version.
-*
-* VNLib.Plugins.Extensions.Data is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU Affero General Public License for more details.
-*
-* You should have received a copy of the GNU Affero General Public License
-* along with this program. If not, see https://www.gnu.org/licenses/.
-*/
-
-using System.IO;
-using System.Threading;
-using System.Threading.Tasks;
-
-namespace VNLib.Plugins.Extensions.Data.Storage
-{
- /// <summary>
- /// Contains filesystem extension methods
- /// </summary>
- public static class FsExtensions
- {
- /// <summary>
- /// Creates a new scope for the given filesystem. All operations will be offset by the given path
- /// within the parent filesystem.
- /// </summary>
- /// <param name="fs"></param>
- /// <param name="offsetPath">The base path to prepend to all requests</param>
- /// <returns>A new <see cref="ISimpleFilesystem"/> with a new filesystem directory scope</returns>
- public static ISimpleFilesystem CreateNewScope(this ISimpleFilesystem fs, string offsetPath) => new FsScope(fs, offsetPath);
-
- private sealed record class FsScope(ISimpleFilesystem Parent, string OffsetPath) : ISimpleFilesystem
- {
- public Task DeleteFileAsync(string filePath, CancellationToken cancellation)
- {
- string path = Path.Combine(OffsetPath, filePath);
- return Parent.DeleteFileAsync(path, cancellation);
- }
-
- public string GetExternalFilePath(string filePath)
- {
- string path = Path.Combine(OffsetPath, filePath);
- return Parent.GetExternalFilePath(path);
- }
-
- public Task<long> ReadFileAsync(string filePath, Stream output, CancellationToken cancellation)
- {
- string path = Path.Combine(OffsetPath, filePath);
- return Parent.ReadFileAsync(path, output, cancellation);
- }
-
- public Task SetFileAsync(string filePath, Stream data, string contentType, CancellationToken cancellation)
- {
- string path = Path.Combine(OffsetPath, filePath);
- return Parent.SetFileAsync(path, data, contentType, cancellation);
- }
- }
- }
-}
diff --git a/lib/VNLib.Plugins.Extensions.Data/src/Storage/ISimpleFilesystem.cs b/lib/VNLib.Plugins.Extensions.Data/src/Storage/ISimpleFilesystem.cs
deleted file mode 100644
index d3dc431..0000000
--- a/lib/VNLib.Plugins.Extensions.Data/src/Storage/ISimpleFilesystem.cs
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
-* Copyright (c) 2023 Vaughn Nugent
-*
-* Library: VNLib
-* Package: VNLib.Plugins.Extensions.Data
-* File: ISimpleFilesystem.cs
-*
-* ISimpleFilesystem.cs is part of VNLib.Plugins.Extensions.Data which is part
-* of the larger VNLib collection of libraries and utilities.
-*
-* VNLib.Plugins.Extensions.Data is free software: you can redistribute it and/or modify
-* it under the terms of the GNU Affero General Public License as
-* published by the Free Software Foundation, either version 3 of the
-* License, or (at your option) any later version.
-*
-* VNLib.Plugins.Extensions.Data is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU Affero General Public License for more details.
-*
-* You should have received a copy of the GNU Affero General Public License
-* along with this program. If not, see https://www.gnu.org/licenses/.
-*/
-
-using System.IO;
-using System.Threading;
-using System.Threading.Tasks;
-
-namespace VNLib.Plugins.Extensions.Data.Storage
-{
-
- /// <summary>
- /// Represents an opaque storage interface that abstracts simple storage operations
- /// ignorant of the underlying storage system.
- /// </summary>
- public interface ISimpleFilesystem
- {
- /// <summary>
- /// Gets the full public file path for the given relative file path
- /// </summary>
- /// <param name="filePath">The relative file path of the item to get the full path for</param>
- /// <returns>The full relative file path</returns>
- string GetExternalFilePath(string filePath);
-
- /// <summary>
- /// Deletes a file from the storage system asynchronously
- /// </summary>
- /// <param name="filePath">The path to the file to delete</param>
- /// <param name="cancellation">A token to cancel the operation</param>
- /// <returns>A task that represents and asynchronous work</returns>
- Task DeleteFileAsync(string filePath, CancellationToken cancellation);
-
- /// <summary>
- /// Writes a file from the stream to the given file location
- /// </summary>
- /// <param name="filePath">The path to the file to write to</param>
- /// <param name="data">The file data to stream</param>
- /// <param name="contentType">The content type of the file to write</param>
- /// <param name="cancellation">A token to cancel the operation</param>
- /// <returns>A task that represents and asynchronous work</returns>
- Task SetFileAsync(string filePath, Stream data, string contentType, CancellationToken cancellation);
-
- /// <summary>
- /// Reads a file from the storage system at the given path asynchronously
- /// </summary>
- /// <param name="filePath">The file to read</param>
- /// <param name="output">The stream to write the file output to</param>
- /// <param name="cancellation">A token to cancel the operation</param>
- /// <returns>The number of bytes read, -1 if the operation failed</returns>
- Task<long> ReadFileAsync(string filePath, Stream output, CancellationToken cancellation);
- }
-}