Pymemri is a python library for creating Plugins for the Memri Personal online datastore (pod). Pymemri has a PodClient to communicate with the pod, and tools to build and test plugins.
Plugins connect and add the information to your Pod. Plugins that import your data from external services are called Importers (Gmail, WhatsApp, etc.). Plugins that connect new data to the existing data are called indexers (face recognition, spam detection, object detection, etc.). Lastly there are plugins that execute actions (sending messages, uploading files).
pip install pymemri
To install the Python package for development, run:
pip install -e .
If you would like to contribute to Pymemri, have a look at our contibuting guidelines to get started and join our Discord if you have any questions about using or contributing to the library.
All interaction between plugins and the pod goes via the Pymemri PodClient
. To use this client in development, we first need to have a pod running locally. The quickest way to do this is to install from the pod repo, and run ./examples/run_development.sh
.
If you have a running pod, you can define and add your own item definitions:
from pymemri.data.schema import Item
from pymemri.pod.client import PodClient
class Dog(Item):
name: Optional[str] = None
age: Optional[int] = None
# Connect to the pod and add the Dog item definition
client = PodClient()
client.add_to_schema(Dog)
# Add a Dog to the pod
dog = Dog(name="Rita", age=3)
client.create(dog)
After installation, users can use the plugin CLI to manually run a plugin. For more information on how to build a plugin, see run_plugin
.
With the pod running, run in your terminal:
store_keys
run_plugin --metadata "example_plugin.json"
This stores a random owner key and database key on your disk for future use, and runs the pymemri example plugin. If everything works correctly, the output should read Plugin run success.