All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.mule.service.soap.metadata.BodyMetadataResolver Maven / Gradle / Ivy

/*
 * Copyright (c) MuleSoft, Inc.  All rights reserved.  http://www.mulesoft.com
 * The software in this package is published under the terms of the CPAL v1.0
 * license, a copy of which has been included with this distribution in the
 * LICENSE.txt file.
 */
package org.mule.service.soap.metadata;

import static org.mule.metadata.api.utils.MetadataTypeUtils.getLocalPart;
import static org.mule.service.soap.util.SoapServiceMetadataTypeUtils.getAttachmentFields;
import static org.mule.service.soap.util.SoapServiceMetadataTypeUtils.getOperationType;

import org.mule.metadata.api.TypeLoader;
import org.mule.metadata.api.model.MetadataType;
import org.mule.metadata.api.model.NullType;
import org.mule.metadata.api.model.ObjectFieldType;
import org.mule.metadata.api.model.ObjectType;
import org.mule.runtime.api.metadata.MetadataResolvingException;
import org.mule.wsdl.parser.model.PortModel;
import org.mule.wsdl.parser.model.operation.OperationModel;

import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.function.Function;

import javax.wsdl.Part;

/**
 * Handles the dynamic {@link MetadataType} resolution for the SOAP Body parts of a web service operation.
 *
 * @since 1.0
 */
abstract class BodyMetadataResolver extends NodeMetadataResolver {

  BodyMetadataResolver(PortModel port,
                       TypeLoader loader,
                       Function> partRetriever) {
    super(port, loader, partRetriever);
  }

  @Override
  public MetadataType getMetadata(String operation) throws MetadataResolvingException {
    Part bodyPart = getBodyPart(operation);
    MetadataType bodyType = buildPartMetadataType(bodyPart);
    List attachmentFields = getAttachmentFields(bodyType);
    return filterAttachmentsFromBodyType(bodyType, attachmentFields);
  }

  /**
   * Filter the attachments fields from the body metadata type since SOAP manages the attachments as regular parameters but
   * we wan't to provide a body decoupled experience for the attachments.
   * 

* If after removing the attachments there are not fields remaining in the request, a {@link NullType} is returned. * * @param bodyType the {@link MetadataType} of the xml input body, with all the required parameters including the * @param attachments the attachments fields on found in the type. * @return the body {@link MetadataType} without the attachment fields. */ private MetadataType filterAttachmentsFromBodyType(MetadataType bodyType, List attachments) { if (!attachments.isEmpty() && bodyType instanceof ObjectType) { ObjectType operationType = getOperationType(bodyType); attachments.forEach(a -> operationType.getFields().removeIf(f -> getLocalPart(f).equals(getLocalPart(a)))); if (operationType.getFields().isEmpty()) { return nullType; } } return bodyType; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy