для генерации интерфейсов к веб-службам – >
type="GenieLamp.Genies.ServicesLayer.ServiceStack.ServicesInterfacesGenie"
assembly="GenieLamp.Genies.ServicesLayer"
active="true"
outDir="%PROJECT_DIR%/../Services.Interfaces"
targetVersion
="*">
для генерации собственно веб-служб – >
type="GenieLamp.Genies.ServicesLayer.ServiceStack.ServicesGenie"
assembly="GenieLamp.Genies.ServicesLayer"
active="true"
outDir="%PROJECT_DIR%/../Services"
targetVersion="*">
name="PrimaryKey.ColumnTemplate" value="NI%TABLE%" />
name="PrimaryKey.ConstraintTemplate" value="PK_%TABLE%" />
… Другие шаблоны именований
name="ForeignKey.CreateIndex" value="true" />
name="BooleanValues" value="YesNo"/>
name="BaseNamespace" value="Company.Business.%PROJECT_NAME%" />
name="BaseNamespace" value="Company.Business.%PROJECT_NAME%" />
name="Schema" value="Core" />
name="PersistentSchema" value="CORE" />
name="RegistryEntity.Name" value="EntityRegistry" />
name="TypesEntity.Name" value="EntityType" />
name="TypesEntity.PrimaryId.Type" value="smallint" />
name="PrimaryId.Type" value="bigint" />
name="Attribute.Name" value="Version" />
name="Attribute.Type" value="int" />
В описании конфигурации джиннов видно, что его основу составляет сборка, один из классов которой, реализующий интерфейс IGenie, является точкой входа. Каждый джинн имеет как общие для всех параметры, например каталог для выходных файлов, так и специфичные, передаваемые через тег Param, описываемые в документации.
За джиннами следуют конфигурации слоёв. Если для домена и служб можно пока ограничиться спецификацией базового пространства имён, то для слоя хранения, особенно при поддержке более чем одной СУБД, необходимо указать дополнительные ограничения вроде максимальной длины имён.
Заключительная часть конфигурации представляет собой описания шаблонов. Но не тех, о которых идёт речь в книжке «банды четырёх», а о шаблонах реализации типовых задач уровня ядра и системных служб:
• Например, шаблон «Реестр объектов» добавляет к системе возможность ведения централизованного реестра всех создаваемых объектов. Реализован он как соответствующий класс и таблица, ссылка на которые добавляется ко всем другим классам (некоторые классы можно исключить через параметры шаблона).
• Шаблон «Версия состояния» является встроенной в NHibernate возможностью отслеживания конфликтов в многопользовательской среде. Например, если два пользователя изменяют один и тот же объект, то последний из них, сохранивший объект, получит исключение, оповещающее о том, что данные были изменены со времени последнего редактирования. Шаблон реализуется добавлением соответствующего атрибута номера версии ко всем классам.
• Шаблон «Аудит» в простейшем варианте является регистрацией для каждого хранимого объекта информации о времени его создания, последнем редактировании и авторе.
• Шаблон «Локализация» добавляет в генерируемый код возможность перевода сообщений в рамках технологии GNU gettext.
• Наконец, шаблон «Безопасность» в простейшем варианте ограничивает доступ к веб-службам через механизм аутентификации, логику которой необходимо реализовать в переопределяемом методе соответствующего класса. Например, обратиться к стороннему LDAP или непосредственно к базе данных с регистрационной информацией для проверки имени пользователя и хеша пароля.
Теперь, если запустить «заклинатель» с параметром файла конфигурации проекта и не будет обнаружено ошибок, на выходе мы получим инициализированные структуры баз данных и готовые к компиляции файлы. Рассмотрим их чуть подробнее.