-
-
Notifications
You must be signed in to change notification settings - Fork 122
Quick Start Guide
This quick start guide will help you get a RomM instance up and running. It is split into 3 parts:
- Prepare
- Build
- Configure
This guide will assume that you already have the following done, if not - stop here and come back when you do.
- Docker and Docker Compose installed
- OpenSSL installed
- A Twitch account (optional)
- 2-factor authentication set up on your Twitch account
- This is required to get a dev account and an IGDB key
- A MobyGames account (optional)
- Your Roms organized in the correct format
Head over to API key docs to get your Twitch and/or MobyGames keys, then come back here
This step will generate a key that is used in the authorization of RomM. Without this, you will be unable to log in and use the platform
Run the following command in a terminal:
openssl rand -hex 32
Then copy the output and save it to the ROMM_AUTH_SECRET_KEY
variable in the docker-compose file. It should look like this:
~$: openssl rand -hex 32
03a054b6ca27e0107c5eed552ea66becd9f3a2a8a91e7595cd462a593f9ecd09
Now that we have everything gathered, we can begin getting your instance set up!
- Download a copy of the latest docker-compose.example.yml file from GitHub
- Edit the file and modify the following values to configure the database
-
MYSQL_ROOT_PASSWORD
: Sets the root password of the database. Use a unique and secure password (use a password generator for simplicity) -
MYSQL_DATABASE
: Sets the database name for RomM. This can be modified - but it's not necessary -
MYSQL_USER
: User to connect to the database with. This can be modified - but it's not necessary -
MYSQL_PASSWORD
: Password for the user to connect to the database with. Use a unique and secure password (use a password generator for simplicity)
-
- Modify the following values in the environment to configure the application. -- Other values can be changed, but should not be done unless you know what you are doing, and are outside the scope of this guide
-
DB_NAME
: Name of the database set in the database section -
DB_USER
: Name of the user to connect to the database -
DB_PASSWD
: Password of the user to connect to the database
-
- Modify the following values in the volumes to configure the application
-
/path/to/library
: Path to the directory where your rom files will be stored -
/path/to/assets
: Path to the directory where you will store your saves, etc -
/path/to/config
: Path to the directory where you will store the config.yml
-
- Save the file as docker-compose.yml instead of docker-compose.example.yml. It should look soomething like this:
- Open the terminal and navigate to the directory containing the docker-compose file
- Run
docker compose up -d
to kick off the docker pull. You will see it pull the container and set up the volumes and network:
- Run
docker ps -f name=romm
to verify that the containers are running - Open a web browser and navigate to
http://localhost:8080
, where you should be greeted with the RomM setup page - Go through the setup wizard, setting your admin username and password
- Log in with the credentials you set in the setup flow
Now that the container is running, we will configure it by importing your roms
This method is certainly viable, but not recommended if you have a lot of roms and/or multiple platforms. It is good for adding after the fact as your collection grows, but wouldn't be recommended for the first set up, nor for multi-file roms
- Log into RomM with your user credentials
- Navigate to Library -> Upload roms
- Select the platform, then click ADD ROMS and select the roms you want to upload in the file selector that appears
- Click UPLOAD to begin uploading the roms
- Repeat for all the roms/platforms you have
This method is generally the fastest and recommended for first time setup
- Stop your RomM instance.
docker compose down
if you are in the terminal and directory containing the docker-compose file, otherwisedocker stop romm
- Go to the library folder created by RomM, set in the docker-compose file under :/romm/library and create a folder named
roms
- Copy your platform folders/rom files into the
roms
folder you created - Start the RomM instance back up.
docker compose up -d
if you are in the terminal and directory containing the docker-compose file, otherwisedocker start romm
- Log into RomM with your user credentials
- Navigate to Library -> Scan
- The system will now begin scanning the rom files and applying metadata to them. You can click on any of the items that it has tagged to see the metadata it pulled without having to stop the scan
- After the scan completes, click the RomM logo to go back to the main screen. You should see the platforms and recent games it has scanned. You are now ready to rock and RomM!