Files
Umbraco-CMS/src/Umbraco.Infrastructure/ModelsBuilder/ModelsGenerationError.cs

88 lines
2.3 KiB
C#
Raw Normal View History

using System;
2019-06-24 11:58:36 +02:00
using System.IO;
using System.Text;
using Microsoft.Extensions.Options;
using Umbraco.Cms.Core.Configuration.Models;
using Umbraco.Cms.Core.Hosting;
using Umbraco.Extensions;
2019-06-24 11:58:36 +02:00
Merge remote-tracking branch 'origin/netcore/dev' into netcore/feature/AB10314-mb-embedded-dependencies # Conflicts: # src/Umbraco.Infrastructure/ModelsBuilder/ApiVersion.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/Builder.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/ModelsGenerator.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/PropertyModel.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/TextBuilder.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/TextHeaderWriter.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/TypeModel.cs # src/Umbraco.Infrastructure/ModelsBuilder/Building/TypeModelHasher.cs # src/Umbraco.Infrastructure/ModelsBuilder/LiveModelsProvider.cs # src/Umbraco.Infrastructure/ModelsBuilder/ModelsBuilderAssemblyAttribute.cs # src/Umbraco.Infrastructure/ModelsBuilder/ModelsBuilderDashboard.cs # src/Umbraco.Infrastructure/ModelsBuilder/ModelsGenerationError.cs # src/Umbraco.Infrastructure/ModelsBuilder/OutOfDateModelsStatus.cs # src/Umbraco.Infrastructure/ModelsBuilder/PublishedElementExtensions.cs # src/Umbraco.Infrastructure/ModelsBuilder/PublishedModelUtility.cs # src/Umbraco.Infrastructure/ModelsBuilder/RoslynCompiler.cs # src/Umbraco.Infrastructure/ModelsBuilder/TypeExtensions.cs # src/Umbraco.Infrastructure/ModelsBuilder/UmbracoServices.cs # src/Umbraco.ModelsBuilder.Embedded/ImplementPropertyTypeAttribute.cs # src/Umbraco.ModelsBuilder.Embedded/Umbraco.ModelsBuilder.Embedded.csproj # src/Umbraco.Tests.UnitTests/Umbraco.ModelsBuilder.Embedded/BuilderTests.cs # src/Umbraco.Tests.UnitTests/Umbraco.ModelsBuilder.Embedded/UmbracoApplicationTests.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/ContentTypeModelValidator.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/ContentTypeModelValidatorBase.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/DashboardReport.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/DisableModelsBuilderNotificationHandler.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/MediaTypeModelValidator.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/MemberTypeModelValidator.cs # src/Umbraco.Web.BackOffice/ModelsBuilder/ModelsBuilderDashboardController.cs # src/Umbraco.Web.Common/ModelsBuilder/DependencyInjection/UmbracoBuilderExtensions.cs # src/Umbraco.Web.Common/ModelsBuilder/ModelsBuilderNotificationHandler.cs # src/Umbraco.Web.Common/ModelsBuilder/PureLiveModelFactory.cs # src/Umbraco.Web.Common/ModelsBuilder/RefreshingRazorViewEngine.cs # src/Umbraco.Web.Common/ModelsBuilder/UmbracoAssemblyLoadContext.cs # src/Umbraco.Web.UI.NetCore/Startup.cs # src/Umbraco.Web.Website/DependencyInjection/UmbracoBuilderExtensions.cs
2021-02-22 09:00:33 +01:00
namespace Umbraco.Cms.Infrastructure.ModelsBuilder
2019-06-24 11:58:36 +02:00
{
public sealed class ModelsGenerationError
2019-06-24 11:58:36 +02:00
{
private ModelsBuilderSettings _config;
2020-09-02 14:44:01 +02:00
private readonly IHostingEnvironment _hostingEnvironment;
2019-06-24 11:58:36 +02:00
/// <summary>
/// Initializes a new instance of the <see cref="ModelsGenerationError"/> class.
/// </summary>
public ModelsGenerationError(IOptionsMonitor<ModelsBuilderSettings> config, IHostingEnvironment hostingEnvironment)
{
_config = config.CurrentValue;
2020-09-02 14:44:01 +02:00
_hostingEnvironment = hostingEnvironment;
config.OnChange(x => _config = x);
}
public void Clear()
2019-06-24 11:58:36 +02:00
{
var errFile = GetErrFile();
if (errFile == null)
{
return;
}
2019-06-24 11:58:36 +02:00
// "If the file to be deleted does not exist, no exception is thrown."
File.Delete(errFile);
}
public void Report(string message, Exception e)
2019-06-24 11:58:36 +02:00
{
var errFile = GetErrFile();
if (errFile == null)
{
return;
}
2019-06-24 11:58:36 +02:00
var sb = new StringBuilder();
sb.Append(message);
sb.Append("\r\n");
sb.Append(e.Message);
sb.Append("\r\n\r\n");
sb.Append(e.StackTrace);
sb.Append("\r\n");
File.WriteAllText(errFile, sb.ToString());
}
public string? GetLastError()
2019-06-24 11:58:36 +02:00
{
var errFile = GetErrFile();
if (errFile == null)
{
return null;
}
2019-06-24 11:58:36 +02:00
try
{
return File.ReadAllText(errFile);
}
catch
2019-06-24 11:58:36 +02:00
{
// accepted
2019-06-24 11:58:36 +02:00
return null;
}
}
private string? GetErrFile()
2019-06-24 11:58:36 +02:00
{
2020-09-02 14:44:01 +02:00
var modelsDirectory = _config.ModelsDirectoryAbsolute(_hostingEnvironment);
2019-06-24 11:58:36 +02:00
if (!Directory.Exists(modelsDirectory))
{
2019-06-24 11:58:36 +02:00
return null;
}
2019-06-24 11:58:36 +02:00
return Path.Combine(modelsDirectory, "models.err");
}
}
}