Jump to: navigation, search

Difference between revisions of "HowTo:Create UBIK Plugin"


(Created page with "Microsoft Extensibility Framework (MEF) is used to dynamically load Plugins into the UBIK Kernel. == Basic Prerequisites == If you want to create a Plugin which can be loaded...")
 
m
 
(37 intermediate revisions by 2 users not shown)
Line 1: Line 1:
Microsoft Extensibility Framework (MEF) is used to dynamically load Plugins into the UBIK Kernel.
+
{{UBIK}} Plugins are loaded dynamically into the {{UBIK}} Kernel by the {{UBIK}} [[Injection_Management|Injection Management]] based on the [https://msdn.microsoft.com/de-de/library/dd460648%28v=vs.110%29.aspx Microsoft Extensibility Framework (MEF)].
  
== Basic Prerequisites ==
+
= Introduction =
If you want to create a Plugin which can be loaded in UBIK you have to refer to System.ComponentModel.Composition.
+
=== Basic Prerequisites ===
 
+
Creating an own plugin requires to add references to
UBIK Injection Managemnt provides access to all the basic features used by the Kernel to identifiy and categorize the available Plugins. This management is provided by a library called UBIK.Injection. You have to refer to this library as well.
+
 
+
=== References: ===
+
 
* System.ComponentModel.Composition
 
* System.ComponentModel.Composition
 
* UBIK.Injection
 
* UBIK.Injection
  
  
== Interface  UBIK.Injection.IUbikPlugin ==
+
{{UBIK}} Injection Management provides access to all the basic features used by the Kernel to identifiy and categorize the available plugins. This management is provided by a library called '''UBIK.Injection'''.
Your plugin must implement the Ubik Plugin Interface.
+
To register your plugin for MEF composition by defining the export contract via an Attribute.
+
  
 +
=== Interface: IUbikPlugin ===
 +
The plugin must implement the <code>UBIK.Injection.IUbikPlugin</code> interface and has to be registered for MEF composition by defining the export contract via an attribute.
 
<source lang="csharp">
 
<source lang="csharp">
 +
    [Export(typeof(UBIK.Injection.IUbikPlugin))]
  
    [Export(typeof(UBIK.Injection.IUbikPlugin))]
+
     public class TestPlugin : UBIK.Injection.IUbikPlugin
     public class myPlugIn : UBIK.Injection.IUbikPlugin
+
 
     {
 
     {
 
     }
 
     }
 
 
</source>
 
</source>
  
 +
=== Interface: IUbikInjectionMetaData ===
 +
Managing plugins correctly presumes the following information, as defined by the interface <code>UBIK.Injection.IUbikInjectionMetaData</code>.
  
 +
<source lang="csharp">
 +
    [ExportMetadata("ID", "C149402E-BC86-46D6-8D1B-63C86894EA77")]
 +
    [ExportMetadata("Type", typeof(TestPlugin))]
 +
    [ExportMetadata("Name", "TestPlugin" )]
 +
    [ExportMetadata("Description", "Tests the injection management")]
 +
    [ExportMetadata("Version", 1)]
 +
    [ExportMetadata("Company", "Augmensys GmbH")]
 +
</source>
  
== MetaData ==
+
==== Mandatory information ====
Ubik needs some Meta Information to manage plugins correctly.
+
{| class="wikitable" | width = "100%"
The available MetaInformation are defined by the interface UBIK.Injection.IUbikInjectionMetaData
+
 
+
=== Mandatory information ===
+
 
+
{| class="wikitable" | width = "50%"
+
 
|-
 
|-
 
! Name !! Type !! Description
 
! Name !! Type !! Description
 
|-
 
|-
| ID|| string || Unique ID of the Plugin
+
| ID|| {{MSDN/String}} || Unique ID of the plugin
 
|-
 
|-
| Type|| System.Type || Systemtype of the Plugin. Used for filtering the Plugins during loading.
+
| Type|| System.Type || Systemtype of the plugin; used for filtering the plugins during loading.
 
|-
 
|-
 
|}
 
|}
  
 
+
==== Optional information ====
 
+
{| class="wikitable" | width = "100%"
=== Optional information ===
+
 
+
{| class="wikitable" | width = "50%"
+
 
|-
 
|-
 
! Name !! Type !! Description
 
! Name !! Type !! Description
 
|-
 
|-
| Name|| string || Name of the plugin (for UI Presentation)
+
| Name|| {{MSDN/String}} || Name of the plugin (for UI Presentation)
 
|-
 
|-
| Description|| string || Name of the plugin (for UI Presentation)
+
| Description|| {{MSDN/String}} || Name of the plugin (for UI Presentation)
 
|-
 
|-
| Version|| int || Version of the plugin. As there are more plugins with the same ID, only the plugin with the highest Version is available.
+
| Version|| {{MSDN/Int32}} || Version of the plugin. As there are more plugins with the same ID, only the plugin with the highest Version is available.
 
|-
 
|-
 
| TargetApplication|| PluginTargetApplication|| Possibility to limit the plugin for a single type of application.
 
| TargetApplication|| PluginTargetApplication|| Possibility to limit the plugin for a single type of application.
 
|-
 
|-
| MinimumKernelVersion|| string|| Minimum required Kernel version: Format x.x.x.x
+
| MinimumKernelVersion|| {{MSDN/String}} || Minimum required Kernel version: Format x.x.x.x
 
|-
 
|-
| MinimumDatabaseVersion|| string|| Minimum required Database version: Format x.x.x.x
+
| MinimumDatabaseVersion|| {{MSDN/String}} || Minimum required Database version: Format x.x.x.x
 +
|-
 +
| Company|| {{MSDN/String}} || Information about the Company (for UI Presentation)
 +
|-
 +
| Copyright|| {{MSDN/String}} || Copyright Information (for UI Presentation)
 
|-
 
|-
 
|}
 
|}
  
 
+
= Example =
Example:
+
 
+
 
<source lang="csharp">
 
<source lang="csharp">
 
 
     [Export(typeof(UBIK.Injection.IUbikPlugin))]
 
     [Export(typeof(UBIK.Injection.IUbikPlugin))]
     [ExportMetadata("ID", "23B72354-A26F-449E-A7DA-F874B4167248")]
+
     [ExportMetadata("ID", "C149402E-BC86-46D6-8D1B-63C86894EA77")]
     [ExportMetadata("Type", typeof(UBIK.Injection.IUbikPlugin))]
+
     [ExportMetadata("Type", typeof(TestPlugin))]
     [ExportMetadata("Name", "my Plugin")]
+
     [ExportMetadata("Name", "TestPlugin" )]
     [ExportMetadata("Description", "does fancy things in version 2.4")]
+
     [ExportMetadata("Description", "Tests the injection management")]
     [ExportMetadata("Version", 3)]
+
     [ExportMetadata("Version", 1)]
 
     [ExportMetadata("MinimumKernelVersion", "2.4.0.0")]
 
     [ExportMetadata("MinimumKernelVersion", "2.4.0.0")]
 
     [ExportMetadata("MinimumDatabaseVersion", "2.4.0.0")]
 
     [ExportMetadata("MinimumDatabaseVersion", "2.4.0.0")]
     public class myPlugIn : UBIK.Injection.IUbikPlugin
+
    [ExportMetadata("Company", "Augmensys GmbH")]
 +
    [ExportMetadata("Copyright", "2014, Augmensys GmbH")]
 +
     public class TestPlugin : UBIK.Injection.IUbikPlugin
 
     {
 
     {
  
 
     }
 
     }
 
 
</source>
 
</source>
 +
 +
<headertabs />
 +
 +
== See also ==
 +
* [[Injection_Management]]
 +
* [[HowTo:Create_UBIK_Workflow_Activity_Plugin|UBIK Workflow Activity Plugin]]
 +
 +
[[Category:How-To|Create UBIK Plugin]]
 +
[[Category:Injecting|Create UBIK Plugin]]

Latest revision as of 11:45, 3 August 2016

UBIK® Plugins are loaded dynamically into the UBIK® Kernel by the UBIK® Injection Management based on the Microsoft Extensibility Framework (MEF).

[edit]

Introduction

Basic Prerequisites

Creating an own plugin requires to add references to

  • System.ComponentModel.Composition
  • UBIK.Injection


UBIK® Injection Management provides access to all the basic features used by the Kernel to identifiy and categorize the available plugins. This management is provided by a library called UBIK.Injection.

Interface: IUbikPlugin

The plugin must implement the UBIK.Injection.IUbikPlugin interface and has to be registered for MEF composition by defining the export contract via an attribute.

    [Export(typeof(UBIK.Injection.IUbikPlugin))]

    public class TestPlugin : UBIK.Injection.IUbikPlugin
    {
    }

Interface: IUbikInjectionMetaData

Managing plugins correctly presumes the following information, as defined by the interface UBIK.Injection.IUbikInjectionMetaData.

    [ExportMetadata("ID", "C149402E-BC86-46D6-8D1B-63C86894EA77")]
    [ExportMetadata("Type", typeof(TestPlugin))]
    [ExportMetadata("Name", "TestPlugin" )]
    [ExportMetadata("Description", "Tests the injection management")]
    [ExportMetadata("Version", 1)]
    [ExportMetadata("Company", "Augmensys GmbH")]

Mandatory information

Name Type Description
ID String Unique ID of the plugin
Type System.Type Systemtype of the plugin; used for filtering the plugins during loading.

Optional information

Name Type Description
Name String Name of the plugin (for UI Presentation)
Description String Name of the plugin (for UI Presentation)
Version Integer Version of the plugin. As there are more plugins with the same ID, only the plugin with the highest Version is available.
TargetApplication PluginTargetApplication Possibility to limit the plugin for a single type of application.
MinimumKernelVersion String Minimum required Kernel version: Format x.x.x.x
MinimumDatabaseVersion String Minimum required Database version: Format x.x.x.x
Company String Information about the Company (for UI Presentation)
Copyright String Copyright Information (for UI Presentation)

Example

    [Export(typeof(UBIK.Injection.IUbikPlugin))]
    [ExportMetadata("ID", "C149402E-BC86-46D6-8D1B-63C86894EA77")]
    [ExportMetadata("Type", typeof(TestPlugin))]
    [ExportMetadata("Name", "TestPlugin" )]
    [ExportMetadata("Description", "Tests the injection management")]
    [ExportMetadata("Version", 1)]
    [ExportMetadata("MinimumKernelVersion", "2.4.0.0")]
    [ExportMetadata("MinimumDatabaseVersion", "2.4.0.0")]
    [ExportMetadata("Company", "Augmensys GmbH")]
    [ExportMetadata("Copyright", "2014, Augmensys GmbH")]
    public class TestPlugin : UBIK.Injection.IUbikPlugin
    {

    }

See also