001/* Copyright (C) 2014 konik.io
002 *
003 * This file is part of the Konik library.
004 *
005 * The Konik library is free software: you can redistribute it and/or modify
006 * it under the terms of the GNU Affero General Public License as
007 * published by the Free Software Foundation, either version 3 of the
008 * License, or (at your option) any later version.
009 *
010 * The Konik library is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
013 * GNU Affero General Public License for more details.
014 *
015 * You should have received a copy of the GNU Affero General Public License
016 * along with the Konik library. If not, see <http://www.gnu.org/licenses/>.
017 */
018package io.konik.validator.annotation;
019
020import static java.lang.annotation.ElementType.ANNOTATION_TYPE;
021import static java.lang.annotation.ElementType.TYPE;
022import static java.lang.annotation.RetentionPolicy.RUNTIME;
023import io.konik.validator.ValidFinancialAccountValidator;
024
025import java.lang.annotation.Documented;
026import java.lang.annotation.Retention;
027import java.lang.annotation.Target;
028
029import javax.validation.Constraint;
030import javax.validation.Payload;
031
032/**
033 *  
034 * The Financial Account will is considered correct when it has an IBAN or a proprietary id.
035 */
036@Target({ TYPE, ANNOTATION_TYPE })
037@Retention(RUNTIME)
038@Constraint(validatedBy = { ValidFinancialAccountValidator.class })
039@Documented
040public @interface ValidFinancialAccount {
041
042    String message() default "{io.konik.validation.constraints.financialaccount.message}";
043
044    Class<?>[] groups() default { };
045
046    Class<? extends Payload>[] payload() default { };
047}