Child-friendly, parent-guided Wayland desktop environment alternative that puts parents, not platforms, in control
  • Rust 86%
  • Shell 7.4%
  • TypeScript 6.6%
Find a file
Albert Armea c87bd71018
All checks were successful
CI / Rustfmt (push) Successful in 4m16s
CI / ShellCheck (push) Successful in 11s
CI / Build (push) Successful in 4m42s
CI / Test (push) Successful in 4m40s
CI / Clippy (push) Successful in 5m7s
CI / E2E (push) Successful in 5m13s
Merge pull request 'Implement unified logout path' (#40) from u/albert/fix/logout-fixes into main
Reviewed-on: #40
2026-05-10 12:33:25 +00:00
.github/workflows Bump CI caches 2026-05-10 07:41:44 -04:00
crates Merge pull request 'Implement unified logout path' (#40) from u/albert/fix/logout-fixes into main 2026-05-10 12:33:25 +00:00
docs Implement touch/mouse remapping 2026-05-10 06:58:12 -04:00
scripts Implement touch/mouse remapping 2026-05-10 06:58:12 -04:00
shepherd-webui Implement logout button 2026-05-09 00:13:55 -04:00
.gitignore Make launcher runnable 2025-12-27 10:50:54 -05:00
AGENTS.md Fix Claude Code integration 2026-04-19 19:57:06 -04:00
Cargo.lock Implement touch/mouse remapping 2026-05-10 06:58:12 -04:00
Cargo.toml Implement touch/mouse remapping 2026-05-10 06:58:12 -04:00
CLAUDE.md Fix Claude Code integration 2026-04-19 19:57:06 -04:00
clippy.toml Add CI 2025-12-28 22:07:23 -05:00
config.example.toml Implement touch/mouse remapping 2026-05-10 06:58:12 -04:00
CONTRIBUTING.md WIP: Add management UI PoC 2026-04-27 19:52:07 -04:00
LICENSE.md Design goals README 2025-12-21 23:52:15 -05:00
README.md Fix management screenshot in README 2026-05-01 18:10:47 -04:00
run-dev Add setup scripts 2026-01-01 13:48:17 -05:00
sway.conf Add /etc/sway/shepherd.conf.d/*.conf support 2026-05-01 21:24:03 -04:00

shepherd-launcher

A child-friendly, parent-guided desktop environment alternative for Wayland, allowing supervised access to applications and content that you define.

Its primary goal is to return control of child-focused computing to parents, not software or hardware vendors, by providing:

  • the ease-of-use of game consoles
  • access to any application that can be run, emulated, or virtualized in desktop Linux
  • with granular access controls inspired by and exceeding those in iOS Screen Time

While this repository provides some examples for existing software packages (including non-free software and abandonware), shepherd-launcher is non-prescriptive: as the end user, you are free to use them, not use them, or write your own.

Screenshots

Home screen

shepherd-launcher presents a list of activities for the user to pick from.

Home screen at 3:00 PM showing the following set of activities: Tux Math, Putt Putt Joins the Circus, Secret of Monkey Island, GCompris, Minecraft, Celeste, A Short Hike, Big Buck Bunny, and Lofi Beats.

The flow of manually opening and closing activities should be familiar.

Activities can be made selectively available at certain times of day.

Home screen at 9:00 PM showing Lofi Beats as the only available activity.

This example, shown at 9 PM, has limited activities as a result.

Time limits

Activities can have configurable time limits, including:

  • individual session length
  • total usage per day
  • cooldown periods before that particular activity can be restarted

Anything on Linux

If it can run on Linux in any way, shape, or form, it can be supervised by shepherd-launcher.

"Big Buck Bunny" hosted within shepherd-launcher UI

Big Buck Bunny playing locally via mpv

"Putt Putt Joins the Circus" hosted within shepherd-launcher UI

Putt Putt Joins the Circus running via ScummVM

"The Secret of Monkey Island" hosted within shepherd-launcher UI

The Secret of Monkey Island running via ScummVM

Minecraft hosted within shepherd-launcher UI

Minecraft running via the Prism Launcher Flatpak

Celeste hosted within shepherd-launcher UI

Celeste running via Steam

A Short Hike hosted within shepherd-launcher UI

A Short Hike running via Steam

Local management

shepherd-launcher optionally runs a management UI and API that can be used to apply temporary overrides.

"Now" screen showing time adjustment and "Stop Session" buttons

"Activities" screen showing the configured activities and manual enable/disable overrides

Core concepts

  • Launcher-first: only one foreground activity at a time
  • Time-scoped execution: applications are granted time slices, not unlimited sessions
  • Parent-defined policy: rules live outside the application being run
  • Wrappers, not patches: existing software is sandboxed, not modified
  • Revocable access: sessions end predictably and enforceably

Non-goals

  1. Modifying or patching third-party applications
  2. Circumventing DRM or platform protections
  3. Replacing parental involvement with automation or third-party content moderation
  4. Remotely monitoring users with telemetry
  5. Collecting, storing, or reporting personally identifying information (PII)

Regarding age verification

shepherd-launcher may be considered "operating system software" under the Digital Age Assurance Act and similar legislation, and therefore subject to an age verification requirement.

As legislated, such requirements are fundamentally incompatible with non-goals 3, 4, and 5.

shepherd-launcher will never collect telemetry or PII, and as such, it will never implement this type of age verification.

As a result, shepherd-launcher is not licensed for use in any region that requires OS-level age verification by law. If you reside in any such region, you may not download, install, or redistribute shepherd-launcher.

This includes, but is not limited to:

The US as a whole and individual states are considering similar legislation.

If you disagree with this assessment and you reside in an affected region, please contact your representatives.

Installation

shepherd-launcher is pre-alpha and in active development. The helper at ./scripts/shepherd can be used to build and install a fully functional local kiosk setup from source:

Check out this repository and run ./scripts/shepherd --help or see INSTALL.md for more.

Example configuration

All behavior shown above is driven entirely by declarative configuration.

For the Minecraft example shown above:

# Prism Launcher - Minecraft launcher (Flatpak)
# Install: flatpak install flathub org.prismlauncher.PrismLauncher
[[entries]]
id = "prism-launcher"
label = "Prism Launcher"
icon = "org.prismlauncher.PrismLauncher"

[entries.kind]
type = "flatpak"
app_id = "org.prismlauncher.PrismLauncher"

[entries.availability]
[[entries.availability.windows]]
days = "weekdays"
start = "15:00"
end = "18:00"

[[entries.availability.windows]]
days = "weekends"
start = "10:00"
end = "20:00"

[entries.limits]
max_run_seconds = 1800  # 30 minutes (roughly 3 in-game days)
daily_quota_seconds = 3600  # 1 hour per day
cooldown_seconds = 600  # 10 minute cooldown

[[entries.warnings]]
seconds_before = 120
severity = "warn"
message = "2 minutes remaining - save your game!"

[[entries.warnings]]
seconds_before = 30
severity = "critical"
message = "30 seconds! Save NOW!"

See config.example.toml and the Wiki for more.

Development

Build instructions and contribution guidelines are described in CONTRIBUTING.md.

If you'd like to help out, you can find potential work items on the Issues page. You may email me patch sets at shepherd-launcher-patch@albertarmea.com.

Written in 2025, responsibly

This project stands on the shoulders of giants in systems software and compatibility infrastructure:

  • Wayland and Sway
  • Rust
  • Flatpak and Snap
  • Proton and WINE

This project was written with the assistance of generative AI-based coding agents. Substantial prompts and design docs provided to agents are disclosed in docs/ai.