Labtainers include more than 50 cyber lab exercises and tools to build your own. Import a single VM appliance or install on a Linux system and your students are done with provisioning and administrative setup, for these and future lab exercises.
- Consistent lab execution environments and automated provisioning via Docker containers
- Multi-component network topologies on a modestly performing laptop computer
- Automated assessment of student lab activity and progress
- Individualized lab exercises to discourage sharing solutions
Labtainers provide controlled and consistent execution environments in which students perform labs entirely within the confines of their computer, regardless of the Linux distribution and packages installed on the student's computer. Labtainers run on our [VM appliance][vm-appliancee], or on any Linux with Dockers installed. And Labtainers is available as cloud-based VMs, e.g., on Azure as described in the Student Guide.
See the Student Guide for installation and use, and the Instructor Guide for student assessment. Developing and customizing lab exercises is described in the Designer Guide. See the Papers for additional information about the framework. The Labtainers website, and downloads (including VM appliances with Labtainers pre-installed) are at https://nps.edu/web/c3o/labtainers.
Distribution created: 10/15/2025 08:46 
Revision: v1.4.4g 
Commit: 8e32d9d3 
Branch: master 
Please see the licensing and distribution information in the docs/license.md file.
- 
scripts/labtainers-student -- the work directory for running and testing student labs. You must be in that directory to run student labs. 
- 
scripts/labtainers-instructor -- the work directory for running and testing automated assessment and viewing student results. 
- 
labs -- Files specific to each of the labs 
- 
setup_scripts -- scripts for installing Labtainers and Docker and updating Labtainers 
- 
docs -- latex source for the labdesigner.pdf, and other documentation. 
- 
UI -- Labtainers lab editor source code (Java). 
- 
headless-lite -- scripts for managing Docker Workstation and cloud instances of Labtainers (systems that do not have native X11 servers.) 
- 
scripts/designer -- Tools for building new labs and managing base Docker images. 
- 
config -- system-wide configuration settings (these are not the lab-specific configuration settings. 
- 
distrib -- distribution support scripts, e.g., for publishing labs to the Docker hub. 
- 
testsets -- Test procedures and expected results. (Per-lab drivers for SimLab are not distributed). 
- 
pkg-mirrors -- utility scripts for internal NPS package mirroring to reduce external package pulling during tests and distribution. 
Use the GitHub issue reports, or email me at [email protected]
Also see https://my.nps.edu/web/c3o/support1
The standard Labtainers distribution does not include files required for development of new labs. For those, run ./update-designer.sh from the labtainer/trunk/setup_scripts directory.
The installation script and the update-designer.sh script set environment variables, so you may want to logout/login, or start a new bash shell before using Labtainers the first time.
October 15, 2025
- Revised packet-introspection lab to update link for maxmind geo location database and note use of legacy database.
April 24, 2025
- Fixed imodule to properly create missing directories per pull request #96
November 22, 2024
- Replaced google cloud VM, this time due to a failure of systemd within containers.
September 23, 2024
- Replaced google cloud VM, which was using the wrong Docker version
September 10, 2024
- Typo in creation of imodule path
July 26, 2024
- Modify capinout to not use grantpt clib function, which now seems to crash when run from a container.
July 22, 2024
- Add a base container for Ubuntu22 and changes to framework to support that.
July 5, 2024
- Migrate to Ubuntu 24 as the VM appliance
- The docker pyhton package uses a broken python http library, requires package downgrade.
- Use virtual python environment to avoid Ubuntu lockdown of python packages.
- Add boot parameter to allow sharing systemd between containers and the VM.
- Redirect error messages from broken tar utility on updates.
- Ubuntu update breakage for msc packages (see update-ubuntu.sh) for version 18 VMs
- The docker-compose command is broken, use "docker compose"
- Force socket permissions in headless labtainers.
- Update headless Labtainers to use Ubuntu 24
November 27, 2023
- Add Google Cloud Platform option for ubuntu22 on ec2 machine.
September 18, 2023
- Previous fix implementation was flawed.
August 8, 2023
- Handle change to DockerHub image json format. Thanks Kees!
April 17, 2023
- Force use latest lab version, e.g., iptables2 intead of iptables. Fix tab completion to only display latest. (Issue #77)
- CyberCIEGE lab installation was failing due to X11 race condition. (Issue #76)
- Note in CyberCIEGE readme to direct students to save collected logs in $HOME directory. (Issue #75)
- Radius lab checkwork was incorrectly reporting "radiusd not running", missing prestop script. (Issue #74)
- Labedit corrupted the start configuration file when the MACVLAN_EXT option was used. (Issue #73)
February 1, 2023
- Bash history for non-default users was not being saved. January 26, 2023
- Modified powershell scripts for gcloud to use the selected zone to qualify VM names. January 4, 2023
- Containers using systemd were failing on newer systemd present in Ubuntu 22
- Add --zone parameter to google cloud scripts, with value derived from the set_defaults script. December 21, 2022
- Fix xforge results criteria to not expect pathname, and add check to see if POST issued to edit profile. And fix attacker http server to run from the home directory. December 19, 2022
- Add strace lab to introduce system call tracing.
- X11 DISPLAY value was incorrect if multiple devices in the /tmp/.X11-unix directory.
- Use of python/bash/sh/etc with no arguments was causing capinout to crash. December 9, 2022
- Modify Azure vm creation script to use a prebuilt Labtainer VM image from the Azure Community Gallery.
- Terminals on cloud VMs crash for unknown reasons during startup or right click on the terminal. Attempt to address by start/stop of a terminal. December 5, 2022
- When collecting artifacts, include modified files from directories of non-default users, e.g., their bash histories.
- Alter web assessment to display the new "other user" files.
- Include files from .local/bin on each container in artifacts. Intended to make these available to instructor via web assesment.
- In the ACL lab, include th /shared_data/bob/fun file in the results for reference by the instructor.
- Catch use of "sh" or "bash" from command line and skip when parsing for given command, e.g., as done with "time" or "sudo".
- In the tcpip lab, could not ssh into the server during subsequent lab sessions, the /run/sshd directory was not being remade. November 16, 2022
- Fix path to Snort Manual in snort lab.
- In ossec manual,fix path to manage_agents October 12, 2022
- Google cloud remove background operator from gnome-terminal command, still crashes on right click but seems stable after running a newterm.sh. October 10, 2022
- Fix Google cloud newterm.sh; expand that boot disk to 30G. September 20, 2022
- Note user id and password for TCP/IP lab in the lab manual. August 30, 2022
- Use the X11 socket name when setting DISPLAY from a container's .profile August 9, 2022
- Fix name of processValueMax function in grader. Issue #63
August 4, 2022
- The labedit program was rebuilt with the wrong JDK, preventing older JREs from running labedit
July 18, 2022
- Creation of Ubuntu20-based containers was failing within IModules. Issue #61.
March 23, 2022
- Fix path to tap lock directory; was causing failure of labs using network taps
- Update plc-traffic netmon computer to have openjfx needed for new grassmarlin in java environment
- Speed up lab startup by avoiding chown -R, which is very slow in docker.
- Another shot at avoiding deletion of the X11 link in container /tmp directory.
- Fix webtrack counting of sites visited and remove live-headers goal, that tool is no longer available. Clarified some lab manual steps.
March 2, 2022
- Add new ssh-tunnel lab (thanks GWD!)
- Fix labedit failure to reflect X11 value set by new_lab_setup
- Add option to not parameterize a container
February 23, 2022
- labedit was corrupting start.config after addition of new containers
- Incorrect path to student guide in the student README file; dynamically change for cloud configs
- Incorrect extension to update-labtainer.sh
- Msc guide enahancements
- Update the ghidra lab to include version 10.1.2 of Ghidra
February 15, 2022
- Revert Azure cloud support to provision for each student. Azure discourages sharing resources.
January 24, 2022
- Azure cloud now uses image stored in an Azure blob instead of provisioning for each student.
- Added support for Google Cloud.
January 19, 2022
- Introduce Labtainers on the Azure cloud. See the Student Guide for details on how to use this.
January 3, 2022
- Revise setuid-env lab to add better assessment; simlab testing and avoid sighup in the printenv child.
- Fix assessment goal count directive to exclude result tag values of false.
- Do not require labname when using gradelab -a with a grader started with the debug option.
- Revise capinout (stdin/stdout mirroring) to handle orphaning of command process children, improved documentation and error handling.
- Added display of progress bars of docker images being pulled when a lab is first run.
- User feedback on progress of container initialization.
- The pcap-lib lab was missing a notify file needed for automated assessment; Remove extraneous step from Lab Manual.
November 23, 2021
- Disable ubuntu popup errors on test VM.
- Fix handling of different DISPLAY variable formats.
October 22, 2021
- Revise the tcpip lab guide to note a successful syn-flood attack is not possible. Fix its automated assessment and add SimLab scripts.
- Change artifact file extension from zip to lab, and add a preamble to confuse GUI file managers. Students were opening the zip and submitting its guts.
- Make the -r option to gradelab the default, add a -c option for cumulative use of grader.
- Modify refresh_mirror to refer to the local release date to avoid frequent queries of DockerHub. Each such query counts as an image pull, and they are now trying to monetize those.
September 30, 2021
- Change bufoverflow lab guide and grading to not expect success with ASLR turned on, assess whether it was run.
- Error handling for web grader for cases where student lacks results.
- Print warning when deprecated lab is run.
- Change formatstring grading to remove unused "_leaked_secret" description and clarify value of leaked_no_scanf.
- Also change formatstring grading to allow any name for the vulnerable executable.
September 29, 2021
- Gradelab error handling, reduce instances of crashes due to bad zip files.
- Limit stdout artifact files to 1MB
September 17, 2021
- Ghidra lab guide had wrong IP address, was not remade from source.
September 14, 2021
- Example labs for LDAP and Mariadb using SSL. Intended as templates for new labs.
- Handle Mariadb log format
- Add per-container parameters to limit CPU use or pin container to CPU set.
- Labpack creation now available via a GUI (makepackui).
- Tab completion for the labtainer, labpack and gradelab commands.
- New parallel computing lab ``parallel'' using MPI.
August 3, 2021
- Add a "WAIT_FOR" configuration option to cause a container to delay parameterization until another container completes its parameterization.
- Support for Mariadb log formats in results parsing
- Remove support for Mac and Windows use of Docker Desktop. That product is too unstable for us to support.
- Supress stderr messages when user uses built-in bash commands such as "which".
- Bug fixes to makepack/labpack programs.
July 19, 2021
- Add a DNS lab to introduce the DNS protocol and configuration.
- Revised VirtualBox appliance image to start with the correct update script.
- Split resolv.conf nameserver parameter out of the lab_gw configuration field into its own value.
- IModule command failed if run before any labs had been started.
July 5, 2021
- Errors in DISPLAY env variable management broke GUI applications on Docker Desktop.
July 1, 2021
- Support Mac package installation of headless Labtainers.
- The routing-basics lab automated assessment failed due to lack of treataslocal files
- Correct typos and incorrect addresses in routing-basics lab, and fix automated assessment.
- Assessment of pcapanalysis was failing.
June 10, 2021
- All lab manual PDFs are now in the github repo
- Convert vpnlab and vpnlab2 instructions to PDF lab manuals.
May 25, 2021
- Add searchable keywords to each lab. See "labtainer -h" for usage.
- Expand routing-basics lab and lab manual
- Remove routing-basics2 lab, it is now redundant.
- sudo on some containers failed because hostnames remove underscores, leading to mismatch with the hosts file. Fix with extra entry in the hosts file with container name sans underscore.
- New Labpack feature to package a collection of labs, and makepack tool to create Labpacks.
- Error check for /sbin directory when using ubuntu20 -- would be silently fatal.
- New network-basics lab
May 5, 2021
- Introduce a new users lab to introduce user/group management
- Surpress Apparmor host messages in centos container syslogs
April 28, 2021
- New base2 images lacked man pages. Used unminimize to restore them in the base image.
- Introduce a OSSEC host-based IDS lab.
April 13, 2021
- CyberCIEGE lab failed because X11 socket was not relocated prior to starting Wine via fixlocal.
April 9, 2021
- New gdb-cpp tutorial lab for using GDB on a simple C++ program.
- Floating point exceptions were revealing use of exec_wrap.sh for stdin/stdout mirroring.
April 7, 2021
- ldap lab failed when moved to Ubuntu 20. Problem traced to problem with nscd cache of pwd. Move ldap to Ubuntu 20
March 23, 2021
- Parameterizing with RANDOM did not include the upper bound.
- Add optional step parameter to RANDOM, e.g., to ensure word boundaries.
- db-access lab: add mysql-workbench to database computer.
- New overrun lab to illustrate memory references beyond bounds of c data structures.
- New printf lab to introduce memory references made by the printf function.
March 19, 2021
- gradelab ignore makdirs error, problem with Windows rmtree on shared folders.
- gradelab handle spaces in student zip file names.
- gradelab handle zip file names from Moodle, including build downloads.
March 12, 2021
- labedit UI: Remove old wireshark image from list of base images.
- labedit UI: Increase some font sizes.
- grader web interface failed to display lab manuals if the manual name does not follow naming conventions.
March 11, 2021
- labedit UI add registry setting in new global lab configuration panel.
March 10, 2021
- labedit UI fixes to not build if syntax error in lab
- labedit UI "Lab running" indicator fix to reflect current lab.
March 8, 2021
- Deprecate use of HOST_HOME_XFER, all labs use directory per the labtainer.config file.
- Add documentation comment to start.config for REGISTRY and BASE_REGISTRY
March 5, 2021
- Error handling on gradelab web interface when missing results.
- labedit addition of precheck, msc bug fixes.
February 26, 2021
- The dmz-example lab had errors in routing and setup of dnsmasq on some components.
February 18, 2021
- UI was rebuilding images because it was updating file times without cause
- Clean up UI code to remove some redundant data copies.
February 14, 2021
- Add local build option to UI
- Create empty faux_init for centos6 bases.
February 11, 2021
- Fix UI handling of editing files. Revise layout and eliminate unused fields.
- Add ubuntu20 base2 base configuration along with ssh2, network2 and wireshark2
- The new wireshark solves the prolem of black/noise windows.
- Map /tmp/.X11-unix to /var/tmp and create a link. Needed for ubuntu20 (was deleting /tmp?) and may fix others.
February 4, 2021
- Add SIZE option to results artifacts
- Simplify wireshark-intro assessment and parameterization and add PDF lab manual.
- Provide parameter list values to pregrade.sh script as environment variables
- enable X11 on the grader
- put update-designer.sh into users path.
January 19, 2021
- Change management of README date/rev to update file in source repo.
- Introduce GUI for creating/editing labs -- see labedit command.
December 21, 2020
- The gradelab function failed when zip files were copied from a VirtualBox shared folder.
- Update Instructor Guide to describe management of student zip files on host computers.
December 4, 2020
- Transition distribution of tar to GitHub releaese artifacts
- Eliminate separate designer tar file, use git repo tarball.
- Testing of grader web functions for analysis of student lab artifacts
- Clear logs from full smoketest and delete grader container in removelab command.
December 1, 2020
- The iptables2 lab assessment relied on random ports being "unknown" to nmap.
- Use a sync diretory to delay smoketests from starting prior to lab startup.
- Begin integrating Lab designer UI elements.
October 13, 2020
- Headless configuraions for running on Docker Desktop on Macs & Windows
- Headless server support, cloud-config file for cloud deployments
- Testing support for headless configurations
- Force mynotify to wait until rc.local runs on boot
- Improve mynotify service ability to merge output into single timestamp
- Python3 for stopgrade script
- SimLab now uses docker top rather than system ps
September 26, 2020
- Clean up the stoplab scripts to ignore non-lab containers
- Add db-access database access control lab for controlles sharing of a mysql db.
September 17, 2020
- The macs-hash lab was unable to run Leafpad due to the X11 setting.
- Grader logging was being redirected to the wrong log file, now captures errors from instructor.py
- Copy instructor.log from grader to the host logs directory if there is an error.
August 28, 2020
- Fix install script to use python3-pip and fix broken scripts: getinfo.py and pull-all.py
- Registry logic was broken, test systems were not using the test registry, add development documentation.
- Add juiceshop and owasp base files for OWASP-based web security labs
- Remove unnecessary sudos from check_nets
- Add CHECK_OK documentation directive for automated assessment
- Change check_nets to fix iptables and routing issues if so directed.
August 12, 2020
- Add timeout to prestop scripts
- Add quiz and checkwork to dmz-lab
- Restarting the dmz-lab without -r option broke routing out of the ISP.
- Allow multiple files for time_delim results.
August 6, 2020
- Bug in error handling when X11 socket is missing
- Commas in quiz questions led to parse errors
- Add quiz and checkwork to iptables2 lab
July 28, 2020
- Add quiz support -- these are guidance quizzes, not assessment quizzes. See the designer guide.
- Add current-state assessment for use with the checkwork command.
July 21, 2020
- Add testsets/bin to designer's path
- Designer guide corrections and explainations for IModule steps.
- Add RANGE_REGEX result type for defining time ranges using regular expressions on log entries.
- Check that X11 socket exists if it is needed when starting a lab.
- Add base image for mysql
- Handle mysql log timestamp formats in results parsing.
June 15, 2020
- New base image contianing the Bird open source router
- Add bird-bgp Border Gateway Protocol lab.
- Add bird-ospf Open Shortest Path First routing protocol.
- Improve handling of DNS changes, external access from some containers was blocked in some sites.
- Add section to Instructor Guide on using Labtainers in environments lacking Internet access.
May 21, 2020
- Move all repositories to the Docker Hub labtainers registry
- Support mounts defined in the start.config to allow persistent software installs
- Change ida lab to use persistent installation of IDA -- new name is ida2
- Add cgc lab for exploration of over 200 vulnerable services from the DARPA Cyber Grand Challenge
- Add type_string command to SimLab
- Add netflow lab for use of NetFlow network traffic analysis
- Add 64-bit versions of the bufoverflow and the formatstring labs
April 9, 2020
- Grader failed assessment of CONTAINS and FILE_REGX conditions when wildcards were used for file selection.
- Include hints for using hexedit in the symlab lab.
- Add hash_equal operator and hash-goals.py to automated assessment to avoid publishing expected answers in configuration files.
- Automated assessment for the pcap-lib lab.
April 7, 2020
- Logs have been moved to $LABTAINER_DIR/logs
- Other cleanup to permit rebuilds and tests using Jenkins, including use of unique temporary directories for builds
- Move build support functions out of labutils into build.py
- Add pcap-lib lab for PCAP library based development of traffic analysis programs
March 13, 2020
- Add plc-traffic lab for use of GrassMarlin with traffic generated during the lab.
- Introduce ability to add "tap" containers to collect PCAPs from selected networks.
- Update GNS3 documentation for external access to containers, and use of dummy_hcd to simulate USB drives.
- Change kali template to use faux_init rather than attempting to use systemd.
- Moving distributions (tar files) to box.com
- Change SimLab use of netstat to not do a dns lookup.
February 26, 2020
- If labtainer command does not find lab, suggest that user run update-labtainer.sh
- Add support preliminary support for a network tap component to view all network traffic.
- Script to fetch lab images to prep VMs that will be used without internet.
- Provide username and password for nmap-discovery lab.
February 18, 2020
- Inherit the DISPLAY environment variable from the host (e.g., VM) instead of assuming :0
February 14, 2020
- Add Ghidra software reverse engineering introduction exercise.
February 11, 2020
- Update guides to describe remote access to containers withing GNS3 environments
- Hide selected components and links within GNS3.
- Figures in the webtrack lab guide were not visible; typos in this and nmap-ssh
February 6, 2020
- Introduce function to remotely manage containers, e.g., push files.
- Add GNS3 environment function to simulate insertion of a USB drive.
- Improve handling of Docker build errors.
February 3, 2020
- On the metasploit lab, the postgresql service was not running on the victim.
- Merge the IModule manual content into the Lab Designer guide.
- More IModule support.
January 27, 2020
- Introduce initial support for IModules (instructor-developed labs). See docs/imodules.pdf.
- Fix broken LABTAINER_DIR env variable within update-labtainer
- Fix access mode on accounting.txt file in ACL lab (had become rw-r-r). Use explicit chmod in fixlocal.sh.
January 14, 2020
- Port framework and gradelab to Python3 (existing Python2 labs will not change)
- Use backward compatible random.seed options
- Hack non-compatable randint to return old values
- Continue to support python2 for platforms that lack python3 (or those such as the older VM appliance that include python 3.5.2, which breaks random.seed compatability).
- Add rebuild alias for rebuild.py that will select python2 if needed.
 
- Centos-based labs manpages were failing; use mandb within base docker file
- dmz-lab netmask for DMZ network was wrong (caught by python3); as was IP address of inner gateway in lab manual
- ghex removed from centos labs -- no longer easily supported by centos 7
- file-deletion lab must be completed without rebooting the VM, note this in the Lab Manual.
- Add NO_GW switch to start.config to disable default gateways on containers.
- Metasploit lab, crashes host VM if runs as privileged; long delays on su if systemd enabled; so run without systemd. Remove use of database from lab manual, configure to use new no_gw switch
- Update file headers for licensing/terms; add consolidated license file.
- Modify publish.py to default to use of test registry, use -d to force use of default_registry
- Revise source control procedures to use different test registry for each branch, and use a premaster branch for final testing of a release.
October 9, 2019
- Remove dnsmasq from dns component in the dmz-lab. Was causing bind to fail on some installations.
October 8, 2019
- Syntax error in test registry setup; lab designer info on large files; fetch bigexternal.txt files
September 30, 2019
- DockerHub registry retrieval again failing for some users. Ignore html prefix to json.
September 20, 2019
- Assessment of onewayhash should allow hmac operations on file of student's choosing.
September 5, 2019
- Rebuild metasploit lab, metasploit-framework exhibited a bug. And the labs "treataslocal" file was left out of the move from svn. Fix type in metasploit lab manual.
August 30, 2019
- Revert test for existence of container directories, they do not always exist.
August 29, 2019
- Lab image pulls from docker hub failed due to change in github or curl? Catch rediret to cloudflare. Addition of GNS3 support. Fix to dmz-lab dnssec.
July 11, 2019
- Automated assessment for CentOS6 containers, fix for firefox memory issue, support arbitrary docker create arguments in the start.config file.
June 6, 2019
- Introduce a Centos6 base, but not support for automated assessment yet
May 23, 2019
- Automated assessment of setuid-env failed due to typos in field separators.
May 8, 2019
- Corrections to Capabilities lab manual
May 2, 2019
- Acl lab fix to bobstuff.txt permissions. Use explicit chmod in fixlocal.sh
- Revise student guide to clarify use of stop and -r option in body of the manual.
March 9, 2019
- The checkwork function was reusing containers, thereby preventing students from eliminating artifacts from previous lab work.
- Add appendix to the symkey lab to describe the BMP image format.
February 22, 2019
- The http server failed to start in the vpn and vpn2 labs. Automated assessment removed from those labs until reworked.
January 7, 2019
- Fix gdblesson automated assessment to at least be operational.
January 27, 2019
- Fix lab manual for routing-basics2 and fix routing to enable external access to internal web server.
December 29, 2018
- Fix routing-basics2, same issues as routing-basics, plus an incorret ip address in the gateway resolv.conf
December 5, 2018
- Fix routing-basics lab, dns resolution at isp and gatway components was broken.
November 14, 2018
- Remove /run/nologin from archive machine in backups2 -- need general solution for this nologin issue
November, 5, 2018
- Change file-integrity lab default aid.conf to track metadata changes rather than file modification times
October 22, 2018
- macs-hash lab resolution verydodgy.com failed on lab restart
- Notify function failed if notify_cb.sh is missing
October 12, 2018
- Set ulimit on file size, limit to 1G
October 10, 2018
- Force collection of parameterized files
- Explicitly include leafpad and ghex in centos-xtra baseline and rebuild dependent images.
September 28, 2018
- Fix access modes of shared file in ACL lab
- Clarify question in pass-crack
- Modify artifact collection to ignore files older than start of lab.
- Add quantum computing algorithms lab
September 12, 2018
- Fix setuid-env grading syntax errors
- Fix syntax error in iptables2 example firewall rules
- Rebuild centos labs, move lamp derivatives to use lamp.xtr for waitparam and force httpd to wait for that to finish.
September 7, 2018
- Add CyberCIEGE as a lab
- read_pre.txt information display prior to pull of images, and chance to bail.
September 5, 2018
- Restore sakai bulk download processing to gradelab function.
- Remove unused instructor scripts.
September 4, 2018
- Allow multiple IP addresses per network interface
- Add base image for Wine
- Add GRFICS virtual ICS simulation
August 23, 2018
- Add GrassMarlin lab (ICS network discovery)
August 23, 2018
- Add GrassMarlin lab (ICS network discovery)
August 21, 2018
- Another fix around AWS authentication issues (DockerHub uses AWS).
- Fix new_lab_setup.py to use git instead of svn.
- Split plc-forensics lab into a basic lab and and advanced lab (plc-forensics-adv)
August 17, 2018
- Transition to git & GitHub as authoritative repo.
August 15, 2018
- Modify plc-forensics lab assessment to be more general; revise lab manual to reflect wireshark on the Labtainer.
August 15, 2018
- Add "checkwork" command allowing students to view automated assessment results for their lab work.
- Include logging of iptables packet drops in the iptables2 and the iptables-ics lab.
- Remove obsolete instances of is_true and is_false from goal.config
- Fix boolean evaluation to handle "NOT foo", it had expected more operands.
August 9, 2018
- Support parameter replacement in results.config files
- Add TIME_DELIM result type for results.config
- Rework the iptables lab, remove hidden nmap commands, introduce custom service
August 7, 2018
- Add link to student guide in labtainer-student directory
- Add link to student guide on VM desktops
- Fixes to iptables-ics to avoid long delay on shutdown; and fixes to regression tests
- Add note to guides suggesting student use of VM browser to transfer artifact zip file to instructor.
August 1, 2018
- Use a generic Docker image for automated assessment; stop creating "instructor" images per lab.
July 30, 2018
- Document need to unblock the waitparam.service (by creating flag directory) if a fixlocal.sh script is to start a service for which waitparam is a prerequisite.
- Add plc-app lab for PLC application firewall and whitelisting exercise.
July 25, 2018
- Add string_contains operator to goals processing
- Modify assessment of formatstring lab to account for leaked secret not always being at the end of the displayed string.
July 24, 2018
- Add SSH Agent lab (ssh-agent)
July 20, 2018
- Support offline building, optionally skip all image pulling
- Restore apt/yum repo restoration to Dockerfile templates.
- Handle redirect URL's from Docker registry blob retrieval to avoid authentication errors (Do not rely on curl --location).
July 12, 2018
- Add prestop feature to allow execution of designer-specified scripts on selected components prior to lab shutdown.
- Correct host naming in the ssl lab, it was breaking automated assessment.
- Fix dmz-lab initial state to permit DNS resolutions from inner network.
- FILE\REGEX processing was not properly handling multiline searches.
- Framework version derived from newly rebuilt images had incorrect default value.
July 10, 2018
- Add an LDAP lab
- Complete transition to systemd based Ubuntu images, remove unused files
- Move lab_sys tar file to per-container tmp directory for concurrency.
July 6, 2018
- All Ubuntu base images replaced with versions based on systemd
- Labtainer container images in registry now tagged with base image ID & have labels reflecting the base image.
- A given installation will pull and use images that are consistent with the base images it possesses.
- If you are using a VM image, you may want to replace that with a newer VM image from our website.
- New labs will not run without downloading newer base images; which can lead to your VM storing multiple versions of large base images (> 500 MB each).
- Was losing artifacts from processes that were running when lab was stopped -- was not properly killing capinout processes.
June 27, 2018
- Add support for Ubuntu systemd images
- Remove old copy of SimLab.py from labtainer-student/bin
- Move apt and yum sources to /var/tmp
- Clarify differences between use of "boolean" and "count_greater" in assessments
- Extend Add-HOST in start.config to include all components on a network.
- Add option to new_lab_setup.py to add a container based on a copy of an existing container.
June 21, 2018
- Set DISPLAY env for root
- Fix to build dependency handling of svn status output
- Add radius lab
- Bug in SimLab append corrected
- Use svn, where appropriate, to change file names with new_lab_setup.py
June 19, 2018
- Retain order of containers defined in start.conf when creating terminal with multiple tabs
- Clarify designer manual to identify path to assessment configuration files.
- Remove prompt for instructor to provide email
- Botched error checking when testing for version number
- Include timestamps of lab starts and redos in the assessment json
- Add an SSL lab that includes bi-directional authentication and creation of certificates.
June 14, 2018
- Add diagnostics to parameterizing, track down why some install seem to fail on that.
- If a container is already created, make sure it is parameterized, otherwise bail to avoid corrupt or half-baked containers.
- Fix program version number to use svn HEAD
June 15, 2018
- Convert plain text instructions that appeared in xterms into pdf file.
- Fix bug in version handling of images that have not yet been pulled.
- Detect occurance of a container that was created, but not parameterized, and prompt the user to restart the lab with the "-r" option.
- Add designer utility: rm_svn.py so that removed files trigger an image rebuild.
June 13, 2018
- Install xterm on Ubuntu 18 systems
- Work around breakage in new versions of gnome-terminal tab handling
June 11, 2018
- Add version checking to compare images to the framework.
- Clarify various lab manuals
June 2, 2018
- When installing on Ubuntu 18, use docker.io instead of docker-ce
- The capinout caused a crash when a "sudo su" monitored command is followed by a non-elevated user command.
- Move routing and resolv.conf settings into /etc/rc.local instead of fixlocal.sh so they persist across start/stop of the containers.
May 31, 2018
- Work around Docker bug that caused text to wrap in a terminal without a line feed.
- Extend COMMAND_COUNT to account for pipes
- Create new version of backups lab that includes backups to a remote server and backs up an entire partition.
- Alter sshlab instructions to use ssh-copy-id utility
- Delte /run/nologin file from parameterize.sh to permit ssh login on CentOS
May 30, 2018
- Extended new_lab_setup.py to permit identification of the base image to use
- Create new version of centos-log that includes centralized logging.
- Assessment validation was not accepting "time_not_during" option.
- Begin to integrate Labtainer Master for managing Labtainers from a Docker container.
May 25, 2018
- Remove 10 second sleeps from various services. Was delaying xinetd responses, breaking automated tests.
- Fix snort lab grading to only require "CONFIDENTIAL" in the alarm. Remove unused files from lab.
- Program finish times were not recorded if the program was running when the lab was stopped.
May 21, 2018
- Fix retlibc grading to remove duplicate goal, was failing automated assessment
- Remove copies of mynotify.py from individual labs and lab template, it is has been part of lab_sys/sbin, but had not been updated to reflect fixes made for acl lab.
May 18, 2018
- Mask signal message from exec_wrap so that segv error message looks right.
- The capinout was sometimes losing stdout, check command stdout on death of cmd.
- Fix grading of formatstring to catch segmentation fault message.
- Add type_function feature to SimLab to type stdout of a script (see formatstring simlab).
- Remove SimLab limitation on combining single/double quotes.
- Add window_wait directive to SimLab to pause until window with given title can be found.
- Modify plc lab to alter titles on physical world terminal to reflect status, this also makes testing easier.
- Fix bufoverflow lab manual link.
May 15, 2018
- Add appendix on use of the SimLab tool to simulate user performance of labs for regression testing and lab development.
- Add wait_net function to SimLab to pause until selected network connections terminate.
- Change acl automated assessment to use FILE_REGEX for multiline matching.
- SimLab test for xsite lab.
May 11, 2018
- Add "noskip" file to force collection of files otherwise found in home.tar, needed for retrieving Firefox places.sqlite.
- Merge sqlite database with write ahead buffer before extracting.
- Corrections to lab manual for the symkeylab
- Grading additions for symkeylab and pubkey
- Improvements to simlab tool: support include, fix window naming.
May 9, 2018
- Fix parameterization of the file-deletion lab. Correct error its lab manual.
- Replace use of shell=True in python scripts to reduce processes and allow tracking PIDs
- Clean up manuals for backups, pass-crack and macs-hash.
May 8, 2018
- Handle race condition to prevent gnome-terminal from executing its docker command before an xterm instruction terminal runs its command.
- Don't display errors when instuctor stops a lab started with "-d".
- Change grading of nmap-ssh to better reflect intent of the lab.
- Several document and script fixes suggested by olberger on github.
May 7, 2018
- Use C-based capinout program instead of the old capinout.sh to capture stdin and stdout. See trunk/src-tool/capinout. Removes limitations associated with use ctrl-C to break monitored programs and the display of passwords in telnet and ssh.
- Include support for saki bulk_download zip processing to extract separately submitted reports, and summarizes missing submits.
- Add checks to user-provided email to ensure they are printable characters.
- While grading, if user-supplied email does not match zip file name, proceed to grade the results, but include note in the table reflecting cheating. Require to recover from cases where student enters garbage for an email address.
- Change telnetlab grading to not look at tcpdump output for passwords -- capinout fix leads to correct character-at-a-time transmission to server.
- Fix typo in install-docker.sh and use sudo to alter docker dns setting in that script.
April 26, 2018
- Transition to use of "labtainer" to start lab, and "stoplab" to stop it.
- Add --version option to labtainer command.
- Add log_ts and log_range result types, and time_not_during goal operators. Revamp the centos-log and sys-log grading to use these features.
- Put labsys.tar into /var/tmp instead of /tmp, sometimes would get deleted before expanded
- Running X applications as root fails after reboot of VM.
- Add "User Command" man pages to CentOS based labs
- Fix recent bug that prevented collection of docs files from students
- Modify smoke-tests to only compare student-specific result line, void of whitespace
April 20, 2018
- The denyhosts service fails to start the first time, moved start to student_startup.sh.
- Move all faux_init services until after parameterization -- rsyslog was failing to start on second boot of container. April 19, 2018
- The acl lab failed to properly assess performance of the trojan horse step.
- Collect student documents by default.
- The denyhost lab changed to reflect that denyhosts (or tcp wrappers?) now modifies iptables. Also, the denyhosts service was failing to start on some occasions.
- When updating Labtainers, do not overwrite files that are newer than those in the archive -- preserve student lab reports.
April 12, 2018
- Add documentation for the purpose of lab goals, and display this for the instructor when the instructor starts a lab.
- Correct use of the precheck function when the program is in treataslocal, pass capintout.sh the full program path.
- Copy instr_config files at run time rather than during image build.
- Add Designer Guide section on debugging automated assessment.
- Incorrect case in lab report file names.
- Unncessary chown function caused instructor.py to sometimes crash.
- Support for automated testing of labs (see SimLab and smoketest).
- Move testsets and distrib under trunk
April 5, 2018
- Revise Firefox profile to remove "you've not use firefox in a while..." message.
- Remove unnessary pulls from registry -- get image dates via docker hub API instead.
March 28, 2018
- Use explicit tar instead of "docker cp" for system files (Docker does not follow links.)
- Fix backups lab use separate file system and update the manual.
March 26, 2018
- Support for multi-user modes (see Lab Designer User Guide).
- Removed build dependency on the lab_bin and lab_sys files. Those are now copied during parameterization of the lab.
- Move capinout.sh to /sbin so it can be found when running as root.
March 21, 2018
- Add CLONE to permit multiple instances of the same container, e.g., for labs shared by multiple concurrent students.
- Adapt kali-test lab to provide example of macvlan and CLONE
- Copy the capinout.sh script to /sbin so root can find it after a sudo su.
March 15, 2018
- Support macvlan networks for communications with external hosts
- Add a Kali linux base, and a Metasploitable 2 image (see kali-test)
March 8, 2018
- Do not require labname when using stop.py
- Catch errors caused by stray networks and advise user on a fix
- Add support for use of local apt & yum repos at NPS
February 21, 2018
- Add dmz-lab
- Change "checklocal" to "precheck", reflecting it runs prior to the command.
- Decouple inotify event reporting from use of precheck.sh, allow inotify event lists to include optional outputfile name.
- Extend bash hook to root operations, flush that bash_history.
- Allow parameterization of start.config fields, e.g., for random IP addresses
- Support monitoring of services started via systemctl or /etc/init.d
- Introduce time delimeter qualifiers to organize a timestamped log file into ranges delimited by some configuration change of interest (see dmz-lab)
February 5, 2018
- Boolean values from results.config files are now treated as goal values
- Add regular expression support for identifying artifact results.
- Support for alternate Docker registries, including a local test registry for testing
- Msc fixes to labs and lab manuals
- The capinout monitoring hook was not killing child processes on exit.
- Kill monitored processes before collecting artifacts
- Add labtainer.wireshark as a baseline container, clean up dockerfiles
January 30, 2018
- Add snort lab
- Integrate log file timestamps, e.g., from syslogs, into timestamped results.
- Remove undefined result values from intermediate timestamped json result files.
- Alter the time_during goal assessment operation to associate timestamps with the resulting goal value.
January 24, 2018
- Use of tabbed windows caused instructor side to fail, use of double quotes.
- Ignore files in _tar directories (other than .tar) when determining build dependencies.