/lila-docker

Lichess local development using Docker Compose.

Primary LanguageRustGNU Affero General Public License v3.0AGPL-3.0

lila-docker

Lichess development environment using Docker Compose, for developing on Mac or Linux.

The only requirements for running on your local machine are git and Docker Desktop. All the other dependencies (Scala, MongoDB, Node.js, etc) are installed and run in Docker containers.

Running in Gitpod

As an alternative to running it on your local machine, you can use Gitpod (a free, online, VS Code-like IDE) for contributing. With a single click, it will launch a workspace and automatically:

  • Clone the necessary Lichess repositories
  • Install all the dependencies
  • Seed your database with test data
  • Start your development site

Click here to create a workspace:

Open in Gitpod

Instructions

  1. Install Docker Desktop and have it running

  2. Clone this repo:

    git clone https://github.com/lichess-org/lila-docker
  3. Start the services

    cd lila-docker
    ./lila-docker start

    Starting new services may take 5-10 minutes. Some services will start before others and you may see errors in the logs until everything comes online.

    Lila will be the last service to complete, at which point you can visit http://localhost:8080/ to see the site.

Stopping

To stop the containers, for later resuming via ./lila-docker start:

./lila-docker stop

To remove the containers:

./lila-docker down

URLs

Always available:

Service URL
Main lila instance http://localhost:8080/
Mongodb manager http://localhost:8081/ (admin/pass)
Email inbox http://localhost:8025/

Depending on which optional services you start:

Service URL
lila-gif http://localhost:6175/image.gif?fen=4k3/6KP/8/8/8/8/7p/8
Picfit http://localhost:3001/healthcheck
Elasticsearch manager http://localhost:5601/
API docs http://localhost:8089/
Chessground http://localhost:8090/demo.html
PGN Viewer http://localhost:8091/

Usage

Scala development:

To restart lila (after making changes to any Scala code):

docker compose restart lila

UI (JS/CSS) development:

To watch for Typescript/SCSS changes and automatically recompile:

docker compose run --rm ui /lila/ui/build -w

Updating Routes

If you edit the conf/routes file, you'll need to update the route cache.

docker compose exec lila bash -c "./lila playRoutes"

To add translation keys:

After modifying a translation/source/*.xml file, run:

docker compose run --rm ui /lila/bin/trans-dump

Code formatting:

./lila-docker format

Berserk (Python library):

To install the development version of Berserk and run a sample script against your local development site:

docker compose run --rm -w /berserk python \
    bash -c "pip install -e . && python /scripts/berserk-example.py"

Scala Metals (IDE helper):

  1. In VS Code, open this lila-docker project and install the Dev Containers extension
  2. Cmd+Shift+P > "Dev Containers: Rebuild and Reopen in Container"
  3. A new VS Code window will open, attached to the container instead of your host machine
  4. File > Open Folder > "/workspaces/lila-docker/repos/lila" (or whichever Scala project you want to work on)
  5. Install + Enable the Scala Metals extension (Cmd+Shift+X > "Scala (Metals)")
  6. Cmd+Shift+P > "Metals: Import build"

Once the build has been imported, you should have code completion, go to definition, etc when you open a Scala file.

Scalachess:

If you're making changes to the Scalachess library, you can have lila use it instead of the published Maven version:

  1. Update the build.sbt file in the scalachess repo:

    -  ThisBuild / version           := "15.6.7"
    +  ThisBuild / version           := "my-test-1"  # give it a custom version
  2. Update the Dependencies.scala file in the lila repo:

    -  val chess = "org.lichess" %% "scalachess" % "15.6.7"
    +  val chess = "org.lichess" %% "scalachess" % "my-test-1"
  3. Publish the local scalachess changes and restart lila:

    docker compose exec lila bash -c "cd /scalachess && sbt publishLocal"
    docker compose restart lila

Other Scalachess commands:

## compile
docker compose run --rm -w /scalachess --entrypoint="sbt compile" lila

## test
docker compose run --rm -w /scalachess --entrypoint="sbt testKit/test" lila

## package
docker compose run --rm -w /scalachess --entrypoint="sbt package" lila

Dartchess:

## run formatter
docker run --rm -v $(pwd)/repos/dartchess:/mnt --workdir /mnt dart:3.1.5-sdk \
    dart format .

## analyze
docker run --rm -v $(pwd)/repos/dartchess:/mnt --workdir /mnt dart:3.1.5-sdk \
    bash -c "dart pub get && dart analyze"

## run tests
docker run --rm -v $(pwd)/repos/dartchess:/mnt --workdir /mnt dart:3.1.5-sdk \
    bash -c "dart pub get && dart test -x full_perft"

bbpPairings:

docker build -f docker/bbpPairings.Dockerfile . -t bbppairings
docker run --rm -v $(pwd)/repos/bbpPairings:/mnt bbppairings make

## verify
./repos/bbpPairings/bbpPairings.exe

Developing Chessground locally

By default, your local lila instance will use the version of chessground that is published to npm. If you want to make changes to that library and see them reflected in your local lila instance, you can do the following:

  1. Update the package.json in the lila repo:

    "dependencies": {
    -  "chessground": "^8.3.11",
    +  "chessground": "link:/chessground",
    }
  2. Start the chessground compiler in watch mode:

    docker compose run --rm ui bash -c "cd /chessground && pnpm install && pnpm run compile --watch"
  3. Start the lila ui build in watch mode:

    docker compose run --rm ui bash -c "/lila/ui/build -w"

Then you can see the updated chessground demo at http://localhost:8090/demo.html and when you refresh lila, it will use the local copy of chessground.

Developing PGN Viewer locally

To re-compile the PGN Viewer after making changes:

docker compose run --rm ui bash -c "cd /pgn-viewer && pnpm run sass-dev && pnpm run bundle-dev"

See the changes on the PGN Viewer demo page: http://localhost:8091/