1 /*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19 package org.apache.maven.api.services.model;
20
21 import org.apache.maven.api.Session;
22 import org.apache.maven.api.model.Model;
23 import org.apache.maven.api.services.ModelProblemCollector;
24
25 /**
26 * Checks the model for missing or invalid values.
27 *
28 */
29 public interface ModelValidator {
30 /**
31 * Denotes minimal validation of POMs. This validation level is meant for processing of POMs from repositories
32 * during metadata retrieval.
33 */
34 int VALIDATION_LEVEL_MINIMAL = 0;
35 /**
36 * Denotes validation as performed by Maven 2.0. This validation level is meant as a compatibility mode to allow
37 * users to migrate their projects.
38 */
39 int VALIDATION_LEVEL_MAVEN_2_0 = 20;
40 /**
41 * Denotes validation as performed by Maven 3.0. This validation level is meant for existing projects.
42 */
43 int VALIDATION_LEVEL_MAVEN_3_0 = 30;
44 /**
45 * Denotes validation as performed by Maven 3.1. This validation level is meant for existing projects.
46 */
47 int VALIDATION_LEVEL_MAVEN_3_1 = 31;
48 /**
49 * Denotes validation as performed by Maven 4.0. This validation level is meant for new projects.
50 */
51 int VALIDATION_LEVEL_MAVEN_4_0 = 40;
52 /**
53 * Denotes validation as performed by Maven 4.1. This validation level is meant for new projects.
54 */
55 int VALIDATION_LEVEL_MAVEN_4_1 = 41;
56 /**
57 * Denotes validation as performed by Maven 4.2. This validation level is meant for new projects.
58 */
59 int VALIDATION_LEVEL_MAVEN_4_2 = 42;
60 /**
61 * Denotes strict validation as recommended by the current Maven version.
62 */
63 int VALIDATION_LEVEL_STRICT = VALIDATION_LEVEL_MAVEN_4_2;
64
65 /**
66 * Checks the specified file model for missing or invalid values. This model is directly created from the POM
67 * file and has not been subjected to inheritance, interpolation or profile/default injection.
68 *
69 * @param model The model to validate, must not be {@code null}.
70 * @param validationLevel The validation level.
71 * @param problems The container used to collect problems that were encountered, must not be {@code null}.
72 */
73 void validateFileModel(Session session, Model model, int validationLevel, ModelProblemCollector problems);
74
75 /**
76 * Checks the specified (raw) model for missing or invalid values. The raw model is the file model + buildpom filter
77 * transformation and has not been subjected to inheritance, interpolation or profile/default injection.
78 *
79 * @param model The model to validate, must not be {@code null}.
80 * @param validationLevel The validation level.
81 * @param problems The container used to collect problems that were encountered, must not be {@code null}.
82 */
83 void validateRawModel(Session session, Model model, int validationLevel, ModelProblemCollector problems);
84
85 /**
86 * Checks the specified (effective) model for missing or invalid values. The effective model is fully assembled and
87 * has undergone inheritance, interpolation and other model operations.
88 *
89 * @param model The model to validate, must not be {@code null}.
90 * @param validationLevel The validation level.
91 * @param problems The container used to collect problems that were encountered, must not be {@code null}.
92 */
93 void validateEffectiveModel(Session session, Model model, int validationLevel, ModelProblemCollector problems);
94 }