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

de.gematik.prepare.ItemsCreator Maven / Gradle / Ivy

/*
 * Copyright 2023 gematik GmbH
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package de.gematik.prepare;

import static de.gematik.prepare.PrepareItemsMojo.getPluginLog;
import static java.util.Objects.nonNull;

import de.gematik.combine.model.CombineItem;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import lombok.Getter;
import org.apache.commons.jexl3.JexlBuilder;
import org.apache.commons.jexl3.JexlContext;
import org.apache.commons.jexl3.JexlEngine;
import org.apache.commons.jexl3.JexlException;
import org.apache.commons.jexl3.MapContext;

public class ItemsCreator {

  private static final String ERROR_START = "Error for api: ";
  private final PrepareItemsConfig config;
  private JexlContext context;

  @Getter private final List contextErrors = new ArrayList<>();

  private final JexlEngine jexlEngine;

  public ItemsCreator(PrepareItemsConfig config) {
    this.config = config;
    jexlEngine =
        new JexlBuilder().strict(!config.isAcceptUnknownInfo()).silent(false).safe(false).create();
  }

  public Void evaluateExpressions(CombineItem item, Map jsonContext) {
    context = new MapContext();
    context.set("$", jsonContext);
    config.getTagExpressions().forEach(e -> checkTagExpression(item, e));
    config.getPropertyExpressions().forEach(e -> checkPropertyExpression(item, e));
    return null;
  }

  private void checkTagExpression(CombineItem item, TagExpression tagExpression) {
    getPluginLog()
        .debug(
            "Evaluating tag expression -> "
                + tagExpression.getExpression()
                + " - "
                + tagExpression.getTag());
    var newTags = new HashSet<>(item.getTags());

    try {
      Boolean result =
          (Boolean) jexlEngine.createExpression(tagExpression.getExpression()).evaluate(context);
      if (result != null && result) {
        newTags.add(tagExpression.getTag());
      } else {
        if (item.getTags().contains(tagExpression.getTag())) {
          contextErrors.add(
              ERROR_START
                  + item.getValue()
                  + " -> for tag "
                  + tagExpression.getTag()
                  + " extension "
                  + tagExpression.getExpression()
                  + " should return true");
          newTags.remove(tagExpression.getTag());
        }
      }
    } catch (JexlException ex) {
      getPluginLog().warn(ex.getMessage(), ex);
      throw ex;
    }
    item.setTags(newTags);
  }

  private void checkPropertyExpression(CombineItem item, PropertyExpression propertyExpression) {
    Entry entry =
        evaluatePropertyExpression(propertyExpression, item.getProperties(), item);
    var propertiesCopy = new HashMap<>(item.getProperties());
    if (entry != null) {
      propertiesCopy.put(entry.getKey(), entry.getValue());
      item.setProperties(propertiesCopy);
    } else {
      item.getProperties().remove(propertyExpression.getProperty());
    }
  }

  private Entry evaluatePropertyExpression(
      PropertyExpression propertyExpression,
      Map existingProperties,
      CombineItem item) {
    getPluginLog().debug("evaluating " + propertyExpression.getExpression());
    String value;
    try {
      value =
          (String)
              jexlEngine.createExpression(propertyExpression.getExpression()).evaluate(context);
    } catch (JexlException ex) {
      getPluginLog().warn(ex.getMessage());
      return null;
    }
    if (value == null) {
      contextErrors.add(
          ERROR_START
              + item.getValue()
              + (nonNull(item.getUrl()) ? " url: " + item.getUrl() : "")
              + " -> at property "
              + propertyExpression.getProperty()
              + ": Could not find any value at -> "
              + propertyExpression.getExpression());
      return null;
    }
    if (existingProperties.containsKey(propertyExpression.getProperty())) {
      String existingProperty = existingProperties.get(propertyExpression.getProperty());
      if (!value.equals(existingProperty)) {
        contextErrors.add(
            ERROR_START
                + item.getValue()
                + (nonNull(item.getUrl()) ? " url: " + item.getUrl() : "")
                + " -> at property "
                + propertyExpression.getProperty()
                + ": Found value -> \""
                + value
                + "\" differ from -> \""
                + existingProperty
                + "\" for expression -> "
                + propertyExpression.getExpression());
      }
    }
    Entry keyValue = Map.entry(propertyExpression.getProperty(), value);
    getPluginLog().debug("proceeded property -> " + keyValue);
    return keyValue;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy