【发布时间】:2016-06-02 17:49:00
【问题描述】:
我正在尝试在 Sitecore 中编写一个自定义发布处理器,以便我可以记录发布任何项目的确切日期和时间。我正在使用的代码(我改编自 Uli Welterbach 的代码here)不会引发错误,但它似乎没有给我实际发布的项目的 ID。我做错了什么?
public class PublicationProcessor : PublishProcessor
{
public override void Process(PublishContext context)
{
Assert.ArgumentNotNull(context, "context");
var cqs = context.Queue.ToList();
string connectionString = "Data Source=MyServer;initial catalog=AuditHistory; User ID=sa;Password=123456789;Integrated Security=false;";
var query = @"INSERT INTO [dbo].[ItemHistory]
([ItemID])
VALUES
(@ItemId)";
using (SqlConnection cn = new SqlConnection(connectionString))
{
foreach (var itemId in GetPublishQueueItems(context.PublishOptions))
{
using (SqlCommand cmd = new SqlCommand(query, cn))
{
// define parameters and their values
cmd.Parameters.Add("@ItemId", SqlDbType.UniqueIdentifier, 50).Value = itemId.ToGuid();
// open connection, execute INSERT, close connection
cn.Open();
cmd.ExecuteNonQuery();
cn.Close();
}
}
}
}
private IEnumerable<ID> GetPublishQueueItems(PublishOptions options)
{
if (options.Mode == PublishMode.Incremental)
return PublishQueue.GetPublishQueue(options).Select(candidate => candidate.ItemId).ToArray();
return PublishQueue.GetContentBranch(options).Select(candidate => candidate.ItemId).ToArray();
}
【问题讨论】: