Python plugins use the JSON-RPC protocol to communicate with Flow via JSON structured calls.
When building a Python plugins there are several things to be mindful of:
-
The most important thing is we do not expect users to have to manually install the dependencies in requirements.txt because we aim to provide a seamless experience for them. This can be achieved by adding the following three things to your project:
- Add a GitHub workflow- use a GitHub workflow that will install all your plugin's dependencies including the Python flowlauncher module to a folder called Lib inside your plugin.
- Publish all as a zip- zip up your project including a lib directory that contains the modules and publish it to GitHub Releases page.
- Point your module imports to the lib directory- reference all the modules to that directory where they are first imported.
-
Users can use their own system-installed Python with Flow Launcher, but in most circumstances they will most likely be using Flow Launcher's download of Embedded Python. This download is isolated from the users system and does not prepend the scripts run directory to the system
PATH
.ref If you need to import external files please follow the example below.
Have a look at this simple example plugin here, notice it has a folder called '.github/workflows' and a file called 'Publish Release.yml'. This is the workflow file that GitHub Workflow uses to run the CI/CD for the project. Moving out of that folder you can go into the main.py file, this is the entry file for your plugin. Notice it has this code block:
import sys,os
parent_folder_path = os.path.abspath(os.path.dirname(__file__))
sys.path.append(parent_folder_path)
sys.path.append(os.path.join(parent_folder_path, 'lib'))
sys.path.append(os.path.join(parent_folder_path, 'plugin'))