Skip to main content

Syncronize local files with MediaWiki

Project description

🗃️ Pöuli 🐙

Synchronize local files with MediaWiki instances.

PyPI, Status – Shields.io badge PyPI, Version – Shields.io badge PyPI, Python Version – Shields.io badge PyPI, License – Shields.io badge

ℹ️ About

This tool was originally conceived by Tommi to upload a subset of their personal knowledge repository, the Jam, with their Personal Reader, PaJamas. Hopefully, it can flourish beyond this specific use-case, and be helpful for other XPUB students or wiki adventurers.

✨ Meaning

The name “Pöuli” (equivalent of PoOuli) stands for:

  • Practically Often Used Lovely Interface
  • Petty yet Outstanding Utility Leading to Integration
  • Phenomenal Optimistic Useful Lovely Idea
  • Paradoxically Obscure but Unstoppable Link Ignitor

It is the anagram of Oulipo, an eclectic, mad, and maddening collective of artists formed in the ’60s.

+++ IDEA: Writing machine name generator

⏬ Installation

Install poouli’s Python package from the Python Package Index (PyPI), however you prefer.

  • By using uv: uv pip install poouli
  • By using pip: pip install poouli
  • By cloning the source code
    • using SSH: git clone ssh://git@codeberg.org/tommi/poouli.git
    • using HTTPS: git clone https://codeberg.org/tommi/poouli.git

⚙️ Configuration

The initial configuration requires to follow the following steps. It’s cumbersome, I know. If you have tips on how to make it simpler and easier, please open a PR!

  1. Generate a Bot Password in MediaWiki:
    1. Visit https://pzwiki.wdka.nl/mediadesign/Special:BotPasswords
    2. Generate a bot
    3. Save the chosen bot name and its generated password
  2. Run pwb generate_family_file to tell the script that you want to use the XPUB’s wiki as the reference wiki
  3. Run pwb generate_user_files to provide the login credentials retrieved while generating a Bot Password
  4. Run pwb login to establish the connection and to check if everything is working nominally
  5. Create a YAML configuration file in the config directory or in the script’s directory. Here is an example. Add the following data:
    • local_directory: path of the directory for the local files
    • wiki_base_path: the path of the main page within which the local files should be synchronized (can be overwritten by permalink_wiki in each note’s front matter)
    • banner (optional): path to an HTML file to include at the end of all wiki pages published via Pöuli, unless wiki_banner is False in the frontmatter.
    • styling (optional): path to an HTML file to include at the end of all wiki pages published via Pöuli, if and only if wiki_styling is True in the frontmatter.

📡 Usage

Run the script with uv run poouli or just poouli

+++ TODO

Source code

The source code is published in three different forges, all synchronized among themselves.

♻️ License

Everything inside this repository is licensed under the European Union Public License.

🤔 To-do list

An unsorted list of things to do. Everything will be moved to proper issue tracking after the first release.

  • Handle images
  • Get configuration settings from command line arguments, overriding config file instructions
  • Links management and testing
    • local → local private
    • local → local public (on tommi.space)
    • local → local synchronized
    • local → Wiki (as a regular https link)
    • Wiki → Jam (as a regular https link to tommi.space)
    • Wiki → Wiki (not part of Pajamas)
    • Wiki → Wiki
    • Anchor links
      • same page
      • another page
  • Deal with Categories (see below)
  • Note metadata
    • aliases
    • updated
    • wiki_categories
  • Move the Wiki information and credentials to the YAML configuration file. Ideally, no scripts or commands should be required to run before the main one.
  • test on Windows
  • Get wiki pages that are in the specified subpage but are not found locally
  • Transclusion
    • transform <includeonly> (and similar) to <div id=includeonly> in Markdown
    • How to transform anchor transclusions in MediaWiki? It’s not supported
  • Exclude JSON and YAML files from the source directory
  • Test how references and foonotes work
  • Add dict and instructions about how the script works

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

poouli-0.3.0.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

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

poouli-0.3.0-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file poouli-0.3.0.tar.gz.

File metadata

  • Download URL: poouli-0.3.0.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.5

File hashes

Hashes for poouli-0.3.0.tar.gz
Algorithm Hash digest
SHA256 dfe91a99d2c149325032601e281af78f0eedb98a7f44d766019d78448c633320
MD5 b3fd07f2ab72b5b76d01cee37c2f0bf5
BLAKE2b-256 8f3e9f8b7d384560a44930e5ec3e5ba41d08593368c6f384b8870e95ae333489

See more details on using hashes here.

File details

Details for the file poouli-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: poouli-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.5

File hashes

Hashes for poouli-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 83ba430813655070795ee9539e0681bcc96faf6ea616be2b90ad1e742b0e759f
MD5 aa9f88d935e788314232def600ec7bfd
BLAKE2b-256 a878d95a8e07812f1be756b0ef172b7975fbbf95b768fab95eb77cd0e2137cf3

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