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

io.github.theangrydev.businessflows.HappyCaseValidationPath Maven / Gradle / Ivy

/*
 * Copyright 2016 Liam Williams .
 *
 * This file is part of business-flows.
 *
 * 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 io.github.theangrydev.businessflows;

import java.util.ArrayList;
import java.util.List;

/**
 * A {@link HappyCaseValidationPath} is a {@link ValidationPath} that is actually a {@link HappyCase}.
 * 

* {@inheritDoc} */ class HappyCaseValidationPath extends HappyCaseHappyPath implements ValidationPath { private final Mapping, SadAggregate> sadAggregateMapping; HappyCaseValidationPath(Happy happy, Mapping, SadAggregate> sadAggregateMapping) { super(happy); this.sadAggregateMapping = sadAggregateMapping; } @Override public ValidationPath validateAll(List> validators) { return validateAllInto(sadAggregateMapping, validators); } @Override public ValidationPath validateAllInto(Mapping, SadAggregate> sadAggregateMapping, List> validators) { try { List validationFailures = validationFailures(validators); if (validationFailures.isEmpty()) { return ValidationPath.validationPathInto(happy, sadAggregateMapping); } SadAggregate sadAggregate = sadAggregateMapping.map(validationFailures); return ValidationPath.validationFailure(sadAggregate); } catch (Exception technicalFailure) { return ValidationPath.technicalFailure(technicalFailure); } } private List validationFailures(List> validators) throws Exception { List validationFailures = new ArrayList<>(validators.size()); for (Validator validator : validators) { validator.attempt(happy).ifSad(validationFailures::add); } return validationFailures; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy