Version 3.0 introduces exciting new fetures that require some changes to how RomM is setup and configured. If you're currently running a 2.x version, please review the migration guide before upgrading.
RomM (ROM Manager) allows you to scan, enrich, and browse your game collection with a clean and responsive interface. With support for multiple platforms, various naming schemes and custom tags, RomM is a must-have for anyone who plays on emulators.
- Scans your existing games library and enchances it with metadata from IGDB
- Supports a large number of platforms
- Play games directly from the browser using EmulatorJS
- Built-in authentication with multiple users and permissions
- Supports MAME, Nintendo Switch and PS2 naming schemes
- Detects and groups multifile games (e.g. PS1 games with multiple CDs)
- Can parse tags in filenames (e.g. (E), (USA), (rev v1), etc.)
- View, upload, update, and delete games from any modern web browser
🖥 Desktop | 📱 Mobile |
---|---|
Before running the image, ensure that Docker is installed and running on your system.
- Generate an API key for IGDB and set the
IGDB_CLIENT_ID
andIGDB_CLIENT_SECRET
variables. This step is essential for running a library scan. Instructions for generating the ID and Secret can be found here. Note that IGDB requires a Twitch account with 2FA enabled to generate the ID and Secret. - Verify that your library folder structure matches one of the options listed in the folder structure section.
- Create a docker-compose.yml file by referring to the example docker-compose.yml file for guidance, and customize it for your setup with the available environment variables.
- Launch the container(s) with
docker-compose up -d
.
If you are having issues with RomM, please review the wiki page for troubleshooting steps and common issues.
As mentioned in the installation section, RomM requires a specific folder structure to work. The two supported structures are as follows:
Structure A (recommended) | Structure B (fallback) |
---|---|
library/roms/gbc/rom_1.gbc
|
library/gbc/roms/rom_1.gbc
|
library/ ├─ roms/ │ ├─ gbc/ │ │ ├─ rom_1.gbc │ │ ├─ rom_2.gbc │ │ │ ├─ gba/ │ │ ├─ rom_1.gba │ │ ├─ rom_2.gba │ │ │ ├─ ps/ │ ├─ my_multifile_game/ │ │ ├─ my_game_cd1.iso │ │ ├─ my_game_cd2.iso │ │ │ ├─ rom_1.iso |
library/ ├─ gbc/ │ ├─ roms/ │ ├─ rom_1.gbc │ ├─ rom_2.gbc │ ├─ gba/ │ ├─ roms/ │ ├─ rom_1.gba │ ├─ rom_2.gba │ ├─ ps/ │ ├─ roms/ │ ├─ my_multifile_game/ │ │ ├─ my_game_cd1.iso │ │ ├─ my_game_cd2.iso │ │ │ ├─ rom_1.iso |
For folder naming conventions, review the Platform Support section. To override default system names in the folder structure (if your directories are named differently), see the Configuration File section.
RomM's "understanding" of your library can be configured with a config.yaml
file. Anytime that file is change, you must restart the container for changes to take effect. Refer to the example config.yml file for guidance on how to configure it, and the example docker-compose.yml file on how to mount it into the container.
The scheduler allows you to scheduled async tasks that run in the Redis container at regular intervals. Jobs can be run at a specific time in the future, after a time delta, or at recurring internals using cron notation. The wiki page on the scheduler has more information on how which tasks are available and how to enable them.
If you adhere to the RomM folder structure, RomM supports all platforms listed on the Supported Platforms page. The folder is is case sensitive and must be used exactly how it appears in the list. When scanning your library, RomM will use the folder name to determine the platform and fetch the appropriate game information, metadata, and cover art.
Additionally, some of these platforms have custom icons available (learn more about platform icons in our wiki).
Games can be tagged with region, revision, or other tags by using parentheses in the file name. Additionally, you can set the region and language by adding a prefix: (USA), [reg-J], (French), [De].
- Revision tags must be prefixed with "rev " or "rev-" (e.g. (rev v1) or (rev-1))
- Other tags will also be imported, for example: my_game [1.0001](HACK)[!].gba
Tags can be used to search for games in the search bar. For example, searching for (USA) will return all games with the USA tag.
Here are a few projects maintained by members of our community. As they are not regularly reviewed by the RomM team, we recommend you closely review them before use.
- CasaOS app via the BigBear App Store
- Helm Chart to deploy on Kubernetes by @psych0d0g
Join us on discord, where you can ask questions, submit ideas, get help, showcase your collection, and discuss RomM with other users.
If you like this project, consider buying me a coffee!
Here are a few projects that we think you might like:
- EmulatorJS: An embeddable, browser-based emulator
- RetroDECK: Retro gaming on SteamOS and Linux
- ES-DE Frontend: Emulator frontend for Linux, macOS and Windows
- Gaseous: Another self-hosted ROM manager