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

org.glassfish.jersey.server.model.ComponentModelValidator Maven / Gradle / Ivy

Go to download

A bundle project producing JAX-RS RI bundles. The primary artifact is an "all-in-one" OSGi-fied JAX-RS RI bundle (jaxrs-ri.jar). Attached to that are two compressed JAX-RS RI archives. The first archive (jaxrs-ri.zip) consists of binary RI bits and contains the API jar (under "api" directory), RI libraries (under "lib" directory) as well as all external RI dependencies (under "ext" directory). The secondary archive (jaxrs-ri-src.zip) contains buildable JAX-RS RI source bundle and contains the API jar (under "api" directory), RI sources (under "src" directory) as well as all external RI dependencies (under "ext" directory). The second archive also contains "build.xml" ANT script that builds the RI sources. To build the JAX-RS RI simply unzip the archive, cd to the created jaxrs-ri directory and invoke "ant" from the command line.

There is a newer version: 3.1.6
Show newest version
/*
 * Copyright (c) 2010, 2019 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */
package org.glassfish.jersey.server.model;

import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedList;
import java.util.List;

import org.glassfish.jersey.Severity;
import org.glassfish.jersey.internal.Errors;
import org.glassfish.jersey.message.MessageBodyWorkers;
import org.glassfish.jersey.server.model.internal.ModelErrors;
import org.glassfish.jersey.server.spi.internal.ValueParamProvider;

/**
 * A resource model validator that checks the given resource model.
 *
 * This base resource model validator class implements the visitor pattern to
 * traverse through all the {@link ResourceModelComponent resource model components}
 * to check validity of a resource model.
 * 

* This validator maintains a list of all the {@link ResourceModelIssue issues} * found in the model. That way all the resource model components can be validated * in a single call to the {@link #validate(ResourceModelComponent) validate(...)} * method and collect all the validation issues from the model. *

* To check a single resource class, the the {@link Resource} * {@code builder(...)} can be used to create a resource model. * * {@link ComponentModelValidator#validate(ResourceModelComponent)} * method then populates the issue list, which could be then obtained by the * {@link ComponentModelValidator#getIssueList()}. Unless the list is explicitly cleared, * a subsequent calls to the validate method will add new items to the list, * so that it can be used to build the issue list for more than one resource. To clear the * list, the {@link ComponentModelValidator#cleanIssueList()} method should be called. *

* * @author Jakub Podlesak * @author Marek Potociar */ public final class ComponentModelValidator { private final List issueList = new LinkedList<>(); public ComponentModelValidator(Collection valueParamProviders, MessageBodyWorkers msgBodyWorkers) { validators = new ArrayList<>(); validators.add(new ResourceValidator()); validators.add(new RuntimeResourceModelValidator(msgBodyWorkers)); validators.add(new ResourceMethodValidator(valueParamProviders)); validators.add(new InvocableValidator()); } private final List validators; /** * Returns a list of issues found after * {@link #validate(org.glassfish.jersey.server.model.ResourceModelComponent)} * method has been invoked. * * @return a non-null list of issues. */ public List getIssueList() { return issueList; } /** * Convenience method to see if there were fatal issues found. * * @return {@code true} if there are any fatal issues present in the current * issue list. */ public boolean fatalIssuesFound() { for (ResourceModelIssue issue : getIssueList()) { if (issue.getSeverity() == Severity.FATAL) { return true; } } return false; } /** * Removes all issues from the current issue list. The method could be used * to re-use the same {@link ComponentModelValidator} for another resource model. */ public void cleanIssueList() { issueList.clear(); } /** * The validate method validates a component and adds possible * issues found to it's list. The list of issues could be then retrieved * via getIssueList method. * * @param component resource model component. */ public void validate(final ResourceModelComponent component) { Errors.process(new Runnable() { @Override public void run() { Errors.mark(); validateWithErrors(component); issueList.addAll(ModelErrors.getErrorsAsResourceModelIssues(true)); Errors.unmark(); } }); } private void validateWithErrors(final ResourceModelComponent component) { for (ResourceModelVisitor validator : validators) { component.accept(validator); } final List componentList = component.getComponents(); if (null != componentList) { for (ResourceModelComponent subComponent : componentList) { validateWithErrors(subComponent); } } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy