Go to file
Timothy Baldridge 531043140f
Merge pull request #1027 from wabbajack-tools/dependabot/nuget/Microsoft.AspNetCore.Mvc.NewtonsoftJson-3.1.7
Bump Microsoft.AspNetCore.Mvc.NewtonsoftJson from 3.1.6 to 3.1.7
2020-08-13 05:47:41 -06:00
.github Updated feature request issue template 2020-08-09 14:11:23 +00:00
.vscode Updated README 2020-08-07 13:50:58 +02:00
Branding Add WabbaPray Emote 2020-06-28 19:27:11 +02:00
Compression.BSA Fix for overpicky filename parser 2020-08-11 11:08:37 -05:00
Compression.BSA.Test Re-hash patched files just in case 2020-08-07 05:24:30 -06:00
extra Added test file 2020-01-27 14:23:33 +01:00
VS Snippets Settings.XamlStyler file. Resaved all XAML /w formatting 2020-07-25 18:37:17 -05:00
Wabbajack Merge pull request #1024 from Noggog/bsa-optimization 2020-08-11 12:54:47 -06:00
Wabbajack.App.Test Re-hash patched files just in case 2020-08-07 05:24:30 -06:00
Wabbajack.CLI Tons of server-side fixes and tweaks to deal with strange nexus states 2020-08-11 22:25:12 -06:00
Wabbajack.Common Merge pull request #1031 from wabbajack-tools/ll-updates 2020-08-13 05:46:54 -06:00
Wabbajack.Common.CSP No more MessagePack, Json is love, Json is life 2020-04-06 14:48:54 -06:00
Wabbajack.Common.Test Removed RxUI from Wabbajack.Common 2020-08-11 10:37:17 -05:00
Wabbajack.Launcher Fix master and bump versions 2020-08-07 21:40:08 -06:00
Wabbajack.Lib Merge pull request #1031 from wabbajack-tools/ll-updates 2020-08-13 05:46:54 -06:00
Wabbajack.Server Merge pull request #1027 from wabbajack-tools/dependabot/nuget/Microsoft.AspNetCore.Mvc.NewtonsoftJson-3.1.7 2020-08-13 05:47:41 -06:00
Wabbajack.Server.Test More test fixes 2020-08-12 22:14:35 -06:00
Wabbajack.Test Merge pull request #1031 from wabbajack-tools/ll-updates 2020-08-13 05:46:54 -06:00
Wabbajack.VirtualFileSystem Default compression to off 2020-08-06 06:15:11 -06:00
Wabbajack.VirtualFileSystem.Test Re-hash patched files just in case 2020-08-07 05:24:30 -06:00
.editorconfig Reduced nullability error verbosity in editorconfig 2020-06-26 12:33:38 -05:00
.gitignore Enabled comment xmls export 2020-06-26 12:23:50 -05:00
.runsettings Clean up some references try to get tests to work 2019-12-26 17:41:33 -07:00
azure-list-validation.yml Update azure-list-validation.yml for Azure Pipelines 2019-11-06 07:24:52 -07:00
azure-pipelines.yml Update azure-pipelines.yml for Azure Pipelines 2020-08-04 07:59:39 -07:00
CHANGELOG.md Updated CHANGELOG 2020-08-11 14:33:13 +02:00
CONTRIBUTING.md Updated the requirements 2020-05-10 13:33:41 -04:00
Directory.Build.props Reduced nullability error verbosity in editorconfig 2020-06-26 12:33:38 -05:00
LICENSE.txt Update LICENSE.txt 2020-01-20 18:11:26 -07:00
NexusPage.html Fix typos + inconsistencies in logs 2020-01-13 22:11:07 +01:00
README.md Updated README 2020-08-10 19:20:02 +02:00
RECIPES.md Update RECIPES.md, revert line in README.md to SKSE 2019-11-11 21:15:47 +01:00
Settings.XamlStyler Settings.XamlStyler file. Resaved all XAML /w formatting 2020-07-25 18:37:17 -05:00
Wabbajack.sln Refactor BSAReader to a lazier overlay style 2020-08-11 09:23:55 -05:00
Wabbajack.sln.DotSettings Bit of a first draft of a launcher 2020-02-06 21:20:49 -07:00

Wabbajack

Build Status

Wabbajack is an automated Modlist Installer that can reproduce an entire modding setup on another machine without bundling any assets or re-distributing any mods.

Supported Games and Mod Manager

Game Platform Versions Notes
Morrowind Steam, GOG, BethNet
Oblivion Steam, GOG Normal and GotY
Fallout 3 Steam, GOG Normal and GotY
Fallout New Vegas Steam, GOG Normal and region locked RU version
Skyrim Steam
Skyrim Special Edition Steam
Enderal Steam
Fallout 4 Steam
Skyrim VR Steam
Fallout 4 VR Steam
Darkest Dungeon Steam, GOG Experimental
The Witcher 3 Steam, GOG Normal and GotY Experimental
Stardew Valley Steam, GOG Experimental

Note about games marked with experiment support:

A new MO2 plugin called Simple Games Plugin enables the easy creation of new game plugins for non BGS games. This is still very experimental in both MO2 and Wabbajack.

Installing a Modlist

Every Modlist comes with its own README containing information and instructions on how to install it correctly. You should definitely read the Modlist specific README if you want a successful installation.

The general procedure is download the Modlist which comes as a .wabbajack file, opening Wabbajack, clicking on the Install From Disk button, configuring Install and Download Location and hitting start.

Do note that installation can take anything from a few minutes to hours depending on the size of the Modlist, your Internet connection as well as your hardware. In the meantime you can take a look at some of the included mods of the Modlist in the Slideshow that is playing during installation.

Creating your own Modlist

Modlist Creation or Compilation as we call it, is a trial and error process. You will likely get a decent amount of compilation errors in the beginning and have to spent some time fixing them before your first compilation succeeds. After that you can do incremental builds which take significantly less time and have close to zero errors compared to your first build.

Requirements

Wabbajack requires that you created your Modlist using a portable version of Mod Organizer 2. This is a hard requirement and Wabbajack won't work with Vortex, Kortex, Wyre Bash, Nexus Mod Manager, Oblivion Mod Manager or any other Mod Manager, not even Mod Organizer 1.

Aside from needed a portable MO2 installation you need to have a specific setup and workflow when modding, see Pre-Compilation for more information about that.

Pre-Compilation

Compilation itself is similar to Installation as you just configure some paths and start the process, sit back and wait for Wabbajack to finish. Wabbajack requires a rather specific MO2 setup and you might have to change your workflow when modding for a WJ Modlist.

Everything comes for somewhere

Wabbajack is an automated Modlist Installer that can reproduce an entire modding setup on another machine without bundling any assets or re-distributing any mods.

The focus is on without bundling any assets or re-distributing any mods. This means that Wabbajack needs to know where every single file came from. The most common origin is your downloads folder.

If you take a quick look inside your MO2 downloads folder you will find 2 types of files:

  1. The actual download (some archive)
  2. A .meta file that has the same name the archive its for

You might have SkyUI_5_1-3863-5-1.7z and SkyUI_5_1-3863-5-1.7z.meta.

These .meta files are created by MO2 and typically get created when you click the MOD MANAGER DOWNLOAD button on Nexus Mods. If you open the .meta file you will find some metadata for the accompanied archive, the most important entries being fileID, modID and gameName.

Wabbajack will use the MO2 .meta files to find out where the archive came from using the Nexus Mods API. This means that you should use the MOD MANAGER DOWNLOAD button on Nexus Mods or you have to create those .meta files yourself (you can also use the Query Info context menu option in the MO2 Downloads tab. This will populate the metadata of the selected archive).

For more information about .meta files, support sites and how to actually create them, see the Meta File section.

Script Extender and Cleaned Masters

The first step for modding a Bethesda game: Download the game, install the Script Extender and clean base game master files (.esms). Wabbajack can, of course, automate these steps.

(You should use MO2s virtual file system for SKSE Scripts, it is not recommended to install the SKSE Scripts into the game folder directly).

Wabbajack can match files from your game folder with your downloads folder (more in-depth info on that topic: Game Folder Files and MO2), this means you download the Script Extender to your MO2 downloads folder and create a .meta file for it. The meta file should look something like this:

[General]
directURL=http://skse.silverlock.org/beta/skse64_2_00_18.7z

In the example above we used SKSE SE 2.0.18 and you'd have to replace the URL with the direct download link of the Script Extender you are using.

Next up are Cleaned Master Files. Use xEdit through MO2 and clean the base game master files normally, copy the cleaned master files to a new mod in MO2 (called Cleaned Master Files or something) and replace the cleaned master files in your game folder with the backup created by xEdit to revert them to their default unmodified state.

Game Folder Files and MO2

You now know about .meta files and understand that every file has to come from somewhere, this also means that you also need to create .meta files for MO2 and files in your game folder. We recommend using the MO2 GitHub Releases instead of the ones you find on the Nexus.

Mods that need to be installed to the game folder by the user are required to be installed to a Game Folder Files folder in your MO2 directory. Let's look at an example for better understanding:

You will likely make use of SKSE/F4SE/OBSE or other Script Extender if you are modding Bethesda titles. Eg for SKSE you'd need to install skse64_1_5_97.dll, skse64_loader.exe and skse64_steam_loader.dll to your game folder. To make things easier for the end user, you can should put those files inside the Game Folder Files folder at MO2\Game Folder Files. You also need the archive and it's .meta file (see Script Extender and Cleaned ESMs section if you haven't) in your downloads folder so Wabbajack can match those files.

The user then only has to copy the files from the Game Folder Files directory to their game folder after installation. This also works for other files that need to be installed directly to the game folder like ENB or ReShade.

Special Flags

There are some special cases where you want to change the default Wabbajack behavior for a specific mod. You can place the following flags in the notes or comments section of a mod to change how Wabbajack handles that mod.

Flag Description Notes
WABBAJACK_INCLUDE All mod files will be inlined into the .wabbajack file
WABBAJACK_NOMATCH_INCLUDE All mod files will be inlined into the .wabbajack file even if Wabbajack did not found a match for them Useful for custom patches you created
WABBAJACK_ALWAYS_ENABLE The mod will not be ignored by Wabbajack even if it's disabled Wabbajack will normally ignore all mods you disabled in MO2 but there are some cases where you might want to give some choice to the end user and want to have the mod included
WABBAJACK_ALWAYS_DISABLE The mod will always be ignored by Wabbajack Useful if you don't want some mods included in the Modlist but still want to keep it active in your own setup

Patches

Reading all the previous section you might wonder if Wabbajack is able to detect modified files and how it deals with them. Wabbajack can't include the modified file so instead we just include the difference between the original and modified version.

This basically means original + patch = final and we only include patch in the .wabbajack file which, by itself, is just gibberish and completely useless without the original file. This allows us to distribute arbitrary changes without violating copyrights as we do not copy copyrighted material. Instead, we copy instructions on how to modify the copyrighted material.

You don't even have to tell Wabbajack that a specific file was modified, that you be way too much work. Instead Wabbajack will figure out which file got modified and create a binary patch. The modified file can be anything from some modified settings file to a patched plugin or optimized mesh/texture.

BSA Decomposition

Wabbajack is able to analyse .bsa and .ba2 files and can also create those. This means that you can compress files into a BSA and Wabbajack will index that BSA, match the files against the downloads and re-create the BSA during installation for the user.

Multiple MO2 Profiles

Wabbajack will normally ignore every other profile but you might have more than one profile that should be included. In this case you can create a otherprofiles.txt file in your main profile folder and write the names of the other profiles (1 per line) in it.

Example:

Profiles: SFW, NSFW (SFW is the main profile)

contents of MO2\profiles\SFW\otherprofiles.txt:

NSFW

Minimal Downloads Folder

We already talked about how Wabbajack will match files to determine where they came from. This can sometimes not work as intended and Wabbajack might end up matching files against the wrong archive. This can happen when you have multiple versions of the same mod in your downloads folder. It is highly recommended that you delete unused downloads and previous versions of mods so that Wabbajack doesn't end up mis-matching files and the end user ends up downloading more than they need.

Compilation

Compilation itself is very straight forward and similar to Installation: you let Wabbajack run and hope it finishes successfully. The key for making it run successfully is having a "Wabbajack-compliant" MO2 setup which you can get by following the advices from the previous sections.

Wabbajack Compilation Configuration

In Wabbajack select Create a Modlist to navigate to the configuration screen. Here you can configure some metadata for your Modlist which will later be viewable by the user.

Field Description Notes
Modlist Name REQUIRED: Name of your Modlist
Version REQUIRED: Current Version Do note that this has to be a real Version and not some random text like "The best version on Earth", this is Wabbajack not the Nexus!
Author Modlist Author Should be your name in original Modlists and/or the name of the original Modlist author if you adapted a normal Modlist to a Wabbajack Modlist
Description 700 characters Descriptions
Image Modlist Image Aspect ratio should be 16:9 for the best result
Website Website URL
Readme Readme URL
NSFW NSFW Checkbox Only really needed for official Modlists as our Galleries have the option to hide NSFW Modlists

Compilation Errors

You will likely get a ton of errors during your first compilation which is to be expected. We highly recommend you join our Discord and check the modlist-development-help channel for help.

Post-Compilation

After you have finished the Compilation you are basically done with Wabbajack and can upload the resulting .wabbajack file to somewhere, share it with people or just keep it for yourself as a Modlist backup. This section is for people who want to share their Modlist with the community.

In the Wabbajack community we differentiate between official and unofficial Modlists. The former being curated Modlists which have been tested and are available in the Wabbajack Gallery while the latter are Modlists submitted on our Discord in the unofficial-modlist-submissions channel and are not tested.

Official Modlists also get their own support channel on our Discord and often have 500-2500 users depending on the game. Do note that these Modlists receive regular updates and the authors are putting in a lot of hours to deliver the best possible version. If you think your Modlist and more importantly: yourself are up for the task you can submit your Modlist for official status on the Discord in the modlist-development-info channel.

Managing a Modlist can be tricky if you have never done something like this. In the early days of Wabbajack we mostly relied on GDocs READMEs and hosted all accompanying files on GDrive while managing issues through the support channel on Discord. This system was later almost completely replaced through valiant effort by one of our developers: almost all new Modlists use GitHub for managing their Modlist.

GitHub was made for developers and is the site you are currently on. It mostly hosts source code for open source projects, such as Wabbajack, but can also be used for project management. Another strong point is Markdown support. This README you are currently reading is, like every other GitHub README, written in Markdown and rendered on GitHub.

On the topic of READMEs: you should create a good one.

It is not sufficient to just slap some install and MCM instructions in there. Your Modlist might contain a thousand mods and offer hundreds of playtime but the user might not know what in oblivion is even going on and what's included.

Example structure for a good README:

  • Preamble: Give a quick overview about what your Modlist is about, the core idea and also mention that it's a Wabbajack Modlist (some might not know what Wabbajack is so link to this README)
  • Requirements: Simple list of requirements such as min CPU, GPU, RAM and most importantly: Drive Space. Also include a list of accounts the user needs such as a Nexus Mods, LoversLab, VectorPlexus Account or any other sites your are downloading from
  • Installation: Installation instructions specific to your Modlist. You can take a look at some of the Modlists linked below as almost all of them use the same instructions with minor changes
  • Important Mods you should know about: This is an important section you should not forget. Go in-depth on core mods and talk about important mods the user should know about. It can be overwhelming for the user to just be thrusted into a completely modded world without knowing what's even included and possible.
  • MCM: If your Modlist has some sort of MCM like for Skyrim or Fallout 4 then you should give instructions on what settings to use
  • Changelog: Should not be in the README and can be in a separate file called CHANGELOG.md but make sure to create one

Some Modlists that host all their stuff on GitHub:

Meta Files

Read Everything comes for somewhere first, as that section explains the basic concept of meta files. This section focuses more on advances uses.

You already know how .meta files should look for mods that come from Nexus Mods:

[General]
gameName=Skyrim
modID=3863
fileID=1000172397

This is the basic configuration for an archive that game from Nexus Mods. You can get these types of .meta files through MO2 by using the Query Info option in the Downloads tab.

Mods can also be hosted somewhere else, eg on other modding sites like LoversLab, ModDB or normal file hosting services like GDrive and MEGA. Below is a table for all supported sites that Wabbajack can download from.

Additional notes:

  • Every .meta file, no matter the site, has to start with [General]
  • .meta files are case sensitive (see Issue #480 for more info, this will be fixed somewhere in the future)
  • The "Whitelist" Wabbajack uses is available on GitHub and you might have to create a Pull Request if you want to add a link
  • For IPS4 Sites: IPS4 sites have a common layout and all behave very similar. There are some minor differences because they use different template versions but in general the same layout applies to all of them. Here are the different download links you can have for IPS4 sites:
    • Multi-file download: {SITE-PREFIX}/files/file/{FILE}/?do=download&r={ID}&confirm=1&t=1
    • Single-file download: {SITE-PREFIX}/files/file/{FILE}/
    • Attachments: {SITE-PREFIX}/applications/core/interface/file/attachment.php?id={ID}
Site Requires Login Requires Whitelist Entry Meta File Layout Example Notes
LoversLab Yes No IPS4 Site Prefix: https://www.loverslab.com directURL=https://www.loverslab.com/files/file/11116-test-file-for-wabbajack-integration/?do=download&r=737123&confirm=1&t=1 IPS4 Site, mostly multi-file downloads
VectorPlexus Yes No IPS4 Site Prefix: https://vectorplexus.com directURL=https://vectorplexus.com/files/file/290-wabbajack-test-file IPS4 Site, mostly multi-file downloads
TES Alliance Yes No IPS4 Site Prefix: http://tesalliance.org/forums/index.php? directURL=http://tesalliance.org/forums/index.php?/files/file/2035-wabbajack-test-file/ IPS4 Site, mostly single-file downloads
TESAll Yes No IPS4 Site Prefix: https://tesall.ru directURL=https://tesall.ru/files/getdownload/594545-wabbajack-test-file/ IPS4 Site, mostly single-file downloads
ModDB No No directURL=https://www.moddb.com/downloads/start/{ID} https://www.moddb.com/downloads/start/124908 Downloads can be very slow
Bethesda.net No No directURL=https://bethesda.net/en/mods/{GAME}/mod-detail/{ID} directURL=https://bethesda.net/en/mods/skyrim/mod-detail/4145641
Patreon No Yes directURL=https://www.patreon.com/file?h={ID1}i={ID2} directURL=https://www.patreon.com/file?h=34874668&i=5247431 Only public downloads, paywalled downloads can not be downloaded
GitHub No No directURL=https://github.com/{USER}/{REPO}/releases/download/{TAG}/{FILE} directURL=https://github.com/ModOrganizer2/modorganizer/releases/download/v2.3.1/Mod.Organizer-2.3.1.7z
GDrive No Yes directURL=https://drive.google.com/file/d/{ID} directURL=https://drive.google.com/file/d/1grLRTrpHxlg7VPxATTFNfq2OkU_Plvh_/ GDrive is known to not be a reliable file hosting service as a file can get temporarily inaccessible if too many users try to download it
MEGA No (Optional) Yes directURL=https://mega.nz/#!{ID} directURL=https://mega.nz/#!CsMSFaaJ!-uziC4mbJPRy2e4pPk8Gjb3oDT_38Be9fzZ6Ld4NL-k MEGA has a 5GB transfer quota on non-premium users, even less for non-registered ones. It is recommended to login to MEGA before downloading any files
Mediafire No Yes directURL=https://www.mediafire.com/file/{FILE} directURL=http://www.mediafire.com/file/agiqzm1xwebczpx/WABBAJACK_TEST_FILE.txt Medafire downloads are known to fail from time to time
Dropbox No Yes directURL=https://www.dropbox.com/s/{FILE}?dl=0 directURL=https://www.dropbox.com/s/5hov3m2pboppoc2/WABBAJACK_TEST_FILE.txt?dl=0
Yandex Disk No Yes directURL=https://yadi.sk/d/{ID} directURL=https://yadi.sk/d/jqwQT4ByYtC9Tw

FAQ

How does Wabbajack differ from Automaton?

I, halgari, used to be a developer working on Automaton. Sadly development was moving a bit too slowly for my liking, and I realized that a complete rewrite would allow the implementation of some really nice features (like BSA packing). As such I made the decision to strike out on my own and make an app that worked first, and then make it pretty. The end result is an app with a ton of features, and a less than professional UI. But that's my motto when coding "make it work, then make it pretty".

Can I charge for a Wabbajack Modlist I created?

No, as specified in the License, Wabbajack Modlists must be available for free. Any payment in exchange for access to a Wabbajack installer is strictly prohibited. This includes paywalling, "pay for beta access", "pay for current version, previous version is free", or any sort of other quid-pro-quo monetization structure. The Wabbajack team reserves the right to implement software that will prohibit the installation of any lists that are paywalled.

Can I accept donations for my installer?

Absolutely! As long as the act of donating does not entitle the donator to access to the installer. The installer must be free, donations must be a "thank you" not a purchase of services or content.

All original code in Wabbajack is given freely via the GPL3 license. Parts of Wabbajack use libraries that carry their own Open Sources licenses, those parts retain their original copyrights. Selling of Modlist files is strictly forbidden. As is hosting the files behind any sort of paywall. You received this tool free of charge, respect this by giving freely as you were given.

Contributing

Look at the CONTRIBUTING.md file for detailed guidelines.

Thanks to

Our testers and Discord members who encourage development and help test the builds.