Compartilhar via


WsdlContractConversionContext Classe

Definição

Passado para exportadores e importadores WSDL personalizados para habilitar a personalização dos processos de importação e exportação de metadados para um contrato.

public ref class WsdlContractConversionContext
public class WsdlContractConversionContext
type WsdlContractConversionContext = class
Public Class WsdlContractConversionContext
Herança
WsdlContractConversionContext

Exemplos

O exemplo de código a seguir mostra o uso das anotações personalizadas do WsdlContractConversionContext WSDL aos metadados exportados usando as propriedades e Contract as WsdlPortType propriedades.

public void ExportContract(WsdlExporter exporter, WsdlContractConversionContext context)
{
Console.WriteLine("Inside ExportContract");
if (context.Contract != null)
{
    // Inside this block it is the contract-level comment attribute.
    // This.Text returns the string for the contract attribute.
    // Set the doc element; if this isn't done first, there is no XmlElement in the
    // DocumentElement property.
    context.WsdlPortType.Documentation = string.Empty;
    // Contract comments.
    XmlDocument owner = context.WsdlPortType.DocumentationElement.OwnerDocument;
    XmlElement summaryElement = Formatter.CreateSummaryElement(owner, this.Text);
    context.WsdlPortType.DocumentationElement.AppendChild(summaryElement);

    foreach (OperationDescription op in context.Contract.Operations)
    {
        Operation operation = context.GetOperation(op);
        object[] opAttrs = op.SyncMethod.GetCustomAttributes(typeof(WsdlDocumentationAttribute), false);
        if (opAttrs.Length == 1)
        {
            string opComment = ((WsdlDocumentationAttribute)opAttrs[0]).Text;

            // This.Text returns the string for the operation-level attributes.
            // Set the doc element; if this isn't done first, there is no XmlElement in the
            // DocumentElement property.
            operation.Documentation = String.Empty;

            // Operation C# triple comments.
            XmlDocument opOwner = operation.DocumentationElement.OwnerDocument;
            XmlElement newSummaryElement = Formatter.CreateSummaryElement(opOwner, opComment);
            operation.DocumentationElement.AppendChild(newSummaryElement);

            // Get returns information
            ParameterInfo returnValue = op.SyncMethod.ReturnParameter;
            object[] returnAttrs = returnValue.GetCustomAttributes(typeof(WsdlParameterDocumentationAttribute), false);
            if (returnAttrs.Length == 1)
            {
                // <returns>text.</returns>
                XmlElement returnsElement =
                  Formatter.CreateReturnsElement(
                    opOwner,
                    ((WsdlParameterDocumentationAttribute)returnAttrs[0]).ParamComment
                  );
                operation.DocumentationElement.AppendChild(returnsElement);
            }

            // Get parameter information.
            ParameterInfo[] args = op.SyncMethod.GetParameters();
            for (int i = 0; i < args.Length; i++)
            {
                object[] docAttrs
                  = args[i].GetCustomAttributes(typeof(WsdlParameterDocumentationAttribute), false);
                if (docAttrs.Length != 0)
                {
                    // <param name="Int1">Text.</param>
                    XmlElement newParamElement = opOwner.CreateElement("param");
                    XmlAttribute paramName = opOwner.CreateAttribute("name");
                    paramName.Value = args[i].Name;
                    newParamElement.InnerText
                      = ((WsdlParameterDocumentationAttribute)docAttrs[0]).ParamComment;
                    newParamElement.Attributes.Append(paramName);
                    operation.DocumentationElement.AppendChild(newParamElement);
                }
            }
        }
    }
}

Comentários

Use o WsdlContractConversionContext objeto para examinar e modificar itens que devem ser convertidos para ou de WSDL.

Ao exportar metadados, um WsdlContractConversionContext objeto é passado para os métodos e ExportEndpoint os ExportContract métodos. Use os vários métodos e propriedades para obter objetos de metadados que você pode usar para examinar e modificar para alterar o WSDL publicado.

Ao importar metadados, um WsdlContractConversionContext objeto é passado para os métodos e ImportEndpoint os ImportContract métodos. Use os vários métodos e propriedades para obter objetos de metadados que você pode usar para examinar e modificar os metadados importados.

Propriedades

Contract

Obtém o ContractDescription que está sendo exportado ou importado.

WsdlPortType

Obtém o PortType que representa o contrato.

Métodos

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
GetFaultDescription(OperationFault)

Retorna a descrição da falha especificada.

GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetMessageDescription(OperationMessage)

Retorna a descrição da mensagem especificada.

GetOperation(OperationDescription)

Retorna a operação da descrição de operação especificada.

GetOperationDescription(Operation)

Retorna a descrição da operação associada à operação.

GetOperationFault(FaultDescription)

Retorna a OperationFault da FaultDescription solicitada.

GetOperationMessage(MessageDescription)

Obtém um objeto OperationMessage para a message especificada que representa um tipo de mensagem passado pela ação de um serviço Web XML.

GetType()

Obtém o Type da instância atual.

(Herdado de Object)
MemberwiseClone()

Cria uma cópia superficial do Object atual.

(Herdado de Object)
ToString()

Retorna uma cadeia de caracteres que representa o objeto atual.

(Herdado de Object)

Aplica-se a