From b4805402718c5f05a7cfd5ae034a5f17e49148e3 Mon Sep 17 00:00:00 2001 From: Ronald Barendse Date: Thu, 11 Apr 2024 14:26:42 +0200 Subject: [PATCH 1/3] Use require modifier instead of setting null-suppressed default values --- tools/Umbraco.JsonSchema/Options.cs | 2 +- tools/Umbraco.JsonSchema/UmbracoCmsSchema.cs | 66 ++++++++++---------- 2 files changed, 34 insertions(+), 34 deletions(-) diff --git a/tools/Umbraco.JsonSchema/Options.cs b/tools/Umbraco.JsonSchema/Options.cs index e2e8793db4ce..cba5d1f16b4f 100644 --- a/tools/Umbraco.JsonSchema/Options.cs +++ b/tools/Umbraco.JsonSchema/Options.cs @@ -3,5 +3,5 @@ internal class Options { [Option("outputFile", Default = "appsettings-schema.Umbraco.Cms.json", HelpText = "Output file to save the generated JSON schema for Umbraco CMS.")] - public string OutputFile { get; set; } = null!; + public required string OutputFile { get; set; } } diff --git a/tools/Umbraco.JsonSchema/UmbracoCmsSchema.cs b/tools/Umbraco.JsonSchema/UmbracoCmsSchema.cs index e72be015a1c6..5a65dc93d24c 100644 --- a/tools/Umbraco.JsonSchema/UmbracoCmsSchema.cs +++ b/tools/Umbraco.JsonSchema/UmbracoCmsSchema.cs @@ -3,14 +3,14 @@ internal class UmbracoCmsSchema { - public UmbracoDefinition Umbraco { get; set; } = null!; + public required UmbracoDefinition Umbraco { get; set; } /// /// Configuration container for all Umbraco products. /// public class UmbracoDefinition { - public UmbracoCmsDefinition CMS { get; set; } = null!; + public required UmbracoCmsDefinition CMS { get; set; } } /// @@ -18,66 +18,66 @@ public class UmbracoDefinition /// public class UmbracoCmsDefinition { - public ContentSettings Content { get; set; } = null!; + public required ContentSettings Content { get; set; } - public DeliveryApiSettings DeliveryApi { get; set; } = null!; + public required DeliveryApiSettings DeliveryApi { get; set; } - public CoreDebugSettings Debug { get; set; } = null!; + public required CoreDebugSettings Debug { get; set; } - public ExceptionFilterSettings ExceptionFilter { get; set; } = null!; + public required ExceptionFilterSettings ExceptionFilter { get; set; } - public ModelsBuilderSettings ModelsBuilder { get; set; } = null!; + public required ModelsBuilderSettings ModelsBuilder { get; set; } - public GlobalSettings Global { get; set; } = null!; + public required GlobalSettings Global { get; set; } - public HealthChecksSettings HealthChecks { get; set; } = null!; + public required HealthChecksSettings HealthChecks { get; set; } - public HostingSettings Hosting { get; set; } = null!; + public required HostingSettings Hosting { get; set; } - public ImagingSettings Imaging { get; set; } = null!; + public required ImagingSettings Imaging { get; set; } - public IndexCreatorSettings Examine { get; set; } = null!; + public required IndexCreatorSettings Examine { get; set; } - public IndexingSettings Indexing { get; set; } = null!; + public required IndexingSettings Indexing { get; set; } - public LoggingSettings Logging { get; set; } = null!; + public required LoggingSettings Logging { get; set; } - public NuCacheSettings NuCache { get; set; } = null!; + public required NuCacheSettings NuCache { get; set; } - public RequestHandlerSettings RequestHandler { get; set; } = null!; + public required RequestHandlerSettings RequestHandler { get; set; } - public RuntimeSettings Runtime { get; set; } = null!; + public required RuntimeSettings Runtime { get; set; } - public SecuritySettings Security { get; set; } = null!; + public required SecuritySettings Security { get; set; } - public TypeFinderSettings TypeFinder { get; set; } = null!; + public required TypeFinderSettings TypeFinder { get; set; } - public WebRoutingSettings WebRouting { get; set; } = null!; + public required WebRoutingSettings WebRouting { get; set; } - public UmbracoPluginSettings Plugins { get; set; } = null!; + public required UmbracoPluginSettings Plugins { get; set; } - public UnattendedSettings Unattended { get; set; } = null!; + public required UnattendedSettings Unattended { get; set; } - public RichTextEditorSettings RichTextEditor { get; set; } = null!; + public required RichTextEditorSettings RichTextEditor { get; set; } - public RuntimeMinificationSettings RuntimeMinification { get; set; } = null!; + public required RuntimeMinificationSettings RuntimeMinification { get; set; } - public BasicAuthSettings BasicAuth { get; set; } = null!; + public required BasicAuthSettings BasicAuth { get; set; } - public PackageMigrationSettings PackageMigration { get; set; } = null!; + public required PackageMigrationSettings PackageMigration { get; set; } - public LegacyPasswordMigrationSettings LegacyPasswordMigration { get; set; } = null!; + public required LegacyPasswordMigrationSettings LegacyPasswordMigration { get; set; } - public ContentDashboardSettings ContentDashboard { get; set; } = null!; + public required ContentDashboardSettings ContentDashboard { get; set; } - public HelpPageSettings HelpPage { get; set; } = null!; + public required HelpPageSettings HelpPage { get; set; } - public InstallDefaultDataSettings DefaultDataCreation { get; set; } = null!; + public required InstallDefaultDataSettings DefaultDataCreation { get; set; } - public DataTypesSettings DataTypes { get; set; } = null!; + public required DataTypesSettings DataTypes { get; set; } - public MarketplaceSettings Marketplace { get; set; } = null!; + public required MarketplaceSettings Marketplace { get; set; } - public WebhookSettings Webhook { get; set; } = null!; + public required WebhookSettings Webhook { get; set; } } } From afa4c66413a8721ad609466c87cb967363f1b69a Mon Sep 17 00:00:00 2001 From: Ronald Barendse Date: Thu, 11 Apr 2024 14:27:31 +0200 Subject: [PATCH 2/3] Only remove read-only properties when IgnoreReadOnlyProperties is set --- .../UmbracoJsonSchemaGenerator.cs | 23 ++++++++++--------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/tools/Umbraco.JsonSchema/UmbracoJsonSchemaGenerator.cs b/tools/Umbraco.JsonSchema/UmbracoJsonSchemaGenerator.cs index 1bfe554a4b46..099ad498c3fd 100644 --- a/tools/Umbraco.JsonSchema/UmbracoJsonSchemaGenerator.cs +++ b/tools/Umbraco.JsonSchema/UmbracoJsonSchemaGenerator.cs @@ -5,7 +5,7 @@ using NJsonSchema.Generation; /// -public class UmbracoJsonSchemaGenerator : JsonSchemaGenerator +internal class UmbracoJsonSchemaGenerator : JsonSchemaGenerator { /// /// Initializes a new instance of the class. @@ -19,11 +19,8 @@ public UmbracoJsonSchemaGenerator() ReflectionService = new UmbracoSystemTextJsonReflectionService(), SerializerOptions = new JsonSerializerOptions() { - Converters = - { - new JsonStringEnumConverter() - }, - WriteIndented = true, + Converters = { new JsonStringEnumConverter() }, + IgnoreReadOnlyProperties = true, }, }) { } @@ -34,16 +31,20 @@ private class UmbracoSystemTextJsonReflectionService : SystemTextJsonReflectionS /// public override void GenerateProperties(JsonSchema schema, ContextualType contextualType, SystemTextJsonSchemaGeneratorSettings settings, JsonSchemaGenerator schemaGenerator, JsonSchemaResolver schemaResolver) { + // Populate schema properties base.GenerateProperties(schema, contextualType, settings, schemaGenerator, schemaResolver); - // Remove read-only properties - foreach (ContextualPropertyInfo property in contextualType.Properties) + if (settings.SerializerOptions.IgnoreReadOnlyProperties) { - if (property.CanWrite is false) + // Remove read-only properties (because this is not implemented by the base class) + foreach (ContextualPropertyInfo property in contextualType.Properties) { - string propertyName = GetPropertyName(property, settings); + if (property.CanWrite is false) + { + string propertyName = GetPropertyName(property, settings); - schema.Properties.Remove(propertyName); + schema.Properties.Remove(propertyName); + } } } } From 57e9a2f0da37cef5246f90c9d5ac3b8871aca577 Mon Sep 17 00:00:00 2001 From: Ronald Barendse Date: Thu, 11 Apr 2024 14:28:25 +0200 Subject: [PATCH 3/3] Obsolete UmbracoPath property and remove work-around for obsolete setter --- src/Umbraco.Core/Configuration/Models/GlobalSettings.cs | 5 ++--- tools/Umbraco.JsonSchema/Program.cs | 4 ---- 2 files changed, 2 insertions(+), 7 deletions(-) diff --git a/src/Umbraco.Core/Configuration/Models/GlobalSettings.cs b/src/Umbraco.Core/Configuration/Models/GlobalSettings.cs index d3135cc3732a..8763ea6e4550 100644 --- a/src/Umbraco.Core/Configuration/Models/GlobalSettings.cs +++ b/src/Umbraco.Core/Configuration/Models/GlobalSettings.cs @@ -78,13 +78,12 @@ internal const string public int VersionCheckPeriod { get; set; } = StaticVersionCheckPeriod; /// - /// Gets or sets a value for the Umbraco back-office path. + /// Gets or sets a value for the Umbraco back-office path. /// + [Obsolete($"UmbracoPath is no longer configurable, use Constants.System.DefaultUmbracoPath instead. This property is scheduled for removal in a future version.")] public string UmbracoPath { get => Constants.System.DefaultUmbracoPath; - [Obsolete($"{nameof(UmbracoPath)} is no longer configurable, this property setter is scheduled for removal in V12.")] - // NOTE: When removing this, also clean up the hardcoded removal of UmbracoPath in Umbraco.JsonSchema set { } } diff --git a/tools/Umbraco.JsonSchema/Program.cs b/tools/Umbraco.JsonSchema/Program.cs index adf17c5c8ca4..4711f0278b03 100644 --- a/tools/Umbraco.JsonSchema/Program.cs +++ b/tools/Umbraco.JsonSchema/Program.cs @@ -1,5 +1,4 @@ using CommandLine; -using Umbraco.Cms.Core.Configuration.Models; await Parser.Default.ParseArguments(args).WithParsedAsync(async options => { @@ -7,8 +6,5 @@ await Parser.Default.ParseArguments(args).WithParsedAsync(async options var jsonSchemaGenerator = new UmbracoJsonSchemaGenerator(); var jsonSchema = jsonSchemaGenerator.Generate(typeof(UmbracoCmsSchema)); - // TODO: When the UmbracoPath setter is removed from GlobalSettings (scheduled for V12), remove this line as well - jsonSchema.Definitions[nameof(GlobalSettings)]?.Properties?.Remove(nameof(GlobalSettings.UmbracoPath)); - await File.WriteAllTextAsync(options.OutputFile, jsonSchema.ToJson()); });