Folder Structure

The folder structure output from using `create-lilypad-module`

Output

After creation, your project should look like this:

project_name
β”œβ”€β”€ config
β”‚   └── constants.py
β”œβ”€β”€ scripts
β”‚   β”œβ”€β”€ docker_build.py
β”‚   β”œβ”€β”€ download_models.py
β”‚   └── run_module.py
β”œβ”€β”€ src
β”‚   └── run_inference.py
β”œβ”€β”€ .dockerignore
β”œβ”€β”€ .env
β”œβ”€β”€ .gitignore
β”œβ”€β”€ Dockerfile
β”œβ”€β”€ lilypad_module.json.tmpl
β”œβ”€β”€ README.md
└── requirements.txt

For the module to run, these files must exist with exact filenames:

  • src/run_inference.py

    • The Dockerfile ENTRYPOINT.

    • If you change this files name or location, you must also update the ENTRYPOINT in your Dockerfile and lilypad_module.json.tmpl file to match.

  • config/constants.py

    • The configuration file that stores the DOCKER_REPO, DOCKER_TAG, MODULE_REPO, and TARGET_COMMIT.

    • If you change this files name or location, you must also update the import statements in scripts/docker_build.py and scripts/run_module.py.

  • Dockerfile

    • Required to build your module into a Docker image, and push the image to Docker Hub where it can be accessed by Lilypad Network.

  • requirements.txt

    • Used by the Dockerfile to install dependencies required by your module.

    • Technically, this file can be deleted or renamed, but this naming convention is highly recommended as an industry standard best practice.

  • lilypad_module.json.tmpl

    • The Lilypad configuration file.

You can delete or rename the other files.

You may create subdirectories inside src. For faster builds and smaller Docker images, only files inside src are copied by Docker. You need to put any files required to run your module inside src, otherwise Docker won’t copy them.

You can create more top-level directories. They will not be included in the final Docker image so you can use them for things like documentation.

If you have Git installed and your project is not part of a larger repository, then a new repository will be initialized resulting in an additional top-level .git directory.

Last updated

Was this helpful?