Check out Ferium's sister projects Ferinth and Furse which are Rust libraries to use the Modrinth and CurseForge APIs respectively
Ferium is an easy to use CLI program for downloading and updating Minecraft mods from Modrinth, CurseForge, and GitHub Releases. Simply specify the mods you use through the CLI and in just one command, you can download all the mods you configured.
ferium upgrade
Ferium is a compiled, statically linked program that does not require any external dependencies.
On Linux the regular version requires GTK to be installed, but the no-gui
version does not need this.
Ferium releases a no-gui version here and a version with a GUI file dialog here. The GUI version dependes on GTK
If you have the Rust toolchain, you can also compile and install Ferium by running cargo install ferium
.
Remember to use an add-on like cargo-update to keep Ferium updated to the latest version!
~/bin
When you first start up, you will have to create a new profile by running ferium profile create
and entering the details for your profile.
ferium add-modrinth project_id
project_id
is the slug or project id of the modsodium
and a project id AANobbMI
modrinth.com/mod/<slug>
), and the project id at the bottom of the left sidebar under 'Technical information'ferium add-modrinth sodium
or ferium add-modrinth AANobbMI
ferium add-github owner name
owner
is the username of the owner of the repository and name
is the name of the repository (both case-insensitive)CaffeineMC
and sodium-fabric
ferium add-github CaffeineMC sodium-fabric
(again, case-insensitive)Now after adding all your mods, run ferium upgrade
to download all of them to your output directory.
This defaults to .minecraft/mods
, where .minecraft
is the default Minecraft resources directory. You don't need to worry about this if you play with Mojang's launcher (unless you changed the resources directory).
You can choose to pick a custom output directory during profile creation or change it later.
If Ferium fails to find a compatible version of a mod, it will print it's name in red and give a reason.It will continue downloading the rest of the mods and will exit with an error. See the advanced section for more information.
You can see all the mods in your current profile by running ferium list
. If you want to see more information about them, you can run ferium list -v
or ferium list --verbose
. You can remove any of your mod by runnning ferium remove
, selecting the ones you would like to remove by using the space key, and pressing enter once you're done.
If some mod is compatible with your profile but Ferium does not download it, create an issue if you think it's a bug. Or else, you can disable the game version or mod loader checks by setting check_game_version
or check_mod_loader
to false in the specific mod.
For example, Just Enough Items does not specify the mod loader for older minecraft versions such as 1.12.2
. In this case, you would disable the mod loader check like so
json
{
"name": "Just Enough Items (JEI)",
"identifier": {
"CurseForgeProject": 238222
},
"check_mod_loader": false
}
You can create a profile by running ferium profile create
and configuring the following settings:
.minecraft/mods
where .minecraft
is the default Minecraft resources directory. You don't need to worry about this if you play with Mojang's launcher (unless you changed the resources directory)Ferium will automatically switch to the newly created profile.
You can configure these same settings afterwards by running ferium profile configure
You can see all the profiles you have by running ferium
profile list
.
Switch between your profiles using ferium profile switch
.
You can delete a profile by running ferium profile delete
and selecting the profile you want to delete.
If you would like to make a feature request, check the issues to see if the feature has already been added/planned. If not, create a new issue.
Note; A lot of Ferium's backend is in a seperate project, Libium. You might want to make some edits there for things like the config, add, upgrade, etc
Firstly, you need the Rust toolchain which includes cargo
, rustup
, etc. You can install these from the Rust website.
You'll also need the Just command runner, its basically a better version of make
.
If you want to build Ferium without cloning the repo, set the CURSEFORGE_API_KEY
environment variable, then run cargo install ferium
.
If you don't have a CurseForge API key you can set the variable to an empty value, however anything using the CurseForge API will not work.
To build the project and install it to your Cargo binary directory, clone the project and run just install
. If you want to install it for testing a developement version, run just
(alias for just install-dev
).
If you want to obtain executables for a specific OS, you can run just build-<OS>
and replace <OS>
with mac
, win
, or linux
. The produced binaries will be zipped and moved to out/
.
You can run clippy linters using just lint
, and integration tests using cargo test
.