generated from ublue-os/boxkit
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0daba72
commit 46c6312
Showing
1 changed file
with
2 additions
and
118 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,119 +1,3 @@ | ||
# boxkit | ||
# Brew Container | ||
|
||
## Description | ||
|
||
boxkit is a set of GitHub actions and skeleton files to build toolbox and distrobox images. Basically, clone this repo, make the changes you want, and then build what you need. Some examples include: | ||
|
||
- [DaVinci Box](https://github.com/zelikos/davincibox) - Container for DaVinci Resolve installation and runtime dependencies on Linux | ||
- [obs-studio-portable](https://github.com/ublue-os/obs-studio-portable) - OCI container image of OBS Studio that bundles a curated collection of 3rd party plugins | ||
- [bazzite-arch](https://github.com/ublue-os/bazzite-arch) - A ready-to-game Arch Linux based OCI designed for use exclusively in distrobox | ||
|
||
## Boxkit Alpine Example | ||
|
||
You can use whatever distribution you want with boxkit, this is the initial example ([here are more](https://github.com/ublue-os/bluefin/tree/main/toolboxes)): | ||
|
||
A base image and action for Toolbx and Distrobox. | ||
Sure, you can use the distro you're used to, but what if ... | ||
|
||
This image is going to experiment with what a "born from cloud native" UNIX terminal experience would look like. | ||
It is used in conjuction with a [dotfile manager](https://dotfiles.github.io/utilities/) and designed to be the companion terminal experience for cloud-native desktops. | ||
We're starting small but have big aspirations. | ||
|
||
- Starts with the latest Alpine image from the [Toolbx Community Images](https://github.com/toolbx-images/images) | ||
- Adds some quality of life | ||
- `starship` prompt for that <3 | ||
- `just` for task execution | ||
- `chezmoi` for dotfile management | ||
- `btop` for process management | ||
- `micro` and `helix` text editors | ||
- [clipboard](https://github.com/Slackadays/Clipboard) to cut, copy, and paste anything, anywhere, all from the terminal! | ||
- `python3` | ||
- Some common power tools: `plocate`, `fzf`, `cosign`, `ripgrep`, `github-cli`, and `ffmpeg` | ||
- CLI tools recommended by [rawkode](https://www.youtube.com/watch?v=TNlDSG1iDW8) | ||
- [zellij](https://github.com/zellij-org/zellij) - terminal workspace | ||
- [direnv](https://direnv.net/) - environment variable extension for your shell | ||
- [atuin](https://github.com/ellie/atuin) - magical shell history | ||
- Host Management QoL | ||
- These are meant for occasional one off commands, not complex workflows | ||
- Auto symlink the flatpak, podman, and docker commands | ||
- Auto symlink rpm-ostree for Fedora | ||
- Auto symlink transactional-update for openSUSE MicroOS | ||
|
||
## How to use | ||
|
||
### Create Box | ||
|
||
If you use distrobox: | ||
|
||
distrobox create -i ghcr.io/ublue-os/boxkit -n boxkit | ||
distrobox enter boxkit | ||
|
||
If you use toolbx: | ||
|
||
toolbox create -i ghcr.io/ublue-os/boxkit -c boxkit | ||
toolbox enter boxkit | ||
|
||
### Pull down your config | ||
|
||
Use `chezmoi` to pull down your dotfiles and set up git sync. | ||
|
||
|
||
### Make your own | ||
|
||
Fork and add programs to this this image - over time you'll end up with the perfect CLI for you. | ||
Keeping it as a pet works, though the author recommends leaving all your config in git and routinely pulling a new image. | ||
|
||
The user experience is much nicer if you [set your terminal open right in the container](https://distrobox.privatedns.org/useful_tips/#using-distrobox-as-main-cli) and is the intended experience. | ||
|
||
## Why? | ||
|
||
While LTS images pay the bills they move at that pace for a reason, I wanted: | ||
|
||
- Something that kept up the pace with cloud native tech | ||
- Expansive repos so all stack needs are covered | ||
- But also has all the cool new tools the rustaceans keep cranking out | ||
- apk is _fast_ | ||
|
||
And of course, as the user space for a cloud-native desktop the biggest reason is it's everywhere in the stack, why not be the "default terminal"? | ||
|
||
Also, I've never gotten really to know Alpine, the problem with running distros like this bare metal on my PC is that there's a whole bunch of hardware quirks and all sorts of little enablement things that more generalized distros tend to get right. | ||
|
||
But in a Toolbx/Distrobox world the kernel and anything that talks to hardware is handled by the host operating system. | ||
This let's us concentrate on just the CLI experience, get yourself some of that UNIX bling. | ||
Also apk is fast. Watch the video for more! | ||
|
||
[![Video Recording](https://img.youtube.com/vi/7-FPAWjROos/0.jpg)](https://youtu.be/7-FPAWjROos) | ||
|
||
## Verification | ||
|
||
These images are signed with sisgstore's [cosign](https://docs.sigstore.dev/cosign/overview/). You can verify the signature by downloading the `cosign.pub` key from this repo and running the following command: | ||
|
||
cosign verify --key cosign.pub ghcr.io/ublue-os/boxkit | ||
|
||
If you're forking this repo you should [read the docs](https://docs.github.com/en/actions/security-guides/encrypted-secrets) on keeping secrets in github. You need to [generate a new keypair](https://docs.sigstore.dev/cosign/overview/) with cosign. The public key can be in your public repo (your users need it to check the signatures), and you can paste the private key in Settings -> Secrets -> Actions. | ||
|
||
## Scope and Cynicism | ||
|
||
I know what you're thinking, we're just going to shove everything from [Modern UNIX](https://github.com/ibraheemdev/modern-unix) in there and it's going to look like a glitter explosion. | ||
|
||
That's why I'm going to be strongly opinionated, so use this as a base to build your own perfect CLI experience. | ||
Custom configs are NOT included, those belong in your dotfiles, use them in combination with an image. | ||
|
||
This is a tame first effort, one of you out there is going to make something better than this, the perfect CLI workspace, I salute you. | ||
|
||
## Finding Good Base Images | ||
|
||
Of course you can make this however you want, but start with the [Toolbx Community images](https://github.com/toolbx-images/images). | ||
These are a set of mostly-stock images with packages needed to run as a toolbox/distrobox already installed. | ||
|
||
Try to derive your blingbox from those base images so we can all help maintain them over time, you can't have bling without good stock! | ||
|
||
Tag your image with `boxkit` to share with others! | ||
|
||
## [![Repography logo](https://images.repography.com/logo.svg)](https://repography.com) / Recent activity [![Time period](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_badge.svg)](https://repography.com) | ||
[![Timeline graph](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_timeline.svg)](https://github.com/ublue-os/boxkit/commits) | ||
[![Issue status graph](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_issues.svg)](https://github.com/ublue-os/boxkit/issues) | ||
[![Pull request status graph](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_prs.svg)](https://github.com/ublue-os/boxkit/pulls) | ||
[![Trending topics](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_words.svg)](https://github.com/ublue-os/boxkit/commits) | ||
[![Top contributors](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_users.svg)](https://github.com/ublue-os/boxkit/graphs/contributors) | ||
[![Activity map](https://images.repography.com/35181738/ublue-os/boxkit/recent-activity/9_nHJKzKdmCsGzSsdjbuHqS2t9mY6ijnFHQGQSEWtW0/lgGy5XEcVYQ14vma9bwaPOYJFIxlNmj5nK3-CFQQkgc_map.svg)](https://github.com/ublue-os/boxkit/commits) | ||
A distrobox (docker) image that is used for homebrew. The `/home/linuxbrew` will be mounted to a directory in ~/ so it will be safe if you regenerate or delete the container. |