Extend meta-models
Describes how to extend meta-models in Business Foundation (BF).
You can extend meta-models through the use of Modules, which is part of the meta-model that provides the main entry point in the client for extensibility objects. Install modules in the system and activate them from the meta-class.
A module consists of the following:
- A module manifest. Defines information about the module and references to module the configuration.
- A module configuration. The .NET class that implemented the IModuleConfigurator interface.
The Module Manager loads and calls the Module Configurator methods when a module is activated, deactivated, installed or uninstalled. Each module should implement the Module Configurator.
Note
You can modify a meta-model only in Design mode. See the MetaClassManager class section.
The following classes are available in the Mediachase.BusinessFoundation.Data.Modules namespace.
Default modules
The following modules are default: Change Tracking, History and Localization.
Change Tracking
Change Tracking adds new fields to a meta-class and registers the user and the date and time of modification. After activation, the Change Tracking module adds these meta-fields:
- Created. Updates this field when a new meta-object is created.
- Modified. Updates this field when a meta-object is modified.
- CreatorId. Copies the current user meta-information from DataContext to this field when a new meta-object is created.
- ModifierId. Copies the current user meta-information from DataContext to this field when a meta-object is modified.
To get the module manifest, call the CreateModuleManifest of the ChangeTrackingManager class.
History
History saves meta-object modifications to the history meta-class. After activation, the History module creates a meta-class named [MetaClassName]\_History, and creates a copy of the entity object if the selected field is modified. The [MetaClassName]\_History meta-class has an ObjectId field that has the original primary key value.
- Call CreateModuleManifest of the HistoryManager class to get the module manifest.
- Call SetSelectedFields of the HistoryManager class, passing the meta-class, to set the collection of selected fields.
- Call GetSelectedFields of the HistoryManager class, passing the meta-class, to get the collection of selected fields.
You can read the history of the entity object from the [MetaClassName]_History meta-class.
Localization
The Localization module localizes field values.
Do the following to define available languages after installation:
- Call GetInstalledLanguages of the LocalizationManager class to get installed languages.
- Call InstallLanguage of the LocalizationManager class passing the culture info Name, to install a new language.
- Call UninstallLanguage of the LocalizationManager class passing the culture info Name, to uninstall a language.
After activation, define the localizable field. The localization module creates a new field named [FieldName]_[ThreeLetterWindowsLanguageName], which reads or saves localizable values. If the value is null, you should use the original field to get a value. When you add a new language, the localization module automatically creates new fields.
- Call GetLocalizableFields of the LocalizationManager to get localizable fields.
- Call ActivateFieldLocalization of the LocalizationManager, passing the meta-class and meta-field, to activate field localization.
- Call DeactivateFieldLocalization of the LocalizationManager, passing meta-class and meta-field, to deactivate field localization.
Install a module
- To install a new module, call Install of the ModuleManager class, passing the module manifest and attributes.
Activate a module
- To activate a module in the meta-class, call Activate of the ModuleManager class, passing the module manifest and meta-class.
Deactivate a module
- To deactivate a module, call Deactivate of the ModuleManager class, passing the module manifest and meta-class.
Uninstall a module
- To uninstall a module, call Uninstall of the ModuleManager class, passing the module manifest.
Updated 6 months ago