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

de.bund.bva.isyfact.serviceapi.annotations.Schluesseltyp Maven / Gradle / Ivy

/*
 * See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 * The Federal Office of Administration (Bundesverwaltungsamt, BVA)
 * licenses this file to you under the Apache License, Version 2.0 (the
 * License). You may not use this file except in compliance with the
 * License. You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 * implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
package de.bund.bva.isyfact.serviceapi.annotations;

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

/**
 * Diese Annotation kennzeichnet ein Schlüsselfeld oder einen Schlüsselparameter, dessen mögliche Ausprägungen
 * im Schlüsselverzeichnis hinterlegt sind.
 * 
 * Die Annotation kann auf zwei Arten verwendet werden:
 * 
 * 
    *
  • Für Felder einer Datenklasse (z.B. einer TO-Klasse). Es wird der Getter des Felds * annotiert. Der Setter und das Feld selbst erhalten keine Annotation.
  • *
  • Für Parameter einer Schnittstelle (z.B. einer RemoteBean-Schnittstelle).
  • *
* */ @Target({ ElementType.METHOD, ElementType.PARAMETER }) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface Schluesseltyp { /** * Der Typ des Schlüssels im Schlüsselverzeichnis. */ String value(); /** * Gibt an, unter welchen Bedingungen der definierte Schlüsseltyp zutreffend ist. Optional. */ String qualifier() default ""; /** * Diese Annotation wird benutzt, um für ein Schlüsselfeld oder einen Schlüsselparameter um eine Liste von * möglichen Schlüsseltypen zu definieren. Höchstens eine Schlüsseltyp-Annotation in der Liste darf keinen * qualifier tragen. * */ @Target({ ElementType.METHOD, ElementType.PARAMETER }) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface List { /** * Eine Menge von Schlüsseltypen, mit dessen Attribut qualifier kann angegeben werden unter welchen * Bedingungen welcher Schlüsseltyp anzuwenden ist. */ Schluesseltyp[] value(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy