Skip to content

Template for itwinai plugin, useful for use cases code to be included in the main library

License

Notifications You must be signed in to change notification settings

interTwin-eu/itwinai-plugin-template

Repository files navigation

Writing plugins for itwinai

It would be beneficial to integrate the interTwin use case code directly into itwinai, providing an easy way to distribute and compare AI methods used by various researchers.

However, requiring all researchers to maintain their code within the itwinai repository can be complicated and may create an unnecessary barrier for newcomers interested in joining this ecosystem. Researchers and use case developers often prefer the flexibility of developing their code in a separate repository. This allows them to independently manage the packaging and publishing of their software, for instance, by releasing it to PyPI when it best suits their needs.

To address this challenge, itwinai implements a plugin architecture, allowing the community to independently develop sub-packages for itwinai. These sub-packages can later be installed from PyPI and imported into Python code as if they were part of itwinai. This is made possible by namespace packages.

Itwinai plugins are developed by assuming that the plugin logic, once installed alongside itwinai, will be accessible under the itwinai.plugins.* namespace. Example:

from itwinai.plugins.my_awesome_plugin import awesome_module

# Call a function implemented by the plugin
awesome_module.awesome_function(some=1, argument='foo')

# Instantiate a class implemented by the plugin
my_obj = awesome_module.AwesomeClass(another='bar', arg=False)

How to write a new plugin

To write a new plugin, you can take inspiration from this repository, and you can also use it as a template when creating a new repository in GitHub.

Note

Do NOT contribute directly to the plugin template repository, rather use it as a GitHub repository template, or fork it, or copy it.

The plugin template repository describes a python project using a pyproject.toml, where the following configuration declares that the Python package implemented by the plugin belongs under the itwinai.plugins.* namespace:

[tool.setuptools.packages.find]
# Declare this package as part of the `itwinai.plugins` namespace
where = ["src"]
include = ["itwinai.plugins.my_awesome_plugin"]

As a plugin developer, all you have to do is maintaining your Python packages and modules under src/itwinai/plugins.

Warning

It is important to use an original name for the root package of your plugin (my_awesome_plugin in the example above). Avoid reusing existing plugin names, otherwise your plugin may be overridden by another one when installed at the same time!

Alternatively, instead of a pyproject.toml, you can as well use the legacy setup.py to describe your plugin package. In that case, remember to add the following arguments to the setup function, to ensure the correct installation of the plugin under the itwinai.plugins namespace:

from setuptools import setup, find_namespace_packages

setup(
    name='itwinai-awesome-plugin',
    ...
    packages=find_namespace_packages(where='src/', include=['itwinai.plugins.my_awesome_plugin']),
    package_dir={'': 'src'},
    install_requires=['itwinai'],  # Ensure `itwinai` is installed
    ...
)

Installing a plugin

An end user can install a plugin directly from its repository or from PyPI (if available).

To use a plugin in your code, install it alongside itwinai:

# Install itwinai
pip install itwinai

# Now, install one or more plugins
pip install itwinai-awesome-plugin
# Or directly from the plugin's repository
pip install itwinai-awesome-plugin@git+https://github.com/USER/PROJECT@BRANCH

Conversely, a plugin developer may be interested in installing the plugin in editable mode from the project directory:

git clone git@github.com:USER/REPOSITORY.git && cd REPOSITORY

# After having installed itwinai with its dependencies,
# install the plugin from source in editable mode.
pip install --editable . 

Beware of installations in editable mode

When a package is installed in editable mode, it creates a symlink to the source directory, which works differently from how non-editable packages are installed. Namespace packages can behave inconsistently when some parts are installed in editable mode and others are not.

To check whether a package was installed in editable mode you can use pip show PACKAGE_NAME. Editable packages show an "Editable" path in the output of the command.

Warning

When itwinai, the core library, is installed in editable mode also the plugin must be installed in editable mode. Otherwise, the plugin may not be visible when imported.

From empirical experience, the following installation configurations seem to be working:

  • itwinai: editable, plugin: editable
  • itwinai: non-editable, plugin: non-editable
  • itwinai: non-editable, plugin: editable

About

Template for itwinai plugin, useful for use cases code to be included in the main library

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages