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.2.0a1.tar.gz (10.2 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.2.0a1-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file poouli-0.2.0a1.tar.gz.

File metadata

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

File hashes

Hashes for poouli-0.2.0a1.tar.gz
Algorithm Hash digest
SHA256 271a576a8d26ad75e35c90f3eb31690cbd90ee5d790fa0abb2434dee64c7e043
MD5 e73cbb9c70b01c051d2e33d144413afa
BLAKE2b-256 142521932ca660e81a8a1256d808027b098d7be3b8999a2ce41d8fa8a396c612

See more details on using hashes here.

File details

Details for the file poouli-0.2.0a1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for poouli-0.2.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 2f9453a1f2a49d5e43fdde35335c45a79204e27229ddcc9a82e06853fd28408b
MD5 f3c0a32c08da05e1598d89d595aa74d7
BLAKE2b-256 27b16f99eadf654308a2e4379b90ba2fe47b1cc879e6afb72350b23e57a22413

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