this is my own scratchpad for keeping track of things. it gets truncated frequently.
see CHANGELOG.md for a more formal list of changes by release
-
rename
strongbox
release tostrongbox.AppImage
- re-submit
- update release scripts
- done
-
update release script
- update references from 'strongbox' to 'strongbox.AppImage'
- done
-
cataclysm classic support
- done
-
gui, 'set-icon' is taking a long time to do it's thing.
-
nfo, replace the URL as the group-id with something random
-
github, catalogue, no download counts.
-
github, catalogue, add any tags if they exist
-
github, catalogue, add 'created date'
-
no errors displayed when installing from addon detail page
-
generate a
.flatpakref
file as an asset for release. -
possible bug? installing combuctor 8.1.1 from file matches against the catalogue (good), then installing 9.1.3 file loses the match.
- mutual dependencies information is mostly blank
- I think this was fixed in 6.1.0 but check anyway
- "ignored addons in the addon detail pane now display mutual dependencies (if any)."
-
catalogue/search results, if there are addons from the same host (github) with the same name (tukui), disambiguate them
- 'tukui' in the search results shouldn't mean 'ogri-la/tukui' if 'tukui.org/tukui' is also available
- which it isn't, but that's not the point.
- 'tukui' in the search results shouldn't mean 'ogri-la/tukui' if 'tukui.org/tukui' is also available
-
metrics, add a 'catalogue is N days old'
- add an 'oldest' addon (days since created date)?
- add a 'most stale' addon (days since last update)?
- pretty useless ;)
-
wowinterface, catalogue, revisit v4 api
-
gui, try replacing the auto fit columns with something like this:
-
checkbox column for selecting addon rows
- might be nicer than ctrl-click
-
expand-summary, can the game track wrangling logic be made generic rather than per-host?
- this would tie in with returning all releases from a host
- it would insulate host logic from selected game tracks and game track strictness
- it would handle pinned logic as well
- currently handled in catalogue
-
addon detail, 'releases' widget, including all possible releases to download and install
- add an 'WoW' column to know which game-track/interface
- disable releases excluded by selected game-track/strictness setting
-
alpha/beta opt-in
- user can opt to install alpha/beta releases per-addon
- make it a simple preference
-
manually select the primary addon in a group of addons to prevent synthetic titles
-
http, add with-backoff support to download-file
- just had a wowinterface addon download timeout
-
gui, right-click column header and show columns to disable
- right now it's registering as a regular click
-
bug, trade skill master string-converter changed directory names between 2.0.7 and 2.1.0
- see also Combuctor 9.1.3 vs Combuctor 8.1.1 with 'BagBrother' in old addons
- BagBrother was removed but also got 00:35:37.982 [info] [BagBrother] downloading 'Combuctor' version '8.1.1' 00:35:38.017 [info] [BagBrother] removing "Combuctor" version "9.1.3" 00:35:38.017 [error] [BagBrother] addon not removed, path is not a directory: /home/torkus/old-addons/BagBrother 00:35:38.021 [info] [BagBrother] installing "Combuctor" version "8.1.1" 00:35:38.042 [warn] [BagBrother] failed to find any .toc files: /home/torkus/old-addons/Sound
- this can be replicated by: install combuctor 9.1.3 find 'combuctor' and install from wowi (8.1.1) get weird orphaned BagBrother addon
- 2022-06-27, returned to bucket
- I don't have a solution for this, good or bad.
- see also Combuctor 9.1.3 vs Combuctor 8.1.1 with 'BagBrother' in old addons
-
bug, BigWigs_Classic from Github cannot be installed when 'retail strict' is set
- it can be installed from wowi fine
- perhaps check the addon name isn't prefixed with '_Classic' ?
- how many would be affected by this?
- perhaps check the addon name isn't prefixed with '_Classic' ?
- it can be installed from wowi fine
-
ux, offer to clean up .nfo files when removing an addon directory
- not just .nfo files, but .zip files matching a pattern too
-
zip, switch to apache commons compress for decompressing
- https://commons.apache.org/proper/commons-compress/
- .tar.gz and 7z support would be interesting
- rar should just die already
- this would fix a major showstopper in porting to windows
- 2022-05-29: returned to bucket, gazumped by installing addon from file.
-
user catalogue, refreshing may guarantee exceeding github limit.
- if we know this, add a warning? refuse? stop?
-
gui, bug, sorting isn't preserved between addon dir switches
- for example, sorting by 'size' in one addon dir, then switching to another will see random sorting
-
git, add support for cloning repositories
- this is to get around addon repositories not uploading 'releases' when tagging
- switch between branches
- switch between tags
- could branches/tags be considered 'releases'?
- and what if we switch to a different branch and the folder structure changes?
- perhaps what we need is a separate place to clone these, and then copy them into the addons directory
- and what if we switch to a different branch and the folder structure changes?
- only available if local git available
- how to deal with local changes?
- have a policy of wiping out changes. or stashing changes.
- how to deal with repository being a mutual dependency?
- like, some other addon tries to overwrite it with their own version?
- we have ignore rules and pin rules already.
- can pinned addons be replaced? I've forgotten.
- we have ignore rules and pin rules already.
- like, some other addon tries to overwrite it with their own version?
- how about a shallow clone?
- just the files are cloned to a directory
-
github, install addon from the auto-generated .zip files
- it looks like auctionator has disabled/deleted their 'releases' and put a link to their curseforge page up
- pretty sure they used to be there, I can see strongbox has downloaded a bunch
- we still have access to tags though
- we'll have to do some directory name munging
- it looks like auctionator has disabled/deleted their 'releases' and put a link to their curseforge page up
-
grouping addons
- I think the tree-table-view allows us to 'group' things now ...
- it's 'flat' at the moment, but it could be grouped by 'ignored', 'pinned', 'updates available'
- ignored are collapsed
- custom/named groups!
- it's 'flat' at the moment, but it could be grouped by 'ignored', 'pinned', 'updates available'
- I think the tree-table-view allows us to 'group' things now ...
-
wowinterface, fetch addon data from secondary source
- augment what is currently implemented with my own source
- failure to fetch this other data shouldn't prevent wowi updates from working normally
- this source is hosted on github as static content, updated daily.
- augment what is currently implemented with my own source
-
github authentication
- so user doesn't get capped
- or have to wrangle GITHUB_AUTH tokens
- so user doesn't get capped
-
bug, addon detail, highlighted installed version is causing rows to be highlighted in the raw data column?
- looks like a javafx problem, no idea how to fix
- try reducing to smallest possible reproduction
-
create a parser for that shit markup that is preventing reconcilation
-
finer grained control over grouping of addons
- like what?
- like a grouped addon or grouping lists of addons?
- 'website'
- 'x-website'/'x-url' in toc
- add 'website' to addon-detail pane next to 'browse local files' and addon host
- depends on capturing x-website
- add a 'website' column to installed-addons
- 'author'
- add an 'author' column to installed-addons
- add to addon-detail
- search other addons by author
- 'releases'
- capture full set of releases, including hashes if they exist
-
investigate better popularity metric than 'downloads'
- if we make an effort to scrape everyday, we can generate this popularity graph ourselves
-
github, bug, multi-toc addons are getting a warning when
strict?
is true and the game track is changed -
bug, test [:core :clear-addon-ignore-flag--implicit-ignore] is printing an error when game-track-list definitely exists
- what is removing it?
-
default to keeping last three zip files by default
-
icons for browse fs, addon sources
-
preference for 'fat rows'
- increase the padding for each row a bit
-
"developer warnings"
- a preference that bumps certain debug messages to warnings and errors for developers
- like if a release.json is missing assets
- or the toc file is mangled
- or is missing useful information
- or the zip file is badly formed
- stuff a regular user should gloss over but a dev might find useful
- 2023-06: isn't just debug-level output?
- ... we don't have debug output available in the gui. interesting.
- a preference that bumps certain debug messages to warnings and errors for developers
-
a more permanent store than just cached files
- I want to store release data permanently
- multiple pages
- release.json
- why can't we do this using the nfo data?
- I want to store release data permanently
-
github, can we support addons that have no detectable game tracks, no toc files, no release.json, nothing but downloadable assets?
- https://github.com/RealUI/RealUI
- we could download it, unpack it and inspect it then?
-
github, can we support addons that are splitting their game track releases over separate releases?
- like Aptechka
- https://github.com/rgd87/Aptechka/releases
- fucking /sigh!
- https://github.com/rgd87/Aptechka/releases
- like Aptechka
-
toc, add support for 'Interface-Retail', 'Interface-Classic', 'Interface-BCC'
- how much of a thing is this?
- is it more of a templating thing?
- https://github.com/Myrroddin/MrBigglesworthDeath/blob/master/MrBigglesworthDeath.toc
- how much of a thing is this?
-
ux, complex export pane
- choose format
- json, csv, edn
- choose to keep ignored or not
- choose fields to keep
- warning if not enough fields for import
- choose format
-
bug, gui, 'updated' column is using dummy date in certain cases
- I thought I fixed this?
-
gitlab, add optional API authentication like github
-
bug, stacktrace on double refresh
-
gui, toggleable highlighers as a menuitem
- highlight unmatched
- highlight updates
- highlight mismatched game track
- highlight mismatched update host
- installing addon from a different host
- touch of colour against each menuitem would serve as a legend
- 2021-10: not sure about this one anymore
- returned to the bucket.
-
gui 'wow' column is inconsistent
- github returns new
interface-version
values with the update data, wowi stores this in it'sfileList
file. - wowi has
UICompatibility
in v3 of it'sfileList
andgameVersion
in v4 of it'sfileList
, but nothing when fetching an addon's updates.- I'd need to combine the catalogue data (which could be a week old already) with the update data.
- for curseforge, it's pulling it's value from :gameVersion, which may be empty
- in which case it pulls it's value from the toc file, which may be different from the selected game track
- the value in the gui should reflect the installed version if no update pending, else the interface version of the pending update.
- returning to bucket 2021-10
- it works well enough for now
- github returns new
-
centralised download location on filesystem
- The Undermine Journal is large (75MB) and it sucks to download it again and again from different dirs
- perhaps tie this in with a rename of the downloaded zip file so unambiguous reverse lookups can be done:
- source--sourceid--version.zip => curseforge--543210--1-9-26.zip
- perhaps tie this in with a rename of the downloaded zip file so unambiguous reverse lookups can be done:
- The Undermine Journal is large (75MB) and it sucks to download it again and again from different dirs
-
centralised addon directory db
- install an addon, then 'deactivate' it
- essentially uninstalls the addon but it's still available at the tick of a box
- see WADM https://github.com/MBODM/WADM
- does Nexus Mod Manager do something similar?
- that UI is so shit though ... who knows what it is doing.
- essentially uninstalls the addon but it's still available at the tick of a box
- install an addon, then 'deactivate' it
-
gui, "fat rows"
- add option to switch to fatter rows with more styled data
- clicking on the row expands it from small to medium
- clicking 'more' (or whatever) takes to addon detail page
- perhaps coincide with catalogue v3 with more addon details
- add option to switch to fatter rows with more styled data
-
import/export, bring up the split logging pane during operation so any problems can be seen
- or update the tab title to reflect the number of warnings/errors
- otherwise there is zero feedback
- or update the tab title to reflect the number of warnings/errors
-
export/import addons to/from github
- I have a github account, I'd like to push/pull addons to it
- use a gist?
- dedicated repo?
- other targets to publish to?
- always keep the base import/export to a file
- ftp? s3 bucket? ssh? gitlab?
- feels a bit like scope creep to me
- it would be nice and convenient, but a lot of work to build and maintain
- I have a github account, I'd like to push/pull addons to it
-
http, clear non-catalogue cache after session
- it seems reasonable that stopping and starting the app will have it re-fetch addon summaries.
- maybe add as a preference
-
deleting an addon should also remove any of it's zip files
- this sounds like an opt-in preference
-
http, share a pool of connections between jobs
- https://github.com/dakrone/clj-http#user-content-persistent-connections
- N connections serving M threads
- pretty fast just by making requests in parallel
- moving this back to the bucket until I start really looking for optimisations
-
preferences, "update all addons automatically"
- update README features
- punted back to bucket 2021-06-02
-
logging, app level 'help'
- messages to the user that are not informational, or debug or warnings or errors, but simple helpful messages
- 'help' messages strike me now as being 'info' level
- perhaps attach 'detail' metadata to info messages that elaborate on the message and what can be done about it
- it should stand out from the other messages, look friendly, etc
- going with the further 'detail' metadata idea, adding an info icon would make it stand out
- messages to the user that are not informational, or debug or warnings or errors, but simple helpful messages
-
classic addon dir detection
- also check for
- 'classic' 'classic_beta' 'classic_ptr'
- is there an official source on these somewhere?
- also check for
-
bug, I should be able to re-install a pinned addon if the pinned release is available, but I'm getting an error
- "refusing to install addon that will overwrite a pinned addon"
- this is actually a bit more involved than it first looks. shifting to it's own ticket
-
nfo, spend some time futzing with nfo files on disk and how they can break the UI
- I've managed to get some weird error messages by changing 'source' to an int, to a catalogue that doesn't exist, etc
-
test, can gui-diff and main/test be pushed back into the testing namespace and elided from release somehow?
-
add checksum checks after downloading
- curseforge have an md5 that can be used
- unfortunately no checksum in api results
- they do have a 'fileLength' and a 'fingerprint'
- fingerprint is 9 digits and all decimal, so not a hex digest
- wowinterface checksum is hidden behind a javascript tabber but still available
- wowinterface do have a md5sum in results! score
- curseforge have an md5 that can be used
-
EOL planning
- I'm not going away and neither is strongbox, but! should I or my free time disappear will strongbox continue being useful?
- what can I do to ensure it is the most useful if I just give up on it tomorrow?
- catalogues have been pushed into user config, so they can be swapped out if necessary
- more can be done around this to make catalogue generation more accessible and safe
- catalogues have been pushed into user config, so they can be swapped out if necessary
- what can't I control?
- addon hosts
- our interface with them is their API or in wowi's case, their API and website
- addon hosts
- what can I do to ensure it is the most useful if I just give up on it tomorrow?
- I'm not going away and neither is strongbox, but! should I or my free time disappear will strongbox continue being useful?
-
reconciliation, add dirname support
- not sure which hosts support these
-
reconciliation, rename 'reinstall all' to 'reconcile'
- steal from the best
- make the reconcile automatic
- if a nfo file isn't found
- remove the 'first time instructions' from the readme
- it should just fucking do it
-
add a 'tabula rasa' option that wipes everything
- cache, catalog, config, downloaded zip files
-
no-lib
- user can opt to prefer no-lib versions
- what if addon only ever released one no-lib then decided not to use them again?
- addon would be stuck on a very old version
- addon releases would then need to be grouped into lib/no-lib
- what if addon only ever released one no-lib then decided not to use them again?
- user can opt to prefer no-lib versions
-
update check
- ignore pre-releases
- are these like no-lib?
- ignore pre-releases
-
keep a list of previously installed addons
- eh. tie it in with downloading more release information
- defer until after job queue
- very large downloads are possible. just see curseforge dbm
-
import and export addons using addon urls
-
cli, exports
-
import, export, capture 'pinned' information
- we can now import addons at a specific version
- when importing a pinned addon, should we keep the pin?
- or drop the pin it and display updates?
- we can now export addons at specific versions
- I think we already have this though ... called :version
- we can now import addons at a specific version
-
import, skip importing an addon if addon already exists in addon dir
-
import, why can't an export record be matched to the catalogue and then installed that way?
- no need for padding and dummy dirnames then
- installing normally would also include the mutual dependency handling
-
github, importing an exported addon list with a github addon won't see that addon installed
- unless that addon is present in the user catalogue
- which in a fresh install where a list of addons are being restored is unlikely...
- this is interesting actually. the exported addon list has become a mini-catalogue
- some addons require the larger catalogue to resolve
- github addons are resolved and installed by a different means...
- unless that addon is present in the user catalogue
-
github, gitlab, are we paginating release calls?
- no we're not.
- unless authenticated somehow, I wouldn't bother.
-
github, like gitlab, use presence of multiple toc files to determine game track support
-
gui, bug, changing sort order during refresh doesn't reflect which addon is being updated
- I think changing column ordering and moving columns should be disabled while updates happen
- just freeze or disable them or something.
- I think changing column ordering and moving columns should be disabled while updates happen
-
internationalisation?
- Akitools has no english description but it does have a "Notes-zhCN" in the toc file that could be used
- wowman was mentioned on a french forum the other day ..
-
gui, get log window scrolling in other direction
- export to markdown
- I think I'd like a simple list like:
- of course, this would be a different type of export than the one used for import
- although ... I could possibly parse the list ... and nah.
- clostache?
- search, order by date only orders the current page of results
- cli, update specific addon
- cli, install specific addon
- cli, colours!
- cli, replace with a repl
- lein --cli gives you access to the code directly
this is still an interesting idea
- remove log split
- remove tabs
- gui, both panes, filter by categories
- gui, group results
- installed
- updates
- category ...
-
a user catalogue tab pane
- context menu
- refresh selected
- remove selected
- button bar
- refresh all button
- menu
- 'refresh all' switches to user catalogue pane
- 2023-06: the search tab gained a 'star' button that filters to this now essentially
- and periodic user catalogue refreshes are now an opt-in feature if the user thinks it's a big deal
- context menu
-
github, preference to sync stars with github repo, if authenticated
- stars have come to mean 'favourited' and under the hood it adds the addon to the user-catalogue
-
search, group results
- group by downloads/age/category?
- it would finally be the best use for category data
- 2023-06: categories became tags and tags became more useful. 'age' field went away.
- grouping could still happen but the best would be grouping by host and we have filtering by host now so, ehh.
- group by downloads/age/category?
-
importing addons, skip db lookup for addon urls that don't need it
- if we can 'expand it' then we can download it and install it.
- yes, and the explicit url should be respected.
- if the user imported from wowi or curseforge, that host should be used for installation
- after installation, we can match it against the current catalogue and go from there.
- because the addon is added to the user catalogue, it will always be available, there will always be a match.
- but not initially.
- no, but we have the source and source-id (or url) to match against.
- but not initially.
- because the addon is added to the user catalogue, it will always be available, there will always be a match.
- after installation, we can match it against the current catalogue and go from there.
- we need to find a download url
- wowi needs source-id
- curse needs a source-id which comes from the db
- tukui needs source-id and a name if the id negative
- name could come from the url string to import
- if the user imported from wowi or curseforge, that host should be used for installation
- yes, and the explicit url should be respected.
- I think tukui, wowi can, github obs, curseforge could not
- I'm moving this to 'wontfix'
- it's possible for wowi and tukui, not curse
- the error message is clear (can't find in catalogue)
- if we can 'expand it' then we can download it and install it.
-
logs, persistent addon events
- installed, updated, pin, ignore events
- like ... stored in addon history?
- possible, but why? to please data freaks like me?
- going to need a better reason than 'just cos' for this
-
add a 'Delete all' option to cache menu
- we don't really want legitimate nfo files to be accidentally deleted
-
investigate
.csv
as a human-readable but more compact representation- might be able to save a MB on extraneous syntax
- might be able to speed up parsing and loading
- depends on profile task
- update: profiling happened, it's not the json loading that is slow it was many other things.
- reading the file and parsing the json is actually very quick, validation is slower but necessary
- json is just more flexible all around than csv.
-
windows support
- windows is just the worst, most awful dystopian software I've ever seen and it hurts my soul every time I try to use it
- I just plain hate it, it epitomises the very opposite of what I stand for and I refuse to work on it ever again
-
.rar/.tar.gz addons
- !BeautyLoot on wowinterface is an example of this
- rar is a proprietary format
- the vast majority of addons use .zip
- no native support in java/clojure for it
- library here: https://github.com/junrar/junrar
-
cli, interactive interface when no specific action specified
- you have N addons installed. what do you want to do? (list, update, update-all, delete) etc
- this is a huge amount of hassle