Skip to content

Manages dockerfiles and related images available for use with OTTR

License

Notifications You must be signed in to change notification settings

jhudsl/ottr-docker

OTTR Docker library

This repository stores the Dockerfiles and associated files for images that can be used by OTTR for rendering (or other items underneath the hood).

How to use

In your OTTR repositories, you can specify a different docker image for rendering in the config_automation.yml file. For the purposes of rendering different courses, if you have code that needs to be run, you may require a custom Docker image so that you have the packages being called in the code.

Read more about docker customization on ottrproject.org.

To rebuild an image:

Go to Actions > Manual build of docker image > Run workflow

For directory, put the directory/docker image name that you'd like to rebuild. e.g. "base_ottr"

For tag, put the full name of the docker image as it is called on dockerhub. e.g. "jhudsl/base_ottr:main"

For "Push to Dockerhub" either put "true" if you'd like to push to dockerhub or "false" if you just want to test the build but not push it.

Example of a docker image manual rebuild settings:

Screen Shot 2023-02-28 at 2 34 23 PM

Adding a new image

  1. Make a new directory
  2. Put your Dockerfile in this directory. Make sure it is named "Dockerfile" exactly.
  3. Open up pull_request.yml and find where there is a comment like this:
# NEW IMAGES HERE: #
#######   - {dir: directory_path,   name: 'name its called on dockerhub'}
  1. Follow the same format as the other images in this repository and add a line to this list underneath matrix:
- {dir: directory_path,   name: 'name its called on dockerhub'}

For example it should look something like:

- {dir: base_ottr,   name: 'jhudsl/base_ottr'}

Where base_ottr is the path to the directory where the Dockerfile is stored inside the folder named base_ottr and jhudsl/base_ottr is what it is called on Dockerhub.
5. Develop your Dockerfile as your normally would but with each push to your open pull request pull_request.yml will attempt to rebuild it to test it.
6. When it successfully builds and it has what you want then you can have it reviewed and merged.
7. Upon merging merge.yml will rebuild the image one more time and then push to Dockerhub (if it has proper credentials to do so). Dockerhub username and Dockerhub token stored in this repository as GitHub secrets needs to have push access to the image on Dockerhub.

For more information on any of this ask @cansavvy.

About

Manages dockerfiles and related images available for use with OTTR

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •