Got at least one data fetching method working; turns out, we can't use a patched LogicStack to get the data
This commit is contained in:
275
Vendor/EmbedIO-3.5.2/WebModuleContainerExtensions-Files.cs
vendored
Normal file
275
Vendor/EmbedIO-3.5.2/WebModuleContainerExtensions-Files.cs
vendored
Normal file
@@ -0,0 +1,275 @@
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using EmbedIO.Files;
|
||||
using EmbedIO.Utilities;
|
||||
|
||||
namespace EmbedIO
|
||||
{
|
||||
partial class WebModuleContainerExtensions
|
||||
{
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="FileSystemProvider"/>, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="fileSystemPath">The path of the directory to serve.</param>
|
||||
/// <param name="isImmutable"><see langword="true"/> if files and directories in
|
||||
/// <paramref name="fileSystemPath"/> are not expected to change during a web server's
|
||||
/// lifetime; <see langword="false"/> otherwise.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentNullException"><paramref name="fileSystemPath"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentException"><paramref name="fileSystemPath"/> is not a valid local path.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="FileSystemProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithStaticFolder<TContainer>(
|
||||
this TContainer @this,
|
||||
string baseRoute,
|
||||
string fileSystemPath,
|
||||
bool isImmutable,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
=> WithStaticFolder(@this, null, baseRoute, fileSystemPath, isImmutable, configure);
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="FileSystemProvider"/>, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container,
|
||||
/// giving it the specified <paramref name="name"/> if not <see langword="null"/>.
|
||||
/// </summary>
|
||||
/// <remarks>
|
||||
/// OSX doesn't support <see cref="FileSystemWatcher" />, the parameter <paramref name="isImmutable" /> will be always <see langword="true"/>.
|
||||
/// </remarks>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="name">The name.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="fileSystemPath">The path of the directory to serve.</param>
|
||||
/// <param name="isImmutable"><see langword="true"/> if files and directories in
|
||||
/// <paramref name="fileSystemPath"/> are not expected to change during a web server's
|
||||
/// lifetime; <see langword="false"/> otherwise.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentNullException"><paramref name="fileSystemPath"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentException"><paramref name="fileSystemPath"/> is not a valid local path.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="FileSystemProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithStaticFolder<TContainer>(
|
||||
this TContainer @this,
|
||||
string? name,
|
||||
string baseRoute,
|
||||
string fileSystemPath,
|
||||
bool isImmutable,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
{
|
||||
#pragma warning disable CA2000 // Call Dispose on disposable - Ownership of provider is transferred to module
|
||||
var provider = new FileSystemProvider(fileSystemPath, isImmutable);
|
||||
#pragma warning restore CA2000
|
||||
try
|
||||
{
|
||||
var module = new FileModule(baseRoute, provider);
|
||||
return WithModule(@this, name, module, configure);
|
||||
}
|
||||
catch
|
||||
{
|
||||
provider.Dispose();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ResourceFileProvider"/>, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="assembly">The assembly where served files are contained as embedded resources.</param>
|
||||
/// <param name="pathPrefix">A string to prepend to provider-specific paths
|
||||
/// to form the name of a manifest resource in <paramref name="assembly"/>.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentNullException"><paramref name="assembly"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ResourceFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithEmbeddedResources<TContainer>(
|
||||
this TContainer @this,
|
||||
string baseRoute,
|
||||
Assembly assembly,
|
||||
string pathPrefix,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
=> WithEmbeddedResources(@this, null, baseRoute, assembly, pathPrefix, configure);
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ResourceFileProvider"/>, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container,
|
||||
/// giving it the specified <paramref name="name"/> if not <see langword="null"/>.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="name">The name.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="assembly">The assembly where served files are contained as embedded resources.</param>
|
||||
/// <param name="pathPrefix">A string to prepend to provider-specific paths
|
||||
/// to form the name of a manifest resource in <paramref name="assembly"/>.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <exception cref="ArgumentNullException"><paramref name="assembly"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ResourceFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithEmbeddedResources<TContainer>(
|
||||
this TContainer @this,
|
||||
string? name,
|
||||
string baseRoute,
|
||||
Assembly assembly,
|
||||
string pathPrefix,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
{
|
||||
var module = new FileModule(baseRoute, new ResourceFileProvider(assembly, pathPrefix));
|
||||
return WithModule(@this, name, module, configure);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ZipFileProvider"/> using a file-system path, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="zipFilePath">The local path of the Zip file.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ZipFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithZipFile<TContainer>(
|
||||
this TContainer @this,
|
||||
string baseRoute,
|
||||
string zipFilePath,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
=> WithZipFile(@this, null, baseRoute, zipFilePath, configure);
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ZipFileProvider"/> using a file-system path, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container,
|
||||
/// giving it the specified <paramref name="name"/> if not <see langword="null"/>.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="name">The name.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="zipFilePath">The zip file-system path.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ZipFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithZipFile<TContainer>(
|
||||
this TContainer @this,
|
||||
string? name,
|
||||
string baseRoute,
|
||||
string zipFilePath,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
{
|
||||
#pragma warning disable CA2000 // Call Dispose on disposable - Ownership of provider is transferred to module
|
||||
var provider = new ZipFileProvider(zipFilePath);
|
||||
#pragma warning restore CA2000
|
||||
try
|
||||
{
|
||||
var module = new FileModule(baseRoute, provider);
|
||||
return WithModule(@this, name, module, configure);
|
||||
}
|
||||
catch
|
||||
{
|
||||
provider.Dispose();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ZipFileProvider"/> using a zip file as stream, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="zipFileStream">The zip file as stream.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ZipFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithZipFileStream<TContainer>(
|
||||
this TContainer @this,
|
||||
string baseRoute,
|
||||
Stream zipFileStream,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
=> WithZipFileStream(@this, null, baseRoute, zipFileStream, configure);
|
||||
|
||||
/// <summary>
|
||||
/// Creates an instance of <see cref="ZipFileProvider"/> using a zip file as stream, uses it to initialize
|
||||
/// a <seealso cref="FileModule"/>, and adds the latter to a module container,
|
||||
/// giving it the specified <paramref name="name"/> if not <see langword="null"/>.
|
||||
/// </summary>
|
||||
/// <typeparam name="TContainer">The type of the module container.</typeparam>
|
||||
/// <param name="this">The <typeparamref name="TContainer"/> on which this method is called.</param>
|
||||
/// <param name="name">The name.</param>
|
||||
/// <param name="baseRoute">The base route of the module.</param>
|
||||
/// <param name="zipFileStream">The zip file as stream.</param>
|
||||
/// <param name="configure">A callback used to configure the module.</param>
|
||||
/// <returns><paramref name="this"/> with a <see cref="FileModule"/> added.</returns>
|
||||
/// <exception cref="NullReferenceException"><paramref name="this"/> is <see langword="null"/>.</exception>
|
||||
/// <seealso cref="FileModule"/>
|
||||
/// <seealso cref="ZipFileProvider"/>
|
||||
/// <seealso cref="IWebModuleContainer.Modules"/>
|
||||
/// <seealso cref="IComponentCollection{T}.Add"/>
|
||||
public static TContainer WithZipFileStream<TContainer>(
|
||||
this TContainer @this,
|
||||
string? name,
|
||||
string baseRoute,
|
||||
Stream zipFileStream,
|
||||
Action<FileModule>? configure = null)
|
||||
where TContainer : class, IWebModuleContainer
|
||||
{
|
||||
#pragma warning disable CA2000 // Call Dispose on disposable - Ownership of provider is transferred to module
|
||||
var provider = new ZipFileProvider(zipFileStream);
|
||||
#pragma warning restore CA2000
|
||||
try
|
||||
{
|
||||
var module = new FileModule(baseRoute, provider);
|
||||
return WithModule(@this, name, module, configure);
|
||||
}
|
||||
catch
|
||||
{
|
||||
provider.Dispose();
|
||||
throw;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user