/* Copyright 2013 Red Hat, Inc. and/or its affiliates. This file is part of lightblue. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.redhat.lightblue.crud; import com.redhat.lightblue.metadata.FieldConstraint; import com.redhat.lightblue.metadata.FieldTreeNode; import com.redhat.lightblue.util.Path; import com.redhat.lightblue.util.JsonDoc; /** * Field constraint checker for constraints that run once for the document. This * is to implement stuff like the required constraint, so that even if the field * does not exist, constraint can be checked. */ public interface FieldConstraintDocChecker extends FieldConstraintChecker { /** * Field constraint checker function that is run once for the document * * @param validator The constraint validator instance from which the * implementation can access the metadata and context information * @param fieldMedata The field metadata * @param fieldMetadataPath The path for the field metadata (i.e. may * contain *) * @param constraint field constraint * @param doc The document * * The function should add the errors to validator */ void checkConstraint(ConstraintValidator validator, FieldTreeNode fieldMetadata, Path fieldMetadataPath, FieldConstraint constraint, JsonDoc doc); }