Contratos de dados compatíveis com o futuro
Um recurso do sistema de contrato de dados do Windows Communication Foundation (WCF) é que os contratos podem evoluir ao longo do tempo de maneiras ininterruptas. Ou seja, um cliente com uma versão mais antiga de um contrato de dados pode se comunicar com um serviço com uma versão mais recente do mesmo contrato de dados, ou um cliente com uma versão mais recente de um contrato de dados pode se comunicar com uma versão mais antiga do mesmo contrato de dados. Para obter mais informações, consulte Práticas recomendadas: controle de versão de contrato de dados.
Você pode aplicar a maioria dos recursos de controle de versão conforme necessário quando novas versões de um contrato de dados existente são criadas. No entanto, um recurso de controle de versão, round-tripping, deve ser incorporado ao tipo da primeira versão para funcionar corretamente.
Ida e volta
A ida e volta ocorre quando os dados passam de uma nova versão para uma versão antiga e voltam para a nova versão de um contrato de dados. A viagem de ida e volta garante que nenhum dado seja perdido. A habilitação de ida e volta torna o tipo compatível com quaisquer alterações futuras suportadas pelo modelo de controle de versão do contrato de dados.
Para habilitar a viagem de ida e volta para um tipo específico, o tipo deve implementar a IExtensibleDataObject interface. A interface contém uma propriedade ExtensionData (retornando o ExtensionDataObject tipo). A propriedade armazena quaisquer dados de versões futuras do contrato de dados que sejam desconhecidos para a versão atual.
Exemplo
O contrato de dados a seguir não é compatível com alterações futuras.
[DataContract]
public class Person
{
[DataMember]
public string fullName;
}
<DataContract()> _
Public Class Person
<DataMember()> _
Public fullName As String
End Class
Para tornar o tipo compatível com alterações futuras (como adicionar um novo membro de dados chamado "phoneNumber"), implemente a IExtensibleDataObject interface.
[DataContract]
public class Person : IExtensibleDataObject
{
[DataMember]
public string fullName;
private ExtensionDataObject theData;
public virtual ExtensionDataObject ExtensionData
{
get { return theData; }
set { theData = value; }
}
}
<DataContract()> _
Public Class Person
Implements IExtensibleDataObject
<DataMember()> _
Public fullName As String
Private theData As ExtensionDataObject
Public Overridable Property ExtensionData() As _
ExtensionDataObject Implements _
IExtensibleDataObject.ExtensionData
Get
Return theData
End Get
Set
theData = value
End Set
End Property
End Class
Quando a infraestrutura WCF encontra dados que não fazem parte do contrato de dados original, os dados são armazenados na propriedade e preservados. Não é processado de qualquer outra forma, exceto para armazenamento temporário. Se o objeto for devolvido ao local de origem, os dados originais (desconhecidos) também serão retornados. Portanto, os dados fizeram uma viagem de ida e volta de e para o endpoint de origem sem perda. Observe, no entanto, que se o ponto de extremidade de origem exigiu que os dados fossem processados, essa expectativa não será atendida e o ponto de extremidade deve, de alguma forma, detetar e acomodar a alteração.
O ExtensionDataObject tipo não contém métodos ou propriedades públicas. Assim, é impossível obter acesso direto aos dados armazenados dentro da ExtensionData propriedade.
O recurso de ida e volta pode ser desativado, seja definindo ignoreExtensionDataObject
como true
no DataContractSerializer construtor ou definindo a IgnoreExtensionDataObject propriedade como true
no ServiceBehaviorAttribute. Quando esse recurso estiver desativado, o desserializador não preencherá a ExtensionData propriedade e o serializador não emitirá o conteúdo da propriedade.