Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Antony’s modulesystem allows you to write a registry which will be loaded by the antony client and/or antonyHub. The registry is needed to let you hook into our software.

...

From a top level perspective we need create a registry to embed our classes into the di-container, antony provides. To do so we need to write a custom registry for it. To do so, we need to register as a module developer and define our module.

We provide an example project here: https://bitbucket.org/diegroupware/antony.demo.trainee.desktop/src/master/?search_id=ceb40d4f-44b2-41a7-b340-c7ae4c46727a

Tl;Dr;

  • Add the nuget package https://www.nuget.org/packages/antony.Groupware.ExtensionInterfaces/ and https://www.nuget.org/packages/Microsoft.Extensions.DependencyInjection.Abstractions/8.0.0-preview.3.23174.8 (Version 3.1.32) to your project.

  • Be sure your project is on NET Framework 462

  • Write a RegistryClass, decorate your assembly with AntonyModuleAttribute and add your ModuleKey

    • Code Block
      [assembly: AntonyModule(typeof(MyClassRegistry), ModuleKey = "de.die_groupware.mymodule")]
  • Decorate your method within you RegistryClass with the AntonyServiceRegistryAttribute,

    • Code Block
      [AntonyServiceRegistry()]
      public void Register(IServiceCollection services)
  • Add the file-link for your uri to the registry under.

    • Computer\HKEY_CURRENT_USER\SOFTWARE\SCOM\antony\modules\AntonyGroupware\<moduleKey>\Path = ““

      • or

    • Computer\HKEY_CURRENT_USER\SOFTWARE\SCOM\antony\modules\AntonyHubClient\<moduleKey>\Path = ““

ExtensionInterfaces

Antony provides custom interfaces which are used to detect and load your registry. This interfaces comes within an easy to handle nuget package. This package doent doesnt have any other dependencies but .netstandard 2.0. Therefore you should be able to use this in nearly every project. You find this Project on http://nuget.org : https://www.nuget.org/packages/antony.Groupware.ExtensionInterfaces/

The Version of this NuGet Package will correlate with the Version of antony itselfe. A 2.21.130 of antony.Groupware.ExtensionInterfaces will be shipped with the 2.21.130 of antony. We’ll make sure, to minimize breaking changes within this interfaces. Therefore the module written for a specific version will also work on a further version. As you can read here Modules and dependent assemblies might work with another version of this interfaces and your dependencies at runtime.

...

.

...

Registry

To register you need to specify the assembly attribute AntonyModule to your assembly. Within this attribute you need to point to a class, containing the registry. Every registry need to be part of a module for licencing. Every module needs to be licencened - even if its free. To define a identify your module you need to register as a Module-Developer within out shopprovide a ModuleKey.

Info

We’re sorry! Defining a module is not available at the moment.

...

At the moment you cannot register a module by yourself. Please let us know, if you want to write a module by mailing us at info(at).die-groupware.de

The Register method needs to be annotated with the AntonyServiceRegistry attribute to be loaded. . You are loaded in every application on default. The signature of this method is provided in the snipped below. In this method you can finally provide your types at the ExtensionPoints you want to integrate to.register within antony’s DI-Container.

We use AutoFac as the DI-Container (https://autofac.org)

Code Block
breakoutModewide
languagec#
[assembly: AntonyModule(typeof(ZoomModuleAntonyRegistry), ModuleKey = "de.die_groupware.zoom")]
namespace antony.Groupware.AddinX.Zoom
{
    public class ZoomModuleAntonyRegistry
    {
        [AntonyServiceRegistry()]
        public void Register(IServiceCollection services)
        {
           // ...
        }
    }
}

Let antony search

As After we defined the registry we also need to tell antony where to find your assembly. We’ll do this by using the windows registry. You need to add a value into the following key

...

  • AntonyGroupware: To integrate within Antonys Administator or GroupwareclientGroupware-Client

  • AntonyHubClient: To integrate within the antonyHub to provide add configuraton dialogs and logic for a custom server. You need to to so, if you want to deploy a service via the antonyHub.

...

You need to provide the path to the file of your assembly. antony will check checks all available modules at startup, compares with the available licences and call the calls your registry. You Congratulations, you are in (wink)

Conclusion

As you saw it is

Specific Implementation for specific versions

The ExtensionInterfaces will change over time, as we add or extends the possibility to integrate into antony. Therefore we might add more interfaces for theses extension points. You as an module developer can use these interfaces to extend your module too. As you update the ExtensionInterfaces you are able to do so.

As we described in Modules and dependent assemblies we the assemblies of antony itself are preferred to load, including the ExtensionInterfaces.Therefore you will get a TypeNotFoundException, if you try to load your band new module within an old antony installation. To get around this, we provide the possibility to declare a minimal version of antony your registry runs on.

So if you create a new version with new interfaces of your module you need to create a new registry defining the version you want to add. In this case the old registry works as usual, and the new registry registered the new interfaces and implementations within the DI-container.

Conclusion

It is quite simple to provide a module which is loaded by antony. You only need to specify a registry and let antony know where to search for it. You should be able to use the classes within nearly every project.

So open up a VisualStudio, Create your favorite IDE, create a Project and go for it. You can do it right 🇳 🅾 🇼