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}