Skip to main content

A addon for syncing metadata with nostr

Project description

eteaching.plone.nostrmetadatasync

Nostr integration for Plone.

eteaching.plone.nostrmetadatasync synchronises metadata of Plone contents with Nostr. This is done on the basis of subscribers (event handlers). When content is created, deleted or modified on the Plone website, corresponding Nostr events are created, signed and sent to predefined relias in the Nostr network. Two control panels are also provided. One is for settings, where you can specify which content types and filters should be used to select the content affected by synchronization. The second control panel can be used to create all events in the Nostre relays for the entire content selected using the settings, or to send delete events.

Features

  • Synchronizes metadata of event based objects (e.g. plone.app.event) with Nostr Time-Based Calendar Event (NIP-52)
  • Synchronizes metadata of objects with Nostr AMB Event (NIP-AMB)

Installation

Prerequisites ✅

Install eteaching.plone.nostrmetadatasync with pip

  1. Install

    pip install eteaching.plone.nostrmetadatasync
    
  2. Create the Plone site

    make create-site
    
  3. Start the Plone site

    make start
    

Install eteaching.plone.nostrmetadatasync with git 🔧

  1. Clone this repository, then change your working directory

    git clone git@github.com:e-teachingorg/eteaching.plone.nostrmetadatasync.git
    cd eteaching.plone.nostrmetadatasync
    
  2. Create environment

    python3 -m venv .
    bin/pip install uv
    source bin/activate
    
  3. Create an .env file to set NOST_KEY as an environment variable.

    vi .env
    
    NOSTR_KEY=MyPrivateNostrKey
    
  4. Install the code base

    make install
    
  5. Create the Plone site

    make create-site
    
  6. Start

    make start
    

Install eteaching.plone.nostrmetadatasync via buildout

  1. Use zc.buildout >=5, e.g. using the following requirements.txt:

    horse-with-no-namespace==20251105.1
    packaging==25.0
    pip==25.3
    setuptools==80.9.0
    wheel==0.45.1
    zc.buildout==5.1.1
    
  2. Install Python venv and requirements:

    bin/python3 -m venv .
    bin/pip install -r requirements.txt
    
  3. Add the following to buildout.cfg:

    [buildout]
    
    ...
    
    eggs =
        eteaching.plone.nostrmetadatasync
    
  4. Run buildout

    bin/buildout	
    
  5. Start

    bin/instance fg
    

Contribute

License

The project is licensed under the GPLv2.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eteaching_plone_nostrmetadatasync-1.0.0a1.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file eteaching_plone_nostrmetadatasync-1.0.0a1.tar.gz.

File metadata

File hashes

Hashes for eteaching_plone_nostrmetadatasync-1.0.0a1.tar.gz
Algorithm Hash digest
SHA256 d8fde53c44f0c5aebbd84f2b2c0cb449ef09737c940d4e9985768a0e81123e0d
MD5 6bdc020cefd4740d9268a68286cdfbc7
BLAKE2b-256 5f0cf58da58bad5542e25f891694838e58bc63ede8afe089a683793946dcaff9

See more details on using hashes here.

File details

Details for the file eteaching_plone_nostrmetadatasync-1.0.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for eteaching_plone_nostrmetadatasync-1.0.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 95fafcd7a6d5029bc6385e44028db557c186e00716c681ceeecae8ef2d48e381
MD5 e138653d3aeea1b1bb2ad6b6a5db5451
BLAKE2b-256 d273d154db458a7d83f1075bbdb1a99b07420535773f668b4fabfa3d44f4e173

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page