Пользовательский конвейерный компонент BizTalk не загружает переопределенные свойства
У меня есть пользовательский компонент конвейера BizTalk 2013 R2, в котором определены несколько свойств времени разработки. По какой-то причине BizTalk загрузит значения свойств времени разработки, установленные в конструкторе конвейера VS, но игнорирует значения времени выполнения, установленные в консоли администрирования BizTalk. Мой компонент реализует IPersistPropertyBag, и я убедился, что он не выдает никаких исключений.
При отладке конвейера (подключенного к изолированному экземпляру хоста) я заметил, что BizTalk вызывает метод Load только при создании экземпляра конвейера. Это только загружает значения конструктора VS, и BizTalk должен затем снова вызвать метод Load перед вызовом Execute. К сожалению, этого не происходит.
[Edit] Я сделал еще несколько отладок и выяснил, что это, кажется, происходит только в конвейере отправки для двустороннего порта приема. Приемный конвейер загружает свойства времени проектирования и времени исполнения, как и ожидалось.
Вот пример моего кода:
[ComponentCategory(CategoryTypes.CATID_PipelineComponent)]
[ComponentCategory(CategoryTypes.CATID_Encoder)]
[System.Runtime.InteropServices.Guid(COMPONENT_GUID)]
public class RhapsodyMessageEncoder : BasePipelineComponent, IBaseComponent, IComponentUI,
IPersistPropertyBag, Microsoft.BizTalk.Component.Interop.IComponent
{
...
public void Load(IPropertyBag propertyBag, int errorLog)
{
try
{
this.Enabled = Convert.ToBoolean(this.ReadPropertyBag(propertyBag, "Enabled"));
this.UsernameSSOKey = this.ReadPropertyBag(propertyBag, "UsernameSSOKey") as string;
this.PasswordSsoKey = this.ReadPropertyBag(propertyBag, "PasswordSsoKey") as string;
this.AffiliateAppName = this.ReadPropertyBag(propertyBag, "AffiliateAppName") as string;
}
catch (Exception e) { this.WriteErrorLog(e); }
}
public void Save(IPropertyBag propertyBag, bool clearDirty, bool saveAllProperties)
{
try
{
this.WritePropertyBag(propertyBag, "Enabled", this.Enabled);
this.WritePropertyBag(propertyBag, "UsernameSSOKey", this.UsernameSSOKey);
this.WritePropertyBag(propertyBag, "PasswordSsoKey", this.PasswordSsoKey);
this.WritePropertyBag(propertyBag, "AffiliateAppName", this.AffiliateAppName);
}
catch (Exception e) { this.WriteErrorLog(e); }
}
...
}
Методы помощника мешка чтения / записи:
protected virtual object ReadPropertyBag(IPropertyBag pb, string propName)
{
PropertyInfo pInfo = this.GetType().GetProperty(propName);
object currentValue = null;
object val = null;
if (pInfo != null)
currentValue = pInfo.GetValue(this, null);
try
{
pb.Read(propName, out val, 0);
}
catch (System.ArgumentException e)
{
System.Diagnostics.Trace.WriteLine(
"Argument Exception encountered: " + e.Message,
this.Name
);
}
catch (System.Exception e)
{
throw new System.ApplicationException("Can't read design time Properties", e);
}
return val ?? currentValue;
}
protected virtual void WritePropertyBag(IPropertyBag pb, string propName, object val)
{
try
{
object obj = val;
pb.Write(propName, ref obj);
}
catch (System.Exception e)
{
throw new System.ApplicationException("Can't write design time properties", e);
}
}