liquibase.change.DatabaseChangeProperty Maven / Gradle / Ivy
package liquibase.change;
import liquibase.ChecksumVersion;
import liquibase.database.Database;
import liquibase.serializer.LiquibaseSerializable;
import java.lang.annotation.*;
/**
* Annotation used by {@link AbstractChange} to declare {@link ChangeParameterMetaData} information.
* The annotation should be placed on the read method.
* This annotation should not be checked for outside AbstractChange, if any code is trying to determine the
* metadata provided by this annotation, it should get it from
* {@link liquibase.change.ChangeFactory#getChangeMetaData(Change)}
*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@Repeatable(DatabaseChangeProperties.class)
public @interface DatabaseChangeProperty {
/**
* Value to put into {@link ChangeParameterMetaData#getDescription()}
*/
String description() default "";
/**
* Value to put into {@link liquibase.change.ChangeParameterMetaData#getExampleValue(Database)}
*/
String exampleValue() default "";
/**
* Value to put into {@link liquibase.change.ChangeParameterMetaData#getSince()}
*/
String since() default "";
/**
* If false, this field or method will not be included in {@link liquibase.change.ChangeParameterMetaData}
*/
boolean isChangeProperty() default true;
/**
* Value to put into {@link ChangeParameterMetaData#getRequiredForDatabase()}
*/
String[] requiredForDatabase() default ChangeParameterMetaData.COMPUTE;
/**
* Value to put into {@link ChangeParameterMetaData#getSupportedDatabases()}
*/
String[] supportsDatabase() default ChangeParameterMetaData.COMPUTE;
/**
* Value to put into {@link liquibase.change.ChangeParameterMetaData#getMustEqualExisting()}
*/
String mustEqualExisting() default "";
/**
* Format to use when serializing this Change via a {@link liquibase.serializer.ChangeLogSerializer}.
*/
LiquibaseSerializable.SerializationType serializationType() default LiquibaseSerializable.SerializationType
.NAMED_FIELD;
/**
* The checksum version that this annotation applies to. This can be omitted, and it is assumed that the
* annotation applies to all checksum versions. If a version is applied to some, but not all of the
* {@link DatabaseChangeProperty} annotations on a particular property, the most specific matching annotation
* is selected. For example, if a particular property has:
*
*
* @DatabaseChangeProperty(isChangeProperty = false, version = {ChecksumVersions.V8})
* @DatabaseChangeProperty(serializationType = SerializationType.DIRECT_VALUE)
*
*
* and checksum calculation for version 8 is requested, the first annotation is used. If any other checksum version
* is requested, the second annotation is used.
*/
ChecksumVersion[] version() default {};
String[] alternatePropertyNames() default {};
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy