Moving interfaces for services to Umbraco.Core.
Adding xml extensions for Content to generate xml for the xml cache. Adding test for xml generation.
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
using System;
|
||||
using System.Linq;
|
||||
using System.Xml;
|
||||
using System.Xml.Linq;
|
||||
|
||||
namespace Umbraco.Core.Models
|
||||
{
|
||||
@@ -41,6 +43,44 @@ namespace Umbraco.Core.Models
|
||||
}
|
||||
}
|
||||
|
||||
//TODO Possibly add a ToXml method, which will generate valid xml for the current Content object
|
||||
/// <summary>
|
||||
/// Creates the xml representation for the <see cref="IContent"/> object
|
||||
/// </summary>
|
||||
/// <param name="content"><see cref="IContent"/> to generate xml for</param>
|
||||
/// <returns>Xml representation of the passed in <see cref="IContent"/></returns>
|
||||
public static XElement ToXml(this IContent content)
|
||||
{
|
||||
//nodeName should match Casing.SafeAliasWithForcingCheck(content.ContentType.Alias);
|
||||
var nodeName = content.ContentType.Alias.ToUmbracoAlias(StringAliasCaseType.CamelCase, true);
|
||||
|
||||
var xml = new XElement(nodeName,
|
||||
new XAttribute("id", content.Id),
|
||||
new XAttribute("parentID", content.Level > 1 ? content.ParentId : -1),
|
||||
new XAttribute("level", content.Level),
|
||||
new XAttribute("writerID", content.Writer.Id),
|
||||
new XAttribute("creatorID", content.Creator.Id),
|
||||
new XAttribute("nodeType", content.ContentType.Id),
|
||||
new XAttribute("template", content.Template),//Template name versus Id
|
||||
new XAttribute("sortOrder", content.SortOrder),
|
||||
new XAttribute("createDate", content.CreateDate),
|
||||
new XAttribute("updateDate", content.UpdateDate),
|
||||
new XAttribute("nodeName", content.Name),
|
||||
new XAttribute("urlName", content.UrlName),//Format Url ?
|
||||
new XAttribute("writerName", content.Writer.Name),
|
||||
new XAttribute("creatorName", content.Creator.Name),
|
||||
new XAttribute("path", content.Path));
|
||||
|
||||
foreach (var property in content.Properties)
|
||||
{
|
||||
if (property == null) continue;
|
||||
|
||||
xml.Add(property.ToXml());
|
||||
|
||||
if (property.Alias == "umbracoUrlName" && property.Value.ToString().Trim() != string.Empty)
|
||||
xml.SetAttributeValue("urlName", property.Value);
|
||||
}
|
||||
|
||||
return xml;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -61,6 +61,12 @@ namespace Umbraco.Core.Models
|
||||
[IgnoreDataMember]
|
||||
internal DataTypeDatabaseType DataTypeDatabaseType { get { return _propertyType.DataTypeDatabaseType; } }
|
||||
|
||||
/// <summary>
|
||||
/// Returns the PropertyType, which this Property is based on
|
||||
/// </summary>
|
||||
[IgnoreDataMember]
|
||||
internal PropertyType PropertyType { get { return _propertyType; } }
|
||||
|
||||
/// <summary>
|
||||
/// Gets or Sets the version id for the Property
|
||||
/// </summary>
|
||||
|
||||
26
src/Umbraco.Core/Models/PropertyExtensions.cs
Normal file
26
src/Umbraco.Core/Models/PropertyExtensions.cs
Normal file
@@ -0,0 +1,26 @@
|
||||
using System;
|
||||
using System.Xml;
|
||||
using System.Xml.Linq;
|
||||
|
||||
namespace Umbraco.Core.Models
|
||||
{
|
||||
public static class PropertyExtensions
|
||||
{
|
||||
/// <summary>
|
||||
/// Creates the xml representation for the <see cref="Property"/> object
|
||||
/// </summary>
|
||||
/// <param name="property"><see cref="Property"/> to generate xml for</param>
|
||||
/// <returns>Xml of the property and its value</returns>
|
||||
public static XElement ToXml(this Property property)
|
||||
{
|
||||
string nodeName = property.Alias.ToUmbracoAlias();
|
||||
|
||||
var xd = new XmlDocument();
|
||||
XmlNode xmlNode = xd.CreateNode(XmlNodeType.Element, nodeName, "");
|
||||
xmlNode.AppendChild(property.PropertyType.DataType(property.Id).Data.ToXMl(xd));
|
||||
|
||||
var element = xmlNode.GetXElement();
|
||||
return element;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -126,7 +126,7 @@ namespace Umbraco.Core.Models
|
||||
internal Guid DataTypeControlId
|
||||
{
|
||||
get { return _dataTypeControlId; }
|
||||
private set
|
||||
set
|
||||
{
|
||||
_dataTypeControlId = value;
|
||||
OnPropertyChanged(DataTypeControlIdSelector);
|
||||
@@ -140,7 +140,7 @@ namespace Umbraco.Core.Models
|
||||
internal DataTypeDatabaseType DataTypeDatabaseType
|
||||
{
|
||||
get { return _dataTypeDatabaseType; }
|
||||
private set
|
||||
set
|
||||
{
|
||||
_dataTypeDatabaseType = value;
|
||||
OnPropertyChanged(DataTypeDatabaseTypeSelector);
|
||||
|
||||
@@ -8,6 +8,7 @@ namespace Umbraco.Core.Models
|
||||
/// Resolves the IDataType for a PropertyType.
|
||||
/// </summary>
|
||||
/// <param name="propertyType">PropertyType that references a DataType</param>
|
||||
/// <param name="propertyId">Id of the Property which references this DataType through its PropertyType</param>
|
||||
/// <returns><see cref="IDataType"/></returns>
|
||||
/// <remarks>
|
||||
/// This extension method is left internal because we don't want to take
|
||||
@@ -15,11 +16,12 @@ namespace Umbraco.Core.Models
|
||||
/// be replaced by PropertyEditors. It is however needed to generate xml
|
||||
/// for a property/propertytype when publishing.
|
||||
/// </remarks>
|
||||
internal static IDataType DataType(this PropertyType propertyType)
|
||||
internal static IDataType DataType(this PropertyType propertyType, int propertyId)
|
||||
{
|
||||
Mandate.ParameterNotNull(propertyType, "propertyType");
|
||||
var dataType = DataTypesResolver.Current.GetById(propertyType.DataTypeControlId);
|
||||
dataType.DataTypeDefinitionId = propertyType.DataTypeId;
|
||||
dataType.Data.PropertyId = propertyId;
|
||||
return dataType;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user