Skip to main content

CLI for managing World of Warcraft add-ons

Project description

instawow is a package manager for World of Warcraft, written in Python. It can be used to install, remove and update add-ons from WoWInterface, CurseForge and Tukui.

instawow tries to make installing, updating and removing add-ons quick and painless for those of us who are (ever so slightly) proficient with the command line and do not revel in using bloatware which infringe on our privacy or inhabiting walled gardens.

Asciicast demonstrating the operation of instawow.

Installation

I recommend installing instawow in an isolated environment. pipx makes this easy:

pipx install instawow

Or using Nix:

nix-env -if https://github.com/layday/instawow-nix/tarball/master

Installing with pip is also supported:

pip3 install --upgrade instawow

Getting started

instawow is able to interpret add-on URLs, slugs and IDs. All of the following will install Molinari:

instawow install https://www.curseforge.com/wow/addons/molinari
instawow install curse:molinari
instawow install curse:20338
instawow install https://www.wowinterface.com/downloads/info13188-Molinari.html
instawow install wowi:13188
  • The update and remove commands work in the same way, and update can be run without arguments to update all add-ons.

  • You can opt into alpha and beta quality add-ons from CurseForge using the --with-strategy option on install.

  • Use list to list add-ons managed by instawow; list-folders -e to list unmanaged add-ons; info to display add-on information, visit to open an add-on homepage in your browser and reveal to open the primary add-on folder in your file manager.

  • Non-destructive operations accept partial definitions, e.g. instawow info moli will display information about Molinari.

instafying add-ons

instawow does not know about add-ons it did not itself install. The Twitch and Minion clients each use their own, proprietary fingerprinting algorithm to reconcile add-ons you have installed with add-ons their respective hosts keep on their servers. Though the details of their implementation elude me, instawow tries to accomplish something similar by combining a variety of cues (e.g. folders and TOC entries). This is not done automatically; you will need to execute instawow reconcile to absorb add-ons installed through other means.

Searching for add-ons

instawow comes with a rudimentary search command which allows you to select add-ons to install. The search does not display add-on details other than the name and source; pressing <o> will bring the add-on page up in your browser. Search uses a collated add-on catalogue internally which is updated once daily.

WoW Classic

instawow supports Classic – it will correctly install Classic versions of add-ons from sources depending on the value of the game_flavour configuration setting. What instawow does not have is a switch you can flick to go from managing your retail add-ons to managing your classic add-ons and vice versa. This was a conscious design decision, the merits of which (I should admit) are open to debate. If you are already using instawow for retail, you will need to create a separate profile for Classic. On Linux, this might be:

env INSTAWOW_CONFIG_DIR=~/.config/instawow-classic instawow

For ease of use, you might want to set up an alias. In your Bash profile, add:

alias instawow-classic='INSTAWOW_CONFIG_DIR=~/.config/instawow-classic instawow'

You would then be able to invoke instawow using instawow-classic.

If you find yourself needing to install a retail-only add-on that you know to work in Classic, the any_flavour strategy is available.

Additional functionality

WeakAuras aura updater

instawow contains a WeakAuras updater modelled on WeakAuras Companion. To use the updater and provided that you have WeakAuras installed:

instawow weakauras-companion build -a <your account name>
instawow install instawow:weakauras-companion

You will have to rebuild the companion add-on prior to updating to receive aura updates. If you would like to check for updates on every invocation of instawow update, install the instawow:weakauras-companion-autoupdate variant, exposing your account name as an env var:

env WAC_ACCOUNT=<your account name> instawow install instawow:weakauras-companion-autoupdate
env WAC_ACCOUNT=<your account name> instawow update

You may then choose to bypass the companion add-on simply by ommitting the env var.

Metadata sourcing

Originally, instawow relied on the official feeds provided by Curse. Curse retired the feeds in June 2018 and – for a period – instawow would scrape the CurseForge website. The alternative would have been to use the old XML-like API. Because the API was not built for third-party use, it had not been isolated from user accounts (cf. GitHub integrations). If users were to log into the API, instawow would acquire full access to their account. Authentication was also complicated by the ongoing Curse account migration to Twitch and is (or should be) unnecessary for the simple use case of installing and updating add-ons. Thankfully, Twitch migrated to an unauthenticated API interally in Q2 2019, which we have adopted for our own use. This is similar to what Minion, the WoWInterface-branded add-on manager, has been doing for years. The good people at Tukui provide an API for public use. instawow might break whenever one of our sources introduces a change to their website or API (though only temporarily).

Remote hosts

When installing, updating or searching for add-ons, instawow will retrieve scraped add-on metadata from https://raw.githubusercontent.com, CurseForge add-on metadata from https://addons-ecs.forgesvc.net, WoWInterface add-on metadata from https://api.mmoui.com, Tukui add-on metadata from https://www.tukui.org, and aura data from https://data.wago.io; and will follow file URLs contained in metadata.

Every 24 hours, on launch, instawow will query PyPI (https://pypi-hypernode.com) – the canonical Python package repository – to suggest updating instawow to the latest version.

Requests made by instawow can be identified by its user agent string.

Contributing

Bug reports and fixes are welcome. Do open an issue before committing to making any significant changes.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

instawow-1.7.1.tar.gz (441.3 kB view details)

Uploaded Source

Built Distribution

instawow-1.7.1-py3-none-any.whl (64.2 kB view details)

Uploaded Python 3

File details

Details for the file instawow-1.7.1.tar.gz.

File metadata

  • Download URL: instawow-1.7.1.tar.gz
  • Upload date:
  • Size: 441.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20200103 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.7.6

File hashes

Hashes for instawow-1.7.1.tar.gz
Algorithm Hash digest
SHA256 ddc71da768d269c1976b91785013cfab84c4bf0815dc48aa22e7fb62c695b9c0
MD5 0c69b5dce00e144adce88df92efa9855
BLAKE2b-256 237ff3cab6aab7ce259dbc05eb3bf9ae96693d5a6f585f52ee9fb8a264a3141a

See more details on using hashes here.

File details

Details for the file instawow-1.7.1-py3-none-any.whl.

File metadata

  • Download URL: instawow-1.7.1-py3-none-any.whl
  • Upload date:
  • Size: 64.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20200103 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.7.6

File hashes

Hashes for instawow-1.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0485511fd2a5f44bb52aec24d088102d6dfecf12f449ac8b75f3bcb0a7e88ff2
MD5 d6df0d0e3b0d9b628f1650968c0f63e2
BLAKE2b-256 cf250806cabca37d0273288f303e63b9881433c55f9c9f1280022fe0cb31caaf

See more details on using hashes here.

Supported by

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