diff --git a/src/Orchard.Web/Core/Common/Drivers/IdentityPartDriver.cs b/src/Orchard.Web/Core/Common/Drivers/IdentityPartDriver.cs new file mode 100644 index 000000000..7665e3d40 --- /dev/null +++ b/src/Orchard.Web/Core/Common/Drivers/IdentityPartDriver.cs @@ -0,0 +1,30 @@ +using JetBrains.Annotations; +using Orchard.ContentManagement.Drivers; +using Orchard.Core.Common.Models; +using Orchard.Localization; + +namespace Orchard.Core.Common.Drivers { + [UsedImplicitly] + public class IdentityPartDriver : ContentPartDriver { + public IdentityPartDriver() { + T = NullLocalizer.Instance; + } + + public Localizer T { get; set; } + + protected override string Prefix { + get { return "Identity"; } + } + + protected override void Importing(IdentityPart part, ContentManagement.Handlers.ImportContentContext context) { + var identity = context.Attribute(part.PartDefinition.Name, "Identifier"); + if (identity != null) { + part.Identifier = identity; + } + } + + protected override void Exporting(IdentityPart part, ContentManagement.Handlers.ExportContentContext context) { + context.Element(part.PartDefinition.Name).SetAttributeValue("Identifier", part.Identifier); + } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Core/Common/Handlers/IdentityPartHandler.cs b/src/Orchard.Web/Core/Common/Handlers/IdentityPartHandler.cs new file mode 100644 index 000000000..5565678cb --- /dev/null +++ b/src/Orchard.Web/Core/Common/Handlers/IdentityPartHandler.cs @@ -0,0 +1,28 @@ +using System; +using JetBrains.Annotations; +using Orchard.ContentManagement; +using Orchard.Core.Common.Models; +using Orchard.Data; +using Orchard.ContentManagement.Handlers; + +namespace Orchard.Core.Common.Handlers { + [UsedImplicitly] + public class IdentityPartHandler : ContentHandler { + public IdentityPartHandler(IRepository identityRepository) { + Filters.Add(StorageFilter.For(identityRepository)); + OnInitializing(AssignIdentity); + } + + protected void AssignIdentity(InitializingContentContext context, IdentityPart part) { + part.Identifier = Guid.NewGuid().ToString("n"); + } + + protected override void GetItemMetadata(GetContentItemMetadataContext context) { + var part = context.ContentItem.As(); + + if (part != null) { + context.Metadata.Identity.Add("Identifier", part.Identifier); + } + } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Core/Common/Migrations.cs b/src/Orchard.Web/Core/Common/Migrations.cs index f66d75518..65e67510a 100644 --- a/src/Orchard.Web/Core/Common/Migrations.cs +++ b/src/Orchard.Web/Core/Common/Migrations.cs @@ -36,5 +36,16 @@ namespace Orchard.Core.Common { return 1; } + + public int UpdateFrom1() { + SchemaBuilder.CreateTable("IdentityPartRecord", + table => table + .ContentPartRecord() + .Column("Identifier", column => column.Unlimited()) + ); + ContentDefinitionManager.AlterPartDefinition("IdentityPart", builder => builder.Attachable()); + + return 2; + } } } \ No newline at end of file diff --git a/src/Orchard.Web/Core/Common/Models/IdentityPart.cs b/src/Orchard.Web/Core/Common/Models/IdentityPart.cs new file mode 100644 index 000000000..2c34ab5e6 --- /dev/null +++ b/src/Orchard.Web/Core/Common/Models/IdentityPart.cs @@ -0,0 +1,10 @@ +using Orchard.ContentManagement; + +namespace Orchard.Core.Common.Models { + public class IdentityPart : ContentPart { + public string Identifier { + get { return Record.Identifier; } + set { Record.Identifier = value; } + } + } +} diff --git a/src/Orchard.Web/Core/Common/Models/IdentityPartRecord.cs b/src/Orchard.Web/Core/Common/Models/IdentityPartRecord.cs new file mode 100644 index 000000000..04f36d457 --- /dev/null +++ b/src/Orchard.Web/Core/Common/Models/IdentityPartRecord.cs @@ -0,0 +1,7 @@ +using Orchard.ContentManagement.Records; + +namespace Orchard.Core.Common.Models { + public class IdentityPartRecord : ContentPartRecord { + public virtual string Identifier { get; set; } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Core/Orchard.Core.csproj b/src/Orchard.Web/Core/Orchard.Core.csproj index 54d6e3a87..ada38aafc 100644 --- a/src/Orchard.Web/Core/Orchard.Core.csproj +++ b/src/Orchard.Web/Core/Orchard.Core.csproj @@ -61,7 +61,11 @@ + + + + diff --git a/src/Orchard.Web/Modules/Orchard.Comments/Handlers/CommentPartHandler.cs b/src/Orchard.Web/Modules/Orchard.Comments/Handlers/CommentPartHandler.cs index 116c431ce..396364fe4 100644 --- a/src/Orchard.Web/Modules/Orchard.Comments/Handlers/CommentPartHandler.cs +++ b/src/Orchard.Web/Modules/Orchard.Comments/Handlers/CommentPartHandler.cs @@ -1,6 +1,5 @@ using JetBrains.Annotations; using Orchard.Comments.Models; -using Orchard.ContentManagement; using Orchard.ContentManagement.Handlers; using Orchard.Data; @@ -10,13 +9,5 @@ namespace Orchard.Comments.Handlers { public CommentPartHandler(IRepository commentsRepository) { Filters.Add(StorageFilter.For(commentsRepository)); } - - protected override void GetItemMetadata(GetContentItemMetadataContext context) { - var part = context.ContentItem.As(); - - if (part != null) { - context.Metadata.Identity.Add("Comment.CommentAuthor", part.Record.Author); - } - } } } \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Comments/Migrations.cs b/src/Orchard.Web/Modules/Orchard.Comments/Migrations.cs index 977a8e231..bc16f96cf 100644 --- a/src/Orchard.Web/Modules/Orchard.Comments/Migrations.cs +++ b/src/Orchard.Web/Modules/Orchard.Comments/Migrations.cs @@ -38,6 +38,7 @@ namespace Orchard.Comments { cfg => cfg .WithPart("CommentPart") .WithPart("CommonPart") + .WithPart("IdentityPart") ); ContentDefinitionManager.AlterTypeDefinition("Blog", @@ -47,7 +48,13 @@ namespace Orchard.Comments { ContentDefinitionManager.AlterPartDefinition("CommentsPart", builder => builder.Attachable()); - return 1; + return 2; + } + + public int UpdateFrom1() { + ContentDefinitionManager.AlterTypeDefinition("Comment", cfg => cfg.WithPart("IdentityPart")); + + return 2; } } } \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Setup/Recipes/blog.recipe.xml b/src/Orchard.Web/Modules/Orchard.Setup/Recipes/blog.recipe.xml index 24dc4ef4b..f0aca5d34 100644 --- a/src/Orchard.Web/Modules/Orchard.Setup/Recipes/blog.recipe.xml +++ b/src/Orchard.Web/Modules/Orchard.Setup/Recipes/blog.recipe.xml @@ -48,9 +48,9 @@ layer create Disabled /LayerRule:"false" layer create TheHomepage /LayerRule:"url '~/'" blog create /Slug:"blog" /Title:"Blog" /Homepage:true /Description:"This is your Orchard Blog." - widget create HtmlWidget /Title:"First Leader Aside" /Zone:"TripelFirst" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true - widget create HtmlWidget /Title:"Second Leader Aside" /Zone:"TripelSecond" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true - widget create HtmlWidget /Title:"Third Leader Aside" /Zone:"TripelThird" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"First Leader Aside" /Zone:"TripelFirst" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget1" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"Second Leader Aside" /Zone:"TripelSecond" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget2" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"Third Leader Aside" /Zone:"TripelThird" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget3" /UseLoremIpsumText:true menuitem create /MenuPosition:"1" /MenuText:"Home" /Url:"" /OnMainMenu:true diff --git a/src/Orchard.Web/Modules/Orchard.Setup/Recipes/default.recipe.xml b/src/Orchard.Web/Modules/Orchard.Setup/Recipes/default.recipe.xml index 0ec81bbdd..c3af9e0de 100644 --- a/src/Orchard.Web/Modules/Orchard.Setup/Recipes/default.recipe.xml +++ b/src/Orchard.Web/Modules/Orchard.Setup/Recipes/default.recipe.xml @@ -44,9 +44,9 @@ layer create Disabled /LayerRule:"false" layer create TheHomepage /LayerRule:"url '~/'" page create /Slug:"welcome-to-orchard" /Title:"Welcome to Orchard!" /Path:"welcome-to-orchard" /Homepage:true /Publish:true /UseWelcomeText:true - widget create HtmlWidget /Title:"First Leader Aside" /Zone:"TripelFirst" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true - widget create HtmlWidget /Title:"Second Leader Aside" /Zone:"TripelSecond" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true - widget create HtmlWidget /Title:"Third Leader Aside" /Zone:"TripelThird" /Position:"5" /Layer:"TheHomepage" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"First Leader Aside" /Zone:"TripelFirst" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget1" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"Second Leader Aside" /Zone:"TripelSecond" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget2" /UseLoremIpsumText:true + widget create HtmlWidget /Title:"Third Leader Aside" /Zone:"TripelThird" /Position:"5" /Layer:"TheHomepage" /Identity:"SetupHtmlWidget3" /UseLoremIpsumText:true menuitem create /MenuPosition:"1" /MenuText:"Home" /Url:"" /OnMainMenu:true diff --git a/src/Orchard.Web/Modules/Orchard.Widgets/Commands/WidgetCommands.cs b/src/Orchard.Web/Modules/Orchard.Widgets/Commands/WidgetCommands.cs index 30593283f..6fb3d12c6 100644 --- a/src/Orchard.Web/Modules/Orchard.Widgets/Commands/WidgetCommands.cs +++ b/src/Orchard.Web/Modules/Orchard.Widgets/Commands/WidgetCommands.cs @@ -34,6 +34,9 @@ namespace Orchard.Widgets.Commands { [OrchardSwitch] public string Layer { get; set; } + [OrchardSwitch] + public string Identity { get; set; } + [OrchardSwitch] public string Owner { get; set; } @@ -47,8 +50,8 @@ namespace Orchard.Widgets.Commands { public bool Publish { get; set; } [CommandName("widget create")] - [CommandHelp("widget create /Title: /Zone:<zone> /Position:<position> /Layer:<layer> [/Owner:<owner>] [/Text:<text>] [/UseLoremIpsumText:true|false]\r\n\t" + "Creates a new widget")] - [OrchardSwitches("Title,Zone,Position,Layer,Owner,Text,UseLoremIpsumText")] + [CommandHelp("widget create <type> /Title:<title> /Zone:<zone> /Position:<position> /Layer:<layer> [/Identity:<identity>] [/Owner:<owner>] [/Text:<text>] [/UseLoremIpsumText:true|false]\r\n\t" + "Creates a new widget")] + [OrchardSwitches("Title,Zone,Position,Layer,Identity,Owner,Text,UseLoremIpsumText")] public void Create(string type) { var widgetTypes = _widgetsService.GetWidgetTypes(); if (!widgetTypes.Contains(type)) { @@ -81,6 +84,10 @@ namespace Orchard.Widgets.Commands { var owner = _membershipService.GetUser(Owner); widget.As<ICommonPart>().Owner = owner; + if (widget.Has<IdentityPart>() && !String.IsNullOrEmpty(Identity)) { + widget.As<IdentityPart>().Identifier = Identity; + } + Context.Output.WriteLine(T("Widget created successfully.").Text); } diff --git a/src/Orchard.Web/Modules/Orchard.Widgets/Handlers/WidgetPartHandler.cs b/src/Orchard.Web/Modules/Orchard.Widgets/Handlers/WidgetPartHandler.cs index adaeaed34..4bccfe343 100644 --- a/src/Orchard.Web/Modules/Orchard.Widgets/Handlers/WidgetPartHandler.cs +++ b/src/Orchard.Web/Modules/Orchard.Widgets/Handlers/WidgetPartHandler.cs @@ -37,10 +37,6 @@ namespace Orchard.Widgets.Handlers { {"Action", "EditWidget"}, {"Id", context.ContentItem.Id} }; - - context.Metadata.Identity.Add("Widget.Title", widget.Title); - context.Metadata.Identity.Add("Widget.Position", widget.Position); - context.Metadata.Identity.Add("Widget.Zone", widget.Zone); } } } \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Widgets/Migrations.cs b/src/Orchard.Web/Modules/Orchard.Widgets/Migrations.cs index 3f0e64889..aa50f10c8 100644 --- a/src/Orchard.Web/Modules/Orchard.Widgets/Migrations.cs +++ b/src/Orchard.Web/Modules/Orchard.Widgets/Migrations.cs @@ -56,10 +56,17 @@ namespace Orchard.Widgets { .WithPart("WidgetPart") .WithPart("BodyPart") .WithPart("CommonPart") + .WithPart("IdentityPart") .WithSetting("Stereotype", "Widget") ); - return 1; + return 2; + } + + public int UpdateFrom1() { + ContentDefinitionManager.AlterTypeDefinition("HtmlWidget", cfg => cfg.WithPart("IdentityPart")); + + return 2; } } } \ No newline at end of file