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

jaxrs.examples.client.validator.ValidatorExample Maven / Gradle / Ivy

/*
 * Copyright (c) 2011, 2017 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Distribution License v. 1.0, which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

package jaxrs.examples.client.validator;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;

import jakarta.enterprise.util.AnnotationLiteral;
import jakarta.validation.Constraint;
import jakarta.validation.ConstraintValidator;
import jakarta.validation.ConstraintValidatorContext;
import jakarta.validation.Payload;

/**
 * Example that shows how to use the Validation API.
 */
public class ValidatorExample {

    /**
     * Email annotation.
     */
    @java.lang.annotation.Target({ ElementType.METHOD, ElementType.FIELD, ElementType.PARAMETER })
    @Retention(RetentionPolicy.RUNTIME)
    @Constraint(validatedBy = EmailValidator.class)
    public @interface Email {

        String message() default "{foo.bar.validation.constraints.email}";

        Class[] groups() default {};

        Class[] payload() default {};
    }

    /**
     * Email validator.
     */
    public static class EmailValidator implements ConstraintValidator {

        @Override
        public void initialize(Email email) {
            // no-op
        }

        @Override
        public boolean isValid(String value, ConstraintValidatorContext context) {
            // Ensure value is a valid e-mail address
            return true;
        }
    }

    /**
     * Email annotation literal.
     */
    public class EmailImpl extends AnnotationLiteral implements Email {

        private static final long serialVersionUID = -3177939101972190621L;

        @Override
        public String message() {
            return "{jakarta.validation.constraints.NotNull.message}";
        }

        @Override
        public Class[] groups() {
            return new Class[0];
        }

        @Override
        @SuppressWarnings("unchecked")
        public Class[] payload() {
            return (Class[]) new Class[0];
        }
    }
//    public void annotationBasedRequestResponseValidation() {
//        Client c = ClientBuilder.newClient();
//
//        HttpResponse response = c.target("http://example.com/foo/").post().entity("[email protected]", new EmailImpl()).invoke();
//
//        String userId = response.annotateEntity(new NotNull(), new Pattern("[0-9]+")).getEntity(String.class);
//        System.out.println("User id = " + userId);
//    }
//    public void annotationBasedRequestParameterValidation() {
//        Client c = ClientBuilder.newClient();
//
//        final Target rootResource = c.target("http://example.com/foo");
//        String userId = rootResource.get().queryParam("email", "[email protected]", new EmailImpl()).invoke(String.class);
//
//        // Path param validation using resource target:
//        HttpResponse r1 = rootResource.path("{userId}").pathParam("userId", userId, new Pattern("[0-9]+")).get().invoke();
//        assert r1.getStatus() == Response.Status.OK;
//
//        // Path param validation using invocation:
//        HttpResponse r2 = rootResource.path("{userId}").get().pathParam("userId", userId, new Pattern("[0-9]+")).invoke();
//        assert r2.getStatus() == Response.Status.OK;
//    }
//    public void example2() {
//        Client c = ClientBuilder.newClient();
//        /*
//        String response = c.resourceUri("http://example.com/foo/")
//        .put()
//        .entity("[email protected]", EmailValidator.class)
//        .invoke(String.class, EmailValidator.class);
//         */
//    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy