Для создания конфигурационного интерфейса необходимо:
-
Создать интерфейс, унаследованный от
com.haulmont.cuba.core.config.Config
(не путать с классом сущностиcom.haulmont.cuba.core.entity.Config
) -
Добавить интерфейсу аннотацию
@Source
для указания источника (способа хранения) параметров:-
SourceType.SYSTEM
- значение свойства будет взято из системных свойств данной JVM, т.е. методомSystem.getProperty()
-
SourceType.APP
- значение свойства будет взято из файловapp.properties
-
SourceType.DATABASE
- значение свойства будет взято из таблицы SYS_CONFIG
-
-
Создать методы доступа к свойству (getter / setter). Если значение свойства не предполагается изменять во время выполнения, метод доступа на запись не нужен. Возможный тип свойства рассмотрен ниже.
-
Добавить методу доступа на чтение аннотацию
@Property
, определяющую имя свойства. -
Опционально аннотацию
@Source
можно задать для отдельного свойства в интерфейсе, если его источник отличается от заданного для всего интерфейса.
Например:
@Source(type = SourceType.DATABASE) public interface SalesConfig extends Config { @Property("sales.companyName") String getCompanyName(); }
Создавать класс реализации конфигурационного интерфейса не нужно - при получении ссылки на интерфейс через Configuration будет автоматически создан необходимый прокси-объект.