13609 lines
560 KiB
Text
13609 lines
560 KiB
Text
---
|
||
# eslint-disable eslint-comments/disable-enable-pair, max-len, max-lines, no-warning-comments
|
||
#
|
||
# `softwarePackages` is a map of possible package managers to use while installing a program. The installer will
|
||
# look at the `installerPreference` variable and find the first package manager that is in the package's possible
|
||
# installation method and then use that. It is also sensitive to the type of operating system so a package with
|
||
# only `apt` defined will not install on macOS.
|
||
#
|
||
# Everything should be fairly straight forward. Take a look at the `installerPreference` for a list of package managers. If a package
|
||
# has dependencies, the dependencies are defined under the `_deps` key. All of the `_deps` should also be defined in the
|
||
# `softwarePackages` map. The installer will check for the presence of the package's key in the PATH. If the package's key
|
||
# does not match the executable's name, then the `_bin` key can be defined so that the installer will look at that instead.
|
||
#
|
||
# Full example of a softwarePackage:
|
||
# altair:
|
||
# _appimageName: SwitchHosts.AppImage # Name of file that the appimage: field downloads to
|
||
# _bin: ng # Instead of checking if the object key (altair) is in the PATH, check if "ng" is in the PATH and only proceed if it is not available
|
||
# _deps: # Any piece of data can be a string or array. _deps will take each dep and run that through the installer first. If you need to just install dependencies with apt (for instance), you can also set the _deps equals to [altair:deps] and then define the apt dependencies like that instead of creating a new entry for each apt dependency.
|
||
# - angular-cli
|
||
# _docker: docker run --rm bannmann/docker-cheat # Command that the _bin value should alias to (similar to Whalebrew)
|
||
# _groups: # Groups that should be created / user added to
|
||
# - docker
|
||
# _when: | # Run the script defined with _when and only proceed if it exits with a 0
|
||
# test -f /usr
|
||
# _pre: |
|
||
# echo "_pre allows you to define a script that runs before the installation"
|
||
# _post:brew:debian: |
|
||
# echo "_post allows you to define a script that runs after the installation"
|
||
# _service: smbd # System service to enable, restart, and/or start (can also be an array).
|
||
# _restricted: true # True if it should be skipped on a restricted machine (i.e. a work machine).
|
||
# _epel: true # True if https://docs.fedoraproject.org/en-US/epel/ should be enabled
|
||
# ansible: professormanhattan.docker
|
||
# apk: altair
|
||
# appimage: https://developers.yubico.com/yubikey-manager-qt/Releases/yubikey-manager-qt-1.2.4b-linux.AppImage
|
||
# appinstaller: https://example.com/package.appinstaller # TODO - https://pieces.app has example of this type of file
|
||
# basher: xwmx/nb
|
||
# binary:darwin: https://dl.min.io/client/mc/release/darwin/mc # Any piece of data can have the OS type (darwin, linux, windows) or release ID (arch, debian, ubuntu, centos, fedora) added to the end. The script will try to execute it first before trying to run other items.
|
||
# binary:linux: https://dl.min.io/client/mc/release/linux-amd64/mc
|
||
# binary:windows: https://dl.min.io/client/mc/release/windows-amd64/mc.exe
|
||
# bpkg: xwmx/nb
|
||
# brew: altair
|
||
# cargo: tree-sitter-cli
|
||
# cask: altair-graphql-client
|
||
# crew: altair
|
||
# choco: altair-graphql
|
||
# _rpmFusion: true # Enable the RPM Fusion Free repository if true
|
||
# dnf: altair
|
||
# flatpak: com.yubico.yubioath
|
||
# gem: altair
|
||
# go: github.com/ProfessorManhattan/blockinfile@latest
|
||
# krew:
|
||
# - ctx
|
||
# - ns
|
||
# nix: emplace
|
||
# npm: altair
|
||
# pacman: altair
|
||
# pipx: altair
|
||
# pkg-darwin: https://google.com/macos-pkgfile.pkg
|
||
# pkg-freebsd: altair
|
||
# pkg-termux: altair
|
||
# port: altair
|
||
# scoop: altair
|
||
# script >-
|
||
# curl -sS https://getcomposer.org/installer | php
|
||
# sudo mv composer.phar /usr/local/bin/composer
|
||
# sudo chmod +x /usr/local/bin/composer
|
||
# _snapClassic: true # Install the snap in classic mode
|
||
# snap: altair
|
||
# whalebrew:
|
||
# winget: Neovim.Neovim
|
||
# xbps: altair
|
||
# yay: altair
|
||
# zypper: altair
|
||
# angular-cli:
|
||
# _bin: ng # Only install if "ng" is not available in the PATH
|
||
# _name: Gitify # Pretty name of the package
|
||
# _home: https://angular.io/ # Homepage if there is one
|
||
# _desc: GitHub notifications on the menu bar # Short description of the package
|
||
# _docs: https://docs.angular.io/ # Link to documentation (if available)
|
||
# _github: https://github.com/manosim/gitify # GitHub link to the package
|
||
# _type: menubar # Type of package (either application, cli, webapp, or menubar)
|
||
# npm:
|
||
# - '@angular/cli'
|
||
# - gulp
|
||
|
||
installerPreference:
|
||
apt:
|
||
- flatpak
|
||
- snap
|
||
- whalebrew
|
||
- apt
|
||
- brew
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- pip
|
||
- gem
|
||
- appimage
|
||
- script
|
||
- ansible
|
||
- binary
|
||
darwin:
|
||
- whalebrew
|
||
- cask
|
||
- brew
|
||
# Removed because port installation from default list because encountered this error: Creating user "macports" make: *** [install] Killed: 9 --- might be due to remote managed macOS settings.
|
||
# - port
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- pip
|
||
- gem
|
||
- pkg-darwin
|
||
- script
|
||
- ansible
|
||
- binary
|
||
dnf:
|
||
- flatpak
|
||
- snap
|
||
- whalebrew
|
||
- dnf
|
||
- brew
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- pip
|
||
- gem
|
||
- appimage
|
||
- script
|
||
- ansible
|
||
- binary
|
||
freebsd:
|
||
- pkg
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- gem
|
||
- script
|
||
pacman:
|
||
- flatpak
|
||
- snap
|
||
- whalebrew
|
||
- pacman
|
||
- brew
|
||
- yay
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- pip
|
||
- gem
|
||
- appimage
|
||
- script
|
||
- ansible
|
||
- binary
|
||
ubuntu:
|
||
- snap
|
||
- flatpak
|
||
- whalebrew
|
||
- apt
|
||
- brew
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- pip
|
||
- gem
|
||
- appimage
|
||
- script
|
||
- ansible
|
||
- binary
|
||
windows:
|
||
- choco
|
||
- scoop
|
||
- winget
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- gem
|
||
- script
|
||
- ansible
|
||
- binary
|
||
zypper:
|
||
- flatpak
|
||
- snap
|
||
- whalebrew
|
||
- zypper
|
||
- brew
|
||
- go
|
||
- cargo
|
||
- npm
|
||
- pipx
|
||
- gem
|
||
- appimage
|
||
- script
|
||
- ansible
|
||
- binary
|
||
softwarePackages:
|
||
_envchain:deps:
|
||
_github: false
|
||
apt:
|
||
- gnome-keyring
|
||
- gcc
|
||
- gnome-keyring
|
||
- libsecret-1-dev
|
||
- make
|
||
- libreadline-dev
|
||
dnf:
|
||
- gcc
|
||
- gnome-keyring
|
||
- libsecret-devel
|
||
- make
|
||
- readline-devel
|
||
pacman:
|
||
- gcc
|
||
- gnome-keyring
|
||
- libsecret
|
||
- make
|
||
- readline
|
||
_kde:
|
||
_github: false
|
||
_deps:
|
||
- kde-plasma-desktop
|
||
_misc-flatpaks:
|
||
_github: false
|
||
_deps:
|
||
- bottles
|
||
- cockpit-client
|
||
- connections
|
||
- dconf-editor
|
||
- deja-dup
|
||
- dialect
|
||
- drawing
|
||
- flatseal
|
||
- forklift
|
||
- gnome-calendar
|
||
- gnome-document-viewer
|
||
- gnome-extension-manager
|
||
- gnome-eyedropper
|
||
- gnome-file-roller
|
||
- gnome-image-viewer
|
||
- gnome-network-displays
|
||
- gnome-passwords-keys
|
||
- gnome-photos
|
||
- gnome-sound-recorder
|
||
# OSes usually have a text editor preinstalled
|
||
# - gnome-text-editor
|
||
- gnome-video-player
|
||
- gnome-weather
|
||
- junction
|
||
- kooha
|
||
- newsflash
|
||
- pinapp
|
||
- vup
|
||
- warp-transfer
|
||
- web-font-generator
|
||
- what-ip
|
||
- live-captions
|
||
- libre-menu-editor
|
||
- iso-image-writer
|
||
- trayscale
|
||
_nautilus-extensions:
|
||
_github: false
|
||
_deps:
|
||
- nautilus-brasero
|
||
- nautilus-gtkhash
|
||
- nautilus-gsconnect
|
||
- nautilus-image-converter
|
||
- nautilus-python
|
||
- nautilus-seahorse
|
||
- nautilus-search-tool
|
||
- nautilus-share
|
||
- nautilus-wipe
|
||
ack:
|
||
_bin: ack
|
||
_github: https://github.com/beyondgrep/ack3
|
||
_name: Ack
|
||
apt: ack
|
||
brew: ack
|
||
choco: ack
|
||
dnf: ack
|
||
pacman: ack
|
||
port: perl/p5-app-ack
|
||
act:
|
||
_bin: act
|
||
_desc: '[Act](https://github.com/nektos/act) Run GitHub actions locally'
|
||
_docs: https://github.com/nektos/act#example-commands
|
||
_github: https://github.com/nektos/act
|
||
_home: https://github.com/nektos/act
|
||
_name: Act
|
||
brew: act
|
||
choco: act-cli
|
||
go: github.com/nektos/act@
|
||
nix: nixpkgs.act
|
||
port: act
|
||
scoop: act
|
||
yay: act
|
||
adobe-creative-cloud:
|
||
_bin: adobe-creative-cloud
|
||
_name: Adobe Creative Cloud
|
||
_github: false
|
||
_when:cask: '! test -d "/Applications/Adobe Creative Cloud" && ! test -d "$HOME/Applications/Adobe Creative Cloud"'
|
||
cask: adobe-creative-cloud
|
||
ai-shell:
|
||
_bin: ai
|
||
_github: https://github.com/BuilderIO/ai-shell
|
||
_name: AI Shell
|
||
npm: '@builder.io/ai-shell'
|
||
aiac:
|
||
_bin: aiac
|
||
_github: https://github.com/gofireflyio/aiac
|
||
_name: AIAC
|
||
brew: gofireflyio/aiac/aiac
|
||
go: github.com/gofireflyio/aiac/v3@latest
|
||
aicommits:
|
||
_bin: aicommits
|
||
_github: https://github.com/Nutlope/aicommits
|
||
_name: AI Commits
|
||
brew: aicommits
|
||
npm: aicommits
|
||
aider:
|
||
_bin: aider
|
||
_github: https://github.com/paul-gauthier/aider
|
||
_name: Aider AI Chat
|
||
pipx: aider-chat
|
||
aifiles:
|
||
_bin: aifiles
|
||
_deps:
|
||
- pandoc
|
||
- exiftool
|
||
- poppler
|
||
- csvkit
|
||
_github: https://github.com/jjuliano/aifiles
|
||
_name: AI Files
|
||
_todo: Implement this when XDG spec is supported so we can store configs in ~/.config
|
||
npm: aifiles
|
||
airdrop-cli:
|
||
_bin: airdrop
|
||
_github: https://github.com/vldmrkl/airdrop-cli
|
||
_name: Airdrop CLI
|
||
brew:darwin: vldmrkl/formulae/airdrop-cli
|
||
airtame:
|
||
_app: Airtame.app
|
||
_bin: airtame
|
||
_github: false
|
||
_name: Airtame
|
||
cask: airtame
|
||
choco: airtame
|
||
flatpak: com.airtame.Client
|
||
snap: airtame-application
|
||
alda:
|
||
_bin: alda
|
||
_github: https://github.com/alda-lang/alda
|
||
_name: Alda
|
||
brew: alda
|
||
allure:
|
||
_bin: allure
|
||
_desc: '[Allure Report](https://docs.qameta.io/allure-testops/) is a flexible, lightweight multi-language test reporting tool. It provides clear graphical reports and allows everyone involved in the development process to extract the maximum of information from the everyday testing process.'
|
||
_docs: https://docs.qameta.io/allure-report/
|
||
_github: https://github.com/allure-framework/allure2
|
||
_home: https://docs.qameta.io/allure-testops/
|
||
_name: Allure
|
||
_post:binary:darwin: |
|
||
#!/usr/bin/env bash
|
||
echo "TODO"
|
||
_post:binary:linux: |
|
||
#!/usr/bin/env bash
|
||
# TODO How to pass the path of the file downloaded in `binary` step? That can replace the `wget` command below
|
||
mkdir -p /usr/local/share/allure
|
||
cd /usr/local/share/allure
|
||
wget https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/2.20.1/allure-commandline-2.20.1.zip -O /usr/local/share/allure/allure.zip
|
||
unzip -o allure.zip
|
||
ln -s /usr/local/share/allure/allure<version>/bin/allure
|
||
_post:binary:windows: |
|
||
# TODO
|
||
binary: https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/2.20.1/allure-commandline-2.20.1.zip
|
||
# TODO: Find latest version from https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/maven-metadata.xml and use it in the _binary_ URL
|
||
brew: allure
|
||
scoop: allure
|
||
yay: allure
|
||
alt-tab:
|
||
_app: AltTab.app
|
||
_bin: alt-tab
|
||
_github: https://github.com/lwouis/alt-tab-macos
|
||
_name: Alt+Tab for macOS that works like alt+tab on Windows
|
||
cask: alt-tab
|
||
altair:
|
||
_app: Altair GraphQL Client.app
|
||
_bin:snap: altair
|
||
_desc: '[Altair GraphQL Client](https://altairgraphql.dev/) A beautiful feature-rich GraphQL Client for all platforms.'
|
||
_docs: https://altairgraphql.dev/docs/
|
||
_env:
|
||
ALTAIR_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Altair GraphQL Client"
|
||
choco: "TODO"
|
||
snap: "$HOME/snap/altair/current/.config/Altair GraphQL Client"
|
||
_github: https://github.com/altair-graphql/altair
|
||
_home: https://altairgraphql.dev/
|
||
_name: Altair GraphQL Client
|
||
cask: altair-graphql-client
|
||
choco: altair-graphql
|
||
snap: altair
|
||
yay: altair
|
||
amethyst:
|
||
_app: Amethyst.app
|
||
_bin: amethyst
|
||
_github: https://github.com/ianyh/Amethyst
|
||
_name: Amethyst
|
||
cask: amethyst
|
||
android-commandlinetools:
|
||
_bin: false
|
||
_deps:
|
||
- java
|
||
_github: false
|
||
_name: Android Studio Command Line Tools
|
||
_when:cask: '! test -d "${HOMEBREW_PREFIX:-/opt/homebrew}/share/android-commandlinetools"'
|
||
cask: android-commandlinetools
|
||
android-platform-tools:
|
||
_bin: adb
|
||
_github: false
|
||
_name: Android Platform Tools
|
||
cask: android-platform-tools
|
||
android-studio:
|
||
_app: Android Studio.app
|
||
_github: false
|
||
_bin: android-studio
|
||
_deps:
|
||
- android-commandlinetools
|
||
- java
|
||
_desc: >-
|
||
[Android Studio](https://developer.android.com/studio) is the official integrated development environment for Google's Android operating system, built on JetBrains' IntelliJ IDEA software and designed specifically for Android development. This role installs Android Studio on nearly any operating system and also ensures a configurable list of command-line tools and SDKs are installed and seamlessly integrated with the system (i.e. the role adds the appropriate items to the `PATH` environment variable).
|
||
_docs: https://developer.android.com/docs
|
||
_env:
|
||
ANDROID_STUDIO_APPDATA:
|
||
cask: "TODO"
|
||
choco: "TODO"
|
||
flatpak: "TODO"
|
||
snap: "TODO"
|
||
_home: https://developer.android.com/studio
|
||
_name: Android Studio
|
||
cask: android-studio
|
||
choco: androidstudio
|
||
flatpak: com.google.AndroidStudio
|
||
snap: android-studio
|
||
yay: android-studio
|
||
angular-cli:
|
||
_bin: ng
|
||
_desc: '[Angular](https://angular.io) The web development framework for building the future'
|
||
_docs: https://angular.io/docs
|
||
_github: https://github.com/angular/angular
|
||
_home: https://angular.io
|
||
_name: Angular
|
||
brew: angular-cli
|
||
npm: '@angular/cli'
|
||
ansible:
|
||
_bin: ansible
|
||
_desc: '[Ansible](https://www.ansible.com/) Ansible is a radically simple IT automation platform that makes your applications and systems easier to deploy and maintain'
|
||
_docs: https://docs.ansible.com/
|
||
_github: https://github.com/ansible/ansible
|
||
_home: https://www.ansible.com/
|
||
_name: Ansible
|
||
_post:pipx: |
|
||
#!/usr/bin/env bash
|
||
pipx inject ansible PyObjC PyObjC-core docker lxml netaddr pexpect python-vagrant pywinrm requests-credssp watchdog
|
||
# brew: ansible
|
||
# dnf: ansible
|
||
pipx: ansible
|
||
ansible-lint:
|
||
_bin: ansible-lint
|
||
_desc: '[Ansible Lint](https://github.com/ansible/ansible-lint/) is a command-line tool for linting playbooks, roles and collections aimed toward any Ansible users'
|
||
_docs: https://ansible-lint.readthedocs.io/
|
||
_github: https://github.com/ansible/ansible-lint/
|
||
_home: https://github.com/ansible/ansible-lint/
|
||
_name: Ansible Lint
|
||
pipx: ansible-lint
|
||
ansibleconnect:
|
||
_bin: ansibleconnect
|
||
_deps:
|
||
- sshpass
|
||
- tmux
|
||
_desc: '[ansibleconnect](https://github.com/psykulsk/ansibleconnect) allows you to connect to all hosts from the inventory with one command'
|
||
_docs: https://github.com/psykulsk/ansibleconnect
|
||
_github: https://github.com/psykulsk/ansibleconnect
|
||
_home: https://github.com/psykulsk/ansibleconnect
|
||
_name: Ansibleconnect
|
||
pipx: ansibleconnect
|
||
ansibler:
|
||
_bin: ansibler
|
||
_desc: Megabyte Labs Python project used to extract test information from Molecule and save it as JSON that can be rendered into charts
|
||
_docs: https://pypi.org/project/ansibler/
|
||
_github: https://github.com/megabyte-labs/ansibler
|
||
_home: https://pypi.org/project/ansibler/
|
||
_name: Ansibler
|
||
pipx: ansibler
|
||
ansifilter:
|
||
_bin: ansifilter
|
||
_name: Ansifilter
|
||
_github: false
|
||
brew: ansifilter
|
||
choco: ansifilter
|
||
port: ansifilter
|
||
apktool:
|
||
_bin: apktool
|
||
_github: https://github.com/iBotPeaches/Apktool
|
||
_name: APKTool
|
||
brew: apktool
|
||
choco: apktool
|
||
appium:
|
||
_bin: appium
|
||
_desc: '[Appium](https://appium.io/) is an open source automation tool for running scripts and testing native applications, mobile-web applications and hybrid applications on Android or iOS using a webdriver.'
|
||
_docs: https://appium.io/docs/en/about-appium/intro/
|
||
_github: https://github.com/appium/appium
|
||
_home: https://appium.io/
|
||
_name: Appium
|
||
_service: appium
|
||
brew: appium
|
||
npm: appium
|
||
appium-desktop:
|
||
_app: Appium Server GUI.app
|
||
_bin: appium-desktop
|
||
_github: https://github.com/appium/appium-desktop
|
||
_name: Appium Desktop
|
||
appimage: appium/appium-desktop
|
||
cask: appium
|
||
choco: appium-desktop
|
||
appium-inspector:
|
||
_app: Appium Inspector.app
|
||
_bin: appium-inspector
|
||
_github: https://github.com/appium/appium-inspector
|
||
_name: Appium Inspector
|
||
appimage: appium/appium-inspector
|
||
cask: appium-inspector
|
||
choco: appium-desktop
|
||
appnest-readme:
|
||
_bin: readme
|
||
_desc: '[Readme](https://github.com/andreasbm/readme/) automatically generate a beautiful best-practice README file based on the contents of your repository'
|
||
_docs: https://github.com/andreasbm/readme/
|
||
_github: https://github.com/andreasbm/readme/
|
||
_home: https://github.com/andreasbm/readme/
|
||
_name: Readme
|
||
npm: '@appnest/readme'
|
||
apprise:
|
||
_bin: apprise
|
||
_deps:
|
||
- pywin32
|
||
- terminal-notifier
|
||
_github: https://github.com/caronc/apprise
|
||
_name: Apprise
|
||
dnf: apprise
|
||
pipx: apprise
|
||
apt-cacher-ng:
|
||
_bin: null
|
||
_desc: '[Apt-Cacher-NG](https://wiki.debian.org/AptCacherNg) is a caching proxy server (or apt proxy) for Debian based distributions like Ubuntu, Kubuntu, Xubuntu, Edubuntu, Linux Mint, etc, which is used to cache the downloaded packages locally on your server.'
|
||
_docs: https://www.unix-ag.uni-kl.de/~bloch/acng/html/index.html
|
||
_github: https://salsa.debian.org/blade/apt-cacher-ng
|
||
_home: https://wiki.debian.org/AptCacherNg
|
||
_name: AptCacherNG
|
||
_systemd: apt-cacher-ng
|
||
ansible: professormanhattan.aptcacherng
|
||
aqua:
|
||
_bin: aqua
|
||
_desc: '[aqua](https://aquaproj.github.io/) is a Declarative CLI Version manager written in Go. It supports Lazy Install, Registry, and continuous update with Renovate.'
|
||
_docs: https://aquaproj.github.io
|
||
_github: https://github.com/aquaproj/aqua
|
||
_home: https://aquaproj.github.io
|
||
_name: aqua
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Aqua Initialization
|
||
# @brief Updates and installs any Aqua dependencies that are defined in Aqua's configuration file.
|
||
# @description
|
||
# This script updates Aqua and then installs any Aqua dependencies that are defined.
|
||
|
||
if command -v aqua > /dev/null; then
|
||
logg info 'Updating Aqua'
|
||
aqua update-aqua
|
||
logg info 'Installing Aqua dependencies (if any are defined)'
|
||
aqua install -a
|
||
else
|
||
logg info 'Skipping aqua install script because aqua was not installed'
|
||
fi
|
||
binary:linux: https://github.com/aquaproj/aqua/releases/download/v2.0.0-0/aqua_linux_amd64.tar.gz
|
||
binary:windows: https://github.com/aquaproj/aqua/releases/download/v2.0.0-0/aqua_windows_amd64.tar.gz
|
||
brew: aquaproj/aqua/aqua
|
||
go: github.com/aquaproj/aqua/v2/cmd/aqua@latest
|
||
arduino-ide:
|
||
_app: Arduino.app
|
||
_bin: arduino
|
||
_github: https://github.com/arduino/arduino-ide
|
||
cask: arduino
|
||
choco: arduino
|
||
flatpak: cc.arduino.IDE2
|
||
argc:
|
||
_bin: argc
|
||
_github: https://github.com/sigoden/argc
|
||
_name: Argc
|
||
cargo: argc
|
||
argo-cli:
|
||
_bin: argocd
|
||
_desc: ArgoCD is a declarative GitOps continuous delivery platform.
|
||
_docs: https://argoproj.github.io/argo-workflows/walk-through/argo-cli/
|
||
_github: https://github.com/argoproj/argo-cd
|
||
_home: https://argo-cd.readthedocs.io/en/stable/
|
||
_name: argo
|
||
brew: argocd
|
||
choco: argocd-cli
|
||
github: https://github.com/argoproj/argo-workflows
|
||
pacman:
|
||
- argocd
|
||
- argocd-cli
|
||
aria2:
|
||
_bin: aria2c
|
||
_desc: '[aria2](https://aria2.github.io/) is a lightweight multi-protocol & multi-source command-line download utility. It supports HTTP/HTTPS, FTP, SFTP, BitTorrent and Metalink. [AriaNg](http://ariang.mayswind.net/) is a modern web frontend that makes working with aria2 easier.'
|
||
_docs: https://aria2.github.io/manual/en/html/
|
||
_github: https://github.com/aria2/aria2
|
||
_name: Aria2/AriaNg
|
||
ansible: professormanhattan.aria
|
||
apt: aria2
|
||
brew: aria2
|
||
choco: aria2
|
||
dnf:fedora: aria2
|
||
pacman: aria2
|
||
port: aria2
|
||
scoop: aria2
|
||
ariang:
|
||
_app: AriaNg Native.app
|
||
_github: https://github.com/mayswind/AriaNg
|
||
cask: ariang
|
||
arping:
|
||
_bin: arping
|
||
_github: https://github.com/ThomasHabets/arping
|
||
_name: ARPing
|
||
apt: arping
|
||
brew: arping
|
||
choco: arping
|
||
dnf: arping
|
||
pacman: arping
|
||
asciinema:
|
||
_bin: asciinema
|
||
_desc: '[Asciinema](https://asciinema.org) allows you to record and share your terminal sessions, the simple way'
|
||
_docs: https://asciinema.org/docs/
|
||
_github: https://github.com/asciinema/asciinema
|
||
_home: https://asciinema.org/
|
||
_name: asciinema
|
||
apk: asciinema
|
||
apt: asciinema
|
||
brew: asciinema
|
||
dnf: asciinema
|
||
pacman: asciinema
|
||
pipx: asciinema
|
||
asdf:
|
||
_bin: asdf
|
||
_desc: '[asdf](https://asdf-vm.com/#/) is a CLI tool that can manage multiple language runtime versions on a per-project basis or globally. It is like gvm, nvm, rbenv, and pyenv all in one. This role installs asdf on Linux or macOS.'
|
||
_docs: https://asdf-vm.com/guide/introduction.html
|
||
_github: https://github.com/asdf-vm/asdf
|
||
_home: https://asdf-vm.com/
|
||
_name: asdf-vm
|
||
ansible: professormanhattan.asdf
|
||
assh:
|
||
_bin: assh
|
||
_desc: '[assh](https://manfred.life/assh) makes your ssh client smarter'
|
||
_docs: https://github.com/moul/assh
|
||
_github: https://github.com/moul/assh
|
||
_home: https://manfred.life/assh
|
||
_name: assh
|
||
brew: assh
|
||
go: moul.io/assh/v2
|
||
yay: assh
|
||
astronvim:
|
||
_deps:
|
||
- bottom
|
||
- lazygit
|
||
- neovim
|
||
- node
|
||
- python
|
||
- ripgrep
|
||
- tree-sitter
|
||
_desc: '[AstroNvim](https://astronvim.github.io/) is an aesthetic and feature-rich neovim config that is extensible and easy to use with a great set of plugins'
|
||
_docs: https://astronvim.github.io/
|
||
_github: https://github.com/AstroNvim/AstroNvim
|
||
_home: https://astronvim.github.io/
|
||
_name: AstroNvim
|
||
# TODO: Add timeouts to all commands in install-program
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
echo "Waiting on command that installs nvim plugins"
|
||
# bash -ci "nvim --headless -c 'quitall'"
|
||
atuin:
|
||
_bin: atuin
|
||
_github: https://github.com/ellie/atuin
|
||
_name: Atuin
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
source "${XDG_CONFIG_HOME:-$HOME/.config}/shell/private.sh"
|
||
atuin register -u "$ATUIN_USERNAME" -e "$ATUIN_EMAIL" -p "$ATUIN_PASSWORD"
|
||
atuin import auto
|
||
atuin sync
|
||
brew: atuin
|
||
cargo: atuin
|
||
pacman: atuin
|
||
pkg-termux: atuin
|
||
port: atuin
|
||
audacity:
|
||
_app: Audacity.app
|
||
_bin: audacity
|
||
_desc: An open-source audio editor
|
||
_docs: https://support.audacityteam.org/
|
||
_github: https://github.com/audacity/audacity
|
||
_home: https://www.audacityteam.org/
|
||
_name: Audacity
|
||
appimage: Audacity
|
||
apt: audacity
|
||
cask: audacity
|
||
choco: audacity
|
||
dnf: audacity
|
||
flatpak: org.audacityteam.Audacity
|
||
scoop: extras/audacity
|
||
snap: audacity
|
||
auto-install:
|
||
_bin: auto-install
|
||
_desc: '[auto-install](https://github.com/siddharthkp/auto-install) installs dependencies as you code'
|
||
_docs: https://github.com/siddharthkp/auto-install
|
||
_github: https://github.com/siddharthkp/auto-install
|
||
_home: https://github.com/siddharthkp/auto-install
|
||
_name: auto-install
|
||
npm: auto-install
|
||
autodoc:
|
||
_bin: doc
|
||
_github: https://github.com/context-labs/autodoc
|
||
_name: Autodoc
|
||
npm: '@context-labs/autodoc'
|
||
autokey:
|
||
_bin: null
|
||
_desc: '[AutoKey](https://github.com/autokey/autokey) is a free, open-source scripting application for Linux. AutoKey allows the user to define hotkeys and trigger phrases which expand to predefined text, automating frequent or repetitive tasks such as correcting typographical errors or common spelling mistakes and inserting boiler plate sections of text. [AutoHotKey](https://www.autohotkey.com/) is a similar piece of software that is only available on the Windows platform.'
|
||
_docs: https://autokey.github.io/
|
||
_github: https://github.com/autokey/autokey
|
||
_home: https://code.google.com/archive/p/autokey/
|
||
_name: Autokey
|
||
ansible:linux: professormanhattan.autokey
|
||
ansible:windows: professormanhattan.autokey
|
||
apt: autokey
|
||
choco: autohotkey
|
||
dnf: autokey
|
||
yay: autokey-gtk
|
||
automake:
|
||
_bin: automake
|
||
_github: false
|
||
_desc: '[GNU Automake](https://www.gnu.org/software/automake/) is a tool for automatically generating Makefile.in files compliant with the GNU Coding Standards'
|
||
_docs: https://www.gnu.org/software/automake/manual/automake.html
|
||
_home: https://www.gnu.org/software/automake/
|
||
_name: GNU Automake
|
||
apk: automake
|
||
apt: automake
|
||
brew: automake
|
||
dnf: automake
|
||
pacman: automake
|
||
pkg: automake
|
||
autorestic:
|
||
_bin: autorestic
|
||
_desc: '[Autorestic](https://autorestic.vercel.app/) is a wrapper around [Restic](https://restic.net/). The Restic CLI can be a bit overwhelming and difficult to manage if you have many different location that you want to backup to multiple locations. Autorestic makes managing all your S3 backups easier by making it config / cron driven.'
|
||
_docs: https://autorestic.vercel.app/quick
|
||
_github: https://github.com/cupcakearmy/autorestic/
|
||
_home: https://autorestic.vercel.app/
|
||
_name: Autorestic
|
||
ansible: professormanhattan.autorestic
|
||
brew: autorestic
|
||
aws-shell:
|
||
_bin: aws-shell
|
||
_desc: An integrated shell for working with the AWS CLI.
|
||
_docs: https://github.com/awslabs/aws-shell
|
||
_github: https://github.com/awslabs/aws-shell
|
||
_home: https://pypi.org/project/aws-shell/
|
||
_name: AWS Shell
|
||
brew: aws-shell
|
||
pipx: aws-shell
|
||
awscli:
|
||
_bin: aws
|
||
_desc: 'The [AWS CLI](https://aws.amazon.com/cli/) is a unified tool to manage your AWS services. With just one tool to download and configure, you can control multiple AWS services from the command line and automate them through scripts.'
|
||
_docs: https://docs.aws.amazon.com/cli/index.html
|
||
_github: https://github.com/aws/aws-cli
|
||
_home: https://aws.amazon.com/
|
||
_name: AWS CLI
|
||
ansible: professormanhattan.awscli
|
||
binary:darwin: https://awscli.amazonaws.com/AWSCLIV2.pkg
|
||
binary:linux: https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip
|
||
binary:windows: https://awscli.amazonaws.com/AWSCLIV2.msi
|
||
brew: awscli@2
|
||
choco: awscli
|
||
awxcli:
|
||
_bin: awx
|
||
_desc: '[ansible-tower-cli](https://docs.ansible.com/ansible-tower/latest/html/towercli/index.html) is a CLI program that interacts with Ansible Tower or AWX. It is the official command-line client for both Ansible Tower and AWX. It uses naming and structure consistent with the AWX HTTP API, provides consistent output formats with optional machine-parsable formats, and auto-detects API versions, available endpoints, and feature support.'
|
||
_docs: https://docs.ansible.com/ansible-tower/latest/html/towercli/index.html
|
||
_github: https://github.com/ansible/awx
|
||
_home: https://docs.ansible.com/automation.html
|
||
_name: AWX CLI
|
||
ansible: professormanhattan.awxcli
|
||
pipx: https://releases.ansible.com/ansible-tower/cli/ansible-tower-cli-latest.tar.gz
|
||
axel:
|
||
_bin: axel
|
||
_github: https://github.com/axel-download-accelerator/axel
|
||
_name: Axel
|
||
apt: axel
|
||
brew: axel
|
||
choco: axel
|
||
dnf:fedora: axel
|
||
pacman: axel
|
||
port: axel
|
||
azure-cli:
|
||
_bin: az
|
||
_desc: 'The [Azure CLI](https://docs.microsoft.com/en-us/cli/azure/) is a set of commands used to create and manage Azure resources. The Azure CLI is available across Azure services and is designed to get you working quickly with Azure, with an emphasis on automation. It is the official CLI, released by Microsoft.'
|
||
_docs: https://docs.microsoft.com/en-us/cli/azure/
|
||
_github: https://github.com/Azure/azure-cli
|
||
_home: https://azure.microsoft.com/
|
||
_name: Azure CLI
|
||
ansible: professormanhattan.azurecli
|
||
brew: azure-cli
|
||
choco: azure-cli
|
||
winget: Microsoft.AzureCLI
|
||
yay: azure-cli
|
||
azure-functions:
|
||
_bin: func
|
||
_desc: '[azure-functions-core-tools](https://github.com/Azure/azure-functions-core-tools) A local development experience for creating, developing, testing, running, and debugging Azure Functions'
|
||
_github: https://github.com/Azure/azure-functions-core-tools
|
||
_name: azure-functions-core-tools
|
||
brew: azure/functions/azure-functions-core-tools@4
|
||
choco: azure-functions-core-tools
|
||
github: github.com/Azure/azure-functions-core-tools
|
||
npm: azure-functions-core-tools@4
|
||
backup:
|
||
_bin: backup
|
||
_github: https://github.com/backup/backup
|
||
_name: Backup
|
||
gem: backup -v5.0.0.beta.1
|
||
balenaetcher:
|
||
_app: balenaEtcher.app
|
||
_appImageName: balenaEtcher.AppImage
|
||
_bin: null
|
||
_desc: '[balenaEtcher](https://www.balena.io/etcher/) is a powerful OS image flasher built with web technologies to ensure flashing an SDCard or USB drive is a pleasant and safe experience. It protects from accidentally writing to hard-drives, ensures every byte of data was written correctly, and much more. It can also directly flash Raspberry Pi devices that support USB device boot mode. It will run on any platform officially supported by Electron.'
|
||
_docs: https://www.balena.io/docs/learn/welcome/introduction/
|
||
_github: https://github.com/balena-io/etcher
|
||
_home: https://www.balena.io/etcher/
|
||
_name: balenaEtcher
|
||
ansible:linux: professormanhattan.etcher
|
||
# Waiting for zap to allow headless automation of AppImage Catalog images
|
||
# Currently, it fails because there are multiple versions to select
|
||
# appimage: etcher
|
||
appimage: etcher
|
||
cask: balenaetcher
|
||
choco: etcher
|
||
yay: balena-etcher
|
||
bandwhich:
|
||
_bin: bandwhich
|
||
_desc: '[Bandwhich](https://github.com/imsnif/bandwhich) is a CLI utility for displaying current network utilization by process, connection and remote IP/hostname.'
|
||
_github: https://github.com/imsnif/bandwhich
|
||
_name: Bandwhich
|
||
ansible: professormanhattan.bandwhich
|
||
brew: bandwhich
|
||
github: github.com/imsnif/bandwhich
|
||
pacman: bandwhich
|
||
pkg: bandwhich
|
||
bane:
|
||
_bin: bane
|
||
_desc: '[bane](https://github.com/genuinetools/bane) Custom & better AppArmor profile generator for Docker containers'
|
||
_github: https://github.com/genuinetools/bane
|
||
_name: bane
|
||
github: github.com/genuinetools/bane
|
||
go: github.com/genuinetools/bane@latest
|
||
barrier:
|
||
_app: Barrier.app
|
||
_bin: barrier
|
||
_github: https://github.com/debauchee/barrier
|
||
_name: Barrier
|
||
_todo: TODO
|
||
cask: barrier
|
||
choco: barrier
|
||
flatpak: com.github.debauchee.barrier
|
||
bash-completion:
|
||
_bin: null
|
||
_docs: https://docs.brew.sh/Shell-Completion
|
||
_name: Bash Completion Formula
|
||
_github: https://github.com/scop/bash-completion
|
||
apt: bash-completion
|
||
brew: bash-completion@2
|
||
dnf: bash-completion
|
||
pacman: bash-completion
|
||
bashly:
|
||
_bin: bashly
|
||
_github: https://github.com/DannyBen/bashly
|
||
_name: Bashly
|
||
gem: bashly
|
||
basictex:
|
||
_github: false
|
||
_name: Basictex
|
||
_when: '! test -d /Library/TeX'
|
||
cask: basictex
|
||
bat:
|
||
_bin: bat
|
||
_desc: '[bat](https://github.com/sharkdp/bat) is a cat(1) clone with syntax highlighting and Git integration.'
|
||
_github: https://github.com/sharkdp/bat
|
||
_name: bat
|
||
ansible: professormanhattan.bat
|
||
apk: bat
|
||
apt: bat
|
||
brew: bat
|
||
cargo: bat
|
||
choco: bat
|
||
pacman: bat
|
||
pkg: bat
|
||
port: bat
|
||
scoop: bat
|
||
zypper: bat
|
||
bat-extras:
|
||
_bin: batman
|
||
_github: https://github.com/eth-p/bat-extras
|
||
_name: Bat Extras
|
||
brew: bat-extras
|
||
emerge: sys-apps/bat-extras
|
||
pacman: bat-extras
|
||
bats:
|
||
_bin: bats
|
||
_github: https://github.com/bats-core/bats-core
|
||
_name: Bats Bash Testing
|
||
brew: bats-core
|
||
npm: bats
|
||
bazelisk:
|
||
_bin: bazelisk
|
||
_desc: A user-friendly launcher for Bazel.
|
||
_docs: https://bazel.build/docs
|
||
_github: https://github.com/bazelbuild/bazelisk
|
||
_home: https://bazel.build/
|
||
_name: Bazel
|
||
brew: bazelisk
|
||
choco: bazelisk
|
||
go: github.com/bazelbuild/bazelisk@latest
|
||
npm: '@bazel/bazelisk'
|
||
scoop: main/bazel
|
||
beekeeper-studio:
|
||
_app: Beekeeper Studio.app
|
||
_github: https://github.com/beekeeper-studio/beekeeper-studio
|
||
_name: Beekeeper Studio
|
||
_bin: beekeeper-studio
|
||
cask: beekeeper-studio
|
||
choco: beekeeper-studio
|
||
flatpak: io.beekeeperstudio.Studio
|
||
beets:
|
||
_bin: beet
|
||
_desc: 'The purpose of [Beets](https://beets.io/) is to get your music collection right once and for all. It catalogs your collection, automatically improving its metadata as it goes using the MusicBrainz database. Then it provides a bouquet of tools for manipulating and accessing your music.'
|
||
_docs: https://beets.readthedocs.io/en/stable/
|
||
_github: https://github.com/beetbox/beets
|
||
_home: https://beets.io/
|
||
_name: Beets
|
||
ansible: professormanhattan.beets
|
||
pipx: beets
|
||
betwixt:
|
||
_app: Betwixt.app
|
||
_bin: null
|
||
_desc: Web Debugging Proxy based on Chrome DevTools Network panel
|
||
_docs: https://github.com/kdzwinel/betwixt
|
||
_github: https://github.com/kdzwinel/betwixt
|
||
_home: https://github.com/kdzwinel/betwixt
|
||
_name: Betwixt
|
||
cask: betwixt
|
||
bfg:
|
||
_bin: bfg
|
||
_docs: https://rtyley.github.io/bfg-repo-cleaner/
|
||
_github: https://github.com/rtyley/bfg-repo-cleaner
|
||
_home: https://rtyley.github.io/bfg-repo-cleaner/
|
||
_name: BFG Repo Cleaner
|
||
brew: bfg
|
||
choco: bfg-repo-cleaner
|
||
port: bfg
|
||
bin:
|
||
_bin: bin
|
||
_desc: Effortless binary manager
|
||
_github: https://github.com/marcosnils/bin
|
||
_name: bin
|
||
github: github.com/marcosnils/bin
|
||
go: github.com/marcosnils/bin@latest
|
||
binwalk:
|
||
_bin: binwalk
|
||
_github: https://github.com/ReFirmLabs/binwalk
|
||
_name: Binwalk
|
||
apt: binwalk
|
||
brew: binwalk
|
||
choco: binwalk
|
||
dnf: binwalk
|
||
pacman: binwalk
|
||
bismuth:
|
||
_bin: bismuth
|
||
_github: https://github.com/Bismuth-Forge/bismuth
|
||
_name: Bismuth
|
||
apt: kwin-bismuth
|
||
dnf: bismuth
|
||
pacman: kwin-bismuth
|
||
bitly:
|
||
_bin: bitly
|
||
_desc: Shorten links with Bitly in your terminal!
|
||
_github: https://github.com/xxczaki/bitly-cli-client
|
||
_name: bitly
|
||
npm: bitly-cli-client
|
||
bitwarden:
|
||
_app: Bitwarden.app
|
||
_bin: bitwarden
|
||
_desc: The desktop vault (Windows, macOS, & Linux)
|
||
_github: https://github.com/bitwarden/desktop
|
||
_name: BitWarden
|
||
cask: bitwarden
|
||
choco: bitwarden
|
||
flatpak: com.bitwarden.desktop
|
||
github: github.com/bitwarden/desktop
|
||
mas: 1352778147
|
||
snap: bitwarden
|
||
yay: bitwarden-git
|
||
bitwarden-cli:
|
||
_bin: bw
|
||
_desc: '[Bitwarden CLI](https://github.com/bitwarden/cli) (i.e. bw) is a free and open-source official CLI for the [Bitwarden](https://bitwarden.com/) password manager. bw is available on Linux, macOS, and Microsoft Windows.'
|
||
_docs: https://bitwarden.com/help/
|
||
_github: https://github.com/bitwarden/clients
|
||
_home: https://bitwarden.com/
|
||
_name: Bitwarden CLI
|
||
ansible: professormanhattan.bw
|
||
brew: bitwarden-cli
|
||
choco: bitwarden-cli
|
||
npm: '@bitwarden/cli'
|
||
scoop: bitwarden-cli
|
||
snap: bw
|
||
bivac:
|
||
_bin: null
|
||
_desc: '[Bivac](https://bivac.io/) - Backup Interface for Volumes Attached to Containers - allows to backup Container volumes using Restic'
|
||
_github: https://github.com/camptocamp/bivac
|
||
_home: https://bivac.io/
|
||
_name: bivac
|
||
github: github.com/camptocamp/bivac
|
||
blackhole:
|
||
_bin: false
|
||
_desc: Audio loopback device for macOS (supports sound passthrough to screen recording software on macOS)
|
||
_docs: https://github.com/ExistentialAudio/BlackHole#user-guides
|
||
_github: https://github.com/ExistentialAudio/BlackHole
|
||
_home: https://github.com/ExistentialAudio/BlackHole
|
||
_name: BlackHole
|
||
_when:cask: '! test -d /Library/Audio/Plug-Ins/HAL/BlackHole16ch.driver && ! test -d ~/Library/Audio/Plug-Ins/HAL/BlackHole16ch.driver'
|
||
cask: blackhole-16ch
|
||
blender:
|
||
_app: Blender.app
|
||
_bin: blender
|
||
_desc: Blender is the free and open source 3D creation suite. It supports the entirety of the 3D pipeline-modeling, rigging, animation, simulation, rendering, compositing, motion tracking and video editing.
|
||
_docs: https://docs.blender.org/manual/en/latest/
|
||
_github: https://github.com/blender/blender
|
||
_home: https://www.blender.org/
|
||
_name: Blender
|
||
apt: blender
|
||
cask: blender
|
||
choco: blender
|
||
dnf: blender
|
||
flatpak: org.blender.Blender
|
||
scoop: extras/blender
|
||
snap: blender --classic
|
||
blocky:
|
||
_bin: blocky
|
||
_github: https://github.com/0xERR0R/blocky
|
||
_name: Blocky
|
||
_post:brew: |
|
||
#!/usr/bin/env bash
|
||
cp -f "$HOME/.local/etc/blocky/config.yaml" "$(brew --prefix)/etc/blocky/config.yaml"
|
||
_post:linux: |
|
||
#!/usr/bin/env bash
|
||
sudo mkdir -p /usr/local/etc/blocky
|
||
if [ -d /usr/lib/systemd/system ]; then
|
||
sudo cp -f "$HOME/.local/etc/blocky/config.yaml" /usr/local/etc/blocky/config.yaml
|
||
sudo cp -f "$HOME/.local/etc/blocky/blocky.service" /usr/lib/systemd/system/blocky.service
|
||
else
|
||
echo "/usr/lib/systemd/system is missing from the file system"
|
||
fi
|
||
_service: blocky
|
||
_service:brew:
|
||
- name: blocky
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
brew: blocky
|
||
go: github.com/0xERR0R/blocky@mastergithub.com/0xERR0R/blocky@master
|
||
blueutil:
|
||
_bin: blueutil
|
||
_github: https://github.com/toy/blueutil
|
||
_name: BlueUtil
|
||
brew:darwin: blueutil
|
||
boilr:
|
||
_bin: null
|
||
_desc: boilerplate template manager that generates files or directories from template repositories
|
||
_github: https://github.com/tmrts/boilr
|
||
_name: boilr
|
||
github: github.com/tmrts/boilr
|
||
go: github.com/tmrts/boilr@latest
|
||
boringtun:
|
||
_bin: boringtun-cli
|
||
_desc: BoringTun is an implementation of the WireGuard® protocol designed for portability and speed.
|
||
_github: https://github.com/cloudflare/boringtun
|
||
_name: BoringTun
|
||
_todo: Add sudo boringtun-cli utun
|
||
brew: boringtun
|
||
cargo:darwin: boringtun-cli
|
||
cargo:linux: boringtun-cli
|
||
bottles:
|
||
_bin: bottles
|
||
_github: https://github.com/bottlesdevs/Bottles
|
||
flatpak: com.usebottles.bottles
|
||
bottom:
|
||
_bin: bottom
|
||
_bin:brew: btm
|
||
_desc: '[bottom](https://clementtsang.github.io/bottom/) is yet another cross-platform graphical process/system monitor. It is a customizable cross-platform graphical process/system monitor for the terminal that supports Linux, macOS, and Windows'
|
||
_docs: https://clementtsang.github.io/bottom/nightly/
|
||
_github: https://github.com/ClementTsang/bottom
|
||
_home: https://clementtsang.github.io/
|
||
_name: bottom
|
||
brew: bottom
|
||
pacman: bottom
|
||
scoop: bottom
|
||
snap: bottom
|
||
brasero:
|
||
_bin: brasero
|
||
_name: Brasero
|
||
_github: https://github.com/GNOME/brasero
|
||
apt: brasero
|
||
dnf: brasero
|
||
pacman: brasero
|
||
brave-browser:
|
||
_app: Brave Browser.app
|
||
_bin: brave
|
||
_desc: '[Brave Browser](https://brave.com/) is a free and open-source web browser developed by Brave Software, Inc. based on the Chromium web browser. It includes the ability to access Tor websites and has a built-in plugin that replaces ads and pays you to surf the web. It is a privacy-focused browser, which automatically blocks online advertisements and website trackers in its default settings. It also supports Chrome extensions.'
|
||
_docs: https://support.brave.com/hc/en-us/articles/360035410812-Quickstart-guide-New-to-Brave-Start-here-
|
||
_env:
|
||
BRAVE_BROWSER_APPDATA:
|
||
cask: "$HOME/Library/Application Support/BraveSoftware/Brave-Browser/Default"
|
||
choco: "%APPDATA%/Local/BraveSoftware/Brave-Browser/User Data"
|
||
flatpak: "$HOME/.var/app/com.brave.Browser/config/BraveSoftware/Brave-Browser/Default"
|
||
snap: "$HOME/snap/brave/current/.config/BraveSoftware/Brave-Browser/Default"
|
||
_github: https://github.com/brave/brave-browser
|
||
_home: https://brave.com/
|
||
_name: Brave Browser
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @brief See `google-chrome` `_post` script for more details
|
||
function chromeSetUp() {
|
||
### Ensure Chrome policies directory is present
|
||
logg info 'Processing policy directories for Chromium based browsers'
|
||
for POLICY_DIR in "/etc/brave/policies"; do
|
||
if [ -d "$(dirname "$POLICY_DIR")" ]; then
|
||
### Managed policies
|
||
if [ ! -f "$POLICY_DIR/managed/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/managed exists"
|
||
sudo mkdir -p "$POLICY_DIR/managed"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json to $POLICY_DIR/managed/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json" "$POLICY_DIR/managed/policies.json"
|
||
fi
|
||
|
||
### Recommended policies
|
||
if [ ! -f "$POLICY_DIR/recommended/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/recommended exists" && sudo mkdir -p "$POLICY_DIR/recommended"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json to $POLICY_DIR/recommended/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json" "$POLICY_DIR/recommended/policies.json"
|
||
fi
|
||
else
|
||
logg info "Skipping extension injection into $POLICY_DIR - create these folders prior to running to create managed configs"
|
||
fi
|
||
done
|
||
|
||
### Add Chrome extension JSON
|
||
logg info 'Populating Chrome extension JSON'
|
||
for EXTENSION_DIR in "/etc/brave/extensions" "$HOME/Library/Application Support/BraveSoftware/Brave-Browser/External Extensions"; do
|
||
### Ensure program-type is installed
|
||
if [ -d "$(dirname "$EXTENSION_DIR")" ]; then
|
||
### Ensure extension directory exists
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && sudo mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
else
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
fi
|
||
|
||
### Add extension JSON
|
||
logg info "Adding Chrome extensions to $EXTENSION_DIR"
|
||
for EXTENSION in {{ list (.chromeExtensions | toString | replace "[" "" | replace "]" "") | uniq | join " " }}; do
|
||
logg info "Adding Chrome extension manifest ($EXTENSION)"
|
||
if ! echo "$EXTENSION" | grep 'https://chrome.google.com/webstore/detail/' > /dev/null; then
|
||
EXTENSION="https://chrome.google.com/webstore/detail/$EXTENSION"
|
||
fi
|
||
EXTENSION_ID="$(echo "$EXTENSION" | sed 's/^.*\/\([^\/]*\)$/\1/')"
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
else
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
fi
|
||
done
|
||
else
|
||
logg info "$EXTENSION_DIR does not exist"
|
||
fi
|
||
done
|
||
}
|
||
chromeSetUp
|
||
cask: brave-browser
|
||
choco: brave
|
||
flatpak: com.brave.Browser
|
||
snap: brave
|
||
brew-gem:
|
||
_bin: brew-gem
|
||
_github: https://github.com/sportngin/brew-gem
|
||
_name: Homebrew RubyGems
|
||
brew: brew-gem
|
||
brew-pkg:
|
||
_github: https://github.com/timsutton/brew-pkg
|
||
_name: Homebrew Pkg
|
||
_when:brew:darwin: '! brew list brew-pkg'
|
||
brew:darwin: timsutton/formulae/brew-pkg
|
||
broot:
|
||
_bin: broot
|
||
_desc: '[broot](https://dystroy.org/broot/) offers a new way to see and navigate directory trees.'
|
||
_docs: https://dystroy.org/broot/documentation/usage/
|
||
_github: https://github.com/Canop/broot
|
||
_home: https://dystroy.org/broot/
|
||
_name: Broot
|
||
ansible: professormanhattan.broot
|
||
apk: broot
|
||
brew: broot
|
||
cargo: broot
|
||
emerge: broot
|
||
pkgin: broot
|
||
port: broot
|
||
browser-sync:
|
||
_bin: browser-sync
|
||
_desc: '[Browsersync](https://browsersync.io/) allows you to keep multiple browsers & devices in sync when building websites'
|
||
_docs: https://browsersync.io/docs
|
||
_github: https://github.com/BrowserSync/browser-sync
|
||
_home: https://browsersync.io/
|
||
_name: Browsersync
|
||
npm: browser-sync
|
||
browserosaurus:
|
||
_app: Browserosaurus.app
|
||
_bin: null
|
||
_desc: The browser prompter for macOS
|
||
_docs: https://github.com/will-stone/browserosaurus
|
||
_github: https://github.com/will-stone/browserosaurus
|
||
_home: https://browserosaurus.com/
|
||
_name: Browserosaurus
|
||
cask: browserosaurus
|
||
budibase-cli:
|
||
_bin: budi
|
||
_desc: '[Budibase](https://budibase.com) The Budibase CLI is how you initialise, manage and update your Budibase installation'
|
||
_docs: https://docs.budibase.com/docs/budibase-cli-reference
|
||
_github: https://github.com/Budibase/budibase
|
||
_home: https://budibase.com
|
||
_name: budibase-cli
|
||
github: github.com/Budibase/budibase
|
||
npm: '@budibase/cli'
|
||
buildkite-agent:
|
||
_bin: buildkite-agent
|
||
_github: https://github.com/buildkite/agent
|
||
_name: BuildKite Agent
|
||
brew: buildkite/buildkite/buildkite-agent
|
||
bun:
|
||
_bin: bun
|
||
_github: https://github.com/oven-sh/bun
|
||
_name: Bun
|
||
brew: oven-sh/bun/bun
|
||
npm: bun
|
||
proto: bun
|
||
bundler:
|
||
_bin: bundler
|
||
_desc: '[Bundler](https://bundler.io/) provides a consistent environment for Ruby projects by tracking and installing the exact gems and versions that are needed'
|
||
_docs: https://bundler.io/docs.html
|
||
_github: https://github.com/rubygems/rubygems/tree/master/bundler
|
||
_home: https://bundler.io/
|
||
_name: Bundler
|
||
gem: bundler
|
||
caddy:
|
||
_bin: caddy
|
||
_github: https://github.com/caddyserver/caddy
|
||
_name: Caddy
|
||
_service: caddy
|
||
brew: caddy
|
||
choco: caddy
|
||
scoop: caddy
|
||
cakebrew:
|
||
_app: Cakebrew.app
|
||
_bin: null
|
||
_desc: Manage your Homebrew formulas with style using Cakebrew.
|
||
_docs: https://www.cakebrew.com/
|
||
_github: https://github.com/brunophilipe/Cakebrew
|
||
_home: http://www.cakebrew.com/
|
||
_name: Cakebrew
|
||
cask: cakebrew
|
||
caniuse:
|
||
_bin: caniuse
|
||
_desc: caniuse-cmd is a caniuse command line tool, providing all the power of caniuse.com with none of the nice UI or interactivity
|
||
_github: https://github.com/sgentle/caniuse-cmd
|
||
npm: caniuse-cmd
|
||
capacitor:
|
||
_bin: cap
|
||
_github: https://github.com/ionic-team/capacitor
|
||
_name: Capacitor
|
||
npm: '@capacitor/cli'
|
||
captain:
|
||
_bin: captain
|
||
_desc: Helps manage docker-compose.yml files from anywhere in the file system
|
||
_github: https://github.com/jenssegers/captain
|
||
_name: captain
|
||
go: github.com/jenssegers/captain@latest
|
||
carapace:
|
||
_bin: carapace
|
||
_github: https://github.com/rsteube/carapace-bin
|
||
_name: Carapace
|
||
brew: rsteube/tap/carapace
|
||
nix-shell: carapace
|
||
pacman: carapace-bin
|
||
scoop: extras/carapace-bin
|
||
winget: rsteube.Carapace
|
||
carbon-now:
|
||
_bin: carbon-now
|
||
_desc: '[Carbon](https://carbon.now.sh/) lets you create and share beautiful images of your source code'
|
||
_github: https://github.com/carbon-app/carbon
|
||
_home: https://carbon.now.sh/
|
||
_name: Carbon
|
||
npm: carbon-now-cli
|
||
carthage:
|
||
_bin: carthage
|
||
_desc: A simple, decentralized dependency manager for Cocoa
|
||
_github: https://github.com/Carthage/Carthage
|
||
_name: Carthage
|
||
brew:darwin: carthage
|
||
catfs:
|
||
_bin: catfs
|
||
_deps:
|
||
- fuse
|
||
_desc: Cache anything filesystem written in Rust
|
||
_docs: https://github.com/kahing/catfs#usage
|
||
_github: https://github.com/kahing/catfs
|
||
_home: https://github.com/kahing/catfs
|
||
_name: Catfs
|
||
ansible:linux: professormanhattan.s3filesystem
|
||
cargo:linux: catfs
|
||
catlight:
|
||
_app: Catlight.app
|
||
_github: https://github.com/catlightio/CatLight
|
||
_name: Catlight
|
||
cask: catlight
|
||
deb: https://catlight.io/downloads/linux/beta
|
||
ccat:
|
||
_bin: ccat
|
||
_github: https://github.com/owenthereal/ccat
|
||
_name: ccat
|
||
brew: ccat
|
||
go: github.com/owenthereal/ccat@latest
|
||
pacman: ccat
|
||
ceph:
|
||
_bin: ceph-client
|
||
_deps:
|
||
- dokany
|
||
_github: https://github.com/ceph/ceph
|
||
_name: CephFS
|
||
apt: cephadm
|
||
brew: megabyte-labs/tap/ceph-client
|
||
dnf: cephadm
|
||
zypper: cephadm
|
||
cerebro:
|
||
_app: Cerebro.app
|
||
_bin: null
|
||
_desc: Open-source productivity booster with a brain
|
||
_github: https://github.com/cerebroapp/cerebro
|
||
_name: Cerebro
|
||
cask: cerebro
|
||
choco: cerebro
|
||
github: github.com/cerebroapp/cerebro
|
||
yay: cerebro
|
||
certbot:
|
||
_bin: certbot
|
||
_desc: >-
|
||
[Certbot](https://certbot.eff.org/) is part of EFF’s effort to encrypt the entire Internet. Secure communication over the Web relies on HTTPS, which requires the use of a digital certificate that lets browsers verify the identity of web servers (e.g., is that really google.com?). Web servers obtain their certificates from trusted third parties called certificate authorities (CAs). Certbot is an easy-to-use client that fetches a certificate from [Let’s Encrypt](https://letsencrypt.org/)—an open certificate authority launched by the EFF, Mozilla, and others—and deploys it to a web server.
|
||
_docs: https://eff-certbot.readthedocs.io/en/stable/
|
||
_github: https://github.com/certbot/certbot
|
||
_home: https://certbot.eff.org/
|
||
_name: CertBot
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
pipx inject certbot certbot-dns-cloudflare
|
||
_post:windows: |
|
||
#!/usr/bin/env bash
|
||
echo "Add method for Windows"
|
||
pipx: certbot
|
||
cf-terraforming:
|
||
_bin: cf-terraforming
|
||
_github: https://github.com/cloudflare/cf-terraforming
|
||
_name: CloudFlare Terraforming
|
||
cask: cloudflare/cloudflare/cf-terraforming
|
||
cfssl:
|
||
_bin: cfssl
|
||
_desc: "[CFSSL](https://cfssl.org/) is CloudFlare's PKI/TLS swiss army knife. It is both a command line tool and an HTTP API server for signing, verifying, and bundling TLS certificates"
|
||
_github: https://github.com/cloudflare/cfssl
|
||
_home: https://cfssl.org/
|
||
_name: CFSSL
|
||
brew: cfssl
|
||
pacman: cfssl
|
||
charm:
|
||
_bin: charm
|
||
_desc: The Charm Tool and Library
|
||
_docs: https://github.com/charmbracelet/charm
|
||
_github: https://github.com/charmbracelet/charm
|
||
_home: https://charm.sh
|
||
_name: Charm
|
||
brew: charmbracelet/tap/charm
|
||
go: github.com/charmbracelet/charm@main
|
||
nix-env: nixpkgs.charm
|
||
pacman: charm
|
||
chatgpt-menubar:
|
||
_app: Chatgpt.app
|
||
_bin: null
|
||
_desc: ChatGPT for Mac, living in your menubar.
|
||
_docs: https://github.com/vincelwt/chatgpt-mac
|
||
_github: https://github.com/vincelwt/chatgpt-mac
|
||
_home: https://github.com/vincelwt/chatgpt-mac
|
||
_name: ChatGPT Menubar for macOS
|
||
cask: vincelwt-chatgpt
|
||
chatgpt-nofwl:
|
||
_app: NoFWL.app
|
||
_bin: null
|
||
_desc: ChatGPT desktop application (Mac, Windows and Linux)
|
||
_docs: https://app.nofwl.com/docs/chatgpt/config
|
||
_github: https://github.com/lencx/nofwl
|
||
_home: https://app.nofwl.com/
|
||
_name: ChatGPT Desktop (NoFWL Version)
|
||
appimage: lencx/nofwl
|
||
apt: https://github.com/lencx/nofwl/releases/download/v0.1.0/NoFWL_0.1.0_linux_x86_64.deb
|
||
cask: lencx/nofwl/nofwl --no-quarantine
|
||
msi: https://github.com/lencx/nofwl/releases/download/v0.1.0/NoFWL_0.1.0_windows_x86_64.msi
|
||
cheat:
|
||
_bin: cheat
|
||
_desc: Cheat allows you to create and view interactive cheatsheets on the command-line. It was designed to help remind *nix system administrators of options for commands that they use frequently, but not frequently enough to remember.
|
||
_docker: docker run --rm bannmann/docker-cheat
|
||
_docs: https://github.com/cheat/cheat
|
||
_github: https://github.com/cheat/cheat
|
||
_home: https://github.com/cheat/cheat
|
||
_name: Cheat
|
||
brew: cheat
|
||
go: github.com/cheat/cheat/cmd/cheat@latest
|
||
nix: nixos.cheat
|
||
snap: cheat
|
||
yay: cheat
|
||
chef-workstation:
|
||
_app: Chef Workstation App.app
|
||
_bin: chef-workstation
|
||
_github: https://github.com/chef/chef
|
||
_name: Chef Workstation
|
||
apt: https://packages.chef.io/files/stable/chef-workstation/21.10.640/ubuntu/20.04/chef-workstation_21.10.640-1_amd64.deb
|
||
cask: chef-workstation
|
||
choco: chef-workstation
|
||
dnf: https://packages.chef.io/files/stable/chef-workstation/21.10.640/el/8/chef-workstation-21.10.640-1.el8.x86_64.rpm
|
||
chezmoi:
|
||
_bin: chezmoi
|
||
_desc: Manage your dotfiles across multiple diverse machines, securely.
|
||
_docs: https://www.chezmoi.io/user-guide/command-overview/
|
||
_github: https://github.com/twpayne/chezmoi
|
||
_home: https://www.chezmoi.io/
|
||
_name: Chezmoi
|
||
apk: chezmoi
|
||
brew: chezmoi
|
||
choco: chezmoi
|
||
nix: chezmoi
|
||
pacman: chezmoi
|
||
pkg: chezmoi
|
||
snap: chezmoi --classic
|
||
xbps: chezmoi
|
||
zypper: chezmoi
|
||
chrome-cli:
|
||
_bin: chrome-cli
|
||
_desc: chrome-cli is a command line utility for controlling Google Chrome compatible browsers on OS X. It is a native binary that uses the Scripting Bridge to communicate with Chrome
|
||
_github: https://github.com/prasmussen/chrome-cli
|
||
brew:darwin: chrome-cli
|
||
chrome-gnome-shell:
|
||
_bin: null
|
||
_desc: Browser extension for Google Chrome/Chromium, Firefox, Vivaldi (and other Browser Extension, Chrome Extension or WebExtensions capable browsers) and native host messaging connector that provides integration with GNOME Shell and the corresponding extensions repository
|
||
_github: https://gitlab.gnome.org/GNOME/gnome-browser-extension
|
||
_home: ttps://wiki.gnome.org/Projects/GnomeShellIntegration
|
||
apt: chrome-gnome-shell
|
||
dnf: chrome-gnome-shell
|
||
pacman: chrome-gnome-shell
|
||
chromium:
|
||
_bin: chromium
|
||
_github: https://github.com/chromium/chromium
|
||
_deps:
|
||
- chrome-gnome-shell
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
function chromeSetUp() {
|
||
### Ensure Chrome policies directory is present
|
||
logg info 'Processing policy directories for Chromium based browsers'
|
||
for POLICY_DIR in "/etc/chromium/policies"; do
|
||
if [ -d "$(dirname "$POLICY_DIR")" ]; then
|
||
### Managed policies
|
||
if [ ! -f "$POLICY_DIR/managed/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/managed exists"
|
||
sudo mkdir -p "$POLICY_DIR/managed"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json to $POLICY_DIR/managed/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json" "$POLICY_DIR/managed/policies.json"
|
||
fi
|
||
|
||
### Recommended policies
|
||
if [ ! -f "$POLICY_DIR/recommended/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/recommended exists" && sudo mkdir -p "$POLICY_DIR/recommended"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json to $POLICY_DIR/recommended/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json" "$POLICY_DIR/recommended/policies.json"
|
||
fi
|
||
else
|
||
logg info "Skipping extension injection into $POLICY_DIR - create these folders prior to running to create managed configs"
|
||
fi
|
||
done
|
||
|
||
### Add Chrome extension JSON
|
||
logg info 'Populating Chrome extension JSON'
|
||
### TODO - Find `EXTENSION_DIR` for macOS in Application Support folder like `$HOME/Library/Application Support/Google/Chrome/External Extensions` for Google Chrome
|
||
for EXTENSION_DIR in "/etc/chromium/extensions"; do
|
||
### Ensure program-type is installed
|
||
if [ -d "$(dirname "$EXTENSION_DIR")" ]; then
|
||
### Ensure extension directory exists
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && sudo mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
else
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
fi
|
||
|
||
### Add extension JSON
|
||
logg info "Adding Chrome extensions to $EXTENSION_DIR"
|
||
for EXTENSION in {{ list (.chromeExtensions | toString | replace "[" "" | replace "]" "") | uniq | join " " }}; do
|
||
logg info "Adding Chrome extension manifest ($EXTENSION)"
|
||
if ! echo "$EXTENSION" | grep 'https://chrome.google.com/webstore/detail/' > /dev/null; then
|
||
EXTENSION="https://chrome.google.com/webstore/detail/$EXTENSION"
|
||
fi
|
||
EXTENSION_ID="$(echo "$EXTENSION" | sed 's/^.*\/\([^\/]*\)$/\1/')"
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
else
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
fi
|
||
done
|
||
else
|
||
logg info "$EXTENSION_DIR does not exist"
|
||
fi
|
||
done
|
||
}
|
||
chromeSetUp
|
||
apt: chromium
|
||
dnf: chromium
|
||
flatpak: org.chromium.Chromium
|
||
snap: chromium
|
||
clair:
|
||
_bin: clair
|
||
_desc: Vulnerability Static Analysis for Containers
|
||
_docs: https://quay.github.io/clair/
|
||
_github: https://github.com/quay/clair
|
||
_name: clair
|
||
brew: clair
|
||
github: github.com/quay/clair
|
||
clamav:
|
||
_bin: clamav-config
|
||
_desc: '[ClamAV](https://www.clamav.net/) is an open-source antivirus engine for detecting trojans, viruses, malware & other malicious threats.'
|
||
_docs: https://docs.clamav.net/
|
||
_github: https://github.com/Cisco-Talos/clamav
|
||
_home: https://www.clamav.net/
|
||
_name: ClamAV
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
|
||
### Add freshclam.conf
|
||
if [ -f "$HOME/.local/etc/clamav/freshclam.conf" ]; then
|
||
sudo mkdir -p /usr/local/etc/clamav
|
||
sudo cp -f "$HOME/.local/etc/clamav/freshclam.conf" /usr/local/etc/clamav/freshclam.conf
|
||
if [ -d "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav" ] && [ ! -f "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav/freshclam.conf" ]; then
|
||
ln -s /usr/local/etc/clamav/freshclam.conf "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav/freshclam.conf"
|
||
fi
|
||
fi
|
||
|
||
### Add clamd.conf
|
||
if [ -f "$HOME/.local/etc/clamav/clamd.conf" ]; then
|
||
sudo mkdir -p /usr/local/etc/clamav
|
||
sudo cp -f "$HOME/.local/etc/clamav/clamd.conf" /usr/local/etc/clamav/clamd.conf
|
||
if [ -d "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav" ] && [ ! -f "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav/clamd.conf" ]; then
|
||
ln -s /usr/local/etc/clamav/clamd.conf "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/clamav/clamd.conf"
|
||
fi
|
||
fi
|
||
|
||
### Update database
|
||
freshclam
|
||
|
||
### Setting up launchd services on macOS
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
sudo mkdir -p /var/log/clamav
|
||
# sudo chown $USER /var/log/clamav
|
||
sudo cp -f "$HOME/.local/etc/clamav/clamdscan.plist.tmpl" /Library/LaunchDaemons/clamdscan.plist
|
||
sudo cp -f "$HOME/.local/etc/clamav/freshclam.plist.tmpl" /Library/LaunchDaemons/freshclam.plist
|
||
sudo launchctl load -w /Library/LaunchDaemons/clamdscan.plist
|
||
sudo launchctl load -w /Library/LaunchDaemons/freshclam.plist
|
||
fi
|
||
_service:apt: clamav-freshclam
|
||
_service:brew:
|
||
- name: clamav
|
||
sudo: true
|
||
_service:dnf: clamd-freshclam
|
||
_service:pacman: clamav-freshclam
|
||
_serviceEnabled: true
|
||
apt:
|
||
- clamav
|
||
- clamdscan
|
||
brew: clamav
|
||
dnf:
|
||
- clamav
|
||
- clamav-update
|
||
pacman: clamav
|
||
clangd:
|
||
_bin: clangd
|
||
_desc: '[clangd](https://clangd.llvm.org/) is an language server that understands your C++ code and adds smart features to your editor'
|
||
_docs: https://clangd.llvm.org/guides/
|
||
_github: https://github.com/llvm/llvm-project/tree/main/clang-tools-extra/clangd
|
||
_home: https://clangd.llvm.org/
|
||
_name: clangd
|
||
apt: clangd
|
||
brew: llvm
|
||
choco: llvm
|
||
dnf: clang-tools-extra
|
||
pacman: clang
|
||
scoop: llvm
|
||
clipboard:
|
||
_bin: cb
|
||
_github: https://github.com/Slackadays/Clipboard.git
|
||
_name: Clipboard
|
||
apk: clipboard
|
||
brew: clipboard
|
||
emerge: app-misc/clipboard
|
||
flatpak: app.getclipboard.Clipboard
|
||
nix-env: nixpkgs.clipboard-jh
|
||
scoop: clipboard
|
||
snap: clipboard
|
||
xbps: clipboard
|
||
yay: clipboard
|
||
cloc:
|
||
_bin: cloc
|
||
_github: https://github.com/AlDanial/cloc
|
||
_name: Cloc
|
||
apk: cloc
|
||
apt: cloc
|
||
brew: cloc
|
||
choco: cloc
|
||
dnf: cloc
|
||
emerge: dev-util/cloc
|
||
npm: cloc
|
||
pacman: cloc
|
||
pkg-freebsd: cloc
|
||
pkg_add: cloc
|
||
port: cloc
|
||
scoop: cloc
|
||
clocker:
|
||
_app: Clocker.app
|
||
_bin: null
|
||
_desc: Clocker is designed to help you keep track of your friends and colleagues in different time zones.
|
||
_github: https://github.com/n0shake/clocker
|
||
cask: clocker
|
||
cloudflare-cli:
|
||
_bin: cfcli
|
||
_github: https://github.com/danielpigott/cloudflare-cli
|
||
_name: CloudFlare CLI
|
||
npm: cloudflare-cli
|
||
cloudflared:
|
||
_bin: cloudflared
|
||
_desc: '[CloudFlare Argo Tunnel Client](https://developers.cloudflare.com/argo-tunnel/) contains the command-line client for CloudFlare Argo Tunnel, a tunneling daemon that proxies any local webserver through the Cloudflare network.'
|
||
_github: https://github.com/cloudflare/cloudflared
|
||
_name: CloudFlared
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
|
||
{{- $registrationToken := "" }}
|
||
{{- if and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "cloudflared" .host.hostname)) -}}
|
||
{{- $registrationToken = (includeTemplate (print "cloudflared/" .host.hostname) | decrypt) -}}
|
||
{{- end }}
|
||
### Set up CloudFlare tunnels
|
||
if command -v cloudflared > /dev/null && [ -d "$HOME/.local/etc/cloudflared" ]; then
|
||
# Show warning message about ~/.cloudflared already existing
|
||
if [ -d "$HOME/.cloudflared" ]; then
|
||
logg warn '~/.cloudflared is already in the home directory - to ensure proper deployment, remove previous tunnel configuration folders'
|
||
fi
|
||
|
||
### Ensure /usr/local/etc/cloudflared exists
|
||
if [ -d /usr/local/etc/cloudflared ]; then
|
||
logg info 'Creating folder /usr/local/etc/cloudflared'
|
||
sudo mkdir -p /usr/local/etc/cloudflared
|
||
fi
|
||
|
||
# Copy over configuration files
|
||
logg info 'Ensuring /usr/local/etc/cloudflared exists' && sudo mkdir -p /usr/local/etc/cloudflared
|
||
logg info 'Copying over configuration files from ~/.local/etc/cloudflared to /usr/local/etc/cloudflared'
|
||
sudo cp -f "$HOME/.local/etc/cloudflared/cert.pem" /usr/local/etc/cloudflared/cert.pem
|
||
sudo cp -f "$HOME/.local/etc/cloudflared/config.yml" /usr/local/etc/cloudflared/config.yml
|
||
|
||
# Register tunnel (if not already registered)
|
||
if sudo cloudflared tunnel list | grep "host-{{ .host.hostname }}" > /dev/null; then
|
||
logg info 'CloudFlare tunnel is already registered'
|
||
else
|
||
logg info 'Creating a CloudFlare tunnel to this host'
|
||
sudo cloudflared tunnel create "host-{{ .host.hostname }}"
|
||
fi
|
||
TUNNEL_ID="$(sudo cloudflared tunnel list | grep 'host-{{ .host.hostname }}' | sed 's/ .*//')"
|
||
logg info "Tunnel ID: $TUNNEL_ID"
|
||
if [ -f "/usr/local/etc/cloudflared/${TUNNEL_ID}.json" ]; then
|
||
logg info 'Symlinking tunnel configuration to /usr/local/etc/cloudflared/credentials.json'
|
||
rm -f /usr/local/etc/cloudflared/credentials.json
|
||
sudo ln -s "/usr/local/etc/cloudflared/${TUNNEL_ID}.json" /usr/local/etc/cloudflared/credentials.json
|
||
else
|
||
logg info 'Handling case where the tunnel registration is not present in /usr/local/etc/cloudflared'
|
||
{{ if eq $registrationToken "" -}}
|
||
logg warn 'Registration token is unavailable - you might have to delete the pre-existing tunnel or set up secrets properly'
|
||
{{- else -}}
|
||
logg info 'Registration token retrieved from encrypted blob stored at home/.chezmoitemplates/cloudflared/{{ .host.hostname }}'
|
||
{{ if eq (substr 0 1 $registrationToken) "{" -}}
|
||
logg info 'Registration token stored in credential file form'
|
||
echo -n '{{ $registrationToken }}' | sudo tee /usr/local/etc/cloudflared/credentials.json > /dev/null
|
||
{{ else }}
|
||
logg info 'Registration token is in token form - it will be used in conjunction with sudo cloudflared service install'
|
||
{{- end }}
|
||
{{- end }}
|
||
fi
|
||
|
||
# Set up service
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
# System is macOS
|
||
if [ -f /Library/LaunchDaemons/com.cloudflare.cloudflared.plist ]; then
|
||
logg info 'cloudflared service is already installed'
|
||
else
|
||
logg info 'Running sudo cloudflared service install'
|
||
sudo cloudflared service install{{ if and (ne $registrationToken "") (eq (substr 0 1 $registrationToken) "{") -}} {{ $registrationToken }}{{ end }}
|
||
fi
|
||
logg info 'Ensuring cloudflared service is installed'
|
||
sudo launchctl start com.cloudflare.cloudflared
|
||
elif [ -f /etc/os-release ]; then
|
||
# System is Linux
|
||
if systemctl --all --type service | grep -q "cloudflared" > /dev/null; then
|
||
logg info 'cloudflared service is already available as a service'
|
||
else
|
||
logg info 'Running sudo cloudflared service install'
|
||
sudo cloudflared service install{{ if and (ne $registrationToken "") (eq (substr 0 1 $registrationToken) "{") -}} {{ $registrationToken }}{{ end }}
|
||
fi
|
||
logg info 'Ensuring cloudflared service is started'
|
||
sudo systemctl start cloudflared
|
||
logg info 'Enabling cloudflared as a boot systemctl service'
|
||
sudo systemctl enable cloudflared
|
||
else
|
||
# System is Windows
|
||
cloudflared service install
|
||
mkdir C:\Windows\System32\config\systemprofile\.cloudflared
|
||
# Copy same cert.pem as being used above
|
||
# copy C:\Users\%USERNAME%\.cloudflared\cert.pem C:\Windows\System32\config\systemprofile\.cloudflared\cert.pem
|
||
# https://developers.cloudflare.com/cloudflare-one/connections/connect-apps/install-and-setup/tunnel-guide/local/as-a-service/windows/
|
||
fi
|
||
else
|
||
logg info 'cloudflared was not installed so CloudFlare Tunnels cannot be enabled. (Or the ~/.local/etc/cloudflared folder is not present)'
|
||
fi
|
||
ansible: professormanhattan.cloudflared
|
||
binary:linux: https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64
|
||
brew:darwin: cloudflare/cloudflare/cloudflared
|
||
github: github.com/cloudflare/cloudflared
|
||
cmake:
|
||
_bin: cmake
|
||
_desc: CMake is an open-source, cross-platform family of tools designed to build, test and package software.
|
||
_docs: https://cmake.org/documentation/
|
||
_github: https://github.com/Kitware/CMake
|
||
_home: https://cmake.org/
|
||
_name: Chezmoi
|
||
brew: cmake
|
||
choco: cmake
|
||
snap: cmake --classic
|
||
cmctl:
|
||
_bin: cmctl
|
||
_desc: A CLI tool that can help you to manage cert-manager resources inside your cluster
|
||
_docs: https://cert-manager.io/docs/
|
||
_github: https://github.com/cert-manager/cert-manager
|
||
_home: https://cert-manager.io/docs/usage/cmctl/
|
||
_name: cmctl
|
||
brew: cmctl
|
||
cockpit:
|
||
_bin: cockpit
|
||
_desc: '[Cockpit](https://cockpit-project.org/) allows you to view many aspects of system performance and make configuration changes, though the task list may depend on the particular flavor of Linux that you are using.'
|
||
_docs: https://cockpit-project.org/documentation.html
|
||
_github: https://github.com/cockpit-project/cockpit
|
||
_home: https://cockpit-project.org/
|
||
_name: Cockpit
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo usermod -a -G libvirtdbus libvirt
|
||
_service:pacman: cockpit.socket
|
||
_systemd: cockpit
|
||
_systemd:pacman: cockpit.socket
|
||
ansible:linux: professormanhattan.cockpit
|
||
apt:
|
||
- 389-ds-base
|
||
- cockpit
|
||
- cockpit-389-ds
|
||
- cockpit-machines
|
||
- cockpit-networkmanager
|
||
- cockpit-packagekit
|
||
- cockpit-podman
|
||
- cockpit-storaged
|
||
- libvirt-dbus
|
||
dnf:centos:
|
||
- 389-ds-base
|
||
- cockpit
|
||
- cockpit-machines
|
||
- cockpit-networkmanager
|
||
- cockpit-packagekit
|
||
- cockpit-podman
|
||
- cockpit-storaged
|
||
- libvirt-dbus
|
||
dnf:fedora:
|
||
- 389-ds-base
|
||
- cockpit
|
||
- cockpit-389-ds
|
||
- cockpit-machines
|
||
- cockpit-networkmanager
|
||
- cockpit-packagekit
|
||
- cockpit-podman
|
||
- cockpit-storaged
|
||
- libvirt-dbus
|
||
pacman:
|
||
- 389-ds-base
|
||
- cockpit
|
||
- cockpit-389-ds
|
||
- cockpit-machines
|
||
- cockpit-networkmanager
|
||
- cockpit-packagekit
|
||
- cockpit-podman
|
||
- cockpit-storaged
|
||
- libvirt-dbus
|
||
cockpit-client:
|
||
_bin: cockpit-client
|
||
_github: https://github.com/cockpit-project/cockpit
|
||
_home: https://cockpit-project.org/
|
||
_name: Cockpit Desktop Client
|
||
flatpak: org.cockpit_project.CockpitClient
|
||
cocoapods:
|
||
_bin: null
|
||
_desc: '[CocoaPods](https://cocoapods.org/) is an application level dependency manager for Objective-C, Swift and any other languages that run on the Objective-C runtime, such as RubyMotion, that provides a standard format for managing external libraries.'
|
||
_docs: https://guides.cocoapods.org/using/getting-started.html
|
||
_github: https://github.com/CocoaPods/CocoaPods
|
||
_home: https://cocoapods.org/
|
||
_name: cocoapods
|
||
ansible:darwin: professormanhattan.cocoapods
|
||
brew:darwin: cocoapods
|
||
gem:darwin: cocoapods
|
||
cod:
|
||
_bin: cod
|
||
_desc: Cod is a completion daemon for bash/fish/zsh that automatically adds auto-completions when --help is used
|
||
_docs: https://github.com/dim-an/cod
|
||
_github: https://github.com/dim-an/cod
|
||
_home: https://github.com/dim-an/cod
|
||
_name: Cod
|
||
_todo: Check for brew install later on (5/14/2023)
|
||
go: github.com/dim-an/cod@master
|
||
codeclimate:
|
||
_bin: codeclimate
|
||
_github: https://github.com/codeclimate/codeclimate
|
||
_name: CodeClimate
|
||
_todo: Add check to ensure Docker is loaded / running
|
||
_usesDocker: true
|
||
brew: codeclimate/formulae/codeclimate
|
||
brew:darwin: codeclimate/formulae/codeclimate
|
||
script:linux: cd /tmp && curl -L https://github.com/codeclimate/codeclimate/archive/master.tar.gz | tar xvz && cd codeclimate-* && sudo make install
|
||
codeedit:
|
||
_app: CodeEdit.app
|
||
_bin: codeedit
|
||
_github: https://github.com/CodeEditApp/CodeEdit
|
||
_name: CodeEdit
|
||
_todo: TODO once this is out of alpha
|
||
cask: codeedit
|
||
coder:
|
||
_bin: coder
|
||
_desc: A tool that provisions remote development environments via Terraform
|
||
_docs: https://coder.com/docs/v1/latest
|
||
_github: https://github.com/coder/coder
|
||
_home: https://coder.com/
|
||
_name: Coder
|
||
brew: coder
|
||
cointop:
|
||
_bin: cointop
|
||
_desc: '[Cointop](https://github.com/miguelmota/cointop) is a fast and lightweight interactive terminal based UI application for tracking and monitoring cryptocurrency coin stats in real-time.'
|
||
_docs: https://docs.cointop.sh/
|
||
_github: https://github.com/cointop-sh/cointop
|
||
_home: https://cointop.sh/
|
||
_name: Cointop
|
||
ansible:darwin: professormanhattan.cointop
|
||
ansible:linux: professormanhattan.cointop
|
||
brew: cointop
|
||
port: cointop
|
||
commitizen:
|
||
_bin: cz
|
||
_desc: Commitizen is a tool designed for teams. Its main purpose is to define a standard way of committing rules and communicating it
|
||
_docs: https://commitizen-tools.github.io/commitizen/
|
||
_github: https://github.com/commitizen/cz-cli
|
||
_home: https://commitizen-tools.github.io/commitizen/
|
||
_name: commitizen
|
||
npm: commitizen
|
||
commitlint:
|
||
_bin: commitlint
|
||
_desc: Lint commit messages
|
||
_docs: https://commitlint.js.org/#/?id=documentation
|
||
_github: https://github.com/conventional-changelog/commitlint
|
||
_home: https://commitlint.js.org
|
||
_name: commitlint
|
||
npm: '@commitlint/cli'
|
||
common:
|
||
_bin: null
|
||
_github: false
|
||
_desc: 'For example, this role sets the timezone, sets the hostname, sets up the swap space, ensures auto-login is either disabled or enabled, and customizes GRUB (on Linux). It also ensures that specified groups are present on the system. On Windows, the role ensures all the available updates are installed, ensures [Scoop](https://scoop.sh/) is installed, and ensures common dependencies like [Bandizip](https://en.bandisoft.com/bandizip/) (a compressed-file manager) are installed.'
|
||
_name: Common
|
||
ansible: professormanhattan.common
|
||
composer:
|
||
_bin: composer
|
||
_desc: '[Composer](https://getcomposer.org/) is an application-level package manager for the PHP programming language that provides a standard format for managing dependencies of PHP software and required libraries. It was developed by Nils Adermann and Jordi Boggiano, who continue to manage the project.'
|
||
_docs: https://getcomposer.org/doc/
|
||
_github: https://github.com/composer/composer
|
||
_home: https://getcomposer.org/
|
||
_name: Composer
|
||
ansible: professormanhattan.composer
|
||
brew: composer
|
||
choco: composer
|
||
pacman: composer
|
||
scoop: composer
|
||
script:darwin: cd ~ && curl -sS https://getcomposer.org/installer | php && sudo mv composer.phar /usr/local/bin/composer && sudo chmod +x /usr/local/bin/composer
|
||
script:linux: cd ~ && curl -sS https://getcomposer.org/installer | php && sudo mv composer.phar /usr/local/bin/composer && sudo chmod +x /usr/local/bin/composer
|
||
confd:
|
||
_bin: confd
|
||
_desc: Manage local application configuration files using templates and data from etcd or consul
|
||
_github: https://github.com/kelseyhightower/confd
|
||
_name: confd
|
||
brew: confd
|
||
choco: confd
|
||
github: github.com/kelseyhightower/confd
|
||
yay: confd
|
||
connections:
|
||
_bin: connections
|
||
_github: false
|
||
_gitlab: https://gitlab.gnome.org/GNOME/connections
|
||
flatpak: org.gnome.Connections
|
||
consul-cli:
|
||
_bin: consul
|
||
_desc: '[Consul](https://www.consul.io/) uses service identities and traditional networking practices to help organizations securely connect applications running in any environment'
|
||
_docs: https://developer.hashicorp.com/consul/docs
|
||
_github: https://www.github.com/hashicorp/consul
|
||
_home: https://www.consul.io/
|
||
_name: Consul
|
||
_service: consul
|
||
apt: consul
|
||
brew: consul
|
||
pkg: consul
|
||
yay: consul-bin
|
||
consul-template:
|
||
_bin: consul-template
|
||
_desc: '[Consul-Template](https://github.com/hashicorp/consul-template) provides a convenient way to populate values from [Consul](https://www.consul.io/) into the file system using the consul-template daemon. It was created by [HashiCorp](https://www.hashicorp.com/) (the creators of Consul).'
|
||
_docs: https://learn.hashicorp.com/tutorials/consul/consul-template
|
||
_github: https://github.com/hashicorp/consul-template
|
||
_home: https://www.hashicorp.com/
|
||
_name: Consul Template
|
||
ansible: professormanhattan.consultemplate
|
||
brew: consul-template
|
||
choco: consul-template
|
||
scoop: main/consul
|
||
container-structure-test:
|
||
_github: https://github.com/GoogleContainerTools/container-structure-test
|
||
_bin: container-structure-test
|
||
_desc: The Container Structure Tests provide a powerful framework to validate the structure of a container image. These tests can be used to check the output of commands in an image, as well as verify metadata and contents of the filesystem
|
||
_name: Container Structure Tests
|
||
_post:binary:linux: |
|
||
#!/usr/bin/env bash
|
||
echo "TODO"
|
||
binary:linux: https://storage.googleapis.com/container-structure-test/latest/container-structure-test-linux-amd64
|
||
brew: container-structure-test
|
||
yay: container-structure-test
|
||
cookiecutter:
|
||
_bin: cookiecutter
|
||
_desc: A cross-platform command-line utility that creates projects from cookiecutters (project templates)
|
||
_docs: https://cookiecutter.readthedocs.io/
|
||
_github: https://github.com/cookiecutter/cookiecutter
|
||
_name: cookiecutter
|
||
brew: cookiecutter
|
||
pipx: cookiecutter
|
||
cordova:
|
||
_bin: cordova
|
||
_desc: >-
|
||
[Apache Cordova](https://cordova.apache.org/) is a tool to create cross-platform apps from standard web technologies (HTML, CSS, and JavaScript). Its primary purpose is to provide a bridge for native device API access and to bundle for distribution
|
||
_docs: https://cordova.apache.org/docs/en/latest/
|
||
_github: https://github.com/apache/cordova
|
||
_home: https://cordova.apache.org/
|
||
_name: Apache Cordova
|
||
npm: cordova
|
||
coreutils:
|
||
_bin:
|
||
- cat
|
||
- ls
|
||
- rm
|
||
_bin:darwin: gchown
|
||
_github: false
|
||
apt: coreutils
|
||
brew: coreutils
|
||
dnf: coreutils
|
||
pacman: coreutils
|
||
croc:
|
||
_bin: croc
|
||
_desc: Easily and securely send things from one computer to another
|
||
_github: https://github.com/schollz/croc
|
||
_name: croc
|
||
brew: croc
|
||
choco: croc
|
||
github: github.com/schollz/croc
|
||
go: github.com/schollz/croc/v9@latest
|
||
pacman: croc
|
||
pkg: croc
|
||
scoop: croc
|
||
crunch:
|
||
_app: Crunch.app
|
||
_bin: crunch
|
||
_desc: The crunch command line executable is a *nix executable that supports parallel PNG image optimization with local (off of the system PATH) installs of the pngquant and zopflipng project dependencies.
|
||
_docs: https://github.com/chrissimpkins/Crunch
|
||
_github: https://github.com/chrissimpkins/Crunch
|
||
_home: https://github.com/chrissimpkins/Crunch
|
||
_name: Crunch
|
||
cask: crunch
|
||
script: cd /tmp && rm -rf Crunch && git clone https://github.com/chrissimpkins/Crunch.git && make build-dependencies && make install-executable && cd /tmp && rm -rf Crunch && rm -rf ~/zopfli && rm -rf ~/pngquant && echo "TODO WARNING - The ~/zopfli and ~/pngquant directories were deleted and may be required (but were removed due to HOME directory pollution)"
|
||
crunch-app:
|
||
_app: Crunch.app
|
||
_bin: null
|
||
_desc: The macOS companion app for the crunch CLI tool that compresses PNG images.
|
||
_docs: https://github.com/chrissimpkins/Crunch/blob/master/docs/MACOSGUI.md
|
||
_github: https://github.com/chrissimpkins/Crunch
|
||
_home: https://github.com/chrissimpkins/Crunch
|
||
_name: Crunch macOS App
|
||
cask: crunch
|
||
cryptomator:
|
||
_app: Cryptomator.app
|
||
_github: https://github.com/cryptomator/cryptomator
|
||
_bin: cryptomator
|
||
cask: cryptomator
|
||
choco: cryptomator
|
||
flatpak: org.cryptomator.Cryptomator
|
||
csvkit:
|
||
_bin: csvcut
|
||
_github: https://github.com/wireservice/csvkit
|
||
brew: csvkit
|
||
ctop:
|
||
_bin: ctop
|
||
_desc: Top-like interface for container metrics
|
||
_github: https://github.com/bcicen/ctop
|
||
_name: ctop
|
||
brew: ctop
|
||
github: github.com/bcicen/ctop
|
||
yay: ctop-bin
|
||
cumulus:
|
||
_app: Cumulus.app
|
||
_bin: null
|
||
_desc: A SoundCloud player that lives in the menubar
|
||
_github: https://github.com/gillesdemey/Cumulus
|
||
_name: Cumulus
|
||
cask: cumulus
|
||
github: github.com/gillesdemey/Cumulus
|
||
cups:
|
||
_bin: cupsctl
|
||
_desc: '[CUPS](https://www.cups.org/) is a modular printing system for Unix-like computer operating systems which allows a computer to act as a print server. A computer running CUPS is a host that can accept print jobs from client computers, process them, and send them to the appropriate printer.'
|
||
_github: https://github.com/apple/cups
|
||
_name: CUPS
|
||
_ports:
|
||
- port: 631
|
||
proto: tcp
|
||
_systemd: smbd
|
||
ansible: professormanhattan.cups
|
||
apt:
|
||
- avahi-daemon
|
||
- cups
|
||
brew: cups
|
||
dnf: cups
|
||
pacman:
|
||
- avahi-daemon
|
||
- cups
|
||
curator:
|
||
_bin: curator
|
||
_desc: Elasticsearch Curator helps you curate, or manage, your Elasticsearch indices and snapshots
|
||
_docs: https://www.elastic.co/guide/en/elasticsearch/client/curator
|
||
_github: https://github.com/elastic/curator
|
||
_home: https://www.elastic.co/guide/en/elasticsearch/client/curator
|
||
_name: curator
|
||
pipx: elasticsearch-curator
|
||
curl:
|
||
_bin: curl
|
||
_desc: cURL is a computer software project providing a library (libcurl) and command-line tool (curl) for transferring data using various network protocols.
|
||
_docs: https://curl.se/docs/
|
||
_github: https://github.com/curl/curl
|
||
_home: https://curl.se/
|
||
_name: cURL
|
||
apk: curl
|
||
apt: curl
|
||
brew: curl
|
||
choco: curl
|
||
dnf: curl
|
||
pacman: curl
|
||
pkg: curl
|
||
scoop: curl
|
||
xbps: curl
|
||
zypper: curl
|
||
curlie:
|
||
_bin: curlie
|
||
_desc: Curlie is a frontend to curl that adds the ease of use of httpie, without compromising on features and performance.
|
||
_docs: https://curlie.io/
|
||
_github: https://github.com/rs/curlie
|
||
_home: https://curlie.io/
|
||
_name: Curlie
|
||
brew: curlie
|
||
go: github.com/rs/curlie@latest
|
||
pkg: curlie
|
||
port: curlie
|
||
scoop: curlie
|
||
cutter:
|
||
_app: Cutter.app
|
||
_github: https://github.com/rizinorg/cutter
|
||
_bin: cutter
|
||
cask: cutter
|
||
choco: cutter
|
||
flatpak: re.rizin.cutter
|
||
d2vm:
|
||
_bin: d2vm
|
||
_github: https://github.com/linka-cloud/d2vm
|
||
_name: Docker 2 VM
|
||
brew: linka-cloud/tap/d2vm
|
||
dagu:
|
||
_bin: dagu
|
||
_github: https://github.com/dagu-dev/dagu
|
||
_name: Dagu
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo mkdir -p /var/log/dagu
|
||
brew: yohamta/tap/dagu
|
||
dasel:
|
||
_bin: dasel
|
||
_desc: Select, put and delete data from JSON, TOML, YAML, XML and CSV files with a single tool
|
||
_github: https://github.com/TomWright/dasel
|
||
_name: dasel
|
||
brew: dasel
|
||
github: github.com/TomWright/dasel
|
||
go: github.com/tomwright/dasel/cmd/dasel@master
|
||
dat:
|
||
_bin: dat
|
||
_desc: Peer-to-peer sharing & live syncronization of files via command line
|
||
_github: https://github.com/datproject/dat
|
||
_name: dat
|
||
github: github.com/dat-ecosystem-archive/dat
|
||
npm: dat@next
|
||
dat-desktop:
|
||
_app: Dat Desktop.app
|
||
_bin: null
|
||
_desc: Peer to peer data syncronization
|
||
_github: https://github.com/datproject/dat-desktop
|
||
_name: Dat Desktop
|
||
appimage: dat-ecosystem-archive/dat-desktop
|
||
cask: dat
|
||
exe: https://github.com/dat-ecosystem-archive/dat-desktop/releases/download/v3.0.1/Dat-Desktop-Setup-3.0.1.exe
|
||
dconf-editor:
|
||
_bin: dconf-editor
|
||
_github: https://github.com/GNOME/dconf-editor/tree/master
|
||
_gitlab: https://gitlab.gnome.org/GNOME/dconf-editor
|
||
flatpak: ca.desrt.dconf-editor
|
||
debloat:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This repository is the home of an Ansible role that Debloats Windows
|
||
_name: Debloat Windows
|
||
ansible: professormanhattan.debloat
|
||
debsecan:
|
||
_bin: debsecan-by-type
|
||
_github: false
|
||
_desc: debsecan analyzes the list of installed packages on the current host and reports vulnerabilities found on the system.
|
||
_gitlab: https://gitlab.com/fweimer/debsecan
|
||
_home: https://wiki.debian.org/DebianSecurity/debsecan
|
||
_name: Debian Security Analyzer
|
||
apt: debsecan
|
||
defaultbrowser:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role performs the necessary logic to set the default browser on nearly any platform.
|
||
_name: Default Browser Setter
|
||
ansible: professormanhattan.defaultbrowser
|
||
deja-dup:
|
||
_bin: dejadup
|
||
_home: https://apps.gnome.org/DejaDup/
|
||
_gitlab: https://gitlab.gnome.org/World/deja-dup
|
||
_github: false
|
||
flatpak: org.gnome.DejaDup
|
||
delta:
|
||
_bin: delta
|
||
_desc: '[delta](https://github.com/dandavison/delta) is a viewer for git and diff output'
|
||
_docs: https://dandavison.github.io/delta/
|
||
_github: https://github.com/dandavison/delta
|
||
_home: https://github.com/dandavison/delta
|
||
_name: Delta
|
||
ansible: professormanhattan.delta
|
||
brew: git-delta
|
||
cargo: git-delta
|
||
choco: delta
|
||
dnf:fedora: git-delta
|
||
pacman: git-delta
|
||
pkg: git-delta
|
||
scoop: delta
|
||
delve:
|
||
_bin: dlv
|
||
_desc: Delve is a debugger for the Go programming language.
|
||
_docs: https://github.com/go-delve/delve/tree/master/Documentation
|
||
_github: https://github.com/go-delve/delve
|
||
_home: https://github.com/go-delve/delve
|
||
_name: Delve
|
||
brew: delve
|
||
go: github.com/go-delve/delve/cmd/dlv@latest
|
||
deno:
|
||
_bin: deno
|
||
_desc: '[Deno](https://deno.land/) is a modern runtime for JavaScript and TypeScript. It is advertised as a simple runtime that uses V8 and Rust. It is boasted as secure-by-default because there is no file, network, or environment access unless explicitly enabled. Deno compiles apps into single executables. An app made with Deno generally specifies its dependencies as URLs mainly hosted in the [Deno standard module repository](https://deno.land/std).'
|
||
_docs: https://deno.land/manual
|
||
_github: https://github.com/denoland/deno
|
||
_home: https://deno.land/
|
||
_name: Deno
|
||
ansible: professormanhattan.deno
|
||
brew: deno
|
||
cargo: deno
|
||
choco: deno
|
||
nix: deno
|
||
scoop: deno
|
||
desed:
|
||
_bin: desed
|
||
_desc: Debugger for sed used to demystify and debug the sed scripts, from comfort of terminal
|
||
_docs: https://github.com/SoptikHa2/desed#controls
|
||
_github: https://github.com/SoptikHa2/desed
|
||
_home: https://github.com/SoptikHa2/desed
|
||
_name: desed
|
||
cargo: desed
|
||
dnf:fedora: desed
|
||
github: github.com/SoptikHa2/desed
|
||
pkg: desed
|
||
xbps-freebsd: desed
|
||
desk:
|
||
_bin: desk
|
||
_github: https://github.com/jamesob/desk
|
||
_name: Desk
|
||
brew: desk
|
||
desktop:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role is essentially the place where all desktop-specific tasks that are substantial enough for their own role are placed.
|
||
_name: Desktop
|
||
ansible: professormanhattan.desktop
|
||
deta:
|
||
_bin: deta
|
||
_desc: Command line interface for managing Deta micros and deployments
|
||
_docs: https://docs.deta.sh/docs/cli/install
|
||
_github: https://github.com/deta/deta-cli
|
||
_home: https://www.deta.sh/
|
||
_name: deta
|
||
github: github.com/deta/deta-cli
|
||
script:darwin: curl -fsSL https://get.deta.dev/cli.sh | sh
|
||
script:linux: curl -fsSL https://get.deta.dev/cli.sh | sh
|
||
script:windows: iwr https://get.deta.dev/cli.ps1 -useb | iex
|
||
devbox:
|
||
_bin: devbox
|
||
_github: https://github.com/jetpack-io/devbox
|
||
_todo: Revisit because install via script would require expect since piping y to the installer is not working
|
||
# nix-env: nixpkgs.devbox
|
||
# script: curl -fsSL https://get.jetpack.io/devbox | bash
|
||
devpod:
|
||
_bin: devpod
|
||
_github: https://github.com/loft-sh/devpod
|
||
_name: DevPod
|
||
cask: devpod
|
||
devspace:
|
||
_bin: devspace
|
||
_github: https://github.com/devspace-sh/devspace
|
||
_name: DevSpace
|
||
brew: devspace
|
||
npm: devspace
|
||
scoop: devspace
|
||
devtoys:
|
||
_app: DevToys.app
|
||
_bin: devtoys
|
||
_github: https://github.com/ObuchiYuki/DevToysMac
|
||
cask: devtoys
|
||
devtoys-windows:
|
||
_bin: devtoys
|
||
_github: https://github.com/veler/DevToys
|
||
_name: Windows DevToys
|
||
choco: devtoys
|
||
winget: devtoys
|
||
dframe:
|
||
_bin: dframe
|
||
_desc: Put device frames around your mobile/web/progressive app screenshots
|
||
_github: https://github.com/c0bra/deviceframe
|
||
npm: deviceframe
|
||
dialect:
|
||
_bin: dialect
|
||
_github: https://github.com/dialect-app/dialect/
|
||
apt: dialect
|
||
dnf: dialect
|
||
flatpak: app.drey.Dialect
|
||
dialog:
|
||
_bin: dialog
|
||
_github: false
|
||
_home: https://invisible-island.net/dialog/
|
||
_name: Dialog
|
||
apt: dialog
|
||
brew: dialog
|
||
choco: dialog
|
||
dnf: dialog
|
||
pacman: dialog
|
||
difftastic:
|
||
_bin: difft
|
||
_desc: Difftastic is a structural diff tool that understands syntax.
|
||
_docs: https://difftastic.wilfred.me.uk/git.html
|
||
_github: https://github.com/Wilfred/difftastic
|
||
_home: https://difftastic.wilfred.me.uk/
|
||
_name: Difftastic
|
||
brew: difftastic
|
||
cargo: difftastic
|
||
direnv:
|
||
_bin: direnv
|
||
_desc: '[direnv](https://direnv.net/) is an extension for your shell. It augments existing shells with a new feature that can load and unload environment variables depending on the current directory.'
|
||
_docs: https://direnv.net/
|
||
_github: https://github.com/direnv/direnv
|
||
_home: https://direnv.net/
|
||
_name: direnv
|
||
ansible: professormanhattan.direnv
|
||
apt: direnv
|
||
brew: direnv
|
||
github: github.com/direnv/direnv
|
||
discord:
|
||
_github: false
|
||
_app: Discord.app
|
||
_bin: discord
|
||
_name: Discord
|
||
cask: discord
|
||
choco: discord
|
||
flatpak: com.discordapp.Discord
|
||
distrobox:
|
||
_bin: distrobox
|
||
_github: https://github.com/89luca89/distrobox
|
||
_name: Distrobox
|
||
apk: distrobox
|
||
apt: distrobox
|
||
dnf: distrobox
|
||
pacman: distrobox
|
||
dive:
|
||
_bin: dive
|
||
_desc: '[dive](https://github.com/wagoodman/dive) is a tool for exploring a docker image, layer contents, and discovering ways to shrink the size of the Docker/OCI image.'
|
||
_description: A tool for exploring each layer in a docker image
|
||
_github: https://github.com/wagoodman/dive
|
||
_home: https://github.com/wagoodman/dive
|
||
_name: dive
|
||
ansible: professormanhattan.dive
|
||
brew: dive
|
||
github: github.com/wagoodman/dive
|
||
go: github.com/wagoodman/dive@latest
|
||
yay: dive
|
||
dns:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role ensures that DNS requests are encrypted if you supply it the appropriate configuration. It uses systemd on Linux. On macOS/Windows, it installs and configures [Stubby](https://github.com/getdnsapi/stubby).
|
||
_name: DNS
|
||
ansible: professormanhattan.dns
|
||
dnsmasq:
|
||
_bin: dnsmasq
|
||
_desc: '[Dnsmasq](https://wiki.debian.org/dnsmasq) is free software providing Domain Name System caching, a Dynamic Host Configuration Protocol server, router advertisement and network boot features, intended for small computer networks.'
|
||
_docs: https://thekelleys.org.uk/dnsmasq/docs/dnsmasq-man.html
|
||
_github: https://github.com/imp/dnsmasq
|
||
_name: dnsmasq
|
||
_service: dnsmasq
|
||
ansible: professormanhattan.dnsmasq
|
||
apt: dnsmasq
|
||
brew: dnsmasq
|
||
dnf: dnsmasq
|
||
pacman: dnsmasq
|
||
port: dnsmasq
|
||
docker:
|
||
_github: https://github.com/microsoft/docker
|
||
_bin: docker
|
||
_deps:
|
||
- docker-images
|
||
_name: Docker CLI
|
||
apt:
|
||
- containerd.io
|
||
- docker-ce
|
||
- docker-ce-cli
|
||
- docker-compose-plugin
|
||
dnf:
|
||
- containerd.io
|
||
- docker-ce
|
||
- docker-ce-cli
|
||
- docker-compose-plugin
|
||
pacman:
|
||
- containerd.io
|
||
- docker-ce
|
||
- docker-ce-cli
|
||
- docker-compose-plugin
|
||
script:darwin: echo "Docker CLI installed by Docker Desktop on macOS"
|
||
zypper:
|
||
- containerd.io
|
||
- docker-ce
|
||
- docker-ce-cli
|
||
- docker-compose-plugin
|
||
docker-credential-helper:
|
||
_bin:darwin: docker-credential-osxkeychain
|
||
_bin:linux: docker-credential-secretservice
|
||
_bin:windows: docker-credential-wincred
|
||
_desc: Programs to keep Docker login credentials safe by storing in platform keystores
|
||
_docs: https://github.com/docker/docker-credential-helpers
|
||
_github: https://github.com/docker/docker-credential-helpers
|
||
_home: https://github.com/docker/docker-credential-helpers
|
||
_name: Docker Credential Helper
|
||
_preload: true
|
||
brew: docker-credential-helper
|
||
docker-desktop:
|
||
_app: Docker.app
|
||
_desc: '[Docker](https://www.docker.com/) is a set of platform-as-a-service products that use OS-level virtualization to deliver software in packages called containers. Containers are isolated from one another and bundle their own software, libraries and configuration files; they can communicate with each other through well-defined channels. [Docker Desktop](https://www.docker.com/products/docker-desktop/) adds a sleek UI for Docker and makes it easier to manage Docker on macOS and Windows.'
|
||
_docs: https://docs.docker.com/
|
||
_github: https://github.com/docker/compose
|
||
_home: https://www.docker.com/
|
||
_name: Docker Desktop
|
||
_post: "#!/usr/bin/env bash\n# @file DockerHub Login\n# @brief Logs into DockerHub for Docker Desktop\n# @description\n# This script logs into DockerHub so that Docker Desktop is pre-authenticated. This\n# functionality requires that the `DOCKERHUB_USER` be passed in as an environment variable (or \n# directly editted in the `~/.config/chezmoi/chezmoi.yaml` file) and that the `DOCKERHUB_TOKEN`\n# be passed in as a secret (either via the encrypted secret method or passed in as an environment\n# variable).\n\n### Login to DockerHub\nif command -v docker > /dev/null; then\n DOCKERHUB_TOKEN=\"{{ if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"DOCKERHUB_TOKEN\")) }}{{- includeTemplate \"secrets/DOCKERHUB_TOKEN\" | decrypt | trim -}}{{ else }}{{- env \"DOCKERHUB_TOKEN\" -}}{{ end }}\"\n DOCKERHUB_USER=\"{{ .user.docker.username }}\"\n if [ -d \"/Applications/Docker.app\" ] || [ -d \"$HOME/Applications/Docker.app\" ]; then\n logg info 'Ensuring Docker.app is open' && open --background -a Docker --args --accept-license --unattended\n fi\n logg info 'Headlessly authenticating with DockerHub registry' && echo \"$DOCKERHUB_TOKEN\" | docker login -u \"$DOCKERHUB_USER\" --password-stdin > /dev/null && logg success 'Successfully authenticated with DockerHub registry'\nfi\n\n### Symlink on macOS\nif [ -f \"$HOME/Library/Containers/com.docker.docker/Data/docker.raw.sock\" ]; then\n logg info 'Symlinking /var/run/docker.sock to macOS Library location' && sudo ln -s \"$HOME/Library/Containers/com.docker.docker/Data/docker.raw.sock\" /var/run/docker.sock\nfi\n"
|
||
apt: https://desktop.docker.com/linux/main/amd64/docker-desktop-4.16.2-amd64.deb
|
||
cask: docker
|
||
choco: docker-desktop
|
||
dnf: https://desktop.docker.com/linux/main/amd64/docker-desktop-4.16.2-x86_64.rpm
|
||
pacman: https://desktop.docker.com/linux/main/amd64/docker-desktop-4.16.2-x86_64.pkg.tar.zst
|
||
docker-images:
|
||
_github: false
|
||
_desc: This entry is used to trigger a post-installation docker image pre-load. See the `docker-images` entry in `.chezmoidata.yaml`.
|
||
script: echo "Enabling docker-images pre-load"
|
||
docker-langserver:
|
||
_bin: docker-langserver
|
||
_desc: A Docker language server
|
||
_docs: https://github.com/rcjsuen/dockerfile-language-server-nodejs
|
||
_github: https://github.com/rcjsuen/dockerfile-language-server-nodejs
|
||
_home: https://github.com/rcjsuen/dockerfile-language-server-nodejs
|
||
_name: Docker Language Server
|
||
npm: dockerfile-language-server-nodejs
|
||
docker-plugins:
|
||
_github: false
|
||
_desc: This entry is used to trigger a post-installation Docker plugin installation. See `docker-plugins` entry in `.chezmoidata.yaml`.
|
||
docker-pushrm:
|
||
_bin: docker-pushrm
|
||
_github: https://github.com/christian-korneck/docker-pushrm
|
||
_name: Docker PushRM
|
||
script: |
|
||
if [ ! -f "${XDG_CONFIG_HOME:-$HOME/.config}/docker/cli-plugins/docker-pushrm" ]; then
|
||
logg info 'Acquiring release information for Docker push-rm'
|
||
RELEASE_TAG="$(curl -sSL https://api.github.com/repos/christian-korneck/docker-pushrm/releases/latest | jq -r '.tag_name')"
|
||
mkdir -p "${XDG_CONFIG_HOME:-$HOME/.config}/docker/cli-plugins"
|
||
logg info 'Downloading Docker push-rm' && curl https://github.com/christian-korneck/docker-pushrm/releases/download/$RELEASE_TAG/docker-pushrm_darwin_amd64 -o "${XDG_CONFIG_HOME:-$HOME/.config}/docker/cli-plugins/docker-pushrm"
|
||
chmod +x "${XDG_CONFIG_HOME:-$HOME/.config}/docker/cli-plugins/docker-pushrm"
|
||
logg success 'Added Docker push-rm'
|
||
else
|
||
logg info 'Docker push-rm already added'
|
||
fi
|
||
docker-slim:
|
||
_bin: slim
|
||
_desc: "[DockerSlim](https://dockersl.im/) will optimize and secure your containers by understanding your application and what it needs using various analysis techniques. It will throw away what you don't need, reducing the attack surface of your container. What if you need some of those extra things to debug your container? You can use dedicated debugging side-car containers for that."
|
||
_docs: https://github.com/docker-slim/docker-slim#basic-usage-info
|
||
_github: https://github.com/docker-slim/docker-slim
|
||
_home: https://dockersl.im/
|
||
_name: Docker Slim
|
||
brew: docker-slim
|
||
dnf:fedora: golang-github-docker-slim
|
||
github: github.com/docker-slim/docker-slim
|
||
yay: docker-slim
|
||
dockfmt:
|
||
_bin: dockfmt
|
||
_github: https://github.com/jessfraz/dockfmt
|
||
_name: dockfmt
|
||
go: github.com/jessfraz/dockfmt@latest
|
||
dockle:
|
||
_bin: dockle
|
||
_desc: Container Image Linter for Security, Helping build the Best-Practice Docker Image, Easy to start
|
||
_github: https://github.com/goodwithtech/dockle
|
||
_name: dockle
|
||
brew: goodwithtech/r/dockle
|
||
github: github.com/goodwithtech/dockle
|
||
yay: dockle-bin
|
||
dockly:
|
||
_bin: dockly
|
||
_github: https://github.com/lirantal/dockly
|
||
_name: Dockly
|
||
npm: dockly
|
||
dockutil:
|
||
_bin: dockutil
|
||
_github: https://github.com/kcrawford/dockutil
|
||
_name: DockUtil
|
||
brew:darwin: dockutil
|
||
doctl:
|
||
_bin: doctl
|
||
_desc: The official command line interface for the DigitalOcean API
|
||
_github: https://github.com/digitalocean/doctl
|
||
_name: doctl
|
||
brew: doctl
|
||
github: github.com/digitalocean/doctl
|
||
pacman: doctl
|
||
pkg: doctl
|
||
snap: doctl
|
||
dog:
|
||
_bin: dog
|
||
_desc: A command-line DNS client
|
||
_github: https://github.com/ogham/dog
|
||
_name: dog
|
||
brew: dog
|
||
github: github.com/ogham/dog
|
||
pacman: dog
|
||
pkg: dog
|
||
doitlive:
|
||
_bin: doitlive
|
||
_github: https://github.com/sloria/doitlive
|
||
_name: Do It Live!
|
||
brew: doitlive
|
||
pipx: doitlive
|
||
dokany:
|
||
_bin: dokany
|
||
_github: https://github.com/dokan-dev/dokany
|
||
_name: Dokany
|
||
_note: Required for CephFS on Windows
|
||
choco: dokany
|
||
dotenv-linter:
|
||
_bin: dotenv-linter
|
||
_desc: '[Dotenv Linter](https://dotenv-linter.github.io) is a lightning-fast linter for .env files. Written in Rust'
|
||
_github: https://github.com/dotenv-linter/dotenv-linter
|
||
_home: https://dotenv-linter.github.io/
|
||
_name: Dotenv Linter
|
||
brew: dotenv-linter
|
||
cargo: dotenv-linter
|
||
scoop: dotenv-linter
|
||
yay: dotenv-linter
|
||
dotenv-vault:
|
||
_bin: dotenv-vault
|
||
_name: Dotenv Vault
|
||
_github: https://github.com/dotenv-org/dotenv-vault
|
||
brew: dotenv-org/brew/dotenv-vault
|
||
npm: dotenv-vault
|
||
dotnet:
|
||
_bin: dotnet
|
||
_desc: "[.Net](https://dotnet.microsoft.com/) lets you create beautiful apps and scalable cloud services, faster and easier with the free, open-source platform that's loved by developers and trusted by organizations"
|
||
_docs: https://learn.microsoft.com/en-us/dotnet/
|
||
_github: https://github.com/dotnet
|
||
_home: https://dotnet.microsoft.com/
|
||
_name: .Net
|
||
brew: dotnet
|
||
choco: dotnet
|
||
yay: dotnet-sdk-bin
|
||
dprint:
|
||
_bin: dprint
|
||
_desc: '[dprint](https://dprint.dev/) is a pluggable and configurable code formatting platform written in Rust.'
|
||
_docs: https://dprint.dev/
|
||
_github: https://github.com/dprint
|
||
_home: https://dprint.dev/
|
||
_name: DPrint
|
||
brew: dprint
|
||
cargo: dprint
|
||
npm: dprint
|
||
scoop: dprint
|
||
script:darwin: curl -fsSL https://dprint.dev/install.sh | sh
|
||
script:linux: curl -fsSL https://dprint.dev/install.sh | sh
|
||
script:windows: iwr https://dprint.dev/install.ps1 -useb | iex
|
||
drawing:
|
||
_bin: drawing
|
||
_github: https://github.com/maoschanz/drawing
|
||
flatpak: com.github.maoschanz.drawing
|
||
drawio:
|
||
_app: draw.io.app
|
||
_bin: null
|
||
_desc: Desktop version of the popular diagrams.net diagramming software
|
||
_docs: https://www.drawio.com/doc/
|
||
_github: https://github.com/jgraph/drawio-desktop
|
||
_home: https://www.diagrams.net/
|
||
_name: DrawIO Desktop
|
||
appimage: draw.io
|
||
cask: drawio
|
||
choco: drawio
|
||
drone-cli:
|
||
_bin: drone
|
||
_desc: The Drone command line tools are used to interact with the Drone from the command line, and provide important utilities for managing users and repository settings
|
||
_docs: https://docs.drone.io/cli/install/
|
||
_github: https://github.com/harness/drone-cli
|
||
_home: https://www.drone.io/
|
||
_name: Drone CLI
|
||
brew: drone/drone/drone
|
||
github: github.com/harness/drone-cli
|
||
scoop: drone
|
||
dua:
|
||
_bin: dua
|
||
_github: https://github.com/Byron/dua-cli
|
||
brew: dua-cli
|
||
cargo: dua-cli
|
||
dnf:fedora: dua-cli
|
||
pacman: dua-cli
|
||
pkgin: dua-cli
|
||
port: dua-cli
|
||
scoop: dua
|
||
xbps: dua-cli
|
||
duf:
|
||
_bin: duf
|
||
_desc: "[duf](https://github.com/muesli/duf) is a Disk Usage/Free Utility - a better 'df' alternative. It displays a chart within your terminal that gives you an overview of hard-drive usage statistics."
|
||
_docs: https://github.com/muesli/duf#usage
|
||
_github: https://github.com/muesli/duf
|
||
_home: https://github.com/muesli/duf
|
||
_name: duf
|
||
ansible: professormanhattan.duf
|
||
brew: duf
|
||
choco: duf
|
||
github: github.com/muesli/duf
|
||
pacman: duf
|
||
pkg: duf
|
||
scoop: duf
|
||
dust:
|
||
_bin: dust
|
||
_desc: A more intuitive version of du in rust
|
||
_docs: https://github.com/bootandy/dust#usage
|
||
_github: https://github.com/bootandy/dust
|
||
_home: https://github.com/bootandy/dust
|
||
_name: dust
|
||
apk: dust
|
||
brew:darwin: dust
|
||
brew:linux: tgotwig/linux-dust/dust
|
||
cargo: du-dust
|
||
github: github.com/bootandy/dust
|
||
pacman: dust
|
||
duti:
|
||
_bin: duti
|
||
_github: https://github.com/moretension/duti
|
||
_name: Duti
|
||
brew:darwin: duti
|
||
eartrumpet:
|
||
_bin: null
|
||
_desc: Advanced, sleek volume controls for Windows
|
||
_docs: https://github.com/File-New-Project/EarTrumpet
|
||
_github: https://github.com/File-New-Project/EarTrumpet
|
||
_home: https://eartrumpet.app/
|
||
_name: EarTrumpet
|
||
choco: eartrumpet
|
||
winget: File-New-Project.EarTrumpet
|
||
easyengine:
|
||
_bin: ee
|
||
_desc: "[EasyEngine](https://easyengine.io/) is a command-line control panel for Nginx to manage WordPress sites running on Nginx, PHP, MySQL, and Let's Encrypt."
|
||
_docs: https://easyengine.io/handbook/
|
||
_github: https://github.com/EasyEngine/easyengine
|
||
_home: https://easyengine.io/
|
||
_name: EasyEngine
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
if [ -n "$CLOUDFLARE_EMAIL" ] && [ -n "$CLOUDFLARE_API_KEY" ]; then
|
||
ee config set le-mail "$CLOUDFLARE_EMAIL"
|
||
ee config set cloudflare-api-key "$CLOUDFLARE_API_KEY"
|
||
fi
|
||
brew: easyengine
|
||
script:linux: wget -qO ee rt.cx/ee4 && sudo bash ee
|
||
edex-ui:
|
||
_app: eDEX-UI.app
|
||
_bin: edex-ui
|
||
_desc: A cross-platform, customizable science fiction terminal emulator with advanced monitoring & touchscreen support.
|
||
_docs: https://github.com/GitSquared/edex-ui
|
||
_github: https://github.com/GitSquared/edex-ui
|
||
_home: https://github.com/GitSquared/edex-ui
|
||
_name: EDEX UI
|
||
appimage: edex-ui
|
||
cask: edex-ui
|
||
port: edex-ui
|
||
editly:
|
||
_bin: editly
|
||
_desc: Editly is a tool and framework for declarative NLE (non-linear video editing) using Node.js and ffmpeg. Editly allows you to easily and programmatically create a video from a set of clips, images, audio and titles, with smooth transitions and music overlaid.
|
||
_docs: https://github.com/mifi/editly#usage-command-line-video-editor
|
||
_github: https://github.com/mifi/editly
|
||
_home: https://github.com/mifi/editly
|
||
_name: Editly
|
||
npm: editly
|
||
eget:
|
||
_bin: eget
|
||
_github: https://github.com/zyedidia/eget
|
||
_name: eget
|
||
brew: eget
|
||
choco: eget
|
||
go: github.com/zyedidia/eget@latest
|
||
ejs:
|
||
_bin: ejs
|
||
_github: https://github.com/mde/ejs
|
||
_name: EJS
|
||
npm: ejs
|
||
electron:
|
||
_app: Electron.app
|
||
_bin: electron
|
||
_desc: '[Electron](https://www.electronjs.org/) allows you to build cross-platform desktop apps with JavaScript, HTML, and CSS'
|
||
_docs: https://www.electronjs.org/docs/latest/
|
||
_github: https://github.com/electron/electron
|
||
_home: https://www.electronjs.org/
|
||
_name: Electron
|
||
cask: electron
|
||
choco: electron
|
||
npm: electron
|
||
element:
|
||
_app: Element.app
|
||
_bin: element
|
||
_github: https://github.com/vector-im/element-web
|
||
_name: Element
|
||
cask: element
|
||
choco: element-desktop
|
||
flatpak: im.riot.Riot
|
||
emma:
|
||
_bin: emma
|
||
_desc: Advanced package search for NPM
|
||
_docs: https://www.npmjs.com/package/emma-cli#example
|
||
_github: https://github.com/maticzav/emma-cli
|
||
_home: https://www.npmjs.com/package/emma-cli
|
||
_name: Emma
|
||
npm: emma-cli
|
||
emoj:
|
||
_bin: emoj
|
||
_desc: Find relevant emoji from text on the command-line
|
||
_github: https://github.com/sindresorhus/emoj
|
||
_name: emoj
|
||
npm: emoj
|
||
emplace:
|
||
_bin: emplace
|
||
_desc: Emplace objects and arrays - pointer to pointer style
|
||
_docs: https://github.com/tversteeg/emplace
|
||
_github: https://github.com/tversteeg/emplace
|
||
_home: https://github.com/tversteeg/emplace
|
||
_name: Emplace
|
||
cargo: emplace --locked
|
||
nix: emplace
|
||
scoop: emplace
|
||
empty-trash:
|
||
_bin: empty-trash
|
||
_desc: CLI to empty trash on macOS, Windows, and Linux
|
||
_docs: https://github.com/sindresorhus/empty-trash-cli
|
||
_github: https://github.com/sindresorhus/empty-trash-cli
|
||
_home: https://github.com/sindresorhus/empty-trash-cli
|
||
_name: Empty Trash CLI
|
||
npm: empty-trash-cli
|
||
endlessh:
|
||
_bin: endlessh
|
||
_desc: '[Endlessh](https://github.com/skeeto/endlessh) is an SSH tarpit that very slowly sends an endless, random SSH banner. It keeps SSH clients locked up for hours or even days at a time. The purpose is to put your real SSH server on another port and then let the script kiddies get stuck in this tarpit instead of bothering a real server.'
|
||
_docs: https://github.com/skeeto/endlessh
|
||
_github: https://github.com/skeeto/endlessh
|
||
_home: https://github.com/skeeto/endlessh
|
||
_name: Endlessh
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Endlessh Configuration
|
||
# @brief Applies the Endlessh configuration and starts the service on Linux systems
|
||
# @description
|
||
# Endlessh is a endless SSH tarpit that slowly shows an infinitely long SSH welcome banner on the default
|
||
# SSH port. It is intended to break unsophisticated malware that targets SSH.
|
||
#
|
||
# If the `endlessh` program is installed, this script applies the configuration stored in `home/private_dot_ssh/endlessh/config.tmpl`
|
||
# (that unpacks with Chezmoi to `~/.ssh/endlessh/config`) to the system location and then starts the service.
|
||
#
|
||
# **Note:** _This script runs under the assumption that the actual SSH port which is defined in `home/.chezmoidata.yaml`
|
||
# is assigned to a non-standard port like 2214. This allows the default port to be used for `endlessh`._
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Endlessh GitHub repository](https://github.com/skeeto/endlessh)
|
||
# * [Endlessh configuration](https://github.com/megabyte-labs/install.doctor/blob/master/home/private_dot_ssh/endlessh/config.tmpl)
|
||
|
||
### Configures endlessh service
|
||
function configureEndlessh() {
|
||
### Update the service configuration file
|
||
logg info 'Updating endlessh service configuration file'
|
||
sudo sed -i 's/^.*#AmbientCapabilities=CAP_NET_BIND_SERVICE/AmbientCapabilities=CAP_NET_BIND_SERVICE/' /usr/lib/systemd/system/endlessh.service
|
||
sudo sed -i 's/^.*PrivateUsers=true/#PrivateUsers=true/' /usr/lib/systemd/system/endlessh.service
|
||
logg info 'Reloading systemd' && sudo systemctl daemon-reload
|
||
|
||
### Update capabilities of `endlessh`
|
||
logg info 'Updating capabilities of endlessh' && sudo setcap 'cap_net_bind_service=+ep' /usr/bin/endlessh
|
||
|
||
### Restart / enable Endlessh
|
||
logg info 'Enabling the endlessh service' && sudo systemctl enable endlessh
|
||
logg info 'Restarting the endlessh service' && sudo systemctl restart endlessh
|
||
}
|
||
|
||
### Update /etc/endlessh/config if environment is not WSL
|
||
if [[ ! "$(test -d proc && grep Microsoft /proc/version > /dev/null)" ]]; then
|
||
if command -v endlessh > /dev/null; then
|
||
if [ -d /etc/endlessh ]; then
|
||
logg info 'Copying ~/.ssh/endlessh/config to /etc/endlessh/config' && sudo cp -f "$HOME/.ssh/endlessh/config" /etc/endlessh/config
|
||
|
||
configureEndlessh || CONFIGURE_EXIT_CODE=$?
|
||
if [ -n "$CONFIGURE_EXIT_CODE" ]; then
|
||
logg error 'Configuring endlessh service failed' && exit 1
|
||
else
|
||
logg success 'Successfully configured endlessh service'
|
||
fi
|
||
elif [ -f /etc/endlessh.conf ]; then
|
||
logg info 'Copying ~/.ssh/endlessh/config to /etc/endlessh.conf' && sudo cp -f "$HOME/.ssh/endlessh/config" /etc/endlessh.conf
|
||
|
||
configureEndlessh || CONFIGURE_EXIT_CODE=$?
|
||
if [ -n "$CONFIGURE_EXIT_CODE" ]; then
|
||
logg error 'Configuring endlessh service failed' && exit 1
|
||
else
|
||
logg success 'Successfully configured endlessh service'
|
||
fi
|
||
else
|
||
logg warn 'Neither the /etc/endlessh folder nor the /etc/endlessh.conf file exist'
|
||
fi
|
||
else
|
||
logg info 'Skipping Endlessh configuration because the endlessh executable is not available in the PATH'
|
||
fi
|
||
else
|
||
logg info 'Skipping Endlessh configuration since environment is WSL'
|
||
fi
|
||
_service: endlessh
|
||
# CentOS 9 not in EPEL
|
||
# ansible:linux: professormanhattan.sshtarpit
|
||
apt: endlessh
|
||
dnf:fedora: endlessh
|
||
yay: endlessh-git
|
||
enola:
|
||
_bin: enola
|
||
_desc: Hunt down social media accounts by username across social networks (Sherlock Go clone)
|
||
_docs: https://github.com/TheYahya/enola
|
||
_github: https://github.com/TheYahya/enola
|
||
_home: https://github.com/TheYahya/enola
|
||
_name: Enola
|
||
go: github.com/theyahya/enola/cmd/enola@latest
|
||
envchain:
|
||
_bin: envchain
|
||
_deps:
|
||
- _envchain:deps
|
||
_desc: Environment variables meet macOS Keychain and gnome-keyring
|
||
_docs: https://github.com/sorah/envchain#usage
|
||
_github: https://github.com/sorah/envchain
|
||
_home: https://github.com/sorah/envchain
|
||
_name: envchain
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Store Secrets in Keyring
|
||
# @brief Stores secret environment variables into the System keyring
|
||
# @description
|
||
# This script imports secret environment variables into the System keyring if `envchain` is installed.
|
||
# Secrets stored in the folder 'home/.chezmoitemplates/secrets' following the Install Doctor method are
|
||
# imported into the System keyring by this script. There is only one namespace called `default` where the
|
||
# secrets are stored. Executing `envchain default env` displays all the environment variables and their values.
|
||
#
|
||
# ## Secrets
|
||
#
|
||
# For more information about storing secrets like SSH keys and API keys, refer to our [Secrets documentation](https://install.doctor/docs/customization/secrets).
|
||
|
||
### Import environment variables into `envchain`
|
||
if command -v envchain > /dev/null; then
|
||
{{- if (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) }}
|
||
logg info 'Importing environment variables into the System keyring'
|
||
for file in {{ joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "*" }}; do
|
||
cat "$file" | chezmoi decrypt | envchain -s default "$(basename $file)" > /dev/null || logg info 'Importing "$(basename $file)" failed'
|
||
done
|
||
{{- else }}
|
||
logg warn 'Unable to import any variables into envchain because ~/.config/age/chezmoi.txt was not created by the secrets encryption process yet'
|
||
{{- end }}
|
||
else
|
||
logg info 'envchain is not installed or it is not available in the PATH'
|
||
fi
|
||
brew: envchain
|
||
github: github.com/sorah/envchain
|
||
envconsul:
|
||
_bin: envconsul
|
||
_desc: Launch a subprocess with environment variables using data from @hashicorp Consul and Vault
|
||
_github: https://github.com/hashicorp/envconsul
|
||
_name: envconsul
|
||
ansible: professormanhattan.envconsul
|
||
brew: envconsul
|
||
github: github.com/hashicorp/envconsul
|
||
envio:
|
||
_bin: envio
|
||
_github: https://github.com/humblepenguinn/envio
|
||
_name: Envio
|
||
cargo: envio
|
||
environment:
|
||
_bin: null
|
||
_github: false
|
||
ansible: professormanhattan.environment
|
||
envpane:
|
||
_bin: null
|
||
_desc: An OS X preference pane for environment variables
|
||
_docs: https://github.com/hschmidt/EnvPane
|
||
_github: https://github.com/hschmidt/EnvPane
|
||
_home: https://github.com/hschmidt/EnvPane
|
||
_name: EnvPane
|
||
_when:script: '! test -d "$HOME/Library/PreferencePanes/EnvPane.prefPane"'
|
||
script:darwin: '(cd ~/Library/PreferencePanes && rm -rf EnvPane.prefPane && curl -sL https://github.com/hschmidt/EnvPane/releases/download/releases%2F0.8/EnvPane-0.8.tar.bz2 | tar -xjf -)'
|
||
eslint:
|
||
_bin: eslint
|
||
_desc: '[ESLint](https://eslint.org/) allows you to find and fix problems in your JavaScript code'
|
||
_docs: https://eslint.org/docs
|
||
_github: https://github.com/eslint/eslint
|
||
_home: https://eslint.org/
|
||
_name: ESLint
|
||
brew: eslint
|
||
npm: eslint
|
||
eslint-dashboard:
|
||
_bin: eslint-dashboard
|
||
_github: https://github.com/fengzilong/eslint-dashboard
|
||
_name: ESLint Dashboard
|
||
npm: eslint-dashboard
|
||
eslint-interactive:
|
||
_bin: eslint-interactive
|
||
_github: https://github.com/mizdra/eslint-interactive
|
||
_name: ESLint Interactive
|
||
npm: eslint-interactive
|
||
eslintd:
|
||
_bin: eslint_d
|
||
_docs: https://github.com/mantoni/eslint_d.js
|
||
_github: https://github.com/mantoni/eslint_d.js
|
||
_home: https://github.com/mantoni/eslint_d.js
|
||
_name: ESLint_d
|
||
npm: eslint_d
|
||
espanso:
|
||
_app: Espanso.app
|
||
_bin: espanso
|
||
_github: https://github.com/espanso/espanso
|
||
_name: Espanso
|
||
_post:appimage: |
|
||
#!/usr/bin/env bash
|
||
espanso service register && espanso start
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
espanso service register && espanso start
|
||
appimage: federico-terzi/espanso
|
||
cask: espanso
|
||
choco: espanso
|
||
snap: espanso --channel=latest/edge --classic
|
||
esprint:
|
||
_bin: esprint
|
||
_github: https://github.com/pinterest/esprint
|
||
_name: ESPrint
|
||
npm: esprint
|
||
etcd:
|
||
_bin: etcd
|
||
_desc: Distributed reliable key-value store for the most critical data of a distributed system
|
||
_github: https://github.com/etcd-io/etcd
|
||
_name: etcd
|
||
_service: etcd
|
||
_serviceEnabled: true
|
||
apt: etcd
|
||
brew: etcd
|
||
choco: etcd
|
||
dnf:fedora: etcd
|
||
github: github.com/etcd-io/etcd
|
||
yay: etcd
|
||
ettercap:
|
||
_bin: ettercap
|
||
_github: https://github.com/Ettercap/ettercap
|
||
_name: Ettercap
|
||
apt: ettercap
|
||
brew: ettercap
|
||
choco: ettercap
|
||
dnf: ettercap
|
||
pacman: ettercap
|
||
eul:
|
||
_app: eul.app
|
||
_bin: null
|
||
_desc: Menu bar application that shows system stats like CPU, RAM, and disk usage on macOS
|
||
_docs: https://github.com/gao-sun/eul
|
||
_github: https://github.com/gao-sun/eul
|
||
_home: https://github.com/gao-sun/eul
|
||
_name: Eul
|
||
cask: eul
|
||
mas: 1537133867
|
||
exa:
|
||
_bin: exa
|
||
_desc: A modern replacement for ls.
|
||
_docs: https://the.exa.website/introduction
|
||
_github: https://github.com/ogham/exa
|
||
_home: https://the.exa.website/
|
||
_name: Exa
|
||
apt: exa
|
||
brew: exa
|
||
cargo: exa
|
||
dnf: exa
|
||
emerge: sys-apps/exa
|
||
nix: exa
|
||
pacman: exa
|
||
zypper: exa
|
||
exiftool:
|
||
_bin: exiftool
|
||
_desc: '[exiftool](https://exiftool.org/) is a platform-independent Perl library plus a command-line application for reading, writing and editing meta information in a wide variety of files'
|
||
_docs: https://exiftool.org/exiftool_pod.html
|
||
_github: https://github.com/exiftool/exiftool
|
||
_home: https://exiftool.org/
|
||
_name: exiftool
|
||
ansible: professormanhattan.exiftool
|
||
apt: libimage-exiftool-perl
|
||
brew: exiftool
|
||
choco: exiftool
|
||
dnf: perl-Image-ExifTool.noarch
|
||
pacman: perl-image-exiftool
|
||
port: exiftool
|
||
scoop: exiftool
|
||
expect:
|
||
_bin: expect
|
||
_name: Expect
|
||
_github: false
|
||
apt: expect
|
||
brew: expect
|
||
dnf: expect
|
||
pacman: expect
|
||
port: expect
|
||
extensions:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role acts as a catch-all for extensions for various system software.
|
||
_name: Extensions
|
||
ansible: professormanhattan.extensions
|
||
fabric:
|
||
_bin: fab
|
||
_github: https://github.com/fabric/fabric
|
||
_name: Fabric
|
||
brew: fabric
|
||
pipx: fabric
|
||
fail2ban:
|
||
_bin: fail2ban-client
|
||
_github: https://github.com/fail2ban/fail2ban
|
||
_notes: |
|
||
fail2ban cannot be installed on Qubes Fedora 36 without messing with the qubes-firewall since firewalld is required.
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Fail2ban Configuration
|
||
# @brief Applies the system `fail2ban` jail configuration and then restarts the service
|
||
# @description
|
||
# Fail2ban is an SSH security program that temporarily bans IP addresses that could possibly be
|
||
# attempting to gain unauthorized system access. This script applies the "jail" configuration
|
||
# located at `home/private_dot_ssh/fail2ban/` to the system location. It then enables and restarts
|
||
# the `fail2ban` configuration.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [`fail2ban` configuration folder](https://github.com/megabyte-labs/install.doctor/tree/master/home/private_dot_ssh/fail2ban)
|
||
|
||
### Notify of script start
|
||
logg info 'Configuring fail2ban'
|
||
|
||
### Restart fail2ban
|
||
function restartFailToBan() {
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS
|
||
logg info 'Enabling the fail2ban Homebrew service'
|
||
brew services restart fail2ban
|
||
else
|
||
# Linux
|
||
logg info 'Enabling the fail2ban service'
|
||
sudo systemctl enable fail2ban
|
||
logg info 'Restarting the fail2ban service'
|
||
sudo systemctl restart fail2ban
|
||
fi
|
||
}
|
||
|
||
### Update the jail.local file if environment is not WSL
|
||
logg info 'Checking if script is being run in WSL environment'
|
||
if [[ ! "$(test -d /proc && grep Microsoft /proc/version > /dev/null)" ]]; then
|
||
if [ -d /etc/fail2ban ]; then
|
||
logg info 'Copying ~/.ssh/fail2ban/jail.local to /etc/fail2ban/jail.local'
|
||
sudo cp -f "$HOME/.ssh/fail2ban/jail.local" /etc/fail2ban/jail.local
|
||
restartFailToBan
|
||
elif [ -d /usr/local/etc/fail2ban ]; then
|
||
logg info 'Copying ~/.ssh/fail2ban/jail.local to /usr/local/etc/fail2ban/jail.local'
|
||
sudo cp -f "$HOME/.ssh/fail2ban/jail.local" /usr/local/etc/fail2ban/jail.local
|
||
restartFailToBan
|
||
elif [ -d "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/fail2ban" ]; then
|
||
logg info "Copying ~/.ssh/fail2ban/jail.local to ${HOMEBREW_PREFIX:-/opt/homebrew}/etc/fail2ban/jail.local"
|
||
sudo cp -f "$HOME/.ssh/fail2ban/jail.local" "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/fail2ban/jail.local"
|
||
restartFailToBan
|
||
else
|
||
logg warn 'The /etc/fail2ban (Linux), the /usr/local/etc/fail2ban, and the ${HOMEBREW_PREFIX:-/opt/homebrew}/etc/fail2ban (macOS) folder do not exist'
|
||
fi
|
||
else
|
||
logg info 'Skipping sshd_config application since environment is WSL'
|
||
fi
|
||
_service: fail2ban
|
||
_service:brew:
|
||
- name: fail2ban
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
_when:linux: '! command -v qubes-firewall > /dev/null && test -f /proc/version && ! grep Microsoft /proc/version > /dev/null'
|
||
apt: fail2ban
|
||
brew: fail2ban
|
||
dnf: fail2ban
|
||
pacman: fail2ban
|
||
port: fail2ban
|
||
fastify:
|
||
_bin: fastify
|
||
_desc: Run a Fastify application with one command
|
||
_github: https://github.com/fastify/fastify-cli
|
||
_home: https://www.fastify.io/
|
||
_name: fastify
|
||
npm: fastify-cli
|
||
fastlane:
|
||
_bin: fastlane
|
||
_github: https://github.com/fastlane/fastlane
|
||
_home: https://fastlane.tools/
|
||
_name: Fastlane
|
||
brew: fastlane
|
||
gem: fastlane
|
||
fcp:
|
||
_bin: fcp
|
||
_desc: A significantly faster alternative to the classic Unix cp(1) command, copying large files and directories in a fraction of the time.
|
||
_docs: https://github.com/Svetlitski/fcp#usage
|
||
_github: https://github.com/Svetlitski/fcp
|
||
_home: https://github.com/Svetlitski/fcp
|
||
_name: fcp
|
||
brew: fcp
|
||
cargo: fcp
|
||
nix: unstable.fcp
|
||
fd:
|
||
_bin: fd
|
||
_bin:apt: fdfind
|
||
_desc: "[fd](https://github.com/sharkdp/fd) is a program that can search for files on your filesystem. It is a simple, fast, and user-friendly alternative to find. While it does not aim to support all of find's powerful functionality, it provides sensible (opinionated) defaults for a majority of use cases."
|
||
_github: https://github.com/sharkdp/fd
|
||
_name: fd
|
||
ansible: professormanhattan.fd
|
||
apk: fd
|
||
apt: fd-find
|
||
brew: fd
|
||
cargo: fd-find
|
||
choco: fd
|
||
github: github.com/sharkdp/fd
|
||
pacman: fd
|
||
pkg: fd
|
||
scoop: fd
|
||
fdupes:
|
||
_bin: fdupes
|
||
_github: https://github.com/adrianlopezroche/fdupes
|
||
_name: fdupes
|
||
apt: fdupes
|
||
brew: fdupes
|
||
dnf: fdupes
|
||
pacman: fdupes
|
||
feathers:
|
||
_bin: feathers
|
||
_desc: The command line interface for scaffolding Feathers applications
|
||
_github: https://github.com/feathersjs-ecosystem/cli
|
||
npm: '@feathersjs/cli'
|
||
ferdium:
|
||
_app: Ferdium.app
|
||
_github: https://github.com/ferdium/ferdium-app
|
||
_bin: ferdium
|
||
_env:
|
||
FERDIUM_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Ferdium"
|
||
choco: TODO
|
||
flatpak: "$HOME/.var/app/org.ferdium.Ferdium/config/Ferdium"
|
||
snap: "$HOME/snap/ferdium/current/.config/Ferdium"
|
||
cask: ferdium
|
||
choco: ferdium
|
||
flatpak: org.ferdium.Ferdium
|
||
snap: ferdium
|
||
ffmpeg:
|
||
_bin: ffmpeg
|
||
_desc: '[FFmpeg](https://www.ffmpeg.org/) is the leading multimedia framework. It is able to decode, encode, transcode, mux, demux, stream, filter and play pretty much anything that humans and machines have created. It supports the most obscure ancient formats up to the cutting edge.'
|
||
_github: https://github.com/FFmpeg/FFmpeg
|
||
_name: FFmpeg
|
||
ansible: professormanhattan.ffmpeg
|
||
apk: ffmpeg
|
||
apt: ffmpeg
|
||
brew: ffmpeg
|
||
choco: ffmpeg
|
||
dnf: ffmpeg
|
||
pacman: ffmpeg
|
||
scoop: ffmpeg
|
||
ffsend:
|
||
_bin: ffsend
|
||
_desc: '[ffsend](https://github.com/timvisee/ffsend) (formerly [Firefox Send](https://support.mozilla.org/en-US/kb/what-happened-firefox-send)) allows you to easily and securely share files and directories from the command line through a safe, private and encrypted link using a single simple command. Files are shared using the [Send](https://send.vis.ee/) service and may be up to 1GB. Others are able to download these files with this tool, or through their web browser.'
|
||
_github: https://github.com/timvisee/ffsend
|
||
_name: ffsend
|
||
ansible: professormanhattan.ffsend
|
||
apk: ffsend
|
||
brew: ffsend
|
||
github: github.com/timvisee/ffsend
|
||
pkg: ffsend
|
||
scoop: ffsend
|
||
snap: ffsend
|
||
yay: ffsend
|
||
fiddler:
|
||
_bin: fiddler
|
||
_desc: The community-trusted free Windows-only tool that logs HTTP(s) network traffic.
|
||
_docs: https://docs.telerik.com/fiddler/configure-fiddler/tasks/configurefiddler
|
||
_github: false
|
||
_home: https://www.telerik.com/fiddler
|
||
_name: Fiddler
|
||
_todo: Add headless installation method for Linux
|
||
choco: fiddler
|
||
scoop: extras/fiddler
|
||
fig:
|
||
_app: Fig.app
|
||
_bin: fig
|
||
_desc: '[Fig](https://fig.io/) adds autocomplete to your terminal. As you type, Fig pops up subcommands, options, and contextually relevant arguments in your existing terminal.'
|
||
_docs: https://fig.io/user-manual
|
||
_github: https://github.com/withfig/autocomplete
|
||
_home: https://fig.io/
|
||
_name: Fig
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
source ~/.config/shell/private.sh && fig login --token "$FIG_TOKEN"
|
||
cask: fig
|
||
figlet:
|
||
_bin: figlet
|
||
_github: https://github.com/cmatsuoka/figlet
|
||
_name: Figlet
|
||
apt: figlet
|
||
brew: figlet
|
||
choco: figlet
|
||
dnf: figlet
|
||
pacman: figlet
|
||
zypper: figlet
|
||
figma:
|
||
_app: Figma.app
|
||
_bin: null
|
||
_desc: Collaborative team software
|
||
_docs: https://help.figma.com/hc/en-us
|
||
_github: false
|
||
_home: https://www.figma.com/
|
||
_name: Figma
|
||
appimage: Figma-Linux/figma-linux
|
||
cask: figma
|
||
choco: figma
|
||
flatpak: io.github.Figma_Linux.figma_linux
|
||
snap: figma-linux
|
||
filebrowser:
|
||
_bin: filebrowser
|
||
_desc: '[File Browser](https://filebrowser.org/) is a tool that lets you browse and edit files on any mounting point in the operating system.'
|
||
_docs: https://filebrowser.org/installation
|
||
_github: https://github.com/filebrowser/filebrowser
|
||
_home: https://filebrowser.org/
|
||
_name: File Browser
|
||
ansible: professormanhattan.filebrowser
|
||
brew: filebrowser/tap/filebrowser
|
||
github: github.com/filebrowser/filebrowser
|
||
filezilla:
|
||
_app: FileZilla.app
|
||
_bin: filezilla
|
||
_desc: '[FileZilla](https://filezilla-project.org/) is a free software, cross-platform FTP application, consisting of FileZilla Client and FileZilla Server. Client binaries are available for Windows, Linux, and macOS, server binaries are available for Windows only.'
|
||
_docs: https://wiki.filezilla-project.org/Documentation
|
||
_github: https://svn.filezilla-project.org/filezilla/
|
||
_home: https://filezilla-project.org/
|
||
_name: FileZilla
|
||
ansible:darwin: professormanhattan.filezilla
|
||
apt: filezilla
|
||
choco: filezilla
|
||
dnf: filezilla
|
||
flatpak: org.filezillaproject.Filezilla
|
||
pacman: filezilla
|
||
findutils:
|
||
_bin: gfind
|
||
_github: false
|
||
brew: findutils
|
||
finish:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role should be the last role in the playbook.
|
||
_name: Finish
|
||
ansible: professormanhattan.finish
|
||
firebase:
|
||
_github: https://github.com/firebase/firebase-tools
|
||
_bin: firebase
|
||
_desc: The Firebase Command Line Interface (CLI) Tools can be used to test, manage, and deploy your Firebase project from the command line
|
||
npm: firebase-tools
|
||
firefox:
|
||
_app: Firefox.app
|
||
_bin: firefox
|
||
_github: false
|
||
_deps:
|
||
- htmlq
|
||
_desc: '[Mozilla Firefox](https://www.mozilla.org/en-US/firefox/new/), or simply Firefox, is a free and open-source web browser developed by the Mozilla Foundation and its subsidiary, the Mozilla Corporation. Firefox uses the Gecko layout engine to render web pages, which implements current and anticipated web standards.'
|
||
_docs: https://developer.mozilla.org/en-US/
|
||
_env:
|
||
FIREFOX_APPDATA:
|
||
apt: "$HOME/.mozilla/firefox"
|
||
cask: "$HOME/Library/Application Support/Firefox/Profiles"
|
||
choco: "TODO"
|
||
dnf: "$HOME/.mozilla/firefox"
|
||
flatpak: "$HOME/.var/app/org.mozilla.firefox/.mozilla/firefox"
|
||
pacman: "$HOME/.mozilla/firefox"
|
||
snap: "$HOME/snap/firefox/common/.mozilla/firefox"
|
||
_home: https://www.mozilla.org/en-US/firefox/new/
|
||
_name: Mozilla Firefox
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Firefox Settings / Add-Ons / Profiles
|
||
# @brief This script configures system-wide settings, sets up Firefox Profile Switcher, creates various profiles from different sources, and installs a configurable list of Firefox Add-Ons.
|
||
# @description
|
||
# The Firefox setup script performs a handful of tasks that automate the setup of Firefox as well as
|
||
# useful utilities that will benefit Firefox power-users. The script also performs the same logic on
|
||
# [LibreWolf](https://librewolf.net/) installations.
|
||
#
|
||
# ## Features
|
||
#
|
||
# * Installs and sets up [Firefox Profile Switcher](https://github.com/null-dev/firefox-profile-switcher)
|
||
# * Sets up system-wide enterprise settings (with configurations found in `~/.local/share/firefox`)
|
||
# * Sets up a handful of default profiles to use with the Firefox Profile Switcher
|
||
# * Automatically installs the plugins defined in the firefoxAddOns key of [`home/.chezmoidata.yaml`](https://github.com/megabyte-labs/install.doctor/blob/master/home/.chezmoidata.yaml) to the Standard and Private profiles
|
||
# * Configures the default profile to clone its settings from the profile stored in firefoxPublicProfile of `home/.chezmoidata.yaml`
|
||
# * Optionally, if the Chezmoi encryption key is present, then the default profile will be set to the contents of an encrypted `.tar.gz` that must be stored in the cloud somewhere (with the firefoxPrivateProfile key in `home/.chezmoidata.yaml` defining the URL of the encrypted `.tar.gz`)
|
||
#
|
||
# ## Profiles
|
||
#
|
||
# The script sets up numerous profiles for user flexibility. They can be switched by using the Firefox Profile Switcher
|
||
# that this script sets up. The map of the profiles is generated by using the template file stored in `~/.local/share/firefox/profiles.ini`.
|
||
# The following details the features of each profile:
|
||
#
|
||
# | Name | Description |
|
||
# |------------------|---------------------------------------------------------------------------------------------|
|
||
# | Factory | Default browser settings (system-wide configurations still apply) |
|
||
# | default-release | Same as Factory (unmodified and generated by headlessly opening Firefox / LibreWolf) |
|
||
# | Git (Public) | Pre-configured profile with address stored in `firefoxPublicProfile` |
|
||
# | Standard | Cloned from the profile above with `firefoxAddOns` also installed |
|
||
# | Miscellaneous | Cloned from the Factory profile (with the user.js found in `~/.config/firefox` applied) |
|
||
# | Development | Same as Miscellaneous |
|
||
# | Automation | Same as Miscellaneous |
|
||
# | Private | Populated from an encrypted profile stored in the cloud (also installs `firefoxAddOns`) |
|
||
#
|
||
# ## Notes
|
||
#
|
||
# * The Firefox Profile Switcher is only compatible with Firefox and not LibreWolf
|
||
# * This script is only designed to properly provision profiles on a fresh installation (so it does not mess around with pre-existing / already configured profiles)
|
||
# * Additional profiles for LibreWolf are not added because the Firefox Profile Switcher is not compatible with LibreWolf
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [System-wide configurations](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_local/share/firefox) as well as the location of the `profile.ini` and some other configurations
|
||
# * [User-specific configurations](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/firefox/user.js) added to all profiles except Factory
|
||
|
||
function installFirefoxProfileConnector() {
|
||
logg info 'Installing the Firefox Profile Connector'
|
||
if command -v apt-get > /dev/null; then
|
||
sudo apt-get install -y https://github.com/null-dev/firefox-profile-switcher-connector/releases/latest/download/linux-x64.deb
|
||
elif command -v dnf > /dev/null; then
|
||
sudo dnf install -y https://github.com/null-dev/firefox-profile-switcher-connector/releases/latest/download/linux-x64.rpm
|
||
elif command -v yay > /dev/null; then
|
||
yay -Ss firefox-profile-switcher-connector
|
||
else
|
||
logg warn 'apt-get, dnf, and yay were all unavailable so the Firefox Profile Connector helper executable could not be installed'
|
||
fi
|
||
}
|
||
|
||
function firefoxSetup() {
|
||
### Installs the Firefox Profile Connector on Linux systems (Snap / Flatpak installs are not included in this function, but instead inline below)
|
||
### Add Firefox enterprise profile
|
||
# TODO - figure out how to do this for other installations like Flatpak and macOS and Librewolf
|
||
for FIREFOX_DIR in '/usr/lib/firefox' '/usr/lib/firefox-esr' '/etc/firefox' '/etc/firefox-esr' '/Applications/Firefox.app/Contents/Resources'; do
|
||
if [ -d "$FIREFOX_DIR" ] && [ -d "${XDG_DATA_HOME:-$HOME/.local/share}/firefox" ] && command -v rsync > /dev/null; then
|
||
logg info "Syncing enterprise profiles from ${XDG_DATA_HOME:-$HOME/.local/share}/firefox to $FIREFOX_DIR"
|
||
sudo rsync -artvu "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/" "$FIREFOX_DIR" > /dev/null
|
||
fi
|
||
done
|
||
|
||
### Loop through various Firefox profile locations
|
||
for SETTINGS_DIR in "$HOME/snap/firefox/common/.mozilla/firefox" "$HOME/.var/app/org.mozilla.firefox/.mozilla/firefox" "$HOME/Library/Application Support/Firefox/Profiles" "$HOME/.mozilla/firefox"; do
|
||
### Determine executable to use
|
||
logg info "Processing Firefox profile location $SETTINGS_DIR"
|
||
unset FIREFOX_EXE
|
||
if [ "$SETTINGS_DIR" == "$HOME/.var/app/org.mozilla.firefox/.mozilla/firefox" ]; then
|
||
if ! command -v org.mozilla.firefox > /dev/null || [ ! -d "$HOME/.var/app/org.mozilla.firefox" ]; then
|
||
continue
|
||
else
|
||
FIREFOX_EXE="$(which org.mozilla.firefox)"
|
||
### Firefox Profile Switcher
|
||
BASE_DIR="$HOME/.var/app/org.mozilla.firefox"
|
||
BIN_INSTALL_DIR="$BASE_DIR/data/firefoxprofileswitcher-install"
|
||
MANIFEST_INSTALL_DIR="$BASE_DIR/.mozilla/native-messaging-hosts"
|
||
DOWNLOAD_URL="https://github.com/null-dev/firefox-profile-switcher-connector/releases/latest/download/linux-x64.deb"
|
||
|
||
### Ensure Firefox Profile Switcher is not already installed
|
||
if [ ! -f "$BIN_INSTALL_DIR/usr/bin/ff-pswitch-connector" ] || [ ! -f "$MANIFEST_INSTALL_DIR/ax.nd.profile_switcher_ff.json" ]; then
|
||
### Download profile switcher
|
||
mkdir -p "$BIN_INSTALL_DIR"
|
||
TMP_FILE="$(mktemp)"
|
||
logg info 'Downloading Firefox Profile Switch connector'
|
||
curl -sSL "$DOWNLOAD_URL" -o "$TMP_FILE"
|
||
ar p "$TMP_FILE" data.tar.xz | tar xfJ - --strip-components=2 -C "$BIN_INSTALL_DIR" usr/bin/ff-pswitch-connector
|
||
rm -f "$TMP_FILE"
|
||
|
||
### Create manifest
|
||
logg info 'Copying profile switcher configuration to manifest directory'
|
||
mkdir -p "$MANIFEST_INSTALL_DIR"
|
||
cat "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/profile-switcher.json" | sed 's=PATH_PLACEHOLDER='"$BIN_INSTALL_DIR"'=' > "$MANIFEST_INSTALL_DIR/ax.nd.profile_switcher_ff.json"
|
||
fi
|
||
fi
|
||
elif [ "$SETTINGS_DIR" == "$HOME/.var/app/io.gitlab.librewolf-community/.librewolf" ]; then
|
||
if ! command -v io.gitlab.librewolf-community > /dev/null || [ ! -d "$HOME/.var/app/io.gitlab.librewolf-community" ]; then
|
||
continue
|
||
else
|
||
continue
|
||
# FIREFOX_EXE="$(which io.gitlab.librewolf-community)"
|
||
fi
|
||
elif [ "$SETTINGS_DIR" == "$HOME/Library/Application Support/Firefox/Profiles" ]; then
|
||
FIREFOX_EXE="/Applications/Firefox.app/Contents/MacOS/firefox"
|
||
if [ ! -f "$FIREFOX_EXE" ] || [ ! -d /Applications ]; then
|
||
continue
|
||
else
|
||
### Download Firefox Profile Switcher
|
||
if [ ! -d /usr/local/Cellar/firefox-profile-switcher-connector ]; then
|
||
logg info 'Ensuring Firefox Profile Switcher is installed'
|
||
brew install --quiet null-dev/firefox-profile-switcher/firefox-profile-switcher-connector
|
||
fi
|
||
|
||
### Ensure Firefox Profile Switcher configuration is symlinked
|
||
if [ ! -d "/Library/Application Support/Mozilla/NativeMessagingHosts/ax.nd.profile_switcher_ff.json" ]; then
|
||
logg info 'Ensuring Firefox Profile Switcher is configured'
|
||
sudo mkdir -p "/Library/Applcation Support/Mozilla/NativeMessagingHosts"
|
||
sudo ln -sf "$(brew ls -l firefox-profile-switcher-connector | grep -i ax.nd.profile_switcher_ff.json | head -n1)" "/Library/Application Support/Mozilla/NativeMessagingHosts/ax.nd.profile_switcher_ff.json"
|
||
fi
|
||
fi
|
||
elif [ "$SETTINGS_DIR" == "$HOME/Library/Application Support/LibreWolf/Profiles" ]; then
|
||
continue
|
||
# FIREFOX_EXE="/Applications/LibreWolf.app/Contents/MacOS/librewolf"
|
||
# if [ ! -f "$FIREFOX_EXE" ] || [ ! -d /Applications ]; then
|
||
# logg info "$FIREFOX_EXE is not a file"
|
||
# continue
|
||
# fi
|
||
elif [ "$SETTINGS_DIR" == "$HOME/snap/firefox/common/.mozilla/firefox" ]; then
|
||
FIREFOX_EXE="/snap/bin/firefox"
|
||
if [ ! -f "$FIREFOX_EXE" ] || [ ! -d "$HOME/snap/firefox" ]; then
|
||
continue
|
||
else
|
||
### Firefox Profile Switcher
|
||
BASE_DIR="$HOME/snap/firefox/common"
|
||
BIN_INSTALL_DIR="$BASE_DIR/firefoxprofileswitcher-install"
|
||
MANIFEST_INSTALL_DIR="$BASE_DIR/.mozilla/native-messaging-hosts"
|
||
DOWNLOAD_URL="https://github.com/null-dev/firefox-profile-switcher-connector/releases/latest/download/linux-x64.deb"
|
||
|
||
### Ensure Firefox Profile Switcher is not already installed
|
||
if [ ! -f "$BIN_INSTALL_DIR/usr/bin/ff-pswitch-connector" ] || [ ! -f "$MANIFEST_INSTALL_DIR/ax.nd.profile_switcher_ff.json" ]; then
|
||
### Download profile switcher
|
||
mkdir -p "$BIN_INSTALL_DIR"
|
||
TMP_FILE="$(mktemp)"
|
||
logg info 'Downloading Firefox Profile Switch connector'
|
||
curl -sSL "$DOWNLOAD_URL" -o "$TMP_FILE"
|
||
ar p "$TMP_FILE" data.tar.xz | tar xfJ - --strip-components=2 -C "$BIN_INSTALL_DIR" usr/bin/ff-pswitch-connector
|
||
rm -f "$TMP_FILE"
|
||
|
||
### Create manifest
|
||
logg info 'Copying profile switcher configuration to manifest directory'
|
||
mkdir -p "$MANIFEST_INSTALL_DIR"
|
||
cat "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/profile-switcher.json" | sed 's/PATH_PLACEHOLDER/'"$BIN_INSTALL_DIR"'/' > "$MANIFEST_INSTALL_DIR/ax.nd.profile_switcher_ff.json"
|
||
fi
|
||
fi
|
||
elif [ "$SETTINGS_DIR" == "$HOME/.mozilla/firefox" ]; then
|
||
if command -v firefox-esr > /dev/null; then
|
||
FIREFOX_EXE="$(which firefox-esr)"
|
||
installFirefoxProfileConnector
|
||
elif command -v firefox > /dev/null && [ "$(which firefox)" != *'snap'* ] && [ "$(which firefox)" != *'flatpak'* ] && [ ! -d /Applications ] && [ ! -d /System ]; then
|
||
# Conditional check ensures Snap / Flatpak / macOS Firefox versions do not try to install to the wrong folder
|
||
FIREFOX_EXE="$(which firefox)"
|
||
installFirefoxProfileConnector
|
||
else
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
# Continue on macOS without logging because profiles are not stored here on macOS
|
||
continue
|
||
else
|
||
logg warn 'Unable to register Firefox executable'
|
||
logg info "Settings directory: $SETTINGS_DIR"
|
||
continue
|
||
fi
|
||
fi
|
||
fi
|
||
### Initiatize Firefox default profiles
|
||
logg info "Processing executable located at $FIREFOX_EXE"
|
||
if command -v "$FIREFOX_EXE" > /dev/null; then
|
||
### Create default profile by launching Firefox headlessly
|
||
logg info "Firefox executable set to $FIREFOX_EXE"
|
||
if [ ! -d "$SETTINGS_DIR" ]; then
|
||
logg info 'Running Firefox (or its derivative) headlessly to generate default profiles'
|
||
timeout 14 "$FIREFOX_EXE" --headless
|
||
logg info 'Finished running Firefox headlessly'
|
||
elif [ -d /Applications ] && [ -d /System ] && [ ! -f "$SETTINGS_DIR/../installs.ini" ]; then
|
||
logg info 'Running Firefox (or its derivative) headlessly to generate default profiles because install.ini is not at the macOS default location.'
|
||
timeout 14 "$FIREFOX_EXE" --headless
|
||
logg info 'Finished running Firefox headlessly (while fixing the missing macOS installs.ini issue)'
|
||
fi
|
||
|
||
### Ensure settings directory exists (since the application was brought up temporarily headlessly)
|
||
if [ ! -d "$SETTINGS_DIR" ]; then
|
||
logg warn "The settings directory located at $SETTINGS_DIR failed to be populated by running the browser headlessly"
|
||
continue
|
||
fi
|
||
|
||
### Add the populated profiles.ini
|
||
logg info "Copying "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/profiles.ini" to profile directory"
|
||
logg info "The settings directory is $SETTINGS_DIR"
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
# macOS
|
||
logg info "Copying ~/.local/share/firefox/profiles.ini to $SETTINGS_DIR/../profiles.ini"
|
||
cp -f "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/profiles.ini" "$SETTINGS_DIR/../profiles.ini"
|
||
SETTINGS_INI="$SETTINGS_DIR/../installs.ini"
|
||
else
|
||
# Linux
|
||
logg info "Copying ~/.local/share/firefox/profiles.ini to $SETTINGS_DIR/profiles.ini"
|
||
cp -f "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/profiles.ini" "$SETTINGS_DIR/profiles.ini"
|
||
SETTINGS_INI="$SETTINGS_DIR/installs.ini"
|
||
fi
|
||
|
||
### Default profile (created by launching Firefox headlessly)
|
||
DEFAULT_RELEASE_PROFILE="$(find "$SETTINGS_DIR" -mindepth 1 -maxdepth 1 -name "*.default" -not -name "profile.default")"
|
||
if [ -n "$DEFAULT_RELEASE_PROFILE" ]; then
|
||
logg info "Syncing $DEFAULT_RELEASE_PROFILE to $SETTINGS_DIR/profile.default"
|
||
rsync -a "$DEFAULT_RELEASE_PROFILE/" "$SETTINGS_DIR/profile.default"
|
||
else
|
||
logg warn 'Unable to sync default Mozilla Firefox profile'
|
||
fi
|
||
|
||
### Ensure original installs.ini is removed
|
||
if [ -f "$SETTINGS_INI" ]; then
|
||
# DEFAULT_PROFILE_PROFILE="$SETTINGS_DIR/$(cat "$SETTINGS_INI" | grep 'Default=' | sed 's/.*Profiles\///')"
|
||
logg info 'Removing previous installs.ini file'
|
||
rm -f "$SETTINGS_INI"
|
||
else
|
||
logg info 'installs.ini was not present in the Mozilla Firefox settings folder'
|
||
fi
|
||
|
||
### Miscellaneous default profiles
|
||
for NEW_PROFILE in "automation" "development" "miscellaneous"; do
|
||
if [ ! -d "$SETTINGS_DIR/profile.${NEW_PROFILE}" ] && [ -d "$SETTINGS_DIR/profile.default" ]; then
|
||
logg info "Cloning $NEW_PROFILE from profile.default"
|
||
rsync -a "$SETTINGS_DIR/profile.default/" "$SETTINGS_DIR/profile.${NEW_PROFILE}"
|
||
rsync -a "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/" "$SETTINGS_DIR/profile.${NEW_PROFILE}"
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/firefox/user.js" "$SETTINGS_DIR/profile.${NEW_PROFILE}"
|
||
fi
|
||
done
|
||
|
||
### Public git profile
|
||
if [ -d "$SETTINGS_DIR/profile.git" ]; then
|
||
logg info 'Resetting the Firefox git profile'
|
||
cd "$SETTINGS_DIR/profile.git"
|
||
git reset --hard HEAD
|
||
git clean -fxd
|
||
logg info 'Pulling latest updates to the Firefox git profile'
|
||
git pull origin master
|
||
else
|
||
logg info 'Cloning the public Firefox git profile'
|
||
cd "$SETTINGS_DIR" && git clone "$FIREFOX_PUBLIC_PROFILE" profile.git
|
||
fi
|
||
|
||
### Copy user.js to profile.git profile
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/firefox/user.js" "$SETTINGS_DIR/profile.git"
|
||
|
||
### Git profile w/ plugins installed (installation happens below)
|
||
if [ ! -d "$SETTINGS_DIR/profile.plugins" ]; then
|
||
logg info "Syncing $SETTINGS_DIR/profile.git to $SETTINGS_DIR/profile.plugins"
|
||
rsync -a "$SETTINGS_DIR/profile.git/" "$SETTINGS_DIR/profile.plugins"
|
||
rsync -a "${XDG_DATA_HOME:-$HOME/.local/share}/firefox/" "$SETTINGS_DIR/profile.plugins"
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/firefox/user.js" "$SETTINGS_DIR/profile.plugins"
|
||
fi
|
||
|
||
### Private hosted profile
|
||
# Deprecated in favor of using the Restic profile tasks saved in `~/.config/task/Taskfile.yml`
|
||
# if [ ! -d "$SETTINGS_DIR/profile.private" ]; then
|
||
# logg info 'Downloading the encrypted Firefox private profile'
|
||
# cd "$SETTINGS_DIR"
|
||
# curl -sSL '{ { .firefoxPrivateProfile } }' -o profile.private.tar.gz.age
|
||
# logg info 'Decrypting the Firefox private profile'
|
||
# chezmoi decrypt profile.private.tar.gz.age > profile.private.tar.gz || EXIT_DECRYPT_CODE=$?
|
||
# if [ -z "$EXIT_DECRYPT_CODE" ]; then
|
||
# rm -f profile.private.tar.gz.age
|
||
# logg info 'Decompressing the Firefox private profile'
|
||
# tar -xzf profile.private.tar.gz
|
||
# logg success 'The Firefox private profile was successfully installed'
|
||
# cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/firefox/user.js" "$SETTINGS_DIR/profile.private"
|
||
# logg info 'Copied ~/.config/firefox/user.js to profile.private profile'
|
||
# else
|
||
# logg error 'Failed to decrypt the private Firefox profile'
|
||
# fi
|
||
# fi
|
||
|
||
### Install Firefox addons (using list declared in .chezmoidata.yaml)
|
||
for SETTINGS_PROFILE in "profile.plugins" "profile.private"; do
|
||
if [ -d "$SETTINGS_DIR/$SETTINGS_PROFILE" ]; then
|
||
for FIREFOX_PLUGIN in {{ list (.firefoxAddOns | toString | replace "[" "" | replace "]" "") | uniq | join " " }}; do
|
||
logg info "Processing the $FIREFOX_PLUGIN Firefox add-on"
|
||
PLUGIN_HTML="$(mktemp)"
|
||
curl --silent "https://addons.mozilla.org/en-US/firefox/addon/$FIREFOX_PLUGIN/" > "$PLUGIN_HTML"
|
||
PLUGIN_TMP="$(mktemp)"
|
||
if ! command -v htmlq > /dev/null && command -v brew > /dev/null; then
|
||
logg info 'Installing htmlq using Homebrew since it is a dependency for populating Firefox add-ons' && brew install htmlq
|
||
fi
|
||
cat "$PLUGIN_HTML" | htmlq '#redux-store-state' | sed 's/^<scri.*application\/json">//' | sed 's/<\/script>$//' > "$PLUGIN_TMP"
|
||
PLUGIN_ID="$(jq '.addons.bySlug["'"$FIREFOX_PLUGIN"'"]' "$PLUGIN_TMP")"
|
||
if [ "$PLUGIN_ID" != 'null' ]; then
|
||
PLUGIN_FILE_ID="$(jq -r '.addons.byID["'"$PLUGIN_ID"'"].guid' "$PLUGIN_TMP")"
|
||
if [ "$PLUGIN_FILE_ID" != 'null' ]; then
|
||
PLUGIN_URL="$(cat "$PLUGIN_HTML" | htmlq '.InstallButtonWrapper-download-link' --attribute href)"
|
||
PLUGIN_FILENAME="${PLUGIN_FILE_ID}.xpi"
|
||
PLUGIN_FOLDER="$(echo "$PLUGIN_FILENAME" | sed 's/.xpi$//')"
|
||
if [ ! -d "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions/$PLUGIN_FOLDER" ]; then
|
||
logg info 'Downloading add-on XPI file for '"$PLUGIN_FILENAME"' ('"$FIREFOX_PLUGIN"')'
|
||
if [ ! -d "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions" ]; then
|
||
mkdir -p "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions"
|
||
fi
|
||
curl -sSL "$PLUGIN_URL" -o "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions/$PLUGIN_FILENAME"
|
||
# Unzipping like this causes Firefox to complain about unsigned plugins
|
||
# TODO - figure out how to headlessly enable the extensions in such a way that is compatible with Flatpak / Snap
|
||
# using the /usr/lib/firefox/distribution/policies.json works but this is not compatible with Flatpak / Snap out of the box
|
||
# it seems since they do not have access to the file system by default. Also, using the policies.json approach forces
|
||
# all Firefox profiles to use the same extensions. Ideally, we should find a way to enable the extensions scoped
|
||
# to the user profile.
|
||
# logg info 'Unzipping '"$PLUGIN_FILENAME"' ('"$FIREFOX_PLUGIN"')'
|
||
# unzip "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions/$PLUGIN_FILENAME" -d "$SETTINGS_DIR/$SETTINGS_PROFILE/extensions/$PLUGIN_FOLDER"
|
||
logg success 'Installed '"$FIREFOX_PLUGIN"''
|
||
fi
|
||
else
|
||
logg warn 'A null Firefox add-on filename was detected for '"$FIREFOX_PLUGIN"''
|
||
fi
|
||
else
|
||
logg warn 'A null Firefox add-on ID was detected for '"$FIREFOX_PLUGIN"''
|
||
fi
|
||
done
|
||
fi
|
||
done
|
||
fi
|
||
done
|
||
}
|
||
firefoxSetup
|
||
apt: firefox
|
||
apt:debian: firefox-esr
|
||
cask: firefox
|
||
choco: firefox
|
||
dnf: firefox
|
||
flatpak: org.mozilla.firefox
|
||
pacman: firefox
|
||
firefox-profile:
|
||
_bin: firefox-profile
|
||
_github: https://github.com/saadtazi/firefox-profile-js
|
||
_name: Firefox Profile CLI
|
||
npm: firefox-profile
|
||
firewall-applet:
|
||
_bin: firewall-applet
|
||
_github: false
|
||
apt: firewall-applet
|
||
dnf: firewall-applet
|
||
pacman: firewall-applet
|
||
firewall-config:
|
||
_bin: firewall-config
|
||
_github: false
|
||
apt: firewall-config
|
||
dnf: firewall-config
|
||
pacman: firewall-config
|
||
firewalld:
|
||
_bin: firewall-cmd
|
||
_github: https://github.com/firewalld/firewalld
|
||
_name: FirewallD
|
||
_notes: https://computingforgeeks.com/install-and-use-firewalld-on-ubuntu/
|
||
_pre: |
|
||
#!/usr/bin/env bash
|
||
if command -v ufw > /dev/null; then sudo ufw disable; fi
|
||
_service: firewalld
|
||
apt: firewalld
|
||
dnf: firewalld
|
||
emerge: net-firewall/firewalld
|
||
pacman: firewalld
|
||
zypper: firewalld
|
||
fiscript:
|
||
_app: FiScript.app
|
||
_bin: fiscript
|
||
_github: https://github.com/Mortennn/FiScript
|
||
_name: FiScript
|
||
cask: fiscript
|
||
fission:
|
||
_bin: fission
|
||
_desc: Fast and Simple Serverless Functions for Kubernetes
|
||
_docs: https://fission.io/docs/
|
||
_github: https://github.com/fission/fission
|
||
_home: https://fission.io/
|
||
_name: Fission
|
||
exe: https://github.com/fission/fission/releases/download/v1.19.0/fission-v1.19.0-windows-amd64.exe
|
||
github: github.com/fission/fission
|
||
nix-env: nixos.fission
|
||
script:darwin: cd /tmp && curl -sSLo fission https://github.com/fission/fission/releases/download/v1.19.0/fission-v1.19.0-darwin-amd64 && chmod +x fission && sudo mv fission /usr/local/bin/
|
||
script:linux: cd /tmp && curl -sSLo fission https://github.com/fission/fission/releases/download/v1.19.0/fission-v1.19.0-linux-amd64 && chmod +x fission && sudo mv fission /usr/local/bin/
|
||
fkill:
|
||
_bin: fkill
|
||
_desc: Fabulously kill processes. Cross-platform
|
||
_github: https://github.com/sindresorhus/fkill
|
||
_name: fkill
|
||
npm: fkill-cli
|
||
flake8:
|
||
_bin: flake8
|
||
_desc: Flake8 is a python tool that glues together pycodestyle, pyflakes, mccabe, and third-party plugins to check the style and quality of some python code.
|
||
_docs: https://flake8.pycqa.org/en/latest/
|
||
_github: https://github.com/PyCQA/flake8
|
||
_home: https://flake8.pycqa.org/en/latest/
|
||
_name: Flake8
|
||
brew: flake8
|
||
pipx: flake8
|
||
flameshot:
|
||
_app: flameshot.app
|
||
_bin: flameshot
|
||
_desc: Powerful yet simple to use screenshot software
|
||
_docs: https://flameshot.org/docs/overview/overview/
|
||
_github: https://github.com/flameshot-org/flameshot
|
||
_home: https://flameshot.org/
|
||
_name: Flameshot
|
||
_scoopExtras: true
|
||
apt: flameshot
|
||
cask: flameshot
|
||
choco: flameshot
|
||
dnf: flameshot
|
||
eopkg: flameshot
|
||
flatpak: org.flameshot.Flameshot
|
||
nix: nixos.flameshot
|
||
pacman: flameshot
|
||
port: flameshot
|
||
scoop: flameshot
|
||
snap: flameshot
|
||
winget: flameshot
|
||
xbps: flameshot
|
||
zypper: flameshot
|
||
flatseal:
|
||
_bin: flatseal
|
||
_github: https://github.com/tchx84/Flatseal
|
||
flatpak: com.github.tchx84.Flatseal
|
||
fleetctl:
|
||
_bin: fleetctl
|
||
_desc: Open-source platform for IT and security teams with thousands of computers. (Linux, macOS, Windows, ChromeOS, AWS, Google Cloud, Azure, data center, containers, IoT)
|
||
_docs: https://fleetdm.com/docs
|
||
_github: https://github.com/fleetdm/fleet
|
||
_home: https://fleetdm.com/
|
||
_name: Fleet CLI
|
||
npm: fleetctl
|
||
flow-launcher:
|
||
_bin: null
|
||
_desc: Quick file search & app launcher for Windows with community-made plugins
|
||
_docs: https://www.flowlauncher.com/docs/
|
||
_github: https://github.com/Flow-Launcher/Flow.Launcher
|
||
_home: https://flowlauncher.com/
|
||
_name: Flow Launcher
|
||
choco: Flow-Launcher
|
||
scoop: Flow-Launcher
|
||
winget: Flow Launcher
|
||
flutter:
|
||
_bin: flutter
|
||
_desc: '[Flutter](https://flutter.dev/) transforms the app development process. Build, test, and deploy beautiful mobile, web, desktop, and embedded apps from a single codebase'
|
||
_docs: https://docs.flutter.dev/
|
||
_github: https://github.com/flutter/flutter
|
||
_home: https://flutter.dev/
|
||
_name: Flutter
|
||
cask: flutter
|
||
choco: flutter
|
||
snap: flutter --classic
|
||
yay: flutter
|
||
fly:
|
||
_bin: fly
|
||
_desc: CLI to manage Concourse CI installation
|
||
_home: https://concourse-ci.org/
|
||
_github: https://github.com/concourse/concourse
|
||
_name: fly
|
||
cask: fly
|
||
github: https://github.com/concourse/concourse
|
||
yay: fly-cli
|
||
fm:
|
||
_bin: fm
|
||
_desc: Terminal file manager
|
||
_github: https://github.com/mistakenelf/fm
|
||
_name: fm
|
||
github: github.com/mistakenelf/fm
|
||
go: github.com/mistakenelf/fm@latest
|
||
footloose:
|
||
_bin: footloose
|
||
_desc: Container Machines - Containers that look like Virtual Machines
|
||
_docs: https://github.com/weaveworks/footloose
|
||
_github: https://github.com/weaveworks/footloose
|
||
_home: https://github.com/weaveworks/footloose
|
||
_name: Footloose
|
||
brew: weaveworks/tap/footloose
|
||
go: github.com/weaveworks/footloose@master
|
||
forever:
|
||
_bin: forever
|
||
_github: https://github.com/foreversd/forever
|
||
_name: Forever
|
||
npm: forever
|
||
forklift:
|
||
_bin: forklift
|
||
_github: https://github.com/Johnn3y/Forklift
|
||
flatpak: com.github.Johnn3y.Forklift
|
||
fpm:
|
||
_bin: fpm
|
||
_deps:
|
||
- fpm:deps
|
||
_desc: '[fpm](https://github.com/jordansissel/fpm) (short for Effing package management) allows you to build packages for multiple platforms with great ease. The source of your package can be a gem, Python module, pear, directory, .tar.gz, rpm, deb, Node.js package, or pacman package. The target packages it supports are deb, rpm, solaris, freebsd, tar, directory, Mac OS X .pkg file, or pacman package.'
|
||
_github: https://github.com/jordansissel/fpm
|
||
_name: fpm
|
||
ansible: professormanhattan.fpm
|
||
gem: fpm
|
||
fpm:deps:
|
||
_github: false
|
||
apt:
|
||
- build-essential
|
||
- ruby-dev
|
||
- rubygems
|
||
brew:
|
||
- gnu-tar
|
||
dnf:
|
||
- gcc
|
||
- libffi-devel
|
||
- make
|
||
- rpm-build
|
||
- ruby-devel
|
||
- rubygems
|
||
pacman:
|
||
- base-devel
|
||
- gcc
|
||
fq:
|
||
_bin: fq
|
||
_desc: jq for binary formats
|
||
_github: https://github.com/wader/fq
|
||
_name: fq
|
||
apk: fq
|
||
brew: wader/tap/fq
|
||
github: github.com/wader/fq
|
||
go: github.com/wader/fq@latest
|
||
pacman: fq
|
||
scoop: fq
|
||
fritzing:
|
||
_bin: fritzing
|
||
_desc: Fritzing is an open-source hardware initiative that makes electronics accessible as a creative material for anyone. We offer a software tool, a community website and services in the spirit of Processing and Arduino, fostering a creative ecosystem that allows users to document their prototypes, share them with others, teach electronics in a classroom, and layout and manufacture professional PCBs.
|
||
_docs: https://fritzing.org/learning/get-started
|
||
_github: https://github.com/fritzing/fritzing-app
|
||
_home: https://fritzing.org/
|
||
_name: Fritzing
|
||
_todo: Add installation source for macOS
|
||
choco: fritzing
|
||
flatpak: org.fritzing.Fritzing
|
||
frpc:
|
||
_bin: frpc
|
||
_desc: A fast reverse proxy to help you expose a local server behind a NAT or firewall to the internet.
|
||
_docs: https://github.com/fatedier/frp
|
||
_github: https://github.com/fatedier/frp
|
||
_home: https://github.com/fatedier/frp
|
||
_name: frpc (client)
|
||
brew: frpc
|
||
frps:
|
||
_bin: frps
|
||
_desc: A fast reverse proxy to help you expose a local server behind a NAT or firewall to the internet.
|
||
_docs: https://github.com/fatedier/frp
|
||
_github: https://github.com/fatedier/frp
|
||
_home: https://github.com/fatedier/frp
|
||
_name: frps (server)
|
||
brew: frps
|
||
fselect:
|
||
_bin: fselect
|
||
_desc: Extension to find files with SQL-like queries
|
||
_github: https://github.com/jhspetersson/fselect
|
||
_name: fselect
|
||
brew: fselect
|
||
cargo: fselect
|
||
choco: fselect
|
||
github: github.com/jhspetersson/fselect
|
||
yay: fselect
|
||
fuego:
|
||
_bin: fuego
|
||
_desc: Fuego is a command line client for the Firestore database
|
||
_docs: https://github.com/sgarciac/fuego
|
||
_github: https://github.com/sgarciac/fuego
|
||
_home: https://github.com/sgarciac/fuego
|
||
_name: Fuego
|
||
brew: fuego-firestore
|
||
go: github.com/sgarciac/fuego@latest
|
||
snap: fuego
|
||
fury:
|
||
_bin: fury
|
||
_github: https://github.com/gemfury/gemfury
|
||
_name: Fury
|
||
brew: gemfury/tap/gemfury
|
||
fuse:
|
||
_github: https://github.com/libfuse/libfuse
|
||
_bin: null
|
||
_desc: '[macFUSE](https://osxfuse.github.io/) allows you to extend macOS via third party file systems.'
|
||
_name: Fuse
|
||
_when:cask: '! test -d /usr/local/Caskroom/macfuse && ! test -d "$HOMEBREW_PREFIX/Caskroom/macfuse"'
|
||
ansible:darwin: professormanhattan.fuse
|
||
apt:
|
||
- fuse
|
||
- libfuse-dev
|
||
cask: macfuse
|
||
fx:
|
||
_bin: fx
|
||
_desc: A terminal JSON viewer.
|
||
_docs: https://github.com/antonmedv/fx/blob/master/doc/doc.md
|
||
_github: https://github.com/antonmedv/fx
|
||
_home: https://github.com/antonmedv/fx
|
||
_name: FX
|
||
brew: fx
|
||
go: github.com/antonmedv/fx@latest
|
||
pacman: fx
|
||
pkg: fx
|
||
scoop: fx
|
||
snap: fx
|
||
fzf:
|
||
_bin: fzf
|
||
_desc: "[fzf](https://github.com/junegunn/fzf) is a general-purpose command-line fuzzy finder. It's an interactive Unix filter for command-line that can be used with any list; files, command history, processes, hostnames, bookmarks, git commits, etc."
|
||
_docs: https://github.com/junegunn/fzf#usage
|
||
_github: https://github.com/junegunn/fzf
|
||
_home: https://github.com/junegunn/fzf
|
||
_name: fzf
|
||
ansible: professormanhattan.fzf
|
||
apk: fzf
|
||
apt: fzf
|
||
brew: fzf
|
||
dnf:fedora: fzf
|
||
nix: nixpkgs.fzf
|
||
pacman: fzf
|
||
pkg-freebsd: fzf
|
||
pkg_add: fzf
|
||
pkgin: fzf
|
||
port: fzf
|
||
xbps: fzf
|
||
zypper: fzf
|
||
gawk:
|
||
_bin: gawk
|
||
_desc: An implementation of the AWK programming language
|
||
_docs: https://www.gnu.org/software/gawk/manual/
|
||
_github: false
|
||
_home: https://www.gnu.org/software/gawk/
|
||
_name: gawk
|
||
apt: gawk
|
||
brew: gawk
|
||
choco: gawk
|
||
dnf: gawk
|
||
pacman: gawk
|
||
port: gawk
|
||
scoop: gawk
|
||
gcc:
|
||
_bin: gcc
|
||
_name: GCC
|
||
_github: https://github.com/gcc-mirror/gcc
|
||
apt: gcc
|
||
brew: gcc
|
||
dnf: gcc
|
||
pacman: gcc
|
||
port: gcc11
|
||
gcloud:
|
||
_bin: gcloud
|
||
_github: false
|
||
_desc: '[Google Cloud SDK](https://cloud.google.com/sdk) includes tools and libraries for interacting with Google Cloud products and services. With it, you can orchestrate virtual machine instances directly from your command line, manage Compute Engine networks/firewalls/disks, simulate Pub/Sub locally, and much more.'
|
||
_name: Google Cloud SDK
|
||
ansible: professormanhattan.googlecloudsdk
|
||
cask: google-cloud-sdk
|
||
choco: gcloudsdk
|
||
snap: google-cloud-sdk --classic
|
||
yay: google-cloud-sdk
|
||
gcsf:
|
||
_bin: gcsf
|
||
_github: https://github.com/harababurel/gcsf
|
||
_name: GCSF
|
||
cargo: gcsf
|
||
gdbgui:
|
||
_bin: gdbgui
|
||
_github: https://github.com/cs01/gdbgui
|
||
pipx: gdbgui
|
||
gdown:
|
||
_bin: gdown
|
||
_desc: Download a large file from Google Drive
|
||
_github: https://github.com/wkentaro/gdown
|
||
pipx: gdown
|
||
gdrive:
|
||
_bin: gdrive
|
||
_desc: Google Drive CLI Client
|
||
_docs: https://github.com/prasmussen/gdrive#usage
|
||
_github: https://github.com/prasmussen/gdrive
|
||
_home: https://github.com/prasmussen/gdrive
|
||
_name: gdrive
|
||
brew: gdrive
|
||
choco: gdrive
|
||
github: github.com/prasmussen/gdrive
|
||
go: github.com/prasmussen/gdrive@latest
|
||
port: gdrive
|
||
scoop: gdrive
|
||
yay: gdrive
|
||
gdu:
|
||
_bin: gdu
|
||
_github: https://github.com/dundee/gdu
|
||
_post:brew: |
|
||
#!/usr/bin/env bash
|
||
brew link --overwrite gdu
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
sudo snap connect gdu-disk-usage-analyzer:mount-observe :mount-observe
|
||
sudo snap connect gdu-disk-usage-analyzer:system-backup :system-backup
|
||
sudo snap alias gdu-disk-usage-analyzer.gdu gdu
|
||
apt:debian: gdu
|
||
brew: gdu
|
||
go: github.com/dundee/gdu/v5/cmd/gdu@latest
|
||
pacman: gdu
|
||
snap: gdu-disk-usage-analyzer
|
||
generator-ngx-rocket:
|
||
_bin: ngx
|
||
_github: https://github.com/ngx-rocket/generator-ngx-rocket
|
||
_name: Angular
|
||
npm: generator-ngx-rocket
|
||
genymotion:
|
||
_app: Genymotion.app
|
||
_github: false
|
||
cask: genymotion
|
||
choco: genymotion
|
||
# TODO: Figure out how to install on Android
|
||
gfi:
|
||
_bin: gfi
|
||
_desc: Google Font Installer is a NodeJS module/CLI that lets you Search, Download and Install fonts offered by Google Web Fonts
|
||
_github: https://github.com/lordgiotto/google-font-installer
|
||
npm: google-font-installer
|
||
gh:
|
||
_bin: gh
|
||
_desc: '[gh](https://cli.github.com/) is GitHub on the command line. It brings pull requests, issues, and other GitHub concepts to the terminal next to where you are already working with git and your code.'
|
||
_docs: https://cli.github.com/manual/
|
||
_github: https://github.com/cli/cli
|
||
_home: https://cli.github.com/
|
||
_name: Github CLI
|
||
ansible: professormanhattan.gh
|
||
brew: gh
|
||
choco: gh
|
||
port: gh
|
||
scoop: gh
|
||
winget: GitHub.cli
|
||
ghcup:
|
||
_bin: ghcup
|
||
_github: https://github.com/haskell/ghcup-hs
|
||
_name: GHCup
|
||
brew: ghcup
|
||
ghorg:
|
||
_bin: ghorg
|
||
_desc: "[ghorg](https://github.com/gabrie30/ghorg) allows you to quickly clone all of an org's, or user's repositories into a single directory."
|
||
_github: https://github.com/gabrie30/ghorg
|
||
_name: ghorg
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
ghorg reclone
|
||
ansible: professormanhattan.ghorg
|
||
brew: gabrie30/utils/ghorg
|
||
github: github.com/gabrie30/ghorg
|
||
go: github.com/gabrie30/ghorg@latest
|
||
yay: ghorg
|
||
gifsicle:
|
||
_bin: gifsicle
|
||
_github: https://github.com/kohler/gifsicle
|
||
_name: Gifsicle
|
||
apt: gifsicle
|
||
brew: gifsicle
|
||
choco: gifsicle
|
||
dnf: gifsicle
|
||
pacman: gifsicle
|
||
port: gifsicle
|
||
scoop: gifsicle
|
||
gimp:
|
||
_app: GIMP.app
|
||
_bin: gimp
|
||
_desc: '[GIMP](https://www.gimp.org/) is a free and open-source raster graphics editor used for image manipulation and image editing, free-form drawing, transcoding between different image file formats, and more specialized tasks. GIMP is released under GPLv3+ license and is available for Linux, macOS, and Microsoft Windows.'
|
||
_docs: https://www.gimp.org/docs/
|
||
_github: https://github.com/GNOME/gimp
|
||
_home: https://www.gimp.org/
|
||
_name: GIMP
|
||
ansible: professormanhattan.gimp
|
||
apt: gimp
|
||
cask: gimp
|
||
choco: gimp
|
||
dnf: gimp
|
||
flatpak: org.gimp.GIMP
|
||
pacman: gimp
|
||
snap: gimp
|
||
gist:
|
||
_bin: gist
|
||
_github: https://github.com/defunkt/gist
|
||
_desc: '[gist](https://github.com/defunkt/gist) provides a command that you can use from your terminal to upload content to https://gist.github.com/. This role will optionally set up a dotfile that handles authentication if you pass the appropriate configuration.'
|
||
_name: gist
|
||
ansible: professormanhattan.gist
|
||
gem: gist
|
||
git:
|
||
_bin: git
|
||
_github: https://github.com/git/git
|
||
apk: git
|
||
apt: git
|
||
brew: git
|
||
dnf: git
|
||
git-branchless:
|
||
_bin: git-branchless
|
||
_github: https://github.com/arxanas/git-branchless
|
||
_name: Git Branchless
|
||
_todo: |
|
||
echo "TODO: Consider implementing:"
|
||
echo "echo >> ~/.bashrc "alias git='git-branchless wrap --'""
|
||
apk: git-branchless
|
||
brew: git-branchless
|
||
cargo: --locked git-branchless
|
||
pacman: git-branchless
|
||
port: git-branchless
|
||
scoop: git-branchless
|
||
git-bug:
|
||
_bin: git-bug
|
||
_github: https://github.com/MichaelMure/git-bug
|
||
_name: Git Bug
|
||
brew: git-bug
|
||
pkg-freebsd: git-bug
|
||
scoop: git-bug
|
||
git-extras:
|
||
_bin: git-extras
|
||
_desc: '[Git Extras](https://github.com/tj/git-extras) includes extra git utilities that include repo summary, repl, changelog population, author commit percentages, and more.'
|
||
_name: git-extras
|
||
_github: https://github.com/tj/git-extras
|
||
ansible:windows: professormanhattan.gitextras
|
||
apt: git-extras
|
||
brew: git-extras
|
||
dnf: git-extras
|
||
pacman: git-extras
|
||
git-filter-repo:
|
||
_bin: git-filter-repo
|
||
_github: https://github.com/newren/git-filter-repo
|
||
_desc: '[gitfilterrepo](https://github.com/newren/git-filter-repo) is a versatile tool for rewriting history'
|
||
ansible: professormanhattan.gitfilterrepo
|
||
brew: git-filter-repo
|
||
pipx: git-filter-repo
|
||
git-jump:
|
||
_bin: git-jump
|
||
_github: https://github.com/mykolaharmash/git-jump
|
||
_name: Git Jump
|
||
brew: mykolaharmash/git-jump/git-jump
|
||
npm: git-jump
|
||
git-lfs:
|
||
_bin: git-lfs
|
||
_github: https://github.com/git-lfs/git-lfs
|
||
_deps:
|
||
- git
|
||
_desc: Git LFS (Large File Storage) replaces large files such as audio samples, videos, datasets, and graphics with text pointers inside Git, while storing the file contents on a remote server like GitHub.com or GitHub Enterprise.
|
||
_name: Git LFS
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo git lfs install --system
|
||
git lfs install
|
||
ansible: professormanhattan.gitlfs
|
||
brew: git-lfs
|
||
scoop: git-lfs
|
||
git-notify:
|
||
_bin: git-notify
|
||
_desc: Communicate important updates to your team via git commit messages
|
||
_github: https://github.com/jevakallio/git-notify
|
||
_name: Git Notify
|
||
npm: git-notify
|
||
git-open:
|
||
_bin: git-open
|
||
_desc: Open the repo website (GitHub, GitLab, Bitbucket) in your browser
|
||
_github: https://github.com/paulirish/git-open
|
||
npm: git-open
|
||
git-secret:
|
||
_bin: git-secret
|
||
_desc: '[git-secret](https://git-secret.io/) is a bash tool to store your private data inside a git repo. How’s that? Basically, it just encrypts, using GPG, the tracked files with the public keys of all the users that you trust. So everyone of them can decrypt these files using only their personal secret key.'
|
||
_docs: https://git-secret.io/#commands
|
||
_epel: true
|
||
_github: https://github.com/sobolevn/git-secret
|
||
_home: https://git-secret.io/
|
||
_name: Git Secret
|
||
ansible:darwin: professormanhattan.gitsecret
|
||
ansible:linux: professormanhattan.gitsecret
|
||
apt: git-secret
|
||
brew: git-secret
|
||
dnf:fedora: git-secret
|
||
git-stats:
|
||
_bin: git-stats
|
||
_desc: '[gitstats](https://github.com/IonicaBizau/git-stats) can track and display local git statistics. It includes the capability of displaying a GitHub-like contributions calendar in the terminal.'
|
||
_github: https://github.com/IonicaBizau/git-stats
|
||
_name: git-stats
|
||
ansible: professormanhattan.gitstats
|
||
npm: git-stats
|
||
git-subrepo:
|
||
_bin: git-subrepo
|
||
_github: https://github.com/ingydotnet/git-subrepo
|
||
_name: Git Sub Repo
|
||
brew: git-subrepo
|
||
git-town:
|
||
_bin: git-town
|
||
_github: https://github.com/git-town/git-town
|
||
_name: Git Town
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
git town aliases add
|
||
brew: git-town
|
||
go: github.com/git-town/git-town@latest
|
||
gitdock:
|
||
_app: GitDock.app
|
||
_bin: null
|
||
_desc: '[GitDock](https://gitlab.com/mvanremmerden/gitdock) is an app that displays all your GitLab activities in one place. Instead of the GitLab typical project- or group-centric approach, it collects all your information from a user-centric perspective.'
|
||
_docs: https://gitlab.com/mvanremmerden/gitdock#how-to-use-gitdock-%EF%B8%8F
|
||
_github: https://gitlab.com/mvanremmerden/gitdock
|
||
_home: https://gitlab.com/mvanremmerden/gitdock
|
||
_name: GitDock
|
||
ansible:darwin: professormanhattan.gitdock
|
||
cask: gitdock
|
||
github-classroom-assistant:
|
||
_app: Classroom Assistant.app
|
||
_bin: github-classroom-assistant
|
||
_github: https://github.com/education/classroom-assistant
|
||
_name: GitHub Classroom Assistant
|
||
apt: https://github.com/education/classroom-assistant/releases/download/v2.0.4/classroom-assistant_2.0.4_amd64.deb
|
||
cask: classroom-assistant
|
||
dnf: https://github.com/education/classroom-assistant/releases/download/v2.0.4/classroom-assistant-2.0.4-1.x86_64.rpm
|
||
exe: https://github.com/education/classroom-assistant/releases/download/v2.0.4/Classroom.Assistant-2.0.4.Setup.exe
|
||
github-desktop:
|
||
_app: GitHub Desktop.app
|
||
_bin: github
|
||
_github: https://github.com/desktop/desktop
|
||
cask: github
|
||
choco: github-desktop
|
||
flatpak: io.github.shiftey.Desktop
|
||
github-runner:
|
||
_bin: false
|
||
_desc: '[GitHub Runner](https://docs.github.com/en/actions/hosting-your-own-runners) is a system that you deploy and manage to execute jobs from GitHub Actions on GitHub.com.'
|
||
_docs: https://docs.github.com/en/actions/hosting-your-own-runners
|
||
_github: https://github.com/actions/runner
|
||
_home: https://docs.github.com/en/actions/hosting-your-own-runners
|
||
_name: GitHub Runner
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file GitHub Runner Registration
|
||
# @brief Registers a GitHub action runner with GitHub
|
||
# @description
|
||
# This script registers the host as a self-hosted GitHub runner with scope set
|
||
# in the `.user.github.runnerOrg` input in the `.chezmoi.yaml.tmpl` file. If your organization is `megabyte-labs`, then
|
||
# the value of `.user.github.runnerOrg` should be `megabyte-labs`. A self-hosted runner is an application
|
||
# that that allows you to run tasks from GitHub CI.
|
||
#
|
||
# This script adds 3 labels to the runner: self-hosted, _hostname_, and _operating-system family_.
|
||
#
|
||
# The script automatically acquires the GitHub Action runner token (as long as you specify your `.user.github.runnerOrg` value in `.chezmoi.yaml.tmpl`).
|
||
# In order to authenticate with GitHub, you should have the `GITHUB_TOKEN` environment variable in place with the appropriate permissions
|
||
# specified when you generate the token.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Secrets / Environment variables documentation](https://install.doctor/docs/customization/secrets)
|
||
|
||
|
||
### Check if GitHub runner is installed
|
||
if [ -f "${XDG_DATA_HOME:-$HOME/.local/share}/github-runnerconfig.sh" ]; then
|
||
if [ -f "${XDG_DATA_HOME:-$HOME/.local/share}/github-runner/.runner" ]; then
|
||
logg info "GitHub Actions runner is already configured (${XDG_DATA_HOME:-$HOME/.local/share}/github-runner/.runner file is present)"
|
||
else
|
||
logg info 'Creating runner configuration'
|
||
### Configure labels
|
||
LABELS="self-hosted,{{ .chezmoi.hostname }},{{ .host.distro.family }}"
|
||
if [ '{{ .host.distro.family }}' != '{{ .host.distro.id }}' ]; then
|
||
LABELS="${LABELS},{{ .host.distro.id }}"
|
||
fi
|
||
if command -v VirtualBox > /dev/null; then
|
||
LABELS="${LABELS},virtualbox"
|
||
fi
|
||
if command -v docker > /dev/null; then
|
||
LABELS="${LABELS},docker"
|
||
fi
|
||
|
||
if [ -n "$GITHUB_TOKEN" ]; then
|
||
if command -v jq > /dev/null; then
|
||
### Acquire token
|
||
logg info 'Acquiring runner token'
|
||
RUNNER_TOKEN="$(curl -sSL -X POST -H "Accept: application/vnd.github+json" -H "Authorization: Bearer $GITHUB_TOKEN" -H "X-GitHub-Api-Version: 2022-11-28" https://api.github.com/orgs/{{ .user.github.runnerOrg }}/actions/runners/registration-token | jq -r '.token')"
|
||
### Generate the configuration
|
||
logg info 'Joining GitHub runner to https://github.com/{{ .user.github.runnerOrg }}'
|
||
"${XDG_DATA_HOME:-$HOME/.local/share}/github-runner/config.sh" --unattended --url https://github.com/{{ .user.github.runnerOrg }} --token "$RUNNER_TOKEN" --labels "$LABELS" || EXIT_CODE=$?
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg error 'GitHub runner configuration failed' && exit 1
|
||
fi
|
||
### Install / start the service
|
||
logg info 'Configuring runner service'
|
||
"${XDG_DATA_HOME:-$HOME/.local/share}/github-runner/svc.sh" install && logg success 'Successfully installed the GitHub Actions runner service'
|
||
logg info 'Starting runner service'
|
||
"${XDG_DATA_HOME:-$HOME/.local/share}/github-runner/svc.sh" start && logg success 'Started the GitHub Actions runner service'
|
||
else
|
||
logg warn 'jq is required by the GitHub runner configuration script'
|
||
fi
|
||
else
|
||
logg warn 'The GITHUB_TOKEN environment variable is not present'
|
||
fi
|
||
fi
|
||
else
|
||
logg info "The GitHub Actions runner installation is not present at ${XDG_DATA_HOME:-$HOME/.local/share}/github-runner"
|
||
fi
|
||
_when: '! test -d "${XDG_DATA_HOME:-$HOME/.local/share}/github-runner"'
|
||
script: |
|
||
#!/usr/bin/env bash
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/shell/private.sh" ]; then
|
||
source "${XDG_CONFIG_HOME:-$HOME/.config}/shell/private.sh"
|
||
fi
|
||
if [ -n "$GITHUB_TOKEN" ]; then
|
||
RELEASES="$(curl -sSL --compressed --header "Authorization: Bearer $GITHUB_TOKEN" "https://api.github.com/repos/actions/runner/releases/latest")"
|
||
else
|
||
RELEASES="$(curl -sSL --compressed "https://api.github.com/repos/actions/runner/releases/latest")"
|
||
fi
|
||
LATEST_VERSION="$(echo "$RELEASES" | grep -o '"tag_name": "[^"]*' | grep -o '[^"]*$')"
|
||
ARCHITECTURE="$(uname -m | sed 's/86_//' | sed 's/v7l//')"
|
||
OS_FAMILY="$(test -d /Applications && echo osx || echo linux)"
|
||
curl -sSL "https://github.com/actions/runner/releases/download/$LATEST_VERSION/actions-runner-${OS_FAMILY}-${ARCHITECTURE}-${LATEST_VERSION:1}.tar.gz" > "/tmp/actions-runner-${OS_FAMILY}-${ARCHITECTURE}-${LATEST_VERSION:1}.tar.gz"
|
||
mkdir -p "${XDG_DATA_HOME:-$HOME/.local/share}/github-runner"
|
||
tar xzf "/tmp/actions-runner-${OS_FAMILY}-${ARCHITECTURE}-${LATEST_VERSION:1}.tar.gz" -C "${XDG_DATA_HOME:-$HOME/.local/share}/github-runner"
|
||
chown -Rf "$USER" "${XDG_DATA_HOME:-$HOME/.local/share}/github-runner"
|
||
rm -f "/tmp/actions-runner-${OS_FAMILY}-${ARCHITECTURE}-${LATEST_VERSION:1}.tar.gz"
|
||
gitify:
|
||
_app: Gitify.app
|
||
_bin: null
|
||
_description: GitHub notifications on the menu bar
|
||
_github: https://github.com/manosim/gitify
|
||
_home: https://github.com/manosim/gitify
|
||
_name: Gitify
|
||
cask: gitify
|
||
github: github.com/manosim/gitify
|
||
yay: gitify-bin
|
||
gitkraken:
|
||
_app: GitKraken.app
|
||
_bin: gitkraken
|
||
_desc: '[GitKraken](https://www.gitkraken.com/) is a software product for developers and dev teams. The Git Client is a leading software tool helping developers maximize their productivity with a beautiful, intuitive GUI.'
|
||
_docs: https://support.gitkraken.com/
|
||
_github: Not open-source
|
||
_home: https://www.gitkraken.com/
|
||
_name: GitKraken
|
||
ansible: professormanhattan.gitkraken
|
||
cask: gitkraken
|
||
choco: gitkraken
|
||
flatpak: com.axosoft.GitKraken
|
||
snap: gitkraken --classic
|
||
gitlab-runner:
|
||
_bin: gitlab-runner
|
||
_desc: '[GitLab Runner](https://docs.gitlab.com/runner/) is an application that works with GitLab CI/CD to run jobs in a pipeline.'
|
||
_docs: https://docs.gitlab.com/runner/
|
||
_github: https://github.com/gitlabhq/gitlab-runner
|
||
_home: https://gitlab.com/gitlab-org/gitlab-runner
|
||
_name: Gitlab Runner
|
||
_post: "#!/usr/bin/env bash\n# @file GitLab Runner Configuration\n# @brief Registers GitLab Runner(s) with the given GitLab instance\n# @description\n# This script registers the runner(s) with the given GitLab instance. SaaS GitLab can also be provided as the GitLab instance to register\n# the runners with. The script configures the runners to use either Docker or VirtualBox Executor. Refer to\n# [this page](https://docs.gitlab.com/runner/executors/docker.html) and [this page](https://docs.gitlab.com/runner/executors/virtualbox.html)\n# for details about the available configuration settings.\n#\n# Runners are always tagged with these 2 values: `hostname` and `docker`/`virtualbox` depending on the type of executor. If a list of tags is provided,\n# the runner is tagged with these values in addition to the above mentioned values. If the list of tags is empty, no additonal tags are added and the\n# runner is configured to pickup `untagged` jobs.\n#\n# Configuring other type of executors is not supported by this script.\n#\n# ## Secrets\n#\n# The following chart details the secret(s) that are needed to configure the runner:\n#\n# | Secret | Description |\n# |------------------------|------------------------------------------------------------|\n# | `GITLAB_RUNNER_TOKEN` | The token generated when the runner was created in GitLab |\n#\n# For more information about storing secrets like SSH keys and API keys, refer to our Secrets documentation provided below\n#\n# ## Configuration Variables\n#\n# The following chart details the input variable(s) that are used to determine the configuration of the runner:\n#\n# | Variable | Description |\n# |---------------------|----------------------------------------------------------------------------------------------------------|\n# | `glurl` | The URL of the Gitlab instance to associate the Runner with |\n# | `runnerImage` | Docker image to use to configure the runner. Needed only when configuring `Docker` executor |\n# | `runnerDescription` | Description of this runner |\n# | `runnerTags` | Comma separated list of tags for this runner. See details in the description for more info |\n# | `baseVM` | Name of the VirtualBox VM to use for creating runner. Needed only when configuring `VirtualBox` executor |\n#\n# ## Links\n#\n# * [Secrets / Environment variables documentation](https://install.doctor/docs/customization/secrets)\n\n### Check if Docker is installed and operational so Docker executor(s) can be registered\nif command -v docker > /dev/null && docker run --rm hello-world > /dev/null; then\n HAS_DOCKER=1\nelse\n HAS_DOCKER=0\n logg warn 'Docker is not installed or it is not operational'\nfi\n\n### Check if VirtualBox is installed and operational so VirtualBox executor(s) can be registered\nif command -v VirtualBox > /dev/null; then\n HAS_VIRTUALBOX=1\nelse\n HAS_VIRTUALBOX=0\n logg warn 'VirtualBox is not installed'\nfi\n\n### Configure runners if Docker or VirtualBox is installed\nif [ $HAS_DOCKER -eq 0 ] && [ $HAS_VIRTUALBOX -eq 0 ]; then\n logg warn 'Docker and VirtualBox are not installed. Not registering runner(s).'\nelse\n ### Run logic if gitlab-runner is installed\n if command -v gitlab-runner > /dev/null; then\n ### Populate appropriate token\n case \"$OSTYPE\" in\n solaris*) echo \"TODO\" ;;\n darwin*) GITLAB_RUNNER_TOKEN=\"{{ if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"GITLAB_RUNNER_TOKEN_DARWIN\")) }}{{ includeTemplate \"secrets/GITLAB_RUNNER_TOKEN_DARWIN\" | decrypt | trim }}{{ else }}{{ env \"GITLAB_RUNNER_TOKEN_DARWIN\" }}{{ end }}\" ;; \n linux*) GITLAB_RUNNER_TOKEN=\"{{ if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"GITLAB_RUNNER_TOKEN_LINUX\")) }}{{ includeTemplate \"secrets/GITLAB_RUNNER_TOKEN_LINUX\" | decrypt | trim }}{{ else }}{{ env \"GITLAB_RUNNER_TOKEN_LINUX\" }}{{ end }}\" ;;\n bsd*) echo \"TODO\" ;;\n msys*) GITLAB_RUNNER_TOKEN=\"{{ if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"GITLAB_RUNNER_TOKEN_WINDOWS\")) }}{{ includeTemplate \"secrets/GITLAB_RUNNER_TOKEN_WINDOWS\" | decrypt | trim }}{{ else }}{{ env \"GITLAB_RUNNER_TOKEN_WINDOWS\" }}{{ end }}\" ;;\n cygwin*) GITLAB_RUNNER_TOKEN=\"{{ if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"GITLAB_RUNNER_TOKEN_WINDOWS\")) }}{{ includeTemplate \"secrets/GITLAB_RUNNER_TOKEN_WINDOWS\" | decrypt | trim }}{{ else }}{{ env \"GITLAB_RUNNER_TOKEN_WINDOWS\" }}{{ end }}\" ;;\n *) echo \"unknown: $OSTYPE\" ;;\n esac\n\n ### Check if Runner Token value is present before attempting to register runner(s)\n if [ $GITLAB_RUNNER_TOKEN != \"\" ]; then\n ### Registering runners\n {{ $cmd := `gitlab-runner register \\\n --non-interactive \\\n --token $GITLAB_RUNNER_TOKEN \\` }}\n ### Register Docker based runners if Docker is installed and operational\n if [ $HAS_DOCKER -eq 1 ]; then\n logg info 'Registering GitLab Runner(s) that use Docker executor'\n {{- range .host.gitlabRunners }}\n {{- if index . \"runnerImage\" }}\n {{- $cmd }}\n --url {{ .glurl }} \\\n --executor \"docker\" \\\n --description \"{{ .runnerDescription }} - on {{ $.chezmoi.hostname }}\" \\\n --docker-image {{ .runnerImage }} \\\n {{ if and .runnerTags (gt (len .runnerTags) 0) }}--tag-list \"{{ .runnerTags }},{{ $.chezmoi.hostname }},docker\"\n {{- else }}--tag-list \"{{ $.chezmoi.hostname }},docker\" --run-untagged{{ end }} || echo 'Runner registration failed\"\n {{ end -}}\n {{ end }}\n fi\n \n ### Register VirtualBox based runners if VirtualBox is installed\n if [ $HAS_VIRTUALBOX -eq 1 ]; then\n logg info 'Registering GitLab Runner(s) that use VirtualBox executor'\n {{- range .host.gitlabRunners }}\n {{- if index . \"baseVM\" }}\n {{- $cmd }}\n --url {{ .glurl }} \\\n --executor \"virtualbox\" \\\n --description \"{{ .runnerDescription }} - on {{ $.chezmoi.hostname }}\" \\\n --virtualbox-base-name \"{{ .baseVM }}\" \\\n {{ if and .runnerTags (gt (len .runnerTags) 0) }}--tag-list \"{{ .runnerTags }},{{ $.chezmoi.hostname }},virtualbox\"\n {{- else }}--tag-list \"{{ $.chezmoi.hostname }},virtualbox\" --run-untagged{{ end }} || echo 'Runner registration failed\"\n {{ end -}}\n {{ end }}\n fi\n else\n logg warn 'GITLAB_RUNNER_TOKEN is not set. Not registering runner(s)'\n fi\n else\n logg warn 'gitlab-runner is not installed or is not available in PATH'\n fi\nfi\n"
|
||
_service: gitlab-runner
|
||
_serviceEnabled: true
|
||
ansible: professormanhattan.gitlabrunner
|
||
brew: gitlab-runner
|
||
choco: gitlab-runner
|
||
pacman: gitlab-runner
|
||
port: gitlab-runner
|
||
scoop: gitlab-runner
|
||
gitlabform:
|
||
_bin: gitlabform
|
||
_github: https://github.com/gitlabform/gitlabform/
|
||
pipx: gitlabform
|
||
gitleaks:
|
||
_bin: gitleaks
|
||
_desc: Extension to scan git repos (or files) for secrets using regex and entropy
|
||
_github: https://github.com/zricethezav/gitleaks
|
||
_name: gitleaks
|
||
brew: gitleaks
|
||
dnf:fedora: gitleaks
|
||
github: github.com/zricethezav/gitleaks
|
||
pkg: gitleaks
|
||
yay: gitleaks
|
||
gitmoji-cli:
|
||
_bin: gitmoji
|
||
_github: https://github.com/carloscuesta/gitmoji-cli
|
||
_npm: Gitmoji CLI
|
||
brew: gitmoji
|
||
npm: gitmoji-cli
|
||
gitomatic:
|
||
_bin: gitomatic
|
||
_desc: '[git-o-matic](https://github.com/muesli/gitomatic) is a tool to monitor git repositories and automatically pull & push changes'
|
||
_github: https://github.com/muesli/gitomatic
|
||
_name: git-o-matic
|
||
_post: "#!/usr/bin/env bash\n# @file git-o-matic Configuration\n# @brief Starts service on Linux systems to monitor Git repositories\n# @description\n# git-o-matic is a tool to monitor git repositories and automatically pull/push changes. Multiple repositories can be\n# monitored by running multiple instances of `gitomatic`. This script supports SSH Key based authentication only.\n#\n# If the `gitomatic` program is installed, this script creates and starts a Systemd service to monitor the repositories.\n# The repositories are cloned if they are not available at the path.\n#\n# ## Notes\n# * The author name and email address for commits are the same as `.user.name` and `.user.email` (configured in the `home/.chezmoi.yaml.tmpl` file)\n# * `gitomatic` automatically pushes and pulls changes. The script does not change this behavior\n# * `gitomatic` checks for changes every minute. This setting is not changed by this script\n# * The User's default SSH Key is used for authentication\n#\n# ## Links\n#\n# * [gitomatic GitHub repository](https://github.com/muesli/gitomatic/)\n# * [Systemd Unit file](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/gitomatic/gitomatic.service.tmpl)\n# * [Helper script](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_local/bin/executable_gitomatic_service.tmpl)\n\nif command -v gitomatic > /dev/null; then\n ### Copy bin to /usr/local/bin\n logg info \"Copying $HOME/.local/bin/gitomatic-service to /usr/local/bin/gitomatic-service\" && sudo cp -f \"$HOME/.local/bin/gitomatic-service\" /usr/local/bin/gitomatic-service\n \n ### Copy gitomatic to global directory\n if [ ! -f /usr/local/bin/gitomatic ]; then\n logg info 'Copying gitomatic executable to /usr/local/bin/gitomatic' && sudo cp -f \"$(which gitomatic)\" /usr/local/bin/gitomatic\n fi\n\n if [ -d /Applications ] && [ -d /System ]; then\n ### macOS\n logg info 'Copying gitomatic plist file to /Library/LaunchDaemons' && sudo cp -f \"${XDG_CONFIG_HOME:-$HOME/.config}/gitomatic/com.github.muesli.gitomatic.plist\" /Library/LaunchDaemons/com.github.muesli.gitomatic.plist\n if ! sudo launchctl list | grep 'gitomatic' > /dev/null; then\n logg info 'Running sudo launchctl load /Library/LaunchDaemons/com.github.muesli.gitomatic.plist' && sudo launchctl load /Library/LaunchDaemons/com.github.muesli.gitomatic.plist\n logg info 'Running sudo launchctl start /Library/LaunchDaemons/com.github.muesli.gitomatic.plist' && sudo launchctl start /Library/LaunchDaemons/com.github.muesli.gitomatic.plist\n else\n logg info \"gitomatic services appear to already be loaded\"\n fi\n else\n ### Linux\n logg info 'Copying gitomatic systemd unit file to /etc/systemd/system/' && sudo cp -f \"${XDG_CONFIG_HOME:-$HOME/.config}/gitomatic/gitomatic.service\" /etc/systemd/system/gitomatic.service\n logg info 'Reloading systemd daemon' && sudo systemctl daemon-reload\n logg info 'Enabling and starting gitomatic service' && sudo systemctl enable --now gitomatic\n fi\nelse\n logg info 'gitomatic is not installed or it is not available in PATH'\nfi\n"
|
||
ansible: professormanhattan.gitomatic
|
||
github: github.com/muesli/gitomatic
|
||
go: github.com/muesli/gitomatic@latest
|
||
pacman: gitomatic
|
||
scoop: gitomatic
|
||
gitql:
|
||
_bin: gitql
|
||
_github: https://github.com/filhodanuvem/gitql
|
||
_name: GitQL
|
||
brew: gitql
|
||
gitui:
|
||
_bin: gitui
|
||
_desc: Blazing fast TUI for git written in Rust
|
||
_docs: https://github.com/extrawurst/gitui
|
||
_github: https://github.com/extrawurst/gitui
|
||
_home: https://github.com/extrawurst/gitui
|
||
_name: Git UI
|
||
brew: gitui
|
||
cargo: gitui
|
||
choco: delta
|
||
dnf:fedora: gitui
|
||
nix: nixpkgs.gitui
|
||
pacman: gitui
|
||
pkg: gitui
|
||
port: gitui
|
||
scoop: gitui
|
||
winget: gitui
|
||
gixy:
|
||
_bin: gixy
|
||
_github: https://github.com/yandex/gixy
|
||
pipx: gixy
|
||
glab:
|
||
_bin: glab
|
||
_desc: An open-source GitLab command line tool bringing GitLab's cool features to your command line
|
||
_github: https://github.com/profclems/glab
|
||
_name: glab
|
||
apk: glab
|
||
brew: glab
|
||
github: github.com/profclems/glab
|
||
scoop: glab
|
||
# Only available on edge release (i.e. sudo snap install --edge glab)
|
||
# snap: glab
|
||
yay: gitlab-glab-bin
|
||
glances:
|
||
_bin: glances
|
||
_github: https://github.com/nicolargo/glances
|
||
_desc: '[Glances](https://github.com/nicolargo/glances) is a cross-platform monitoring tool which aims to present a maximum of information in a minimum of space through a curses or a web interface. It can adapt the displayed information depending on the terminal size dynamically. It is a top/htop alternative for Linux, BSD, macOS, and even Windows.'
|
||
_name: Glances
|
||
_post:pipx: |
|
||
#!/usr/bin/env bash
|
||
pipx inject glances glances[all]
|
||
ansible: professormanhattan.glances
|
||
apt:ubuntu:
|
||
- python3-dev
|
||
- python3-jinja2
|
||
- python3-pip
|
||
- python3-psutil
|
||
- python3-setuptools
|
||
- gcc
|
||
- glances
|
||
- lm-sensors
|
||
- wireless-tools
|
||
brew: glances
|
||
dnf:
|
||
- gcc
|
||
- glances
|
||
- lm_sensors
|
||
- python3-devel
|
||
- python3-pip
|
||
pacman:
|
||
- glances
|
||
- python
|
||
- lm_sensors
|
||
- wireless_tools
|
||
pipx: glances
|
||
port: glances
|
||
glen:
|
||
_bin: glen
|
||
_desc: A CLI to gather GitLab project and group variables
|
||
_github: https://github.com/lingrino/glen
|
||
go: github.com/lingrino/glen@latest
|
||
glow:
|
||
_bin: glow
|
||
_desc: Glow is a terminal based markdown reader designed from the ground up to bring out the beauty—and power—of the CLI
|
||
_github: https://github.com/charmbracelet/glow
|
||
_name: glow
|
||
brew: glow
|
||
github: github.com/charmbracelet/glow
|
||
pkg: glow
|
||
scoop: glow
|
||
yay: glow
|
||
glusterfs:
|
||
# TODO - The master / peer logic still needs to be implemented in the .chezmoiscripts
|
||
_bin: gluster
|
||
_desc: '[Gluster](https://www.gluster.org/) is a free and open source software scalable network filesystem. Gluster is a software defined distributed storage that can scale to several petabytes. It provides interfaces for object, block and file storage.'
|
||
_docs: https://docs.gluster.org/en/latest/
|
||
_github: https://github.com/gluster/glusterfs
|
||
_home: https://www.gluster.org/
|
||
_name: GlusterFS
|
||
_service: glusterd
|
||
# ansible:linux: professormanhattan.glusterfs
|
||
apt: glusterfs-server
|
||
dnf:fedora: glusterfs-server
|
||
pacman: glusterfs
|
||
gnome:
|
||
_bin: gnome
|
||
_github: https://github.com/GNOME/gnome-shell
|
||
_name: GNOME
|
||
apt: gnome
|
||
dnf: gnome
|
||
pacman: gnome
|
||
zypper: gnome
|
||
gnome-boxes:
|
||
_bin: gnome-boxes
|
||
_github: https://github.com/GNOME/gnome-boxes
|
||
_desc: GNOME Boxes is an application of the GNOME Desktop Environment, used to access virtual systems. Boxes uses the QEMU, KVM, and libvirt virtualization technologies
|
||
_docs: https://help.gnome.org/users/gnome-boxes/stable/
|
||
_home: https://apps.gnome.org/app/org.gnome.Boxes/
|
||
_name: GNOME Boxes
|
||
apt: gnome-boxes
|
||
dnf: gnome-boxes
|
||
flatpak: org.gnome.Boxes
|
||
pacman: gnome-boxes
|
||
gnome-calendar:
|
||
_bin: calendar
|
||
_github: https://github.com/GNOME/gnome-calendar
|
||
flatpak: org.gnome.Calendar
|
||
gnome-document-viewer:
|
||
_bin: document-viewer
|
||
_github: https://github.com/GNOME/evince
|
||
flatpak: org.gnome.Evince
|
||
gnome-extension-manager:
|
||
_bin: gnome-extension-manager
|
||
_github: https://github.com/mjakeman/extension-manager
|
||
flatpak: com.mattjakeman.ExtensionManager
|
||
gnome-eyedropper:
|
||
_github: https://github.com/FineFindus/eyedropper
|
||
_bin: eyedropper
|
||
flatpak: com.github.finefindus.eyedropper
|
||
gnome-file-roller:
|
||
_github: https://github.com/GNOME/file-roller
|
||
_bin: file-roller
|
||
flatpak: org.gnome.FileRoller
|
||
gnome-image-viewer:
|
||
_bin: image-viewer
|
||
_github: https://github.com/GNOME/eog
|
||
flatpak: org.gnome.eog
|
||
gnome-network-displays:
|
||
_bin: network-displays
|
||
_github: https://github.com/GNOME/gnome-network-displays
|
||
flatpak: org.gnome.NetworkDisplays
|
||
gnome-passwords-keys:
|
||
_bin: seahorse
|
||
_github: https://github.com/GNOME/seahorse
|
||
flatpak: org.gnome.seahorse.Application
|
||
gnome-photos:
|
||
_bin: photos
|
||
_github: https://github.com/GNOME/gnome-photos
|
||
flatpak: org.gnome.Photos
|
||
gnome-sound-recorder:
|
||
_bin: sound-recorder
|
||
_github: false
|
||
_gitlab: https://gitlab.gnome.org/World/vocalis
|
||
flatpak: org.gnome.SoundRecorder
|
||
gnome-text-editor:
|
||
_bin: text-editor
|
||
_github: https://github.com/GNOME/gnome-text-editor
|
||
flatpak: org.gnome.TextEditor
|
||
gnome-tweaks:
|
||
_bin: gnome-tweaks
|
||
_name: GNOME Tweaks
|
||
_github: https://github.com/GNOME/gnome-tweaks
|
||
apt: gnome-tweaks
|
||
dnf: gnome-tweaks
|
||
pacman: gnome-tweaks
|
||
gnome-video-player:
|
||
_bin: video-player
|
||
_github: https://github.com/GNOME/totem
|
||
flatpak: org.gnome.Totem
|
||
gnome-weather:
|
||
_bin: gnome-weather
|
||
_github: https://github.com/GNOME/gnome-weather
|
||
flatpak: org.gnome.Weather
|
||
gnu:
|
||
_github: false
|
||
_deps:darwin:
|
||
- coreutils
|
||
- findutils
|
||
- gawk
|
||
- gnu-indent
|
||
- gnu-tar
|
||
- gnu-sed
|
||
- gnutls
|
||
- grep
|
||
gnu-indent:
|
||
_bin: gindent
|
||
_github: false
|
||
brew: gnu-indent
|
||
gnu-sed:
|
||
_bin: gsed
|
||
_github: false
|
||
brew: gnu-sed
|
||
gnu-tar:
|
||
_bin: gtar
|
||
_github: false
|
||
brew: gnu-tar
|
||
gnutls:
|
||
_github: false
|
||
_bin: gnutls-certtool
|
||
brew: gnutls
|
||
go:
|
||
_bin: go
|
||
_desc: '[Go](https://golang.org/) is a statically typed, compiled programming language designed at Google by Robert Griesemer, Rob Pike, and Ken Thompson. Go is syntactically similar to C, but with memory safety, garbage collection, structural typing, and CSP-style concurrency.'
|
||
_docs: https://go.dev/doc/
|
||
_github: https://github.com/golang/go
|
||
_home: https://go.dev/
|
||
_name: Go
|
||
ansible: professormanhattan.go
|
||
apt: golang-go
|
||
brew: go
|
||
choco: golang
|
||
pacman: go
|
||
port: go
|
||
scoop: go
|
||
snap: go --classic
|
||
go-chromecast:
|
||
_bin: go-chromecast
|
||
_desc: CLI for Google Chromecast, Home devices and Cast Groups
|
||
_github: https://github.com/vishen/go-chromecast
|
||
_name: go-chromecast
|
||
github: github.com/vishen/go-chromecast
|
||
go: github.com/vishen/go-chromecast@latest
|
||
go-outline:
|
||
_bin: go-outline
|
||
_github: https://github.com/ramya-rao-a/go-outline
|
||
go: github.com/ramya-rao-a/go-outline@latest
|
||
goaccess:
|
||
_bin: goaccess
|
||
_desc: GoAccess is a real-time web log analyzer and interactive viewer that runs in a terminal in *nix systems or through your browser.
|
||
_docs: https://goaccess.io/get-started
|
||
_github: https://github.com/allinurl/goaccess
|
||
_home: https://goaccess.io/
|
||
_name: GoAccess
|
||
apt: goaccess
|
||
brew: goaccess
|
||
dnf:fedora: goaccess
|
||
emerge: net-analyzer/goaccess
|
||
pacman: goaccess
|
||
pkgin: goaccess
|
||
gojq:
|
||
_bin: gojq
|
||
_desc: gojq is a pure Go implementation of jq that is mostly backwards compatible (but not completely)
|
||
_github: https://github.com/itchyny/gojq
|
||
_name: gojq
|
||
brew: gojq
|
||
github: github.com/itchyny/gojq
|
||
go: github.com/itchyny/gojq@latest
|
||
golangci-lint:
|
||
_bin: golangci-lint
|
||
_desc: Fast linters Runner for Go
|
||
_github: https://github.com/golangci/golangci-lint
|
||
_home: https://golangci-lint.run/
|
||
brew: golangci-lint
|
||
go: github.com/golangci/golangci-lint/cmd/golangci-lint@latest
|
||
gomodifytags:
|
||
_bin: gomodifytags
|
||
_desc: Go tool to modify struct field tags
|
||
_github: https://github.com/fatih/gomodifytags
|
||
brew: gomodifytags
|
||
go: github.com/fatih/gomodifytags@latest
|
||
gomplate:
|
||
_bin: gomplate
|
||
_desc: A flexible commandline tool for template rendering. Supports lots of local and remote datasources.
|
||
_docker: docker run hairyhenderson/gomplate:stable
|
||
_docs: https://docs.gomplate.ca/
|
||
_github: https://github.com/hairyhenderson/gomplate
|
||
_home: https://gomplate.ca/
|
||
_name: Gomplate
|
||
apk: gomplate
|
||
brew: gomplate
|
||
choco: gomplate
|
||
port: gomplate
|
||
goofys:
|
||
_bin: goofys
|
||
_deps:
|
||
- fuse
|
||
_desc: A high-performance, POSIX-ish Amazon S3 file system written in Go
|
||
_docs: https://github.com/kahing/goofys#usage
|
||
_github: https://github.com/kahing/goofys
|
||
_home: https://github.com/kahing/goofys
|
||
_name: Goofys
|
||
ansible:linux: professormanhattan.goofys
|
||
brew:linux: goofys
|
||
go:linux: github.com/kahing/goofys@latest
|
||
google-assistant:
|
||
_app: Google Assistant.app
|
||
_bin: g-assist
|
||
_desc: '[Google Assistant for Desktop](https://github.com/Melvin-Abraham/Google-Assistant-Unofficial-Desktop-Client) is a cross-platform unofficial Google Assistant Client for Desktop.'
|
||
_github: https://github.com/Melvin-Abraham/Google-Assistant-Unofficial-Desktop-Client
|
||
_name: Google Assistant for Desktop
|
||
ansible:windows: professormanhattan.googleassistant
|
||
cask: google-assistant
|
||
github: github.com/Melvin-Abraham/Google-Assistant-Unofficial-Desktop-Client
|
||
snap: g-assist
|
||
winget: g-assist
|
||
google-chrome:
|
||
_app: Google Chrome.app
|
||
_bin: null
|
||
_deps:
|
||
- chrome-gnome-shell
|
||
_desc: '[Google Chrome](https://www.google.com/chrome/) is a cross-platform web browser developed by Google. It was first released in 2008 for Microsoft Windows, and was later ported to Linux, macOS, iOS, and Android where it is the default browser built into the OS.'
|
||
_docs: https://developer.chrome.com/docs/extensions/reference/
|
||
_env:
|
||
GOOGLE_CHROME_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Google/Chrome/Default"
|
||
flatpak: "$HOME/.var/app/com.google.Chrome/config/google-chrome/Default"
|
||
_github: Not open-source
|
||
_home: https://www.google.com/chrome/
|
||
_name: Google Chrome
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Chrome Settings / Extensions
|
||
# @brief This script configures Chrome, Brave, and Chromium system-wide managed / recommended policies settings. It also pre-loads a configurable list of Chrome extensions to Chrome, Brave, Chromium, and Edge (if they are installed).
|
||
# @description
|
||
# This Chrome setup script applies system-wide settings and pre-loads Chrome extensions into the browser profiles. The
|
||
# extensions still must be enabled but they appear in the Chrome extensions menu and can be enabled with the toggle. The
|
||
# system settings are applied to Chrome, Chromium, and Brave. Extensions are installed to the same browsers plus Microsoft Edge.
|
||
#
|
||
# ## Features
|
||
#
|
||
# * Adds `~/.config/chrome/managed.json` to the `managed/policies.json` system locations
|
||
# * Adds `~/.config/chrome/recommended.json` to the `recommended/policies.json` system locations
|
||
# * Pre-loads extension metadata for all the extensions defined under `chromeExtensions` in the [`home/.chezmoidata.yaml`](https://github.com/megabyte-labs/install.doctor/blob/master/home/.chezmoidata.yaml) file
|
||
#
|
||
# ## TODO
|
||
#
|
||
# * Automatically enable the extensions that are pre-loaded
|
||
# * Create several profiles with different characteristics (similar to the Firefox setup script)
|
||
# * Ensure the directories that the script cycles through to install managed settings and extensions are complete for all installation types (i.e. there might need to be some additions for Flatpak installations since their folder structure is different)
|
||
# * Document how [`chromium-flags.conf`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/chromium-flags.conf) can be or is integrated
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [`managed.json`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/chrome/managed.json)
|
||
# * [`recommended.json`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/chrome/recommended.json)
|
||
|
||
function chromeSetUp() {
|
||
### Ensure Chrome policies directory is present
|
||
logg info 'Processing policy directories for Chromium based browsers'
|
||
for POLICY_DIR in "/opt/google/chrome/policies"; do
|
||
if [ -d "$(dirname "$POLICY_DIR")" ]; then
|
||
### Managed policies
|
||
if [ ! -f "$POLICY_DIR/managed/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/managed exists"
|
||
sudo mkdir -p "$POLICY_DIR/managed"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json to $POLICY_DIR/managed/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json" "$POLICY_DIR/managed/policies.json"
|
||
fi
|
||
|
||
### Recommended policies
|
||
if [ ! -f "$POLICY_DIR/recommended/policies.json" ]; then
|
||
logg info "Ensuring directory $POLICY_DIR/recommended exists" && sudo mkdir -p "$POLICY_DIR/recommended"
|
||
logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json to $POLICY_DIR/recommended/policies.json"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json" "$POLICY_DIR/recommended/policies.json"
|
||
fi
|
||
else
|
||
logg info "Skipping extension injection into $POLICY_DIR - create these folders prior to running to create managed configs"
|
||
fi
|
||
done
|
||
|
||
### Add Chrome extension JSON
|
||
logg info 'Populating Chrome extension JSON'
|
||
for EXTENSION_DIR in "/opt/google/chrome/extensions" "$HOME/Library/Application Support/Google/Chrome/External Extensions"; do
|
||
### Ensure program-type is installed
|
||
if [ -d "$(dirname "$EXTENSION_DIR")" ]; then
|
||
### Ensure extension directory exists
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && sudo mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
else
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
fi
|
||
|
||
### Add extension JSON
|
||
logg info "Adding Chrome extensions to $EXTENSION_DIR"
|
||
for EXTENSION in {{ list (.chromeExtensions | toString | replace "[" "" | replace "]" "") | uniq | join " " }}; do
|
||
logg info "Adding Chrome extension manifest ($EXTENSION)"
|
||
if ! echo "$EXTENSION" | grep 'https://chrome.google.com/webstore/detail/' > /dev/null; then
|
||
EXTENSION="https://chrome.google.com/webstore/detail/$EXTENSION"
|
||
fi
|
||
EXTENSION_ID="$(echo "$EXTENSION" | sed 's/^.*\/\([^\/]*\)$/\1/')"
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
else
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
fi
|
||
done
|
||
else
|
||
logg info "$EXTENSION_DIR does not exist"
|
||
fi
|
||
done
|
||
}
|
||
chromeSetUp
|
||
ansible: professormanhattan.chrome
|
||
cask: google-chrome
|
||
choco: googlechrome
|
||
flatpak: com.google.Chrome
|
||
yay: google-chrome
|
||
google-drive:
|
||
_app: Google Drive.app
|
||
_bin: google-drive
|
||
_desc: Google Drive for Desktop integrates a Google Drive account into your macOS / Windows workstation by adding a menubar with options to synchronize folders to the cloud.
|
||
_docs: false
|
||
_github: false
|
||
_home: https://www.google.com/drive/download/
|
||
_name: Google Drive
|
||
cask: google-drive
|
||
choco: googledrive
|
||
google-web-designer:
|
||
_bin: google-web-designer
|
||
_github: false
|
||
_desc: Google Web Designer gives you the power to create beautiful and compelling videos, images, and HTML5 ads. Use animation and interactive elements to build out your creative vision, then scale your content for different sizes or audiences with responsive and dynamic workflows.
|
||
_name: Google Web Designer
|
||
cask: google-web-designer
|
||
choco: google-web-designer
|
||
gopass:
|
||
_bin: gopass
|
||
_desc: The slightly more awesome standard unix password manager for teams
|
||
_docs: https://github.com/gopasspw/gopass/tree/master/docs
|
||
_github: https://github.com/gopasspw/gopass
|
||
_home: https://www.gopass.pw/
|
||
_name: GoPass
|
||
apk: gopass
|
||
brew: gopass
|
||
choco:
|
||
- gpg4win
|
||
- gopass
|
||
dnf: gopass
|
||
go: github.com/gopasspw/gopass@latest
|
||
pacman: gopass
|
||
scoop: gopass
|
||
winget: gopass.gopass
|
||
gopkgs:
|
||
_bin: gopkgs
|
||
_desc: Tool to get list available Go packages
|
||
_github: https://github.com/uudashr/gopkgs
|
||
go: github.com/uudashr/gopkgs/v2/cmd/gopkgs@latest
|
||
gopls:
|
||
_bin: gopls
|
||
_github: false
|
||
brew: gopls
|
||
go: golang.org/x/tools/gopls@latest
|
||
goreleaser:
|
||
_bin: goreleaser
|
||
_github: https://github.com/goreleaser/goreleaser
|
||
_name: Go Releaser
|
||
brew: goreleaser
|
||
go: github.com/goreleaser/goreleaser@latest
|
||
nix-env: goreleaser
|
||
snap: goreleaser --classic
|
||
yay: goreleaser-bin
|
||
gotests:
|
||
_bin: gotests
|
||
_desc: Automatically generate Go test boilerplate from your source code
|
||
_github: https://github.com/cweill/gotests
|
||
brew: gotests
|
||
go: github.com/cweill/gotests/...@latest
|
||
gphotos-sync:
|
||
_bin: gphotos-sync
|
||
_desc: Google Photos Sync is a backup tool for your Google Photos cloud storage.
|
||
_docs: https://gilesknap.github.io/gphotos-sync/main/index.html
|
||
_github: https://github.com/gilesknap/gphotos-sync
|
||
_home: https://gilesknap.github.io/gphotos-sync/main/index.html
|
||
_name: Google Photos Sync
|
||
pacman: gphotos-sync
|
||
pipx: gphotos-sync
|
||
gping:
|
||
_bin: gping
|
||
_desc: '[gping](https://github.com/orf/gping) is like the regular ping command except it also displays a chart labeled with response timing statistics.'
|
||
_github: https://github.com/orf/gping
|
||
_name: gping
|
||
ansible: professormanhattan.gping
|
||
brew: gping
|
||
cargo: gping
|
||
choco: gping
|
||
github: github.com/orf/gping
|
||
pacman: gping
|
||
scoop: gping
|
||
gpt-engineer:
|
||
_bin: gpt-engineer
|
||
_github: https://github.com/AntonOsika/gpt-engineer
|
||
_name: GPT Engineer
|
||
pipx: gpt-engineer
|
||
gradle:
|
||
_bin: gradle
|
||
_desc: '[Gradle](https://gradle.org/) is a build automation tool for multi-language software development. It controls the development process in the tasks of compilation and packaging to testing, deployment, and publishing. Supported languages include Java, C/C++, JavaScript.'
|
||
_docs: https://docs.gradle.org/current/userguide/userguide.html
|
||
_github: https://github.com/gradle/gradle
|
||
_home: https://gradle.org/
|
||
_name: Gradle
|
||
ansible: professormanhattan.gradle
|
||
brew: gradle
|
||
choco: gradle
|
||
port: gradle
|
||
scoop: gradle
|
||
snap: gradle --classic
|
||
graphql-playground:
|
||
_app: GraphQL Playground.app
|
||
_bin: graphql-playground
|
||
_github: https://github.com/graphql/graphql-playground
|
||
_name: GraphQL Playground
|
||
appimage: graphql/graphql-playground
|
||
cask: graphql-playground
|
||
exe: https://github.com/graphql/graphql-playground/releases/download/v1.8.10/graphql-playground-electron-setup-1.8.10.exe
|
||
grep:
|
||
_bin: grep
|
||
_github: false
|
||
apt: grep
|
||
brew: grep
|
||
dnf: grep
|
||
pacman: grep
|
||
zypper: grep
|
||
grex:
|
||
_bin: grex
|
||
_desc: A command-line tool and library for generating regular expressions from user-provided test cases
|
||
_docs: https://github.com/pemistahl/grex#5-how-to-use
|
||
_github: https://github.com/pemistahl/grex
|
||
_home: https://pemistahl.github.io/grex-js/
|
||
_name: grex
|
||
brew: grex
|
||
cargo: grex
|
||
choco: grex
|
||
github: github.com/pemistahl/grex
|
||
scoop: grex
|
||
snap: grex
|
||
gron:
|
||
_bin: gron
|
||
_desc: Extension to make JSON greppable
|
||
_github: https://github.com/tomnomnom/gron
|
||
_name: gron
|
||
brew: gron
|
||
github: github.com/tomnomnom/gron
|
||
go: github.com/tomnomnom/gron@latest
|
||
grype:
|
||
_bin: grype
|
||
_desc: A vulnerability scanner for container images and filesystems
|
||
_docs: https://github.com/anchore/grype#getting-started
|
||
_github: https://github.com/anchore/grype
|
||
_home: https://github.com/anchore/grype
|
||
_name: Grype
|
||
brew: anchore/grype/grype
|
||
choco: grype
|
||
port: grype
|
||
yay: grype-bin
|
||
gtop:
|
||
_bin: gtop
|
||
_desc: System monitoring dashboard for terminal
|
||
_github: https://github.com/aksakalli/gtop
|
||
brew: gtop
|
||
npm: gtop
|
||
guacamole:
|
||
_bin: null
|
||
_desc: '[Apache Guacamole](https://guacamole.apache.org/) is a clientless remote desktop gateway. It supports standard protocols like VNC, RDP, and SSH.'
|
||
_docs: https://guacamole.apache.org/doc/gug/configuring-guacamole.html
|
||
_github: https://github.com/apache/guacamole-client
|
||
_home: https://guacamole.apache.org/
|
||
_name: Guacamole
|
||
ansible: professormanhattan.guacamole
|
||
gulp:
|
||
_bin: gulp
|
||
_desc: '[Gulp](https://gulpjs.com/) is a toolkit to automate & enhance your workflow'
|
||
_docs: https://gulpjs.com/docs/en/getting-started/quick-start
|
||
_github: https://github.com/gulpjs/gulp
|
||
_home: https://gulpjs.com/
|
||
_name: Gulp
|
||
# Brew gulp is deprecated
|
||
# brew: gulp
|
||
npm: gulp
|
||
gum:
|
||
_bin: gum
|
||
_desc: A tool for glamorous shell scripts. Provides styling and fancy prompts.
|
||
_docs: https://github.com/charmbracelet/gum
|
||
_github: https://github.com/charmbracelet/gum
|
||
_home: https://charm.sh/
|
||
_name: Gum
|
||
apk: gum
|
||
brew: gum
|
||
go: github.com/charmbracelet/gum@latest
|
||
nix: nixpkgs.gum
|
||
pacman: gum
|
||
pkg-termux: gum
|
||
gup:
|
||
_bin: gup
|
||
_github: https://github.com/nao1215/gup
|
||
_name: Gup
|
||
brew: nao1215/tap/gup
|
||
go: github.com/nao1215/gup@latest
|
||
gvm:
|
||
_bin: null
|
||
_desc: '[gvm](https://github.com/moovweb/gvm) lets you manage Go environments and switch between Go versions.'
|
||
_github: https://github.com/moovweb/gvm
|
||
_name: rvm
|
||
ansible: professormanhattan.gvm
|
||
hadolint:
|
||
_bin: hadolint
|
||
_desc: A smarter Dockerfile linter that helps you build best practice Docker images. The linter parses the Dockerfile into an AST and performs rules on top of the AST
|
||
_github: https://github.com/hadolint/hadolint
|
||
_name: hadolint
|
||
brew: hadolint
|
||
dnf:fedora: hadolint
|
||
scoop: hadolint
|
||
handbrake:
|
||
_app: HandBrake.app
|
||
_bin: handbrake
|
||
_github: https://github.com/HandBrake/HandBrake
|
||
cask: handbrake
|
||
choco: handbrake
|
||
flatpak: fr.handbrake.ghb
|
||
handlr:
|
||
_bin: handlr
|
||
_desc: A better xdg-utils
|
||
_docs: https://github.com/chmln/handlr#usage
|
||
_github: https://github.com/chmln/handlr
|
||
_home: https://github.com/chmln/handlr
|
||
_name: Handlr
|
||
cargo: handlr --locked
|
||
yay: handlr-bin
|
||
haproxy:
|
||
_bin: haproxy
|
||
_github: https://github.com/haproxy/haproxy
|
||
_name: HAProxy
|
||
_service: haproxy
|
||
apk: haproxy
|
||
apt: haproxy
|
||
brew: haproxy
|
||
choco: haproxy
|
||
dnf: haproxy
|
||
pacman: haproxy
|
||
zypper: haproxy
|
||
has:
|
||
_bin: has
|
||
_github: https://github.com/kdabir/has
|
||
_name: Has
|
||
brew: kdabir/tap/has
|
||
hbs-cli:
|
||
_bin: hbs
|
||
_desc: This is a CLI tool to render handlebars templates, with the ability to require in Partials, Helpers and JSON Data
|
||
_github: https://github.com/keithamus/hbs-cli
|
||
npm: hbs-cli
|
||
hclq:
|
||
_bin: hclq
|
||
_desc: Command-line processor for HashiCorp config files, like sed for HCL — Terraform, Consul, Nomad, Vault
|
||
_github: https://github.com/mattolenik/hclq
|
||
_name: hclq
|
||
github: github.com/mattolenik/hclq
|
||
go: github.com/mattolenik/hclq@latest
|
||
helix:
|
||
_bin: hx
|
||
_desc: A post-modern modal text editor.
|
||
_docs: https://docs.helix-editor.com/
|
||
_github: https://github.com/helix-editor/helix
|
||
_home: https://helix-editor.com/
|
||
_name: Helix Editor
|
||
_repology: helix
|
||
brew: helix
|
||
choco: helix
|
||
flatpak: com.helix_editor.Helix
|
||
pacman: helix
|
||
scoop: helix
|
||
winget: Helix.Helix
|
||
helm:
|
||
_bin: helm
|
||
_desc: The Kubernetes Package Manager. Helm is the best way to find, share, and use software built for Kubernetes.
|
||
_docs: https://helm.sh/docs
|
||
_github: https://github.com/helm/helm
|
||
_home: https://helm.sh/
|
||
_name: Helm
|
||
brew: helm
|
||
choco: kubernetes-helm
|
||
scoop: helm
|
||
snap: helm --classic
|
||
helm-docs:
|
||
_bin: helm-docs
|
||
_github: https://github.com/norwoodj/helm-docs
|
||
_name: Helm Docs
|
||
brew: norwoodj/tap/helm-docs
|
||
scoop: helm-docs
|
||
helmfile:
|
||
_bin: helmfile
|
||
_github: https://github.com/helmfile/helmfile
|
||
_name: Helmfile
|
||
brew: helmfile
|
||
pacman: helmfile
|
||
scoop: helmfile
|
||
zypper: helmfile
|
||
heroku-cli:
|
||
_bin: heroku
|
||
_github: https://github.com/heroku/cli
|
||
_desc: '[Heroku CLI](https://devcenter.heroku.com/articles/heroku-cli) lets you create and manage Heroku apps directly from the terminal. It’s an essential part of using Heroku.'
|
||
_name: Heroku CLI
|
||
ansible: professormanhattan.heroku
|
||
brew: heroku/brew/heroku
|
||
choco: heroku-cli
|
||
npm: heroku
|
||
scoop: heroku-cli
|
||
yay: heroku-cli
|
||
hexyl:
|
||
_bin: hexyl
|
||
_desc: '[hexyl](https://github.com/sharkdp/hexyl) is a simple hex viewer for the terminal. It uses a colored output to distinguish different categories of bytes (NULL bytes, printable ASCII characters, ASCII whitespace characters, other ASCII characters and non-ASCII).'
|
||
_github: https://github.com/sharkdp/hexyl
|
||
_name: hexyl
|
||
ansible: professormanhattan.hexyl
|
||
apt: hexyl
|
||
brew: hexyl
|
||
cargo: hexyl
|
||
dnf:fedora: hexyl
|
||
github: github.com/sharkdp/hexyl
|
||
nix: hexyl
|
||
pacman: hexyl
|
||
pkg-freebsd: hexyl
|
||
pkg-termux: hexyl
|
||
port: hexyl
|
||
scoop: hexyl
|
||
xbps: hexyl
|
||
hey:
|
||
_bin: hey
|
||
_desc: HTTP load generator, ApacheBench (ab) replacement, formerly known as rakyll/boom
|
||
_github: https://github.com/rakyll/hey
|
||
_name: hey
|
||
brew: hey
|
||
github: github.com/rakyll/hey
|
||
hiddenbar:
|
||
_app: Hidden Bar.app
|
||
_bin: null
|
||
_desc: macOS menu bar application that allows you to add menu bar items to a hideable drawer
|
||
_docs: https://github.com/dwarvesf/hidden
|
||
_github: https://github.com/dwarvesf/hidden
|
||
_home: https://dwarves.foundation/opensource/
|
||
_name: Hidden Bar
|
||
cask: hiddenbar
|
||
mas: 1452453066
|
||
himalaya:
|
||
_bin: himalaya
|
||
_github: https://github.com/soywod/himalaya
|
||
_desc: '[Himalaya](https://github.com/soywod/himalaya) is a CLI email client written in Rust.'
|
||
_name: Himalaya
|
||
ansible: professormanhattan.himalaya
|
||
brew: himalaya
|
||
scoop: himalaya
|
||
hishtory:
|
||
_bin: hishtory
|
||
_github: https://github.com/ddworken/hishtory
|
||
_name: hiSHtory
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
echo y | hishtory init "$HISHTORY_USER_SECRET"
|
||
_todo: Check for Homebrew version
|
||
script: curl -sSL --compressed https://hishtory.dev/install.py | python3 -
|
||
hoard:
|
||
_bin: hoard
|
||
_github: https://github.com/Hyde46/hoard
|
||
_name: Hoard
|
||
# brew: Hyde46/hoard/hoard # Fails with cURL trying to download non-existant release file
|
||
cargo: hoard-rs
|
||
nix-env: hoard
|
||
# Might be paru instead of pacman
|
||
pacman: hoard
|
||
port: hoard-cli
|
||
holehe:
|
||
_bin: holehe
|
||
_github: https://github.com/megadose/holehe
|
||
_name: Holehe
|
||
pipx: holehe
|
||
hostctl:
|
||
_bin: hostctl
|
||
_desc: This tool gives more control over the use of hosts file
|
||
_github: https://github.com/guumaster/hostctl
|
||
_name: hostctl
|
||
brew: guumaster/tap/hostctl
|
||
github: github.com/guumaster/hostctl
|
||
scoop: hostctl
|
||
yay: hostctl
|
||
hosthomepage:
|
||
_bin: null
|
||
_name: Host Home Page
|
||
_github: false
|
||
ansible: professormanhattan.hosthomepage
|
||
hosts:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role is intended to be used with the [main ProfessorManhattan playbook](https://gitlab.com/ProfessorManhattan/Playbooks). It integrates tightly with the configuration variables that come with the playbook.
|
||
_name: Hosts
|
||
ansible: professormanhattan.hosts
|
||
howdoi:
|
||
_bin: howdoi
|
||
_github: https://github.com/gleitz/howdoi
|
||
_name: howdoi
|
||
brew: howdoi
|
||
pipx: howdoi
|
||
hss:
|
||
_bin: hss
|
||
_github: https://github.com/six-ddc/hss
|
||
_name: hss
|
||
brew: hss
|
||
port: hss
|
||
script: cd /tmp && git clone https://github.com/six-ddc/hss.git && cd hss && make && make install && cd /tmp && rm -rf hss
|
||
hstr:
|
||
_bin: hstr
|
||
_github: https://github.com/dvorka/hstr
|
||
_name: HiSToRy
|
||
apk: hstr
|
||
apt: hstr
|
||
brew: hstr
|
||
dnf: hstr
|
||
emerge: app-shells/hstr
|
||
nix-env: hstr
|
||
pkg-freebsd: hstr
|
||
port: histr
|
||
xbps: hstr
|
||
htmlhint:
|
||
_bin: htmlhint
|
||
_desc: The static code analysis tool you need for your HTML
|
||
_docs: https://htmlhint.com/docs/user-guide/getting-started
|
||
_github: https://github.com/htmlhint/HTMLHint
|
||
_home: https://htmlhint.com/
|
||
_name: HTMLHint
|
||
npm: htmlhint
|
||
htmlq:
|
||
_bin: htmlq
|
||
_desc: A lightweight and flexible command-line JSON processor for HTML
|
||
_github: https://github.com/mgdm/htmlq
|
||
_name: htmlq
|
||
brew: htmlq
|
||
cargo: htmlq
|
||
github: github.com/mgdm/htmlq
|
||
htop:
|
||
_bin: htop
|
||
_desc: '[htop](https://htop.dev/) is an interactive system-monitor process-viewer and process-manager. It is designed as an alternative to the Unix program top. It shows a frequently updated list of the processes running on a computer, normally ordered by the amount of CPU usage.'
|
||
_docs: https://www.man7.org/linux/man-pages/man1/htop.1.html
|
||
_github: https://github.com/htop-dev/htop
|
||
_home: https://htop.dev/
|
||
_name: htop
|
||
ansible:darwin: professormanhattan.htop
|
||
ansible:linux: professormanhattan.htop
|
||
apt: htop
|
||
brew: htop
|
||
dnf: htop
|
||
pacman: htop
|
||
port: htop
|
||
http-prompt:
|
||
_bin: http-prompt
|
||
_desc: HTTP Prompt is an interactive command-line HTTP client featuring autocomplete and syntax highlighting, built on HTTPie and prompt_toolkit.
|
||
_docs: https://docs.http-prompt.com/en/latest/
|
||
_github: https://github.com/httpie/http-prompt
|
||
_home: https://http-prompt.com/
|
||
_name: HTTP Prompt
|
||
brew: http-prompt
|
||
pipx: http-prompt
|
||
http-toolkit:
|
||
_app: HTTP Toolkit.app
|
||
_github: https://github.com/httptoolkit/httptoolkit
|
||
_name: HTTP Toolkit
|
||
apt: https://github.com/httptoolkit/httptoolkit-desktop/releases/download/v1.14.8/HttpToolkit-1.14.8.deb
|
||
cask: http-toolkit
|
||
winget: HTTPToolKit.HTTPToolKit
|
||
yay: httptoolkit
|
||
httpie:
|
||
_bin: httpie
|
||
_desc: '[HTTPie](https://httpie.io/) is a terminal-based, user-friendly command-line HTTP client for the API era. It comes with JSON support, syntax highlighting, persistent sessions, wget-like downloads, plugins, and more.'
|
||
_name: HTTPie
|
||
_github: https://github.com/httpie/cli
|
||
_todo: Look into https://github.com/httpie/desktop as alternative to Postman and other HTTP request clients
|
||
ansible: professormanhattan.httpie
|
||
brew: httpie
|
||
choco: httpie
|
||
dnf: httpie
|
||
pacman: httpie
|
||
pipx: httpie
|
||
port: httpie
|
||
snap: httpie
|
||
httpstat:
|
||
_bin: httpstat
|
||
_desc: curl statistics made simple
|
||
_docs: https://github.com/reorx/httpstat#usage
|
||
_github: https://github.com/reorx/httpstat
|
||
_home: https://github.com/reorx/httpstat
|
||
_name: httpstat
|
||
brew: httpstat
|
||
pipx: httpstat
|
||
hub:
|
||
_bin: hub
|
||
_desc: Add GitHub support to git on the command-line
|
||
_github: https://hub.github.com/
|
||
apt: hub
|
||
brew: hub
|
||
choco: hub
|
||
dnf:fedora: hub
|
||
pacman: hub
|
||
pkg: hub
|
||
scoop: hub
|
||
hugo:
|
||
_bin: hugo
|
||
_desc: The world’s fastest framework for building websites.
|
||
_docs: https://gohugo.io/documentation/
|
||
_github: https://github.com/gohugoio/hugo
|
||
_home: https://gohugo.io/
|
||
_name: Hugo
|
||
apt: hugo
|
||
brew: hugo
|
||
choco: hugo
|
||
dnf: hugo
|
||
eopkg: hugo
|
||
go: github.com/gohugoio/hugo@latest
|
||
pacman: hugo
|
||
port: hugo
|
||
scoop: main/hugo
|
||
snap: hugo
|
||
zypper: hugo
|
||
hurl:
|
||
_bin: hurl
|
||
_github: https://github.com/Orange-OpenSource/hurl
|
||
brew: hurl
|
||
cargo: hurl
|
||
choco: hurl
|
||
npm: '@orangeopensource/hurl'
|
||
pkg-freebsd: hurl
|
||
port: hurl
|
||
scoop: hurl
|
||
winget: hurl
|
||
husky:
|
||
_bin: husky
|
||
_desc: Husky improves your commits and more
|
||
_github: https://github.com/typicode/husky
|
||
_home: https://typicode.github.io/husky/
|
||
_name: Husky
|
||
npm: husky
|
||
hyper:
|
||
_appImageName: Hyper
|
||
_bin: null
|
||
_desc: '[Hyper](https://hyper.is/) is an electron-based terminal. It is written using web technologies such as HTML, CSS, JavaScript etc. It looks very modern and has lots of customization options.'
|
||
_docs: https://hyper.is/blog
|
||
_github: https://github.com/vercel/hyper
|
||
_home: https://hyper.is/
|
||
_name: Hyper
|
||
ansible: professormanhattan.hyper
|
||
appimage: hyper
|
||
brew: hyper
|
||
choco: hyper
|
||
yay: hyper
|
||
hyperfine:
|
||
_bin: hyperfine
|
||
_desc: '[hyperfine](https://github.com/sharkdp/hyperfine) is a cross-platform command-line benchmarking tool that can be used to determine the performance of shell commands.'
|
||
_docs: https://docs.rs/crate/hyperfine/1.2.0
|
||
_github: https://github.com/sharkdp/hyperfine
|
||
_name: hyperfine
|
||
ansible: professormanhattan.hyperfine
|
||
apk: hyperfine
|
||
brew: hyperfine
|
||
cargo: hyperfine
|
||
choco: hyperfine
|
||
dnf: hyperfine
|
||
github: github.com/sharkdp/hyperfine
|
||
pacman: hyperfine
|
||
pkg: hyperfine
|
||
hyperkit:
|
||
_bin: hyperkit
|
||
_deps:darwin:
|
||
- xcode
|
||
_github: https://github.com/moby/hyperkit
|
||
_name: HyperKit
|
||
brew:darwin: hyperkit
|
||
ideviceinstaller:
|
||
_bin: ideviceinstaller
|
||
_github: https://github.com/libimobiledevice/ideviceinstaller
|
||
brew:darwin: ideviceinstaller
|
||
iina:
|
||
_app: iina.app
|
||
_bin: null
|
||
_desc: The modern video player for macOS.
|
||
_docs: https://iina.io/
|
||
_github: https://github.com/iina/iina
|
||
_home: https://iina.io/
|
||
_name: iina macOS Video Player
|
||
cask: iina
|
||
imagemagick:
|
||
_bin: convert
|
||
_github: https://github.com/ImageMagick/ImageMagick
|
||
apk: imagemagick
|
||
apt:
|
||
- imagemagick
|
||
- libx11-dev
|
||
brew: imagemagick
|
||
choco: imagemagick
|
||
dnf:fedora: imagemagick
|
||
scoop: imagemagick
|
||
imageoptim:
|
||
_app: ImageOptim.app
|
||
_bin: null
|
||
_desc: Image compressor that utilizes other applications like ImageOptim under the hood
|
||
_github: https://github.com/ImageOptim/ImageOptim
|
||
_home: https://imageoptim.com/mac
|
||
cask: imageoptim
|
||
imageoptim-cli:
|
||
_bin: imageoptim
|
||
_deps:
|
||
- imageoptim
|
||
_desc: Image compressor that utilizes other applications like ImageOptim under the hood
|
||
_github: https://github.com/ImageOptim/ImageOptim
|
||
_home: https://imageoptim.com/mac
|
||
brew:darwin-x86_64: imageoptim-cli
|
||
npm:darwin: imageoptim-cli
|
||
imagine:
|
||
_app: Imagine.app
|
||
_bin: null
|
||
_desc: Imagine is a desktop app for compression of PNG and JPEG, with a modern and friendly UI.
|
||
_docs: https://github.com/meowtec/Imagine
|
||
_github: https://github.com/meowtec/Imagine
|
||
_home: https://github.com/meowtec/Imagine
|
||
_name: Imagine
|
||
appimage: meowtec/Imagine
|
||
exe: https://github.com/meowtec/Imagine/releases/download/v0.7.4/Imagine-Setup-0.7.4.exe
|
||
script:darwin: curl -sSL https://github.com/meowtec/Imagine/releases/download/v0.7.4/Imagine-0.7.4.dmg > /tmp/Imagine.dmg && sudo hdiutil attach /tmp/Imagine.dmg && sudo cp -R "/Volumes/Imagine 0.7.4/Imagine.app" /Applications && sudo hdiutil detach "/Volumes/Imagine 0.7.4" && rm -f /tmp/Imagine.dmg
|
||
imgur-uploader:
|
||
_bin: imgur-uploader
|
||
_desc: Upload images to imgur
|
||
_github: https://github.com/kevva/imgur-uploader-cli
|
||
npm: imgur-uploader-cli
|
||
impl:
|
||
_bin: impl
|
||
_desc: impl generates method stubs for implementing an interface
|
||
_github: https://github.com/josharian/impl
|
||
go: github.com/josharian/impl@latest
|
||
infracost:
|
||
_bin: infracost
|
||
_desc: '[infracost](https://www.infracost.io/) provides cloud cost estimates for Terraform in pull requests'
|
||
_docs: https://www.infracost.io/docs
|
||
_github: https://github.com/infracost/infracost
|
||
_home: https://www.infracost.io/
|
||
_name: infracost
|
||
brew: infracost
|
||
choco: infracost
|
||
yay: infracost
|
||
inkscape:
|
||
_app: Inkscape.app
|
||
_bin: inkscape
|
||
_desc: '[Inkscape](https://inkscape.org/) is a free and open-source vector graphics editor used to create vector images, primarily in Scalable Vector Graphics format. Other formats can be imported and exported. Inkscape can render primitive vector shapes and text. This role installs Inkscape on nearly any platform.'
|
||
_docs: https://inkscape.org/*docs/
|
||
_github: https://github.com/inkscape/inkscape
|
||
_home: https://inkscape.org
|
||
_name: Inkscape
|
||
ansible: professormanhattan.inkscape
|
||
apt: inkscape
|
||
cask: inkscape
|
||
choco: inkscape
|
||
dnf: inkscape
|
||
flatpak: org.inkscape.Inkscape
|
||
pacman: inkscape
|
||
snap: inkscape
|
||
intellij-idea-ce:
|
||
_app: IntelliJ IDEA CE.app
|
||
_bin: intellij-idea-community
|
||
_desc: '[IntelliJ IDEA](https://www.jetbrains.com/idea/) is an integrated development environment written in Java for developing computer software. It is developed by JetBrains, and is available as an Apache 2 Licensed community edition, and in a proprietary commercial edition. Both can be used for commercial development.'
|
||
_docs: https://www.jetbrains.com/help/
|
||
_github: https://github.com/JetBrains/intellij-community
|
||
_home: https://www.jetbrains.com/idea/
|
||
_name: IntelliJ IDEA (CE)
|
||
ansible: professormanhattan.intellij
|
||
cask: intellij-idea-ce
|
||
choco: intellijidea-community
|
||
snap: intellij-idea-community --classic
|
||
iodine:
|
||
_bin: iodined
|
||
_github: https://github.com/yarrick/iodine
|
||
_name: Iodine
|
||
brew: iodine
|
||
choco: iodine
|
||
ionic:
|
||
_bin: ionic
|
||
_desc: '[Ionic Framework](https://ionicframework.com/) The Ionic command line interface (CLI) is your go-to tool for developing Ionic apps'
|
||
_docs: https://ionicframework.com/docs
|
||
_github: https://github.com/ionic-team/ionic-cli
|
||
_home: https://ionicframework.com/
|
||
_name: Ionic Framework
|
||
npm: '@ionic/cli'
|
||
ios-deploy:
|
||
_bin: ios-deploy
|
||
_desc: Install and debug iPhone apps from the command line, without using Xcode
|
||
_github: https://github.com/ios-control/ios-deploy
|
||
brew:darwin: ios-deploy
|
||
npm:darwin: ios-deploy
|
||
ios-sim:
|
||
_bin: ios-sim
|
||
_github: https://github.com/ios-control/ios-sim
|
||
_name: ios-sim
|
||
npm:darwin: ios-sim
|
||
ipfs:
|
||
_bin: ipfs
|
||
_desc: A peer-to-peer hypermedia protocol designed to preserve and grow humanity's knowledge by making the web upgradeable, resilient, and more open
|
||
_docs: https://docs.ipfs.tech/
|
||
_github: https://github.com/ipfs/ipfs
|
||
_home: https://ipfs.tech/
|
||
_name: IPFS
|
||
_service: ipfs
|
||
brew: ipfs
|
||
choco: go-ifps
|
||
nix: ipfs
|
||
port: ipfs
|
||
scoop: go-ipfs
|
||
snap: ipfs
|
||
ipfs-deploy:
|
||
_bin: ipd
|
||
_desc: A peer-to-peer hypermedia protocol designed to preserve and grow humanity's knowledge by making the web upgradeable, resilient, and more open
|
||
_docs: https://docs.ipfs.tech/
|
||
_github: https://github.com/ipfs/ipfs
|
||
_home: https://ipfs.tech/
|
||
_name: IPFS
|
||
npm: ipfs-deploy
|
||
ipfs-desktop:
|
||
_app: IPFS Desktop.app
|
||
_bin: null
|
||
_desc: An unobtrusive and user-friendly desktop application for IPFS on Windows, Mac and Linux.
|
||
_docs: https://docs.ipfs.tech/install/ipfs-desktop/
|
||
_github: https://github.com/ipfs/ipfs-desktop
|
||
_home: https://ipfs.tech/
|
||
_name: IPFS Desktop
|
||
appimage: https://github.com/ipfs-shipyard/ipfs-desktop/releases/download/v0.28.0/ipfs-desktop-0.28.0-linux-x86_64.AppImage
|
||
cask: ipfs
|
||
choco: ipfs-desktop
|
||
scoop: extras/ipfs-desktop
|
||
winget: IPFS.IPFS-Desktop
|
||
ipmitool:
|
||
_bin: ipmitool
|
||
_github: https://github.com/ipmitool/ipmitool
|
||
_name: IPMI Tool
|
||
apt: ipmitool
|
||
brew: ipmitool
|
||
dnf: ipmitool
|
||
pacman: ipmitool
|
||
iproute2mac:
|
||
_bin: ip
|
||
_github: https://github.com/brona/iproute2mac
|
||
_name: iproute2mac
|
||
brew:darwin: iproute2mac
|
||
iredis:
|
||
_bin: iredis
|
||
_desc: A terminal client for Redis with auto-completion and syntax highlightin
|
||
_docs: https://github.com/laixintao/iredis
|
||
_github: https://github.com/laixintao/iredis
|
||
_home: https://pypi.org/project/iredis/
|
||
_name: iRedis
|
||
apt: iredis
|
||
brew: iredis
|
||
pipx: iredis
|
||
irssi:
|
||
_bin: irssi
|
||
_desc: Irssi is a modular text mode chat client. It comes with IRC support built in, and there are third party ICB, SILC, XMPP (Jabber), PSYC and Quassel protocol modules available.
|
||
_docs: https://irssi.org/documentation/
|
||
_github: https://github.com/irssi/irssi
|
||
_home: https://irssi.org/
|
||
_name: irssi
|
||
apt: irssi
|
||
brew: irssi
|
||
dnf: irssi
|
||
pacman: irssi
|
||
port: irssi
|
||
is-up:
|
||
_bin: is-up
|
||
_desc: Check whether a website is up or down using the isitup.org API
|
||
_github: https://github.com/sindresorhus/is-up-cli
|
||
npm: is-up-cli
|
||
iso-image-writer:
|
||
_github: https://github.com/KDE/isoimagewriter
|
||
_bin: iso-image-writer
|
||
_name: ISO Image Writer
|
||
flatpak: org.kde.isoimagewriter
|
||
isort:
|
||
_bin: isort
|
||
_desc: isort is a Python utility / library to sort imports alphabetically, and automatically separated into sections and by type.
|
||
_docs: https://pycqa.github.io/isort/index.html
|
||
_github: https://github.com/PyCQA/isort
|
||
_home: https://pycqa.github.io/isort/
|
||
_name: iSort
|
||
brew: isort
|
||
pipx: isort
|
||
iterm2:
|
||
_app: iTerm.app
|
||
_bin: null
|
||
_desc: '[iTerm2](https://eugeny.github.io/iterm2/) is a highly configurable terminal emulator, SSH and serial client for Windows, macOS and Linux.'
|
||
_docs: https://iterm2.com/documentation.html
|
||
_github: https://github.com/gnachman/iTerm2
|
||
_home: https://iterm2.com/
|
||
_name: iTerm2
|
||
_post:cask: |
|
||
#!/usr/bin/env bash
|
||
echo "Setting iTerm2 options location to Install Doctor Chezmoi location" && defaults write com.googlecode.iterm2 PrefsCustomFolder -string "${XDG_DATA_HOME:-$HOME/.local/share}/chezmoi/home/Library/Preferences/com.googlecode.iterm2.plist"
|
||
echo "Setting iTerm2 to automatically sync with managed options" && defaults write com.googlecode.iterm2 NoSyncNeverRemindPrefsChangesLostForFile_selection -int 2
|
||
ansible:darwin: professormanhattan.iterm2
|
||
cask: iterm2
|
||
java:
|
||
_bin: false
|
||
_desc: '[Java](https://www.java.com/en/) is a class-based, object-oriented programming language that is designed to have as few implementation dependencies as possible.'
|
||
_docs: https://docs.oracle.com/en/cloud/paas/nosql-cloud/index.html
|
||
_github: https://github.com/oracle/nosql-java-sdk
|
||
_home: https://www.java.com/en/
|
||
_name: Java
|
||
_when:cask: '! brew list temurin > /dev/null'
|
||
ansible: professormanhattan.java
|
||
apt: openjdk-11-jdk
|
||
brew: openjdk
|
||
cask: temurin
|
||
choco: jdk11
|
||
dnf: java-11-openjdk-devel.x86_64
|
||
pacman: jdk-openjdk
|
||
port: openjdk11
|
||
scoop: openjdk11
|
||
jc:
|
||
_bin: jc
|
||
_github: https://github.com/kellyjonbrazil/jc
|
||
_name: jc
|
||
apt: jc
|
||
brew: jc
|
||
dnf: jc
|
||
nix-env: nixpkgs.jc
|
||
pacman: jc
|
||
pipx: jc
|
||
zypper: jc
|
||
jenv:
|
||
_bin: jenv
|
||
_desc: '[jenv](https://www.jenv.be/) lets you switch between Java versions. It sets JAVA_HOME inside your shell, in a way that can be set globally, local to the current working directory or per shell.'
|
||
_docs: https://github.com/gcuisinier/jenv/wiki
|
||
_github: https://github.com/jenv/jenv
|
||
_home: https://www.jenv.be/
|
||
_name: jenv
|
||
ansible: professormanhattan.jenv
|
||
brew: jenv
|
||
jest:
|
||
_bin: jest
|
||
_desc: Delightful JavaScript testing.
|
||
_docs: https://jestjs.io/docs/getting-started
|
||
_github: https://github.com/jestjs/jest
|
||
_home: https://jestjs.io/
|
||
_name: Jest
|
||
npm: jest
|
||
jiq:
|
||
_bin: jiq
|
||
_desc: Create jq queries interactively by leveraging a live reload feature in the terminal
|
||
_github: https://github.com/fiatjaf/jiq
|
||
_name: jiq
|
||
github: github.com/fiatjaf/jiq/cmd/jiq
|
||
go: github.com/fiatjaf/jiq/cmd/jiq@latest
|
||
jitsi-meet:
|
||
_app: Jitsi Meet.app
|
||
_bin: jitsi-meet
|
||
_desc: Desktop application for Jitsi Meet built with Electron
|
||
_github: https://github.com/jitsi/jitsi-meet-electron
|
||
_name: Jitsi Meet Electron
|
||
cask: jitsi-meet
|
||
choco: jitsi-meet-electron
|
||
flatpak: org.jitsi.jitsi-meet
|
||
github: github.com/jitsi/jitsi-meet-electron
|
||
pkg: jitsi-meet
|
||
yay: jitsi-meet-desktop-bin
|
||
jo:
|
||
_bin: jo
|
||
_desc: '[jo](https://github.com/jpmens/jo) is a free and open-source command-line tool that allows you to create JSON objects.'
|
||
_github: https://github.com/jpmens/jo
|
||
_name: jo
|
||
ansible: professormanhattan.jo
|
||
apt: jo
|
||
brew: jo
|
||
github: github.com/jpmens/jo
|
||
pkg: jo
|
||
scoop: jo
|
||
snap: jo
|
||
yay: jo
|
||
john:
|
||
_bin: john
|
||
_github: https://github.com/openwall/john
|
||
_name: John
|
||
apt: john
|
||
brew: john
|
||
choco: john
|
||
dnf: john
|
||
pacman: john
|
||
jpegoptim:
|
||
_bin: jpegoptim
|
||
_github: https://github.com/tjko/jpegoptim
|
||
_name: JPEGOptim
|
||
apt: jpegoptim
|
||
brew: jpegoptim
|
||
choco: jpegoptim
|
||
dnf: jpegoptim
|
||
pacman: jpegoptim
|
||
zypper: jpegoptim
|
||
jq:
|
||
_bin: jq
|
||
_desc: '[jq](https://github.com/stedolan/jq) is like sed for JSON data. You can use it to slice and filter and map and transform structured data with the same ease that sed, awk, grep and friends let you play with text.'
|
||
_docs: https://stedolan.github.io/jq/manual/
|
||
_github: https://github.com/stedolan/jq
|
||
_home: https://stedolan.github.io/jq
|
||
_name: jq
|
||
ansible: professormanhattan.jq
|
||
apk: jq
|
||
apt: jq
|
||
brew: jq
|
||
choco: jq
|
||
dnf: jq
|
||
github: github.com/stedolan/jq
|
||
pkg: jq
|
||
jqp:
|
||
_bin: jqp
|
||
_desc: A TUI playground to experiment with jq
|
||
_docs: https://github.com/noahgorstein/jqp#usage
|
||
_github: https://github.com/noahgorstein/jqp
|
||
_home: https://github.com/noahgorstein/jqp
|
||
_name: jqp
|
||
brew: noahgorstein/tap/jqp
|
||
port: jqp
|
||
yay: jqp
|
||
json-server:
|
||
_bin: json-server
|
||
_desc: Get a full fake REST API with zero coding in less than 30 seconds (seriously)
|
||
_docs: https://github.com/typicode/json-server
|
||
_github: https://github.com/typicode/json-server
|
||
_home: https://github.com/typicode/json-server
|
||
_name: JSON Server
|
||
npm: json-server
|
||
juicefs:
|
||
_bin: juicefs
|
||
_github: https://github.com/juicedata/juicefs
|
||
_name: JuiceFS
|
||
_post: |
|
||
#!/usr/bin/env sh
|
||
. "$HOME/.local/bin/installx/juicefs.sh"
|
||
brew: juicefs
|
||
scoop: juicefs
|
||
snap: juicefs
|
||
yay: juicefs
|
||
juju:
|
||
_bin: juju
|
||
_github: https://github.com/juju/juju
|
||
_desc: '[Juju](https://juju.is/) is a Charmed Operator Framework, composed of a Charmed Operator Lifecycle Manager, and the Charmed Operator SDK. It allows you to deploy, integrate, and manage Kubernetes, container, and VM-native applications seamlessly across hybrid clouds. Juju drives Day 0 through Day 2 operations in your complex environment.'
|
||
_docs: https://juju.is/docs
|
||
_home: https://juju.is/
|
||
_name: Juju
|
||
ansible: professormanhattan.juju
|
||
brew: juju
|
||
choco: juju
|
||
snap: juju --classic
|
||
junction:
|
||
_bin: junction
|
||
_github: https://github.com/sonnyp/Junction
|
||
flatpak: re.sonny.Junction
|
||
just:
|
||
_bin: just
|
||
_github: https://github.com/casey/just
|
||
_name: Just
|
||
apk: just
|
||
apt: just
|
||
brew: just
|
||
cargo: just
|
||
choco: just
|
||
dnf: just
|
||
eopkg: just
|
||
nix-env: nixpkgs.just
|
||
pacman: just
|
||
pkg-freebsd: just
|
||
port: just
|
||
scoop: just
|
||
snap: --edge --classic just
|
||
winget: Casey.Just
|
||
xbps: just
|
||
k9s:
|
||
_bin: k9s
|
||
_github: https://github.com/derailed/k9s
|
||
_name: K9s
|
||
brew: derailed/k9s/k9s
|
||
choco: k9s
|
||
pacman: k9s
|
||
port: k9s
|
||
scoop: k9s
|
||
kap:
|
||
_app: Kap.app
|
||
_bin: kap
|
||
_github: https://github.com/wulkano/Kap
|
||
_name: Kap
|
||
cask: kap
|
||
kasmvnc:
|
||
_bin: kasmvncpasswd
|
||
_github: https://github.com/kasmtech/KasmVNC
|
||
script:linux: |
|
||
RELEASES=$(curl -sS "https://api.github.com/repos/kasmtech/KasmVNC/releases/latest") || :
|
||
LATEST_VERSION=$(echo $RELEASES | grep -o '"tag_name": "[^"]*' | grep -o '[^"]*$') || :
|
||
if command -v apt-get > /dev/null; then
|
||
. /etc/os-release
|
||
cd /tmp
|
||
case $VERSION_CODENAME in
|
||
bullseye )
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_bullseye_${LATEST_VERSION:1}_amd64.deb" || :
|
||
;;
|
||
buster )
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_buster_${LATEST_VERSION:1}_amd64.deb" || :
|
||
;;
|
||
focal )
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_focal_${LATEST_VERSION:1}_amd64.deb" || :
|
||
;;
|
||
jammy )
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_jammy_${LATEST_VERSION:1}_amd64.deb" || :
|
||
;;
|
||
* )
|
||
;;
|
||
esac
|
||
if ls kasmvncserver*.deb > /dev/null 2>&1; then sudo apt-get install ./kasmvncserver_*.deb; sudo addgroup $USER ssl-cert; fi
|
||
elif command -v dnf > /dev/null; then
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_centos_core_${LATEST_VERSION:1}_x86_64.rpm" || :
|
||
if ls kasmvncserver*.rpm > /dev/null 2>&1; then sudo rpm -ivh ./kasmvncserver_*.rpm; sudo usermod -a -G kasmvnc-cert $USER; fi
|
||
elif command -v zypper > /dev/null; then
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvncserver_opensuse_15_${LATEST_VERSION:1}_x86_64.rpm" || :
|
||
if ls kasmvncserver*.rpm > /dev/null 2>&1; then sudo rpm -ivh ./kasmvncserver_*.rpm; sudo usermod -a -G kasmvnc-cert $USER; fi
|
||
elif command -v apk > /dev/null; then
|
||
wget "https://github.com/kasmtech/KasmVNC/releases/download/$LATEST_VERSION/kasmvnc.alpine_317_x86_64.tgz" || :
|
||
if ls kasmvncserver*.rpm > /dev/null 2>&1; then sudo tar -xzf "./kasmvnc.alpine_317_x86_64.tgz" -C /; fi
|
||
fi
|
||
yay: kasmvncserver-bin
|
||
kcpassword:
|
||
_bin: kcpassword
|
||
_github: https://github.com/xfreebird/kcpassword
|
||
_name: kcpassword
|
||
brew:darwin: xfreebird/utils/kcpassword
|
||
kdash:
|
||
_bin: kdash
|
||
_desc: A simple and fast dashboard for Kubernetes
|
||
_github: https://github.com/kdash-rs/kdash
|
||
_home: https://kdash.cli.rs/
|
||
_name: kdash
|
||
brew: kdash-rs/kdash/kdash
|
||
cargo: kdash
|
||
choco: kdash
|
||
github: github.com/kdash-rs/kdash
|
||
scoop: kdash
|
||
kde-plasma-desktop:
|
||
_bin: plasmashell
|
||
_github: https://github.com/KDE/plasma-desktop
|
||
_deps:
|
||
- kdeplasma-addons
|
||
apt: kde-plasma-desktop
|
||
dnf: kde-plasma-desktop
|
||
pacman: kde-plasma-desktop
|
||
kdenlive:
|
||
_app: kdenlive.app
|
||
_bin: kdenlive
|
||
_github: https://github.com/KDE/kdenlive
|
||
_name: Kdenlive
|
||
cask: kdenlive
|
||
choco: kdenlive
|
||
flatpak: org.kde.kdenlive
|
||
kdeplasma-addons:
|
||
_github: https://github.com/KDE/kdeplasma-addons
|
||
apt: kdeplasma-addons
|
||
dnf: kdeplasma-addons
|
||
pacman: kdeplasma-addons
|
||
keybase:
|
||
_app: Keybase.app
|
||
_bin: null
|
||
_desc: '[Keybase](https://keybase.io/) is secure messaging and file-sharing. Keybase uses public key cryptography to ensure your messages stay private. Keybase works for families, roommates, clubs, and groups of friends. Keybase connects to public identities, too. You can connect with communities from Twitter, Reddit, and elsewhere.'
|
||
_docs: https://book.keybase.io/docs
|
||
_github: https://github.com/keybase/client
|
||
_home: https://keybase.io/
|
||
_name: Keybase
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Keybase Configuration
|
||
# @brief Updates Keybase's system configuration with the Keybase configuration stored in the `home/dot_config/keybase/config.json` location.
|
||
# @description
|
||
# This script ensures Keybase utilizes a configuration that, by default, adds a security fix.
|
||
|
||
if command -v keybase > /dev/null; then
|
||
KEYBASE_CONFIG="${XDG_CONFIG_HOME:-$HOME/.config}/keybase/config.json"
|
||
if [ -f "$KEYBASE_CONFIG" ]; then
|
||
logg info 'Ensuring /etc/keybase is a directory' && sudo mkdir -p /etc/keybase
|
||
logg info "Copying $KEYBASE_CONFIG to /etc/keybase/config.json" && sudo cp -f "$KEYBASE_CONFIG" /etc/keybase/config.json
|
||
else
|
||
logg warn "No Keybase config located at $KEYBASE_CONFIG"
|
||
fi
|
||
else
|
||
logg info 'The keybase executable is not available'
|
||
fi
|
||
_post:cask: |
|
||
#!/usr/bin/env bash
|
||
if [ ! -f /usr/local/bin/keybase ] && [ -f /Applications/Keybase.app/Contents/SharedSupport/bin/keybase ]; then echo "Fixing missing keybase executable symlink permission issue" && sudo ln -s /Applications/Keybase.app/Contents/SharedSupport/bin/keybase /usr/local/bin/keybase; fi
|
||
_when:ansible: '! test -f /opt/keybase/Keybase'
|
||
ansible: professormanhattan.keybase
|
||
cask: keybase
|
||
choco: keybase
|
||
pacman:
|
||
- keybase
|
||
- keybase-gui
|
||
yay: keybase-bin
|
||
keycastr:
|
||
_app: KeyCastr.app
|
||
_bin: null
|
||
_desc: Keystroke visualizer for macOS screen recordings
|
||
_docs: https://github.com/keycastr/keycastr
|
||
_github: https://github.com/keycastr/keycastr
|
||
_home: https://github.com/keycastr/keycastr
|
||
_name: Keycastr
|
||
cask: keycastr
|
||
kitty:
|
||
_bin: null
|
||
_desc: '[KiTTY](https://sw.kovidgoyal.net/kitty/) is designed for power keyboard users. To that end all its controls work with the keyboard (although it fully supports mouse interactions as well). Its configuration is a simple, human editable, single file for easy reproducibility.'
|
||
_docs: https://sw.kovidgoyal.net/kitty/quickstart/
|
||
_github: https://github.com/kovidgoyal/kitty
|
||
_home: https://sw.kovidgoyal.net/kitty/
|
||
_name: KiTTY
|
||
ansible: professormanhattan.kitty
|
||
kn:
|
||
_bin: kn
|
||
_desc: The Knative CLI (kn) provides a quick and easy interface for creating Knative resources, such as Knative Services and Event Sources
|
||
_github: https://github.com/knative/client
|
||
_name: kn
|
||
brew: kn
|
||
github: github.com/knative/client
|
||
yay: knative-client-bin
|
||
kodi:
|
||
_app: Kodi.app
|
||
_bin: kodi
|
||
_desc: '[Kodi](https://kodi.tv/) is a free and open-source media player software application developed by the XBMC Foundation, a non-profit technology consortium. Kodi is available for multiple operating systems and hardware platforms, with a software 10-foot user interface for use with televisions and remote controls.'
|
||
_docs: https://kodi.wiki/view/Main_Page
|
||
_github: https://github.com/xbmc/xbmc
|
||
_home: https://kodi.tv/
|
||
_name: Kodi
|
||
ansible: professormanhattan.kodi
|
||
apt: kodi
|
||
cask: kodi
|
||
choco: kodi
|
||
dnf: kodi
|
||
flatpak: tv.kodi.Kodi
|
||
pacman: kodi
|
||
koodo-reader:
|
||
_app: Koodo Reader.app
|
||
_bin: koodo-reader
|
||
_github: https://github.com/koodo-reader/koodo-reader
|
||
_name: Koodo Reader
|
||
cask: koodo-reader
|
||
flatpak: io.github.troyeguo.koodo-reader
|
||
scoop: extras/koodo-reader
|
||
winget: AppbyTroye.KoodoReader
|
||
kooha:
|
||
_bin: kooha
|
||
_github: https://github.com/SeaDve/Kooha
|
||
flatpak: io.github.seadve.Kooha
|
||
korkut:
|
||
_bin: korkut
|
||
_github: https://github.com/oguzhaninan/korkut
|
||
_name: Korkut
|
||
npm: korkut
|
||
krew:
|
||
_bin: kubectl-krew
|
||
_github: https://github.com/kubernetes-sigs/krew
|
||
_name: KubeCTL
|
||
brew: krew
|
||
krita:
|
||
_app: krita.app
|
||
_bin: krita
|
||
_github: https://github.com/KDE/krita
|
||
cask: krita
|
||
choco: krita
|
||
flatpak: org.kde.krita
|
||
ksnip:
|
||
_app: ksnip.app
|
||
_bin: ksnip
|
||
_github: https://github.com/ksnip/ksnip
|
||
_name: kSnip
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
sudo snap connect ksnip:network-observe && sudo snap connect ksnip:network-manager-observe && sudo snap connect ksnip:removable-media
|
||
cask: ksnip
|
||
choco: ksnip
|
||
flatpak: org.ksnip.ksnip
|
||
snap: ksnip
|
||
kube-shell:
|
||
_bin: kube-shell
|
||
_desc: An integrated shell for working with the Kubernetes
|
||
_docs: https://github.com/cloudnativelabs/kube-shell
|
||
_github: https://github.com/cloudnativelabs/kube-shell
|
||
_home: https://github.com/cloudnativelabs/kube-shell
|
||
_name: Kube Shell
|
||
pipx: kube-shell
|
||
kubectx:
|
||
_bin: kubectx
|
||
_desc: Faster way to switch between clusters and namespaces in kubectl
|
||
_github: https://github.com/ahmetb/kubectx
|
||
_name: kubectx
|
||
brew: kubectx
|
||
choco:
|
||
- kubens
|
||
- kubectx
|
||
pacman: kubectx
|
||
port: kubectx
|
||
snap: kubectx --classic
|
||
kubekey:
|
||
_bin: kk
|
||
_desc: kk stands for KubeKey and it is an installer for [KubeSphere](https://github.com/kubesphere/kubesphere)
|
||
_docs: https://github.com/kubesphere/kubekey#usage
|
||
_github: https://github.com/kubesphere/kubekey
|
||
_home: https://kubesphere.io/
|
||
_name: KubeKey
|
||
brew: kubekey
|
||
kubenav:
|
||
_app: kubenav.app
|
||
_bin: null
|
||
_desc: kubenav is the navigator for your Kubernetes clusters right in your pocket
|
||
_docs: https://github.com/kubenav/kubenav
|
||
_github: https://github.com/kubenav/kubenav
|
||
_home: https://kubenav.io/
|
||
_name: kubenav
|
||
cask: kubenav
|
||
github: github.com/kubenav/kubenav
|
||
yay: kubenav-bin
|
||
kubernetes-cli:
|
||
_bin: kubectl
|
||
_desc: kubectl is a command line tool for communicating with a Kubernetes cluster's control plane, using the Kubernetes API
|
||
_docs: https://kubernetes.io/docs/reference/kubectl/kubectl/
|
||
_github: https://github.com/kubernetes/kubectl
|
||
_name: kubectl
|
||
brew: kubectl
|
||
choco: kubernetes-cli
|
||
snap: kubectl --classic
|
||
kubernetes-kompose:
|
||
_bin: kompose
|
||
_desc: Go from Docker Compose to Kubernetes
|
||
_docs: https://kompose.io/getting-started/
|
||
_github: https://github.com/kubernetes/kompose
|
||
_home: https://kompose.io/
|
||
_name: kompose
|
||
brew: kompose
|
||
choco: kubernetes-kompose
|
||
snap: kompose
|
||
kubeval:
|
||
_bin: kubeval
|
||
_desc: Validate your Kubernetes configuration files, supports multiple Kubernetes versions
|
||
_github: https://github.com/instrumenta/kubeval/
|
||
_home: https://www.kubeval.com/
|
||
_name: kubeval
|
||
_post:binary:darwin: |
|
||
#!/usr/bin/env bash
|
||
tar xf kubeval-darwin-amd64.tar.gz
|
||
sudo cp kubeval /usr/local/bin
|
||
_post:binary:linux: |
|
||
#!/usr/bin/env bash
|
||
tar xf kubeval-linux-amd64.tar.gz
|
||
sudo cp kubeval /usr/local/bin
|
||
_pre:scoop: scoop bucket add instrumenta https://github.com/instrumenta/scoop-instrumenta
|
||
binary:darwin: https://github.com/instrumenta/kubeval/releases/latest/download/kubeval-darwin-amd64.tar.gz
|
||
binary:linux: https://github.com/instrumenta/kubeval/releases/latest/download/kubeval-linux-amd64.tar.gz
|
||
# Following Homebrew does not work properly
|
||
# brew: instrumenta/instrumenta/kubeval
|
||
go: github.com/instrumenta/kubeval@latest
|
||
scoop: kubeval
|
||
kustomize:
|
||
_bin: kustomize
|
||
_github: https://github.com/kubernetes-sigs/kustomize
|
||
_name: Kustomize
|
||
brew: kustomize
|
||
choco: kustomize
|
||
go: sigs.k8s.io/kustomize/kustomize/v5@latest
|
||
port: kustomize
|
||
kvantum:
|
||
_bin: kvantummanager
|
||
_desc: Kvantum is an SVG-based theme engine for Qt4/Qt5 and KDE, i.e. a program for styling Qt applications with SVG images, with an emphasis on elegance, usability and practicality.
|
||
_docs: https://github.com/tsujan/Kvantum/blob/master/Kvantum/doc/Theme-Config.pdf
|
||
_github: https://github.com/tsujan/Kvantum
|
||
_home: https://github.com/tsujan/Kvantum
|
||
_name: Kvantum
|
||
apt:
|
||
- qt5-style-kvantum
|
||
- qt5-style-kvantum-themes
|
||
dnf:fedora: kvantum
|
||
eopkg: kvantum
|
||
pacman: kvantum
|
||
kvm:
|
||
_github: false
|
||
_bin:
|
||
- kvm
|
||
- qemu-img
|
||
_bin:brew:
|
||
- libvirtd
|
||
- qemu-img
|
||
_desc: Kernel-based Virtual Machine (or [KVM](https://www.linux-kvm.org/page/Main_Page)) is a virtualization module in the Linux kernel that allows the kernel to function as a hypervisor. It was merged into the Linux kernel mainline in kernel version 2.6.20, which was released on February 5, 2007.
|
||
_docs: https://www.linux-kvm.org/page/Documents
|
||
_groups:
|
||
- kvm
|
||
- libvirt
|
||
_home: https://www.linux-kvm.org/page/Main_Page
|
||
_name: KVM
|
||
_service: libvirt
|
||
_serviceEnabled: true
|
||
ansible: professormanhattan.kvm
|
||
apt:
|
||
- bridge-utils
|
||
- libvirt-clients
|
||
- libvirt-daemon-system
|
||
- qemu-kvm
|
||
- virt-manager
|
||
- virtinst
|
||
brew:
|
||
- libvirt
|
||
- qemu
|
||
dnf:
|
||
- bridge-utils
|
||
- libvirt
|
||
- qemu-kvm
|
||
- virt-install
|
||
- virt-manager
|
||
- virt-top
|
||
- virt-viewer
|
||
pacman:
|
||
- bridge-utils
|
||
- libvirt
|
||
- virt-manager
|
||
langflow:
|
||
_bin: langflow
|
||
_github: https://github.com/logspace-ai/langflow
|
||
_name: LangFlow
|
||
pipx: langflow
|
||
lapce:
|
||
_app: Lapce.app
|
||
_bin: lapce
|
||
_desc: Lightning-fast and Powerful Code Editor written in Rust
|
||
_docs: https://docs.lapce.dev/
|
||
_github: https://github.com/lapce/lapce
|
||
_home: https://lapce.dev/
|
||
_name: Lapce
|
||
cask: lapce
|
||
emerge: app-editors/lapce
|
||
flatpak: dev.lapce.lapce
|
||
nix-env: nixpkgs.lapce
|
||
scoop: lapce
|
||
winget: lapce
|
||
lazygit:
|
||
_bin: lazygit
|
||
_desc: Simple terminal UI for git commands
|
||
_github: https://github.com/jesseduffield/lazygit
|
||
brew: lazygit
|
||
choco: lazygit
|
||
eopkg: lazygit
|
||
go: github.com/jesseduffield/lazygit@latest
|
||
pacman: lazygit
|
||
port: lazygit
|
||
scoop: lazygit
|
||
xbps: lazygit
|
||
ledger-live:
|
||
_app: Ledger Live.app
|
||
_bin: ledger-live
|
||
_github: https://github.com/LedgerHQ/ledger-live
|
||
_desc: '[Ledger Live](https://www.ledger.com/ledger-live) is a new generation wallet desktop application providing a unique interface to maintain multiple cryptocurrencies for your Ledger Nano S / Blue. Manage your device, create accounts, receive and send cryptoassets and many more.'
|
||
_home: https://www.ledger.com/ledger-live
|
||
_name: Ledger Live
|
||
ansible: professormanhattan.ledgerlive
|
||
appimage: ledger-live-desktop
|
||
cask: ledger-live
|
||
choco: ledger-live
|
||
lens:
|
||
_app: Lens.app
|
||
_bin: lens
|
||
_bin:snap: kontena-lens
|
||
_desc: '[Lens IDE](https://k8slens.dev/) provides the full situational awareness for everything that runs in Kubernetes. It is an IDE designed for those who work with Kubernetes on a daily basis'
|
||
_docs: https://docs.k8slens.dev/main/
|
||
_github: https://github.com/lensapp/lens
|
||
_home: https://k8slens.dev/
|
||
_name: Lens
|
||
ansible: professormanhattan.lens
|
||
cask: lens
|
||
choco: lens
|
||
snap: kontena-lens --classic
|
||
yay: lens
|
||
lepton:
|
||
_app: Lepton.app
|
||
_bin: lepton
|
||
_bin:snap: lepton
|
||
_desc: Cross-platform snippet manager
|
||
_github: https://github.com/hackjutsu/Lepton
|
||
_home: https://hackjutsu.com/Lepton/
|
||
_name: lepton
|
||
cask: lepton
|
||
snap: lepton
|
||
lexicon:
|
||
_bin: lexicon
|
||
_desc: '[Lexicon](https://github.com/AnalogJ/lexicon) provides a way to manipulate DNS records on multiple DNS providers in a standardized/agnostic way.'
|
||
_github: https://github.com/AnalogJ/lexicon
|
||
_name: Lexicon
|
||
_post:pipx: |
|
||
#!/usr/bin/env bash
|
||
pipx inject dns-lexicon dns-lexicon[full]
|
||
ansible: professormanhattan.lexicon
|
||
pipx: dns-lexicon
|
||
libguestfs-tools:
|
||
_bin: guestfish
|
||
_github: https://github.com/libguestfs/libguestfs
|
||
apt: libguestfs-tools
|
||
dnf: libguestfs-tools
|
||
libimobiledevice:
|
||
_bin: null
|
||
_github: https://github.com/libimobiledevice/libimobiledevice
|
||
_home: https://libimobiledevice.org/
|
||
brew:darwin: libimobiledevice
|
||
libre-menu-editor:
|
||
_bin: libre-menu-editor
|
||
_name: Libre Menu Editor for GNOME
|
||
flatpak: page.codeberg.libre_menu_editor.LibreMenuEditor
|
||
_github: false
|
||
libreoffice:
|
||
_app: LibreOffice.app
|
||
_bin: libreoffice
|
||
_github: https://github.com/LibreOffice/core
|
||
_desc: '[LibreOffice](https://www.libreoffice.org/) is a free and open-source office productivity software suite, a project of The Document Foundation. It was forked in 2010 from OpenOffice.org, which was an open-sourced version of the earlier StarOffice.'
|
||
_docs: https://documentation.libreoffice.org/en/english-documentation/
|
||
_home: https://www.libreoffice.org/
|
||
_name: LibreOffice
|
||
apt: libreoffice
|
||
cask: libreoffice
|
||
choco: libreoffice-fresh
|
||
dnf: libreoffice
|
||
flatpak: org.libreoffice.LibreOffice
|
||
mas: 1630474372
|
||
pacman: libreoffice
|
||
librewolf:
|
||
_app: LibreWolf.app
|
||
_bin: librewolf
|
||
_gitlab: https://gitlab.com/librewolf-community/browser/linux
|
||
_github: https://github.com/librewolf-community/browser-linux
|
||
_scoopExtras: true
|
||
cask: librewolf
|
||
choco: librewolf
|
||
flatpak: io.gitlab.librewolf-community
|
||
scoop: librewolf
|
||
winget: librewolf
|
||
yay: librewolf
|
||
license:
|
||
_bin: license
|
||
_desc: Command-line license text generator
|
||
_github: https://github.com/nishanths/license
|
||
_name: license
|
||
go: github.com/nishanths/license@latest
|
||
yay: nishanths-license-git
|
||
lighthouse:
|
||
_bin: lighthouse
|
||
_github: https://github.com/GoogleChrome/lighthouse
|
||
_name: Lighthouse
|
||
npm: lighthouse
|
||
lightproxy:
|
||
_app: LightProxy.app
|
||
_bin: lightproxy
|
||
_github: https://github.com/alibaba/lightproxy
|
||
_name: LightProxy
|
||
cask: lightproxy
|
||
linkerd2:
|
||
_bin: linkerd
|
||
_desc: Linkerd is an ultralight, security-first service mesh for Kubernetes
|
||
_github: https://github.com/linkerd/linkerd2
|
||
_home: https://linkerd.io/
|
||
_name: linkerd2
|
||
brew: linkerd
|
||
github: github.com/linkerd/linkerd2
|
||
yay: linkerd
|
||
linkliar:
|
||
_app: LinkLiar.app
|
||
_bin: null
|
||
_desc: Menu bar application for macOS that allows you to spoof your MAC address
|
||
_docs: https://halo.github.io/LinkLiar/usage.html
|
||
_github: https://github.com/halo/LinkLiar
|
||
_home: https://halo.github.io/LinkLiar/
|
||
_name: Link Liar
|
||
cask: linkliar
|
||
liquidjs:
|
||
_bin: liquidjs
|
||
_desc: A simple, expressive and safe template engine.
|
||
_docs: https://liquidjs.com/tutorials/intro-to-liquid.html
|
||
_github: https://github.com/harttle/liquidjs
|
||
_home: https://liquidjs.com/
|
||
_name: LiquidJS
|
||
npm: liquidjs
|
||
litecli:
|
||
_bin: litecli
|
||
_desc: CLI for SQLite Databases with auto-completion and syntax highlighting
|
||
_docs: https://litecli.com/features/
|
||
_github: https://github.com/dbcli/litecli
|
||
_home: https://litecli.com/
|
||
_name: LiteCLI
|
||
brew: litecli
|
||
pipx: litecli
|
||
yay: litecli
|
||
live-captions:
|
||
_bin: live-captions
|
||
_github: https://github.com/abb128/LiveCaptions
|
||
_desc: Linux Desktop application that provides live captioning
|
||
flatpak: net.sapples.LiveCaptions
|
||
localtunnel:
|
||
_bin: lt
|
||
_desc: localtunnel exposes your localhost to the world for easy testing and sharing
|
||
_github: https://github.com/localtunnel/localtunnel
|
||
_home: https://theboroer.github.io/localtunnel-www/
|
||
_name: localtunnel
|
||
brew: localtunnel
|
||
npm: localtunnel
|
||
logcli:
|
||
_bin: logcli
|
||
_desc: Run LogQL queries against a Loki server
|
||
_github: https://github.com/grafana/loki
|
||
_home: https://grafana.com/loki
|
||
_name: logcli
|
||
brew: logcli
|
||
github: github.com/grafana/loki
|
||
yay: logcli-git
|
||
logi-options-plus:
|
||
_app: logioptionsplus.app
|
||
_bin: logi-options-plus
|
||
_env:
|
||
LOGI_OPTIONS_PLUS_APPDATA:
|
||
cask: "$HOME/Library/Application Support/LogiOptionsPlus"
|
||
choco: "TODO"
|
||
_github: false
|
||
_name: Logi Options+
|
||
cask: logi-options-plus
|
||
choco: logioptionsplus
|
||
exe: https://download01.logi.com/web/ftp/pub/techsupport/optionsplus/logioptionsplus_installer.exe
|
||
winget: Logitech.OptionsPlus
|
||
logi-tune:
|
||
_bin: logi-tune
|
||
_github: false
|
||
_name: Logi Tune
|
||
dmg: https://software.vc.logitech.com/downloads/tune/LogiTuneInstaller.dmg
|
||
exe: https://software.vc.logitech.com/downloads/tune/LogiTuneInstall.exe
|
||
lolcat:
|
||
_bin: lolcat
|
||
_github: https://github.com/busyloop/lolcat
|
||
_name: lolcat
|
||
brew: lolcat
|
||
choco: lolcat
|
||
snap: lolcat
|
||
lollypop:
|
||
_bin: lollypop
|
||
_gitlab: https://gitlab.gnome.org/World/lollypop
|
||
_github: https://github.com/hamonikr/lollypop
|
||
_desc: '[Lollypop](https://wiki.gnome.org/Apps/Lollypop) is a lightweight modern music player designed to work excellently on the GNOME desktop environment. Lollypop also features a party mode which will automatically select party-related playlists to play; a full-screen view which lets you visually access the player from your couch thanks to its HiDPI support; and native support for replay gain.'
|
||
_docs: https://gitlab.gnome.org/World/lollypop/issues
|
||
_home: https://wiki.gnome.org/Apps/Lollypop
|
||
_name: Lollypop
|
||
ansible:linux: professormanhattan.lollypop
|
||
apt: lollypop
|
||
dnf: lollypop
|
||
flatpak: org.gnome.Lollypop
|
||
pacman: lollypop
|
||
yay: lollypop-stable-git
|
||
loop:
|
||
_bin: loop
|
||
_github: https://github.com/Miserlou/Loop
|
||
_name: Loop
|
||
cargo: loop-rs
|
||
pacman: loop
|
||
snap: loop-rs --beta
|
||
lpass:
|
||
_bin: null
|
||
_desc: >-
|
||
[LastPass CLI](https://github.com/lastpass/lastpass-cli) is a user-friendly command-line client for [LastPass](https://www.lastpass.com/). LastPass is a freemium password manager that stores encrypted passwords online. The standard version of LastPass comes with a web interface, but also includes plugins for various web browsers and apps for many smartphones. It also includes support for bookmarklets. It is similar to but not open-source like [Bitwarden](https://gitlab.com/megabyte-labs/ansible-roles/bw).
|
||
_docs: LastPass command line interface tool
|
||
_github: https://github.com/lastpass/lastpass-cli
|
||
_name: LastPass CLI
|
||
ansible: professormanhattan.lpass
|
||
lsd:
|
||
_bin: lsd
|
||
_desc: '[LSD](https://github.com/Peltoche/lsd) (LSDeluxe), a clone of ls, is the next gen ls command with colorful output, file type icons, and more.'
|
||
_docs: https://github.com/lsd-rs/lsd
|
||
_github: https://github.com/Peltoche/lsd
|
||
_home: https://github.com/lsd-rs/lsd
|
||
_name: LSD (LSDeluxe)
|
||
_notes: Only the Chocolatey definition is included because LSD is only used on Windows (when `exa` is not available)
|
||
apt: lsd
|
||
brew: lsd
|
||
cargo: lsd
|
||
choco: lsd
|
||
dnf: lsd
|
||
eopkg: lsd
|
||
pacman: lsd
|
||
pkg-freebsd: lsd
|
||
pkg-termux: lsd
|
||
port: lsd
|
||
scoop: lsd
|
||
xbps: lsd
|
||
zypper: lsd
|
||
lsyncd:
|
||
_bin: lsyncd
|
||
_desc: Lsyncd (Live Syncing Daemon) synchronizes local directories with remote targets (via SSH and more)
|
||
_docs: https://lsyncd.github.io/lsyncd/
|
||
_github: https://github.com/lsyncd/lsyncd
|
||
_home: false
|
||
_name: Lsyncd
|
||
apt: lsyncd
|
||
brew: lsyncd
|
||
dnf: lsyncd
|
||
pacman: lsyncd
|
||
lua:
|
||
_bin: lua
|
||
_github: https://github.com/lua/lua
|
||
_name: Lua
|
||
apt: lua
|
||
brew: lua
|
||
choco: lua
|
||
dnf: lua
|
||
pacman: lua
|
||
lulu:
|
||
_app: LuLu.app
|
||
_bin: null
|
||
_desc: Powerful firewall application for macOS
|
||
_docs: https://objective-see.org/products/lulu.html
|
||
_github: https://github.com/objective-see/LuLu
|
||
_home: https://objective-see.org/products/lulu.html
|
||
_name: LuLu
|
||
cask: lulu
|
||
lux:
|
||
_bin: lux
|
||
_github: https://github.com/iawia002/lux
|
||
_name: Lux
|
||
brew: lux
|
||
choco: github.com/iawia002/lux
|
||
go: github.com/iawia002/lux@latest
|
||
scoop: lux
|
||
xbps: lux
|
||
lxc:
|
||
_bin: lxc
|
||
_desc: Linux Containers is an operating-system-level virtualization method for running multiple isolated Linux systems on a control host using a single Linux kernel.
|
||
_docs: https://linuxcontainers.org/lxc/documentation/
|
||
_github: https://github.com/lxc/lxc
|
||
_home: https://linuxcontainers.org/lxc/
|
||
_name: LXC
|
||
_service: lxc
|
||
apt: lxc
|
||
brew: lxc
|
||
dnf: lxc
|
||
pacman: lxc
|
||
lxd:
|
||
_bin: null
|
||
_desc: '[LXD](https://linuxcontainers.org) is a next generation system container manager. It offers a user experience similar to virtual machines but using Linux containers instead'
|
||
_docs: https://linuxcontainers.org/lxd/docs/master/
|
||
_github: https://github.com/lxc/lxd
|
||
_groups:
|
||
- lxd
|
||
_home: https://linuxcontainers.org/lxd/
|
||
_name: LXDC
|
||
ansible:linux: professormanhattan.lxdc
|
||
snap: lxd
|
||
lxd-ui:
|
||
_bin: lxd-ui
|
||
_github: https://github.com/canonical/lxd-ui
|
||
_name: LXD UI
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
lxd init && lxc config set core.https_address "[::]:8443"
|
||
snap: lxd
|
||
lxdc:
|
||
_github: false
|
||
_deps:
|
||
- lxc
|
||
- lxd
|
||
m-cli:
|
||
_bin: m
|
||
_desc: Swiss Army Knife for macOS. A wrapper for many types of macOS-specific commands.
|
||
_docs: https://github.com/rgcr/m-cli
|
||
_github: https://github.com/rgcr/m-cli
|
||
_home: https://github.com/rgcr/m-cli
|
||
_name: m-cli
|
||
brew:darwin: m-cli
|
||
maas:
|
||
_bin: maas
|
||
_desc: '[MAAS](https://maas.io/) allows very fast server provisioning for your data centre. It allows self-service, remote installation of Windows, CentOS, ESXi and Ubuntu on real servers. It turns your data centre into a bare metal cloud.'
|
||
_docs: https://maas.io/docs
|
||
_github: https://github.com/maas/maas
|
||
_home: https://maas.io/
|
||
_name: MAAS
|
||
_ports:
|
||
- port: 5240
|
||
proto: tcp
|
||
- port: 5240
|
||
proto: udp
|
||
- port: 5248
|
||
proto: tcp
|
||
- port: 5248
|
||
proto: udp
|
||
- port: 5241-5247
|
||
proto: tcp
|
||
- port: 5241-5247
|
||
proto: udp
|
||
- port: 5250-5270
|
||
proto: tcp
|
||
- port: 5250-5270
|
||
proto: udp
|
||
ansible:ubuntu: professormanhattan.maas
|
||
snap:ubuntu: maas
|
||
mackup:
|
||
_bin: mackup
|
||
_desc: '[mackup](https://github.com/lra/mackup) lets you keep your application settings in sync.'
|
||
_docs: https://github.com/lra/mackup
|
||
_github: https://github.com/lra/mackup
|
||
_home: https://github.com/lra/mackup
|
||
_name: mackup
|
||
ansible: professormanhattan.mackup
|
||
brew: mackup
|
||
pipx: mackup
|
||
macprefs:
|
||
_bin: macprefs
|
||
_github: https://github.com/clintmod/macprefs
|
||
_name: MacPrefs
|
||
brew: clintmod/formulas/macprefs
|
||
macvim:
|
||
_app: MacVim.app
|
||
_github: https://github.com/macvim-dev/macvim
|
||
_todo: Integrate this into macOS setup
|
||
cask: macvim
|
||
mage-ai:
|
||
_bin: mage
|
||
_desc: The modern replacement for Airflow. Build, run, and manage data pipelines for integrating and transforming data.
|
||
_docs: https://docs.mage.ai/introduction/overview
|
||
_github: https://github.com/mage-ai/mage-ai
|
||
_home: https://www.mage.ai
|
||
_name: Mage AI
|
||
pipx: mage-ai
|
||
magic-wormhole:
|
||
_bin: wormhole
|
||
_github: https://github.com/magic-wormhole/magic-wormhole
|
||
_name: Magic Wormhole
|
||
brew: magic-wormhole
|
||
mailcatcher:
|
||
_bin: mailcatcher
|
||
_github: https://github.com/sj26/mailcatcher
|
||
_name: Mail Catcher
|
||
_service: mailcatcher
|
||
brew: mailcatcher
|
||
gem: mailcatcher
|
||
mailspring:
|
||
_app: Mailspring.app
|
||
_bin: mailspring
|
||
_desc: '[Mailspring](https://getmailspring.com/) comes packed with powerful features like Unified Inbox, Snooze, Send Later, Mail Rules, Templates and more. Mailspring Pro, which you can unlock with a monthly subscription, adds even more features for people who send a ton of email: link tracking, read receipts, mailbox analytics, contact and company profiles. All of these features run in the client - Mailspring does not send your email credentials to the cloud.'
|
||
_docs: https://community.getmailspring.com/docs/
|
||
_env:
|
||
MAILSPRING_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Mailspring"
|
||
choco: "TODO"
|
||
flatpak: "TODO"
|
||
snap: "TODO"
|
||
_github: https://github.com/Foundry376/Mailspring
|
||
_home: https://getmailspring.com/
|
||
_name: Mailspring
|
||
cask: mailspring
|
||
choco: mailspring
|
||
flatpak: com.getmailspring.Mailspring
|
||
snap: mailspring
|
||
yay: mailspring
|
||
mailsy:
|
||
_bin: mailsy
|
||
_github: https://github.com/BalliAsghar/Mailsy
|
||
_name: Mailsy
|
||
brew: mailsy
|
||
npm: mailsy
|
||
majestic:
|
||
_bin: majestic
|
||
_github: https://github.com/Raathigesh/majestic
|
||
_name: Majestic
|
||
npm: majestic
|
||
makeself:
|
||
_bin: makeself
|
||
_github: https://github.com/megastep/makeself
|
||
_name: MakeSelf
|
||
brew: makeself
|
||
malwarebytes:
|
||
_app: Malwarebytes.app
|
||
_bin: malwarebytes
|
||
_desc: Cybersecurity. For every one.
|
||
_home: https://www.malwarebytes.com/
|
||
_github: false
|
||
_name: Malwarebytes
|
||
cask: malwarebytes
|
||
choco: malwarebytes
|
||
mambaforge:
|
||
_bin: conda
|
||
_github: https://github.com/mamba-org/mamba
|
||
_name: Mamba Forge
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
echo y | conda update -n base -c conda-forge conda
|
||
cask: mambaforge
|
||
choco: mambaforge
|
||
script:linux: bash <(curl -L -O "https://github.com/conda-forge/miniforge/releases/latest/download/Mambaforge-$(uname)-$(uname -m).sh")
|
||
manta:
|
||
_app: Manta.app
|
||
_bin: null
|
||
_desc: Flexible invoicing desktop app with beautiful & customizable templates
|
||
_github: https://github.com/hql287/Manta
|
||
_name: Manta
|
||
appimage: https://github.com/hql287/Manta/releases/download/v1.1.4/Manta-1.1.4-x86_64.AppImage
|
||
cask: manta
|
||
exe: https://github.com/hql287/Manta/releases/download/v1.1.4/Manta.Setup.1.1.4.exe
|
||
github: github.com/hql287/Manta
|
||
mariadb:
|
||
_bin: mariadb
|
||
_github: false
|
||
_name: MariaDB
|
||
_service: mariadb
|
||
apk: mariadb-server
|
||
apt: mariadb-server
|
||
brew: mariadb
|
||
choco: mariadb
|
||
dnf: mariadb-server
|
||
pacman: mariadb-server
|
||
mark-text:
|
||
_app: MarkText.app
|
||
_bin: marktext
|
||
_desc: A simple and elegant markdown editor, available for Linux, macOS and Windows
|
||
_env:
|
||
MARK_TEXT_APPDATA:
|
||
cask: "$HOME/Library/Application Support/marktext"
|
||
choco: "TODO"
|
||
flatpak: "TODO"
|
||
winget: "TODO"
|
||
_github: https://github.com/marktext/marktext
|
||
_name: MarkText
|
||
cask: mark-text
|
||
choco: marktext
|
||
flatpak: com.github.marktext.marktext
|
||
winget: marktext
|
||
yay: marktext
|
||
markdownlint-cli:
|
||
_bin: markdownlint
|
||
_desc: MarkdownLint command line interface
|
||
_docs: https://github.com/igorshubovych/markdownlint-cli
|
||
_github: https://github.com/igorshubovych/markdownlint-cli
|
||
_home: https://github.com/igorshubovych/markdownlint-cli
|
||
_name: Markdownlint CLI
|
||
brew: markdownlint-cli
|
||
pipx: markdownlint-cli
|
||
markmap:
|
||
_bin: markmap
|
||
_desc: Visualize your Markdown as mindmaps with Markmap.
|
||
_docs: https://markmap.js.org/docs/markmap
|
||
_github: https://github.com/markmap/markmap
|
||
_home: https://markmap.js.org/
|
||
_name: Markmap
|
||
npm: markmap-cli
|
||
marp:
|
||
_bin: marp
|
||
_desc: A CLI interface for Marp and Marpit based converters
|
||
_docs: https://github.com/marp-team/marp-cli
|
||
_github: https://github.com/marp-team/marp-cli
|
||
_home: https://marp.app/
|
||
_name: Marp
|
||
brew: marp-cli
|
||
npm: '@marp-team/marp-cli'
|
||
scoop: marp
|
||
mas:
|
||
_bin: mas
|
||
_desc: '[MAS CLI](https://github.com/mas-cli/mas) is a simple command line interface for the Mac App Store. Designed for scripting and automation.'
|
||
_name: MAS CLI
|
||
_github: https://github.com/mas-cli/mas
|
||
ansible:darwin: professormanhattan.mas
|
||
brew:darwin: mas
|
||
port: mas
|
||
mask:
|
||
_bin: mask
|
||
_github: https://github.com/jacobdeichert/mask
|
||
_name: Mask
|
||
brew: mask
|
||
cargo: mask
|
||
masscan:
|
||
_bin: masscan
|
||
_github: https://github.com/robertdavidgraham/masscan
|
||
_name: Masscan
|
||
brew: masscan
|
||
choco: masscan
|
||
masscode:
|
||
_app: massCode.app
|
||
_bin: null
|
||
_desc: A free and open source code snippets manager for developers
|
||
_github: https://github.com/antonreshetov/massCode
|
||
_name: MassCode
|
||
cask: masscode
|
||
github: github.com/antonreshetov/massCode
|
||
mc:
|
||
_bin: mc
|
||
_desc: MinIO Client is a replacement for ls, cp, mkdir, diff and rsync commands for filesystems and object storage
|
||
_github: https://github.com/minio/mc
|
||
_home: https://min.io/
|
||
_name: mc
|
||
_post:binary:linux: |
|
||
#!/usr/bin/env bash
|
||
# TODO
|
||
_post:binary:windows: |
|
||
#!/usr/bin/env bash
|
||
# TODO
|
||
binary:linux: https://dl.min.io/client/mc/release/linux-amd64/mc
|
||
binary:windows: https://dl.min.io/client/mc/release/windows-amd64/mc.exe
|
||
brew: minio/stable/mc
|
||
go: github.com/minio/mc@latest
|
||
mcfly:
|
||
_bin: mcfly
|
||
_desc: "[McFly](https://github.com/cantino/mcfly) replaces your default CTRL-r shell history search with an intelligent search engine that takes into account your working directory and the context of recently executed commands. McFly's suggestions are prioritized in real time with a small neural network."
|
||
_github: https://github.com/cantino/mcfly
|
||
_name: McFly
|
||
ansible:darwin: professormanhattan.mcfly
|
||
ansible:linux: professormanhattan.mcfly
|
||
brew: mcfly
|
||
port: mcfly
|
||
script:darwin: curl -LSfs https://raw.githubusercontent.com/cantino/mcfly/master/ci/install.sh | sh -s -- --git cantino/mcfly
|
||
script:linux: curl -LSfs https://raw.githubusercontent.com/cantino/mcfly/master/ci/install.sh | sh -s -- --git cantino/mcfly
|
||
medis:
|
||
_app: Medis.app
|
||
_bin: medis
|
||
_github: https://github.com/luin/medis
|
||
_name: Medis
|
||
cask: medis
|
||
medusa:
|
||
_bin: medusa
|
||
_github: https://github.com/medusajs/medusa
|
||
_name: Medusa
|
||
npm: '@medusajs/medusa-cli'
|
||
meetingbar:
|
||
_app: MeetingBar.app
|
||
_bin: null
|
||
_desc: Meeting menu bar application that shows calendar event details on macOS
|
||
_docs: https://github.com/leits/MeetingBar
|
||
_github: https://github.com/leits/MeetingBar
|
||
_home: https://apps.apple.com/app/id1532419400
|
||
_name: Meeting Bar
|
||
cask: meetingbar
|
||
mas: 1532419400
|
||
meld:
|
||
_app: Meld.app
|
||
_bin: meld
|
||
_github: https://github.com/GNOME/meld
|
||
cask: meld
|
||
choco: meld
|
||
flatpak: org.gnome.meld
|
||
meta:
|
||
_bin: meta
|
||
_github: https://github.com/mateodelnorte/meta
|
||
_name: Meta
|
||
npm: meta
|
||
meta-package-manager:
|
||
_bin: mpm
|
||
_github: https://github.com/kdeldycke/meta-package-manager
|
||
_name: Meta Package Manager
|
||
brew: meta-package-manager
|
||
pipx: meta-package-manager
|
||
metasploit:
|
||
_github: https://github.com/rapid7/metasploit-framework
|
||
_name: Metasploit Framework
|
||
_when: '! test -f /opt/metasploit-framework/bin/msfconsole'
|
||
script: curl -sSL --compressed https://raw.githubusercontent.com/rapid7/metasploit-omnibus/master/config/templates/metasploit-framework-wrappers/msfupdate.erb > /tmp/msfinstall && chmod 755 /tmp/msfinstall && sudo /tmp/msfinstall
|
||
micromamba:
|
||
_bin: micromamba
|
||
_github: https://github.com/mamba-org/mamba
|
||
_name: MicroMamba
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
micromamba self-update
|
||
brew: micromamba
|
||
microsoft-edge:
|
||
_app: Microsoft Edge.app
|
||
_bin: microsoft-edge
|
||
_desc: '[Microsoft Edge](https://www.microsoft.com/en-us/edge) is a cross-platform web browser developed by Microsoft. It was first released for Windows 10 and Xbox One in 2015, then for Android and iOS in 2017, for macOS in 2019, and as a preview for Linux in October 2020.'
|
||
_docs: https://docs.microsoft.com/en-us/microsoft-edge/
|
||
_env:
|
||
MICROSOFT_EDGE_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Microsoft Edge/Default"
|
||
choco: "TODO"
|
||
flatpak: "TODO"
|
||
_github: false
|
||
_home: https://www.microsoft.com/en-us/edge
|
||
_name: Microsoft Edge
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @brief See `google-chrome` `_post` script for more details
|
||
function chromeSetUp() {
|
||
### Ensure Chrome policies directory is present
|
||
# logg info 'Processing policy directories for Chromium based browsers'
|
||
### TODO - Find POLICY_DIR location for Microsoft Edge
|
||
# for POLICY_DIR in "/opt/google/chrome/policies" "/etc/chromium/policies" "/etc/brave/policies"; do
|
||
# if [ -d "$(dirname "$POLICY_DIR")" ]; then
|
||
# ### Managed policies
|
||
# if [ ! -f "$POLICY_DIR/managed/policies.json" ]; then
|
||
# logg info "Ensuring directory $POLICY_DIR/managed exists"
|
||
# sudo mkdir -p "$POLICY_DIR/managed"
|
||
# logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json to $POLICY_DIR/managed/policies.json"
|
||
# sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/managed.json" "$POLICY_DIR/managed/policies.json"
|
||
# fi
|
||
# ### Recommended policies
|
||
# if [ ! -f "$POLICY_DIR/recommended/policies.json" ]; then
|
||
# logg info "Ensuring directory $POLICY_DIR/recommended exists" && sudo mkdir -p "$POLICY_DIR/recommended"
|
||
# logg info "Copying ${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json to $POLICY_DIR/recommended/policies.json"
|
||
# sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/recommended.json" "$POLICY_DIR/recommended/policies.json"
|
||
# fi
|
||
# else
|
||
# logg info "Skipping extension injection into $POLICY_DIR - create these folders prior to running to create managed configs"
|
||
# fi
|
||
# done
|
||
|
||
### Add Chrome extension JSON
|
||
logg info 'Populating Chrome extension JSON'
|
||
for EXTENSION_DIR in "$HOME/Library/Application Support/Microsoft/Edge/External Extensions"; do
|
||
### Ensure program-type is installed
|
||
if [ -d "$(dirname "$EXTENSION_DIR")" ]; then
|
||
### Ensure extension directory exists
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && sudo mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
else
|
||
if [ ! -d "$EXTENSION_DIR" ]; then
|
||
logg info "Creating directory $EXTENSION_DIR" && mkdir -p "$EXTENSION_DIR"
|
||
fi
|
||
fi
|
||
|
||
### Add extension JSON
|
||
logg info "Adding Chrome extensions to $EXTENSION_DIR"
|
||
for EXTENSION in {{ list (.chromeExtensions | toString | replace "[" "" | replace "]" "") | uniq | join " " }}; do
|
||
logg info "Adding Chrome extension manifest ($EXTENSION)"
|
||
if ! echo "$EXTENSION" | grep 'https://chrome.google.com/webstore/detail/' > /dev/null; then
|
||
EXTENSION="https://chrome.google.com/webstore/detail/$EXTENSION"
|
||
fi
|
||
EXTENSION_ID="$(echo "$EXTENSION" | sed 's/^.*\/\([^\/]*\)$/\1/')"
|
||
if [[ "$EXTENSION_DIR" == '/opt/'* ]] || [[ "$EXTENSION_DIR" == '/etc/'* ]]; then
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
else
|
||
cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/chrome/extension.json" "$EXTENSION_DIR/${EXTENSION_ID}.json"
|
||
fi
|
||
done
|
||
else
|
||
logg info "$EXTENSION_DIR does not exist"
|
||
fi
|
||
done
|
||
}
|
||
chromeSetUp
|
||
cask: microsoft-edge
|
||
choco: microsoft-edge
|
||
flatpak: com.microsoft.Edge
|
||
yay: microsoft-edge-stable-bin
|
||
microsoft-git:
|
||
_bin: scalar
|
||
_github: https://github.com/microsoft/VFSForGit
|
||
_name: Microsoft Git (with Git VFS)
|
||
cask: microsoft/git/microsoft-git
|
||
script:linux: |
|
||
#!/usr/bin/env bash
|
||
mkdir -p "$HOME/.local/src"
|
||
rm -rf "$HOME/.local/src/microsoft-git"
|
||
git clone https://github.com/microsoft/git "$HOME/.local/src/microsoft-git"
|
||
cd "$HOME/.local/src/microsoft-git"
|
||
make -j12 prefix=/usr/local
|
||
sudo make -j12 prefix=/usr/local install
|
||
winget: microsoft.git
|
||
microsoft-office:
|
||
_app: Microsoft Word.app
|
||
_bin: null
|
||
_github: false
|
||
_desc: '[Microsoft Office](https://www.microsoft.com/en-us/microsoft-365/microsoft-office), or simply Office, is a family of client software, server software, and services developed by Microsoft.'
|
||
_docs: https://docs.microsoft.com/en-us/microsoft-365/?view=o365-worldwide
|
||
_home: https://www.office.com/
|
||
_name: Office
|
||
cask: microsoft-office
|
||
choco: office365business
|
||
microsoft-remote-desktop:
|
||
_app: Microsoft Remote Desktop.app
|
||
_bin: microsoft-remote-desktop
|
||
_github: false
|
||
_name: Microsoft Remote Desktop
|
||
cask: microsoft-remote-desktop
|
||
mas: 1295203466
|
||
microsoft-teams:
|
||
_app: Microsoft Teams.app
|
||
_bin: teams
|
||
_github: false
|
||
_desc: '[Microsoft Teams](https://www.microsoft.com/en-us/microsoft-teams/group-chat-software) is a proprietary business communication platform developed by Microsoft, as part of the Microsoft 365 family of products. Teams primarily competes with the similar service Slack, offering workspace chat and videoconferencing, file storage, and application integration.'
|
||
_name: Microsoft Teams
|
||
ansible: professormanhattan.teams
|
||
cask: microsoft-teams
|
||
choco: microsoft-teams
|
||
flatpak: com.microsoft.Teams
|
||
snap: teams-for-linux
|
||
yay: teams-for-linux
|
||
microsoft-todo:
|
||
_app: Ao.app
|
||
_bin:snap: microsoft-todo-unofficial
|
||
_desc: '[Microsoft To Do](https://todo.microsoft.com/tasks/) is a productivity application developed by Microsoft. It lets you create to do lists, reminders, and notes for any purpose. Sync lists across devices and Microsoft 365 accounts to access daily planner and task manager features anywhere.'
|
||
_docs: https://support.microsoft.com/en-us/todo
|
||
_github: false
|
||
_home: https://todo.microsoft.com/tasks/
|
||
_name: Microsoft To-Do
|
||
ansible: professormanhattan.microsofttodo
|
||
cask: ao
|
||
mas: 1274495053
|
||
snap: microsoft-todo-unofficial
|
||
miller:
|
||
_bin: mlr
|
||
_github: https://github.com/johnkerl/miller
|
||
_name: Miller
|
||
apt: miller
|
||
brew: miller
|
||
choco: miller
|
||
dnf: miller
|
||
port: miller
|
||
minikube:
|
||
_bin: minikube
|
||
_deps:
|
||
- docker
|
||
_deps:darwin:
|
||
- hyperkit
|
||
_desc: minikube quickly sets up a local Kubernetes cluster on macOS, Linux, and Windows
|
||
_docs: https://minikube.sigs.k8s.io/docs/
|
||
_github: https://github.com/kubernetes/minikube
|
||
_name: minikube
|
||
# TODO - Prefer HyperV on Windows https://minikube.sigs.k8s.io/docs/drivers/hyperv/
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
if command -v hyperkit > /dev/null; then minikube config set driver hyperkit; elif command -v docker > /dev/null; then minikube config set driver docker; elif command -v VBoxManage > /dev/null; then minikube config set driver virtualbox; fi
|
||
_todo: A full installation of Xcode.app 9.0 is required. Also, hyperkit x86_64 architecture is required for this software. So automate install of Xcode.app 9.0 and add check for x86_64 prior to installing this
|
||
brew: minikube
|
||
choco: minikube
|
||
mise:
|
||
_bin: mise
|
||
_github: https://github.com/jdx/mise
|
||
_name: mise
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
mise install
|
||
if [ -d "${XDG_DATA_HOME:-$HOME/.local/share}/mise/installs/java/openjdk-20/Contents" ]; then
|
||
sudo mkdir -p /Library/Java/JavaVirtualMachines/openjdk-20.jdk
|
||
sudo ln -s "${XDG_DATA_HOME:-$HOME/.local/share}/mise/installs/java/openjdk-20/Contents" /Library/Java/JavaVirtualMachines/openjdk-20.jdk/Contents
|
||
fi
|
||
apk: mise
|
||
brew: mise
|
||
cargo: mise-cli
|
||
nix-env: mise
|
||
npm: '@jdxcode/mise'
|
||
port: port
|
||
mitmproxy:
|
||
_bin: mitmproxy
|
||
_desc: '[mitmproxy](https://mitmproxy.org/) is an interactive, SSL/TLS-capable intercepting proxy with a console interface for HTTP/1, HTTP/2, and WebSockets. It also includes mitmweb which is a web-based interface for mitmproxy.'
|
||
_docs: https://docs.mitmproxy.org/stable
|
||
_github: https://github.com/mitmproxy/mitmproxy
|
||
_home: https://mitmproxy.org/
|
||
_name: mitmproxy
|
||
ansible: professormanhattan.mitmproxy
|
||
apt: mitmproxy
|
||
cask: mitmproxy
|
||
choco: mitmproxy
|
||
pacman: mitmproxy
|
||
mjml:
|
||
_app: MJML.app
|
||
_bin:npm: mjml
|
||
_desc: The desktop app for MJML
|
||
_docs: https://documentation.mjml.io/
|
||
_github: https://github.com/mjmlio/mjml-app
|
||
_home: https://mjmlio.github.io/mjml-app/
|
||
_name: MJML App
|
||
cask: mjml
|
||
github: github.com/mjmlio/mjml-app
|
||
npm: mjml
|
||
mkcert:
|
||
_bin: mkcert
|
||
_desc: A simple zero-config tool to make locally trusted development certificates with any names
|
||
_github: https://github.com/FiloSottile/mkcert
|
||
_name: mkcert
|
||
brew: mkcert
|
||
choco: mkcert
|
||
github: github.com/FiloSottile/mkcert
|
||
pacman: mkcert
|
||
scoop: mkcert
|
||
mockoon:
|
||
_app: Mockoon.app
|
||
_bin:snap: mockoon
|
||
_desc: Mockoon is the easiest and quickest way to run mock APIs locally. No remote deployment, no account required, open source
|
||
_github: https://github.com/mockoon/mockoon
|
||
_name: Mockoon
|
||
cask: mockoon
|
||
choco: mockoon
|
||
github: github.com/mockoon/mockoon
|
||
npm: '@mockoon/cli'
|
||
snap: mockoon
|
||
winget: mockoon
|
||
yay: mockoon-bin
|
||
modern-flyouts:
|
||
_bin: modern-flyouts
|
||
_github: https://github.com/ModernFlyouts-Community/ModernFlyouts
|
||
_name: Modern Flyouts
|
||
choco: modernflyouts
|
||
winapp: modernflyouts-preview/9MT60QV066RP
|
||
winget: ModernFlyouts.ModernFlyouts
|
||
mods:
|
||
_bin: mods
|
||
_desc: AI for the command-line that leverages OpenAI or LocalAI (if configured to do so)
|
||
_docs: https://github.com/charmbracelet/mods
|
||
_github: https://github.com/charmbracelet/mods
|
||
_home: https://charm.sh/
|
||
_name: Mods
|
||
brew: charmbracelet/tap/mods
|
||
go: github.com/charmbracelet/mods@latest
|
||
yay: mods
|
||
mole:
|
||
_bin: mole
|
||
_desc: CLI application to create ssh tunnels focused on resiliency and user experience
|
||
_docs: https://davrodpin.github.io/mole/
|
||
_github: https://github.com/davrodpin/mole
|
||
_home: https://davrodpin.github.io/mole/
|
||
_name: mole
|
||
brew: davrodpin/homebrew-mole/mole
|
||
github: github.com/davrodpin/mole
|
||
yay: mole-bin
|
||
molecule:
|
||
_bin: molecule
|
||
_desc: Molecule aids in the development and testing of Ansible roles
|
||
_docs: https://molecule.readthedocs.io/en/latest/getting-started.html
|
||
_github: https://github.com/ansible-community/molecule
|
||
_home: https://molecule.readthedocs.io/en/latest/
|
||
_name: Ansible Molecule
|
||
_post:pipx: |
|
||
#!/usr/bin/env bash
|
||
pipx inject molecule ansible PyObjC PyObjC-core docker lxml netaddr pexpect python-vagrant pywinrm requests-credssp watchdog apache-libcloud gcloud junit-xml molecule-docker molecule-gce molecule-vagrant pycrypto
|
||
# brew: molecule
|
||
pipx: molecule
|
||
monero:
|
||
_app: monero-wallet-gui.app
|
||
_bin: monero
|
||
_bin:flatpak: org.getmonero.Monero
|
||
_desc: '[Monero](https://www.getmonero.org/) is a leading cryptocurrency focused on private and censorship-resistant transactions. This role installs the Monero wallet application which is required for interacting with the Monero network.'
|
||
_docs: https://www.getmonero.org/resources/user-guides/
|
||
_github: https://github.com/monero-project/monero
|
||
_home: https://www.getmonero.org/
|
||
_name: Monero
|
||
_restricted: true
|
||
_service: monero
|
||
ansible: professormanhattan.monero
|
||
cask: monero-wallet
|
||
choco: monero
|
||
flatpak: org.getmonero.Monero
|
||
monero-cli:
|
||
_bin: monerod
|
||
_desc: CLI for Monero, a leading cryptocurrency focused on private and censorship-resistant transactions.
|
||
_docs: https://www.getmonero.org/resources/user-guides/
|
||
_github: https://github.com/monero-project/monero
|
||
_home: https://www.getmonero.org/
|
||
_restricted: true
|
||
brew: monero
|
||
scoop: monero
|
||
mongodb:
|
||
_bin: mongod
|
||
_github: https://github.com/mongodb/mongo
|
||
_name: MongoDB
|
||
_service: mongodb
|
||
_service:brew: mongodb-community
|
||
brew: mongodb/brew/mongodb-community
|
||
choco: mongodb
|
||
mongodb-atlas:
|
||
_bin: atlas
|
||
_desc: Install the Atlas CLI to quickly provision and manage Atlas database deployments from the terminal. (Official MongoDB hosted service provider CLI)
|
||
_docs: https://www.mongodb.com/docs/atlas/cli/stable/command/atlas/
|
||
_github: https://github.com/mongodb/mongodb-atlas-cli
|
||
_home: https://www.mongodb.com/docs/atlas/cli/stable/
|
||
_name: MongoDB Atlas
|
||
brew: mongodb-atlas
|
||
choco: mongodb-atlas
|
||
mongodb-compass:
|
||
_app: MongoDB Compass.app
|
||
_bin: mongodb-compass
|
||
_github: https://github.com/mongodb-js/compass
|
||
_name: MongoDB Compass
|
||
apt: https://downloads.mongodb.com/compass/mongodb-compass_1.38.0_amd64.deb
|
||
cask: mongodb-compass
|
||
choco: mongodb-compass
|
||
dnf: https://downloads.mongodb.com/compass/mongodb-compass-1.38.0.x86_64.rpm
|
||
monitorcontrol:
|
||
_app: MonitorControl.app
|
||
_bin: null
|
||
_desc: Menu bar application for macOS that allows you to control the screen brightness and volume
|
||
_docs: https://github.com/MonitorControl/MonitorControl
|
||
_github: https://github.com/MonitorControl/MonitorControl
|
||
_home: https://github.com/MonitorControl/MonitorControl
|
||
_name: Monitor Control
|
||
cask: monitorcontrol
|
||
mono:
|
||
_bin: mono
|
||
_desc: Mono open source ECMA CLI, C# and .NET implementation.
|
||
_docs: https://www.mono-project.com/docs/
|
||
_github: https://github.com/mono/mono
|
||
_home: https://www.mono-project.com/
|
||
_name: Mono
|
||
apt: mono-complete
|
||
brew: mono
|
||
choco: mono
|
||
dnf: mono-complete
|
||
port: mono
|
||
scoop: main/mono
|
||
winget: Mono.Mono
|
||
mosh:
|
||
_bin: mosh
|
||
_desc: Remote terminal application that allows roaming, supports intermittent connectivity, and provides intelligent local echo and line editing of user keystrokes.
|
||
_docs: https://mosh.org/#usage
|
||
_github: https://github.com/mobile-shell/mosh
|
||
_home: https://mosh.org/
|
||
_name: Mosh
|
||
apk: mosh
|
||
apt: mosh
|
||
brew: mosh
|
||
dnf: mosh
|
||
emerge: net-misc/mosh
|
||
pacman: mosh
|
||
pkg-freebsd: net/mosh
|
||
pkg_add: mosh
|
||
port: mosh
|
||
zypper: mosh
|
||
motrix:
|
||
_app: Motrix.app
|
||
_bin: motrix
|
||
_desc: '[Motrix](https://motrix.app/) is a full-featured download manager that supports downloading HTTP, FTP, BitTorrent, Magnet, etc.'
|
||
_github: https://github.com/agalwood/Motrix
|
||
_home: https://motrix.app/
|
||
_name: Motrix
|
||
ansible: professormanhattan.motrix
|
||
cask: motrix
|
||
choco: motrix
|
||
flatpak: net.agalwood.Motrix
|
||
github: github.com/agalwood/Motrix
|
||
scoop: motrix
|
||
yay: motrix-bin
|
||
mpg123:
|
||
_bin: mpg123
|
||
_github: false
|
||
_desc: mpg123 is a free and open-source audio player. It supports MPEG audio formats, including MP3
|
||
_home: https://mpg123.org/
|
||
_name: mpg123
|
||
apt: mpg123
|
||
brew: mpg123
|
||
choco: mpg123
|
||
dnf: mpg123
|
||
pacman: mpg123
|
||
port: mpg123
|
||
scoop: mpg123
|
||
mpv:
|
||
_app: mpv.app
|
||
_bin: mpv
|
||
_github: https://github.com/mpv-player/mpv
|
||
_name: MPV
|
||
_todo: This software does not run on macOS versions other than Mojave, Catalina, Big Sur and Ventura --- probably adding support - this issue will likely fix itself
|
||
brew: mpv
|
||
cask: mpv
|
||
choco: mpv
|
||
flatpak: io.mpv.Mpv
|
||
mqttx:
|
||
_app: MQTTX.app
|
||
_bin: mqttx
|
||
_desc: MQTT X - Elegant Cross-platform MQTT 5.0 Desktop Client
|
||
_github: https://github.com/emqx/MQTTX
|
||
_name: MQTT X
|
||
cask: mqttx
|
||
flatpak: com.emqx.MQTTX
|
||
github: github.com/emqx/MQTTX
|
||
snap: mqttx
|
||
yay: mqttx-bin
|
||
mudlet:
|
||
_app: mudlet.app
|
||
_bin: mudlet
|
||
_desc: A full-featured cross-OS MUD client
|
||
_docs: https://wiki.mudlet.org/?pk_vid=b53bfe5eba0aac5a1685341616dc4f27
|
||
_github: https://github.com/Mudlet/Mudlet
|
||
_home: https://www.mudlet.org/
|
||
_name: Mudlet
|
||
cask: mudlet
|
||
choco: mudlet
|
||
snap: mudlet-linux
|
||
muffet:
|
||
_bin: muffet
|
||
_desc: Fast website link checker in Go
|
||
_github: https://github.com/raviqqe/muffet
|
||
_name: muffet
|
||
brew: muffet
|
||
github: github.com/raviqqe/muffet
|
||
go: github.com/raviqqe/muffet/v2@latest
|
||
yay: muffet-bin
|
||
mullvad-vpn:
|
||
_app: Mullvad VPN.app
|
||
_bin: null
|
||
_desc: The Mullvad VPN client app for desktop and mobile
|
||
_github: https://github.com/mullvad/mullvadvpn-app
|
||
_name: Mullvad VPN
|
||
apt: https://github.com/mullvad/mullvadvpn-app/releases/download/2022.5/MullvadVPN-2022.5_amd64.deb
|
||
cask: mullvadvpn
|
||
dnf: https://github.com/mullvad/mullvadvpn-app/releases/download/2022.5/MullvadVPN-2022.5_x86_64.rpm
|
||
exe: https://github.com/mullvad/mullvadvpn-app/releases/download/2022.5/MullvadVPN-2022.5.exe
|
||
github: github.com/mullvad/mullvadvpn-app
|
||
yay: mullvad-vpn
|
||
multi-gitter:
|
||
_bin: multi-gitter
|
||
_github: https://github.com/lindell/multi-gitter
|
||
_name: Multi-Gitter
|
||
brew: lindell/multi-gitter/multi-gitter
|
||
go: github.com/lindell/multi-gitter@latest
|
||
multipass:
|
||
_app: Multipass.app
|
||
_bin: multipass
|
||
_desc: '[Multipass](https://multipass.run/) makes it so that you can get an instant Ubuntu VM with a single command. Multipass can launch and run virtual machines and configure them with cloud-init like a public cloud. It is a product of [Canonical](https://canonical.com/), the same company that publishes Ubuntu.'
|
||
_docs: https://multipass.run/docs
|
||
_github: https://github.com/canonical/multipass
|
||
_home: https://multipass.run/
|
||
_name: Multipass
|
||
_post:cask: |
|
||
#!/usr/bin/env bash
|
||
multipass set local.driver=virtualbox
|
||
_post:choco: |
|
||
#!/usr/bin/env bash
|
||
multipass set local.driver=virtualbox
|
||
ansible: professormanhattan.multipass
|
||
cask: multipass
|
||
choco: multipass
|
||
snap: multipass
|
||
mutagen:
|
||
_bin: mutagen
|
||
_github: https://github.com/mutagen-io/mutagen
|
||
_name: Mutagen
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
mutagen daemon register
|
||
brew: mutagen-io/mutagen/mutagen
|
||
mycli:
|
||
_bin: mycli
|
||
_desc: A terminal client for MySQL with auto-completion and syntax highlighting.
|
||
_docs: https://www.mycli.net/docs
|
||
_github: https://github.com/dbcli/mycli
|
||
_home: https://www.mycli.net/
|
||
_name: MyCLI
|
||
apt: mycli
|
||
brew: mycli
|
||
pipx: mycli
|
||
mymonero:
|
||
_app: MyMonero.app
|
||
_bin: null
|
||
_desc: Easy-to-use Monero client with managed keys
|
||
_docs: https://github.com/mymonero/mymonero-app-js
|
||
_github: https://github.com/mymonero/mymonero-app-js
|
||
_home: https://mymonero.com/
|
||
cask: mymonero
|
||
choco: mymonero
|
||
nativefier:
|
||
_bin: nativefier
|
||
_deps:
|
||
- imagemagick
|
||
_desc: Make any web page a desktop application
|
||
_github: https://github.com/nativefier/nativefier
|
||
_name: nativefier
|
||
npm: nativefier
|
||
nativescript:
|
||
_bin: ns
|
||
_github: https://github.com/NativeScript/NativeScript
|
||
_name: NativeScript
|
||
npm: nativescript
|
||
nautilus-brasero:
|
||
_github: false
|
||
apt: nautilus-extension-brasero
|
||
dnf: brasero-nautilus
|
||
pacman: brasero-nautilus
|
||
nautilus-gsconnect:
|
||
_github: false
|
||
apt: nautilus-gsconnect
|
||
dnf: nautilus-gsconnect
|
||
pacman: nautilus-gsconnect
|
||
nautilus-gtkhash:
|
||
_github: false
|
||
apt: nautilus-gtkhash
|
||
dnf: gtkhash-nautilus
|
||
pacman: nautilus-gtkhash
|
||
nautilus-image-converter:
|
||
_github: false
|
||
apt: nautilus-image-converter
|
||
dnf:fedora: nautilus-image-converter
|
||
pacman: nautilus-image-converter
|
||
nautilus-python:
|
||
_github: false
|
||
apt: nautilus-python
|
||
dnf:fedora: nautilus-python
|
||
pacman: nautilus-python
|
||
nautilus-seahorse:
|
||
_github: false
|
||
apt: nautilus-seahorse
|
||
dnf: seahorse-nautilus
|
||
pacman: nautilus-seahorse
|
||
nautilus-search-tool:
|
||
_github: false
|
||
apt: nautilus-search-tool
|
||
dnf:fedora: nautilus-search-tool
|
||
pacman: nautilus-search-tool
|
||
nautilus-share:
|
||
_github: false
|
||
apt: nautilus-share
|
||
pacman: nautilus-share
|
||
nautilus-wipe:
|
||
_github: false
|
||
apt: nautilus-wipe
|
||
pacman: nautilus-wipe
|
||
navi:
|
||
_bin: navi
|
||
_desc: An interactive cheatsheet tool for the command-line
|
||
_docs: https://github.com/denisidoro/navi/blob/master/docs/installation.md
|
||
_github: https://github.com/denisidoro/navi
|
||
_home: https://github.com/denisidoro/navi
|
||
_name: Navi
|
||
_repology: navi
|
||
brew: navi
|
||
cargo: navi --locked
|
||
emerge: app-misc/navi
|
||
nix-env: nixpkgs.navi
|
||
pacman: navi
|
||
nb:
|
||
_bin: nb
|
||
_deps:
|
||
- bat
|
||
- netcat
|
||
- pandoc
|
||
- ripgrep
|
||
- tig
|
||
- w3m
|
||
_desc: '[nb](https://xwmx.github.io/nb) is a command line and local web note‑taking, bookmarking, archiving, and knowledge base application with plain text data storage, encryption, filtering, pinning, #tagging, search, Git-backed versioning and syncing, Pandoc-backed conversion and many more features.'
|
||
_github: https://github.com/xwmx/nb
|
||
_home: https://xwmx.github.io/nb
|
||
_name: nb
|
||
# Permission denied: /usr/share/zsh/site-functions after running sudo nb completions install and nb completions install on macOS arm64
|
||
# _post: nb completions install
|
||
ansible: professormanhattan.nb
|
||
basher: xwmx/nb
|
||
bpkg: xwmx/nb
|
||
brew: nb
|
||
npm: nb.sh
|
||
ncc:
|
||
_bin: ncc
|
||
_desc: Compile a Node.js project into a single file. Supports TypeScript, binary addons, dynamic requires.
|
||
_github: https://github.com/vercel/ncc
|
||
brew: ncc
|
||
npm: '@vercel/ncc'
|
||
ndb:
|
||
_bin: ndb
|
||
_github: https://github.com/GoogleChromeLabs/ndb
|
||
_name: ndb
|
||
npm: ndb
|
||
nebula:
|
||
_bin: nebula
|
||
_desc: A scalable overlay networking tool with a focus on performance, simplicity and security
|
||
_docs: https://nebula.defined.net/docs/
|
||
_github: https://github.com/slackhq/nebula
|
||
_home: https://github.com/slackhq/nebula
|
||
_name: nebula
|
||
_service: nebula
|
||
_service:brew:
|
||
- name: nebula
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
brew: nebula
|
||
dnf: nebula
|
||
pacman: nebula
|
||
nectar:
|
||
_bin: nectar
|
||
_desc: JavaScript native compiler. No bytecode no VM, just pure native binaries.
|
||
_docs: https://nectar.js.org/docs/
|
||
_github: https://github.com/NerdLang/nerd
|
||
_home: https://nectar.js.org/
|
||
_name: nerctarjs
|
||
npm: nectarjs
|
||
neofetch:
|
||
_bin: neofetch
|
||
_github: https://github.com/dylanaraps/neofetch
|
||
_name: NeoFetch
|
||
apk:
|
||
- ncurses
|
||
- neofetch
|
||
apt: neofetch
|
||
brew: neofetch
|
||
dnf: neofetch
|
||
eopkg: neofetch
|
||
nix-env: neofetch
|
||
pacman: neofetch
|
||
pkg-freebsd: neofetch
|
||
pkg-termux: neofetch
|
||
scoop: neofetch
|
||
xbps: neofetch
|
||
zypper: neofetch
|
||
neovide:
|
||
_app: Neovide.app
|
||
_bin: neovide
|
||
_desc: No Nonsense Neovim Client in Rust
|
||
_docs: https://neovide.dev/installation.html
|
||
_github: https://github.com/neovide/neovide
|
||
_home: https://neovide.dev/
|
||
_name: Neovide
|
||
cask: neovide
|
||
pacman: neovide
|
||
scoop: neovide
|
||
snap: neovide
|
||
neovim:
|
||
_bin: nvim
|
||
_deps:
|
||
- clangd
|
||
- terraform-ls
|
||
- neovim-node-host
|
||
_desc: '[neovim](https://neovim.io/) is Vim-fork focused on extensibility and usability'
|
||
_docs: https://neovim.io/doc/general/
|
||
_github: https://github.com/neovim/neovim
|
||
_home: https://neovim.io/
|
||
_name: neovim
|
||
apk: neovim
|
||
apt:
|
||
- neovim
|
||
- python3-neovim
|
||
brew: neovim
|
||
choco: neovim
|
||
dnf:
|
||
- neovim
|
||
- python3-neovim
|
||
# Need to figure out how to include neovim plugin suite
|
||
# flatpak: io.neovim.nvim
|
||
nix: neovim
|
||
pacman:
|
||
- neovim
|
||
- python-pynvim
|
||
pkg:
|
||
- neovim
|
||
- py27-pynvim
|
||
- py36-pynvim
|
||
port: neovim
|
||
winget: Neovim.Neovim
|
||
zypper:
|
||
- neovim
|
||
- python-neovim
|
||
- python3-neovim
|
||
neovim-node-host:
|
||
_bin: neovim-node-host
|
||
_github: https://github.com/neovim/node-client
|
||
_name: Neovim Node Host
|
||
npm: neovim
|
||
nest:
|
||
_bin: nest
|
||
_desc: CLI tool for Nest applications
|
||
_docs: https://docs.nestjs.com/cli/overview
|
||
_github: https://github.com/nestjs/nest-cli
|
||
_name: nest
|
||
npm: '@nestjs/cli'
|
||
netcat:
|
||
_bin: netcat
|
||
_github: false
|
||
_desc: netcat (often abbreviated to nc) is a computer networking utility for reading from and writing to network connections using TCP or UDP.
|
||
_home: https://nc110.sourceforge.io/
|
||
_name: netcat
|
||
apt: netcat
|
||
brew: netcat
|
||
choco: netcat
|
||
dnf: netcat
|
||
pacman: netcat
|
||
scoop: netcat
|
||
netdata:
|
||
_bin: netdata
|
||
_deps:
|
||
- debsecan
|
||
- speedtest-cli
|
||
_desc: '[Netdata](https://www.netdata.cloud/) is an open source tool designed to collect real-time metrics, such as CPU usage, disk activity, bandwidth usage, website visits, etc., and then display them in live, easy-to-interpret charts.'
|
||
_docs: https://learn.netdata.cloud/docs/
|
||
_github: https://github.com/netdata/netdata
|
||
_groups:
|
||
- netdata
|
||
_home: https://www.netdata.cloud/
|
||
_name: Netdata
|
||
_post: "#!/usr/bin/env bash\n# @file Netdata\n# @brief Connects Netdata with Netdata's free cloud dashboard and applies some system optimizations, if necessary\n# @description\n# This script connects Netdata with Netdata Cloud if Netdata is installed, the `NETDATA_TOKEN` is provided, and the\n# `NETDATA_ROOM` is defined. This allows you to graphically browse through system metrics on all your connected devices\n# from a single free web application.\n#\n# This script installs additional alerts and enables notifications if Netdata is installed. Email notifications are configured\n# using the provided primary email address. If the OS is Debian based, Netdata shows the number of CVEs in currently installed packages.\n\nensureNetdataOwnership() {\n ### Ensure /usr/local/var/lib/netdata/cloud.d is owned by user\n if [ -d /usr/local/var/lib/netdata ]; then\n logg info 'Ensuring permissions are correct on /usr/local/var/lib/netdata' && sudo chown -Rf netdata:netdata /usr/local/var/lib/netdata 2> /dev/null || sudo chown -Rf netdata:$(id -g -n) /usr/local/var/lib/netdata\n elif [ -d /var/lib/netdata ]; then\n logg info 'Ensuring permissions are correct on /var/lib/netdata' && sudo chown -Rf netdata:netdata /var/lib/netdata 2> /dev/null || sudo chown -Rf netdata:$(id -g -n) /var/lib/netdata\n elif [ -d \"${HOMEBREW_PREFIX:-/opt/homebrew}/var/lib/netdata\" ]; then\n logg info \"Ensuring permissions are correct on ${HOMEBREW_PREFIX:-/opt/homebrew}/var/lib/netdata\" && sudo chown -Rf netdata:netdata \"${HOMEBREW_PREFIX:-/opt/homebrew}/var/lib/netdata\" 2> /dev/null || sudo chown -Rf netdata:$(id -g -n) \"${HOMEBREW_PREFIX:-/opt/homebrew}/var/lib/netdata\"\n else\n logg warn 'No /var/lib/netdata folder found'\n fi\n}\n\n### Claim the instance with Netdata Cloud\nif command -v netdata-claim.sh > /dev/null; then\n ### Add user / group with script in ~/.local/bin/add-usergroup, if it is available\n if command -v add-usergroup > /dev/null; then\n sudo add-usergroup \"$USER\" netdata\n fi\n\n ### Ensure ownership\n ensureNetdataOwnership\n\n ### netdata-claim.sh must be run as netdata user\n sudo -H -u netdata bash -c 'export NETDATA_ROOM=\"{{- if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"NETDATA_ROOM\")) -}}{{- includeTemplate \"secrets/NETDATA_ROOM\" | decrypt | trim -}}{{- else -}}{{- env \"NETDATA_ROOM\" -}}{{- end -}}\" && export NETDATA_TOKEN=\"{{- if (stat (joinPath .chezmoi.sourceDir \".chezmoitemplates\" \"secrets\" \"NETDATA_TOKEN\")) -}}{{- includeTemplate \"secrets/NETDATA_TOKEN\" | decrypt | trim -}}{{- else -}}{{- env \"NETDATA_TOKEN\" -}}{{- end -}}\" && yes | netdata-claim.sh -token=\"$NETDATA_TOKEN\" -rooms=\"$NETDATA_ROOM\" -url=\"https://app.netdata.cloud\"'\n \n ### Kernel optimizations\n # These are mentioned while installing via the kickstart.sh script method. We are using Homebrew for the installation though.\n # Assuming these optimizations do not cause any harm.\n if [ -d /Applications ] && [ -d /System ]; then\n ### macOS\n logg info 'System is macOS so Netdata kernel optimizations are not required'\n else\n ### Linux\n if [ -d /sys/kernel/mm/ksm ]; then\n logg info 'Adding Netdata kernel optimization for /sys/kernel/mm/ksm/run'\n echo 1 | sudo tee /sys/kernel/mm/ksm/run\n logg info 'Adding Netdata kernel optimization for /sys/kernel/mm/ksm/sleep_millisecs'\n echo 1000 | sudo tee /sys/kernel/mm/ksm/sleep_millisecs\n else\n logg info 'The /sys/kernel/mm/ksm directory does not exist so Netdata kernel optimizations are not being applied'\n fi\n fi\n\n ### Install additional alerts and enable notifications\n if command -v netdata > /dev/null; then\n ### Copy the additional alert definitions\n if [ -d /usr/local/etc/netdata ]; then\n NETDATA_ETC='/usr/local/etc/netdata/'\n elif [ -d /etc/netdata ]; then\n NETDATA_ETC='/etc/netdata'\n elif [ -d \"${HOMEBREW_PREFIX:-/opt/homebrew}/etc/netdata\" ]; then\n NETDATA_ETC=\"${HOMEBREW_PREFIX:-/opt/homebrew}/etc/netdata\"\n else\n logg error 'No etc location found for netdata' && exit 1\n fi\n logg info \"Copying ${XDG_CONFIG_HOME:-$HOME/.config}/netdata/health.d/ to $NETDATA_ETC\" && sudo cp -rf \"${XDG_CONFIG_HOME:-$HOME/.config}/netdata/health.d/\" \"$NETDATA_ETC\"\n \n if command -v gsed > /dev/null; then\n SED_UTIL=\"gsed\"\n else\n SED_UTIL=\"sed\"\n fi\n\n ### Blocky\n logg info \"Adding Blocky metrics collection to $NETDATA_ETC/go.d/prometheus.conf\"\n sudo \"$SED_UTIL\" -i \"/jobs:/a\\ - name: blocky_local \\n url: 'http://127.0.0.1:4000/metrics'\" \"$NETDATA_ETC/go.d/prometheus.conf\"\n \n ### SFTPGo\n logg info \"Adding SFTPGo metrics collection to $NETDATA_ETC/go.d/prometheus.conf\"\n sudo \"$SED_UTIL\" -i \"/jobs:/a\\ - name: sftpgo_local \\n url: 'http://127.0.0.1:57500/metrics'\" \"$NETDATA_ETC/go.d/prometheus.conf\"\n\n # Backup current health alarm configuration and apply new one\n if [ -d /usr/local/lib/netdata ]; then\n NETDATA_LIB='/usr/local/lib/netdata'\n elif [ -d /usr/lib/netdata ]; then\n NETDATA_LIB='/usr/lib/netdata'\n elif [ -d \"${HOMEBREW_PREFIX:-/opt/homebrew}/lib/netdata\" ]; then\n NETDATA_LIB=\"${HOMEBREW_PREFIX:-/opt/homebrew}/lib/netdata\"\n else\n logg error 'No lib location found for netdata' && exit 1\n fi\n logg info \"Copying ${XDG_CONFIG_HOME:-$HOME/.config}/netdata/health_alarm_notify.conf to $NETDATA_LIB/conf.d/health_alarm_notify.conf\" && sudo cp -f \"${XDG_CONFIG_HOME:-$HOME/.config}/netdata/health_alarm_notify.conf\" \"$NETDATA_LIB/conf.d/health_alarm_notify.conf\"\n else\n logg warn 'netdata is not available in the PATH or is not installed'\n fi\n\n ### Ensure the apt command is available before running `debsecan` logic\n if command -v apt-get > /dev/null; then\n ### Configure Netdata to gather information about CVEs in the installed packages\n if command -v debsecan > /dev/null; then\n DEBSECAN_GIT=\"${XDG_DATA_HOME:-$HOME/.local/share}/netdata-debsecan\"\n ### Installing the script to generate report on CVEs in installed packages\n logg info 'Installing script to generate report on CVEs in installed packages' && sudo cp -f \"$DEBSECAN_GIT/usr_local_bin_debsecan-by-type\" \"/usr/local/bin/debsecan-by-type\"\n ### Generate initial debsecan reports in /var/log/debsecan/\n logg info 'Generating initial debsecan reports in /var/log/debsecan/' && debsecan-by-type\n ### Configure dpkg to refresh the file after each run\n logg info 'Configuring dpkg to refresh the file after each run' && sudo cp -f \"$DEBSECAN_GIT/etc_apt_apt.conf.d_99debsecan\" /etc/apt/apt.conf.d/99-debsecan\n ### Add a cron job to refresh the file every hour\n logg info 'Adding a cron job to refresh the file every hour' && sudo cp -f \"$DEBSECAN_GIT/etc_cron.d_debsecan\" /etc/cron.d/debsecan\n ### Install the module/configuration file\n logg info 'Installing the module and configuration file'\n sudo \"$DEBSECAN_GIT/debsecan.chart.py\" /usr/libexec/netdata/python.d/debsecan.chart.py\n sudo \"$DEBSECAN_GIT/debsecan.conf\" /etc/netdata/python.d/debsecan.conf\n else\n logg warn 'apt-get is available but debsecan is not available in the PATH or is not installed'\n fi\n fi\n\n ### Ensure / report whether speedtest-cli is installed\n if ! command -v speedtest-cli > /dev/null; then\n if command -v pipx > /dev/null; then\n pipx install speedtest-cli\n else\n logg warn 'speedtest-cli not installed and pipx is not available'\n fi\n fi\n\n ### Configure Netdata to gather information about Internet connection speed\n if command -v speedtest-cli > /dev/null; then\n ### Installing the script to generate report on Internet connection speed\n logg info 'Installing script to generate report on Internet connection speed'\n LIBEXEC_PATH=\"$(netdata -W buildinfo | grep 'Configure' | sed \"s/.*--libexecdir=\\([^ \\']*\\).*/\\1/\")\"\n if [ -d /usr/libexec/netdata/charts.d ]; then\n sudo cp -f \"${XDG_DATA_HOME:-$HOME/.local/share}/netdata-speedtest/speedtest.chart.sh\" \"/usr/libexec/netdata/charts.d/speedtest.chart.sh\"\n elif [ -d \"$LIBEXEC_PATH/netdata/charts.d\" ]; then\n logg info \"$LIBEXEC_PATH/netdata/charts.d present on system\"\n cp -f \"${XDG_DATA_HOME:-$HOME/.local/share}/netdata-speedtest/speedtest.chart.sh\" \"$LIBEXEC_PATH/netdata/charts.d/speedtest.chart.sh\"\n else\n logg warn \"Failed to find appropriate directory to add Netdata speedtest chart script\"\n fi\n else\n logg warn 'speedtest-cli is not available in the PATH or is not installed'\n fi\n\n ### Ensure ownership again\n ensureNetdataOwnership\n\n ### Restart Netdata service\n if command -v systemctl > /dev/null; then\n logg info 'Enabling netdata service' && sudo systemctl enable netdata\n logg info 'Restarting netdata service' && sudo systemctl restart netdata\n elif [ -d /Applications ] && [ -d /System ]; then\n logg info 'Starting / enabling netdata service' && brew services restart netdata\n else\n logg warn 'systemctl is not available'\n fi\nelse\n logg info 'netdata-claim.sh is not available in the PATH'\nfi\n"
|
||
_service: netdata
|
||
_service:brew:
|
||
- name: netdata
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
ansible: professormanhattan.netdata
|
||
brew: netdata
|
||
pacman: netdata
|
||
port: netdata
|
||
script: curl https://my-netdata.io/kickstart.sh > /tmp/netdata-kickstart.sh && sh /tmp/netdata-kickstart.sh
|
||
networkmanager:
|
||
_bin: networkmanager
|
||
_github: https://github.com/BornToBeRoot/NETworkManager
|
||
_name: NETworkManager
|
||
scoop: networkmanager
|
||
winget: BornToBeRoot.NETworkManager
|
||
newman:
|
||
_bin: newman
|
||
_desc: Command-line collection runner for Postman
|
||
_github: https://github.com/postmanlabs/newman
|
||
_home: https://www.getpostman.com
|
||
_name: newman
|
||
brew: newman
|
||
npm: newman
|
||
newsflash:
|
||
_bin: newsflash
|
||
_github: false
|
||
_gitlab: https://gitlab.com/news-flash/news_flash_gtk
|
||
flatpak: com.gitlab.newsflash
|
||
nextcloud:
|
||
_app: Nextcloud.app
|
||
_bin: nextcloudcmd
|
||
_desc: '[Nextcloud Client](https://nextcloud.com) is a tool to keep your files synchronized between your Nextcloud server and your desktop. Select one or more directories on your local machine and always have access to your latest files wherever you are'
|
||
_docs: https://docs.nextcloud.com/server/latest/user_manual/en/
|
||
_github: https://github.com/nextcloud/desktop
|
||
_home: https://nextcloud.com
|
||
_name: Nextcloud Client
|
||
cask: nextcloud
|
||
choco: nextcloud-client
|
||
flatpak: com.nextcloud.desktopclient.nextcloud
|
||
nginx:
|
||
_bin: nginx
|
||
_desc: It also generates sites-enabled proxies using YML configurations. Easter eggs included. [Nginx](https://www.nginx.com/), stylized as NGINX, nginx or NginX, is a web server that can also be used as a reverse proxy, load balancer, mail proxy and HTTP cache. The software was created by Igor Sysoev and publicly released in 2004. Nginx is free and open-source software, released under the terms of the 2-clause BSD license.
|
||
_docs: https://nginx.org/en/docs/
|
||
_github: https://github.com/nginx/nginx
|
||
_home: https://nginx.org/
|
||
_name: NGINX
|
||
_ports:
|
||
- port: 80
|
||
proto: tcp
|
||
- port: 443
|
||
proto: tcp
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file NGINX Amplify Join
|
||
# @brief Set up NGINX Amplify and joins the cloud monitoring service dashboard
|
||
# @description
|
||
# This script installs NGINX Amplify and connects with the user's NGINX Amplify instance, assuming the `NGINX_AMPLIFY_API_KEY`
|
||
# is defined. NGINX Amplify is a free web application that serves as a way of browsing through metrics of all your connected
|
||
# NGINX instances.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [NGINX Amplify login](https://amplify.nginx.com/login)
|
||
# * [NGINX Amplify documentation](https://docs.nginx.com/nginx-amplify/#)
|
||
|
||
if command -v nginx > /dev/null; then
|
||
logg info 'Downloading the NGINX Amplify installer script'
|
||
TMP="$(mktemp)"
|
||
curl -sSL https://github.com/nginxinc/nginx-amplify-agent/raw/master/packages/install.sh > "$TMP"
|
||
logg info 'Running the NGINX Amplify setup script'
|
||
API_KEY="{{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "NGINX_AMPLIFY_API_KEY")) }}{{- includeTemplate "secrets/NGINX_AMPLIFY_API_KEY" | decrypt | trim -}}{{ else }}{{- env "NGINX_AMPLIFY_API_KEY" -}}{{ end }}" sh "$TMP"
|
||
fi
|
||
_service: nginx
|
||
_serviceEnabled: true
|
||
_todo: Check out /opt/homebrew/etc/nginx/nginx.conf / nginx/servers
|
||
ansible: professormanhattan.nginx
|
||
apt: nginx
|
||
brew: nginx
|
||
choco: nginx
|
||
dnf: nginx
|
||
pacman: nginx
|
||
port: nginx
|
||
scoop: nginx
|
||
nginx-unit:
|
||
_bin: unitd
|
||
_github: https://github.com/nginx/unit
|
||
_name: NGINX Unit
|
||
_service: unit
|
||
brew: nginx/unit/unit
|
||
ngrok:
|
||
_bin: ngrok
|
||
_github: false
|
||
_desc: '[Ngrok](https://ngrok.com/) exposes local servers behind NATs and firewalls to the public internet over secure tunnels. Ngrok also provides a real-time web UI where you can introspect all HTTP traffic running over your tunnels. You can replay any request against your tunnels with one click. The main feature is the ability to generate an internet-accessible URL that directs traffic to your local web server even if it is behind a firewall or proxy.'
|
||
_home: https://ngrok.com/)
|
||
_name: Ngrok
|
||
ansible: professormanhattan.ngrok
|
||
cask: ngrok
|
||
choco: ngrok
|
||
snap: ngrok
|
||
ngxtop:
|
||
_bin: ngxtop
|
||
_desc: Real-time metrics for nginx server
|
||
_github: https://github.com/lebinh/ngxtop
|
||
_name: ngxtop
|
||
pipx: ngxtop
|
||
ninja:
|
||
_bin: ninja
|
||
_github: https://github.com/ninja-build/ninja
|
||
_name: Ninja
|
||
apt: ninja
|
||
brew: ninja
|
||
dnf: ninja
|
||
pacman: ninja
|
||
zypper: ninja
|
||
nitroshare:
|
||
_app: nitroshare.app
|
||
_bin: nitroshare
|
||
_desc: Network file transfer application for Windows, OS X, & Linux
|
||
_docs: https://nitroshare.net/
|
||
_github: https://github.com/nitroshare/nitroshare-desktop
|
||
_home: https://nitroshare.net/
|
||
_name: NitroShare
|
||
apt: nitroshare
|
||
cask: nitroshare
|
||
choco: nitroshare
|
||
dnf: nitroshare
|
||
pacman: nitroshare
|
||
nmap:
|
||
_bin: nmap
|
||
_desc: >-
|
||
[Nmap](https://github.com/nmap/nmap) (short for Network Mapper) is a free and open source utility for network discovery and security auditing. Many systems and network administrators also find it useful for tasks such as network inventory, managing service upgrade schedules, and monitoring host or service uptime. Nmap uses raw IP packets in novel ways to determine what hosts are available on the network, what services those hosts are offering, what operating systems they are running, what type of packet filters/firewalls are in use, and dozens of other characteristics. It was designed to rapidly scan large networks, but works fine against single hosts. Nmap runs on all major operating systems.
|
||
_docs: https://nmap.org/docs.html
|
||
_github: https://github.com/nmap/nmap
|
||
_home: https://nmap.org/
|
||
_name: Nmap
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
sudo snap connect nmap:network-control
|
||
ansible: professormanhattan.nmap
|
||
apt: nmap
|
||
brew: nmap
|
||
choco: nmap
|
||
dnf: nmap
|
||
pacman: nmap
|
||
port: nmap
|
||
scoop: nmap
|
||
snap: nmap
|
||
nnn:
|
||
_bin: nnn
|
||
_desc: A full-featured terminal file manager
|
||
_github: https://github.com/jarun/nnn
|
||
_name: nnn
|
||
apk: nnn
|
||
apt: nnn
|
||
brew: nnn
|
||
github: github.com/jarun/nnn
|
||
pacman: nnn
|
||
pkg: nnn
|
||
node:
|
||
_bin: node
|
||
_desc: '[Node.js](https://nodejs.org/en/) is an open-source, cross-platform, back-end JavaScript runtime environment that runs on the V8 engine and executes JavaScript code outside a web browser.'
|
||
_docs: https://nodejs.org/en/docs/
|
||
_github: https://github.com/nodejs/node
|
||
_home: https://nodejs.org/en/
|
||
_name: Node.js
|
||
ansible: professormanhattan.nodejs
|
||
brew: node
|
||
scoop: nodejs
|
||
node-prune:
|
||
_bin: node-prune
|
||
_desc: Extension to remove unnecessary files from node_modules
|
||
_github: https://github.com/tj/node-prune
|
||
_name: node-prune
|
||
github: github.com/tj/node-prune
|
||
go: github.com/tj/node-prune@latest
|
||
nodemon:
|
||
_bin: nodemon
|
||
_github: https://github.com/remy/nodemon
|
||
_name: Nodemon
|
||
npm: nodemon
|
||
nomad:
|
||
_bin: nomad
|
||
_github: https://github.com/hashicorp/nomad
|
||
_desc: '[HashiCorp Nomad](https://www.nomadproject.io/) is a simple and flexible scheduler and workload orchestrator to deploy and manage containers and non-containerized applications across on-prem and clouds at scale.'
|
||
_docs: https://developer.hashicorp.com/nomad/docs
|
||
_home: https://www.nomadproject.io/
|
||
_name: HashiCorp Nomad
|
||
_service: nomad
|
||
ansible: professormanhattan.nomad
|
||
brew: nomad
|
||
choco: nomad
|
||
yay: nomad-git
|
||
nomino:
|
||
_bin: nomino
|
||
_desc: Batch rename utility for developers
|
||
_github: https://github.com/yaa110/nomino
|
||
_name: nomino
|
||
cargo: nomino
|
||
github: github.com/yaa110/nomino
|
||
yay: nomino
|
||
nordvpn:
|
||
_bin: null
|
||
_desc: '[NordVPN](https://nordvpn.com/) is a virtual private network service provider. It has desktop applications for Windows, macOS, and Linux, mobile apps for Android and iOS, as well as an application for Android TV. Manual setup is available for wireless routers, NAS devices and other platforms.'
|
||
_docs: https://support.nordvpn.com/
|
||
_github: https://github.com/jotyGill/openpyn-nordvpn
|
||
_home: https://nordvpn.com/
|
||
_name: NordVPN
|
||
ansible: professormanhattan.nordvpn
|
||
normit:
|
||
_bin: normit
|
||
_deps:
|
||
- mpg123
|
||
_desc: '[Normit](https://github.com/pawurb/normit) allows you to easily translate any text from one language to another. It also includes the ability to generate audio through speech synthesis as well.'
|
||
_github: https://github.com/pawurb/normit
|
||
_name: Normit
|
||
ansible: professormanhattan.normit
|
||
npm: normit
|
||
notion:
|
||
_app: Notion.app
|
||
_bin: null
|
||
_desc: Notion is the connected workspace where better, faster work happens.
|
||
_docs: https://www.notion.so/help/guides/category/documentation
|
||
_env:
|
||
NOTION_APPDATA:
|
||
cask: "$HOME/Library/Application Support/Notion"
|
||
choco: "TODO"
|
||
_github: https://github.com/makenotion/notion-sdk-js
|
||
_home: https://www.notion.so/
|
||
_name: Notion AI
|
||
_note: Waiting on Linux install alternative.
|
||
cask: notion
|
||
choco: notion
|
||
mas: 1559269364
|
||
np:
|
||
_bin: np
|
||
_desc: A better `npm publish`
|
||
_github: https://github.com/sindresorhus/np
|
||
_name: np
|
||
npm: np
|
||
# Error installing aiohttp dependency
|
||
# starred:
|
||
# _bin: starred
|
||
# pipx: starred
|
||
npkill:
|
||
_bin: npkill
|
||
_github: https://github.com/voidcosmos/npkill
|
||
_name: npkill
|
||
npm: npkill
|
||
npm-check:
|
||
_bin: npm-check
|
||
_desc: Check for outdated, incorrect, and unused dependencies.
|
||
_github: https://github.com/dylang/npm-check
|
||
_name: npm-check
|
||
npm: npm-check
|
||
npm-check-updates:
|
||
_bin: ncu
|
||
_github: https://github.com/raineorshine/npm-check-updates
|
||
_name: NPM Check Updates
|
||
npm: npm-check-updates
|
||
ntfy:
|
||
_bin: nfty
|
||
_github: https://github.com/dschep/ntfy
|
||
_name: NFTY
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo mkdir -p /usr/local/etc/branding
|
||
sudo cp -f "$HOME/.local/etc/branding/logo-color-256x256.png" /usr/local/etc/branding/logo-color-256x256.png
|
||
sudo mkdir -p /usr/local/share/sounds
|
||
sudo rsync -rtvp "${XDG_DATA_HOME:-$HOME/.local/share}/sounds/" /usr/local/share/sounds
|
||
if command -v apt-get > /dev/null; then
|
||
sudo apt install python-dbus
|
||
fi
|
||
if command -v termux-setup-storage > /dev/null; then
|
||
apt install termux-api
|
||
fi
|
||
pip3: ntfy[emoji,matrix,pid,slack]
|
||
ntl:
|
||
_bin: ntl
|
||
_github: https://github.com/ruyadorno/ntl
|
||
_name: NTL
|
||
npm: ntl
|
||
nuclear:
|
||
_app: nuclear.app
|
||
_bin: nuclear
|
||
_desc: Streaming music player that finds free music
|
||
_github: https://github.com/nukeop/nuclear
|
||
_home: https://nuclear.js.org/
|
||
_name: Nuclear
|
||
cask: nuclear
|
||
choco: nuclear
|
||
flatpak: org.js.nuclear.Nuclear
|
||
github: github.com/nukeop/nuclear
|
||
snap: nuclear
|
||
yay: nuclear-player-bin
|
||
nugetpackageexplorer:
|
||
_bin: nugetpackageexplorer
|
||
_github: https://github.com/NuGetPackageExplorer/NuGetPackageExplorer
|
||
_name: NuGet Package Explorer
|
||
choco: nugetpackageexplorer
|
||
winapp: nuget-package-explorer/9WZDNCRDMDM3
|
||
winget: NuGet Package Explorer
|
||
nushell:
|
||
_bin: nu
|
||
_github: https://github.com/nushell/nushell
|
||
_name: Nu
|
||
apk: nushell
|
||
apt: nushell
|
||
brew: nushell
|
||
choco: nushell
|
||
dnf: nushell
|
||
pacman: nushell
|
||
port: nushell
|
||
scoop: nushell
|
||
winget: nushell
|
||
nve:
|
||
_bin: nve
|
||
_github: https://github.com/ehmicky/nve
|
||
_name: nve
|
||
npm: nve
|
||
nx:
|
||
_bin: nx
|
||
_github: https://github.com/nrwl/nx
|
||
_name: NX
|
||
npm: nx
|
||
obs-studio:
|
||
_app: OBS.app
|
||
_bin: obs-studio
|
||
_github: https://github.com/obsproject/obs-studio
|
||
_name: OBS Studio
|
||
cask: obs
|
||
choco: obs-studio
|
||
flatpak: com.obsproject.Studio
|
||
obsidian:
|
||
_app: Obsidian.app
|
||
_bin: null
|
||
_desc: Obsidian is the private and flexible note‑taking app that adapts to the way you think.
|
||
_docs: https://help.obsidian.md/Home
|
||
_github: false
|
||
_home: https://obsidian.md/
|
||
_name: Obsidian
|
||
appimage: Obsidian
|
||
cask: obsidian
|
||
choco: obsidian
|
||
flatpak: md.obsidian.Obsidian
|
||
scoop: extras/obsidian
|
||
winget: Obsidian.Obsidian
|
||
obsidian-cli:
|
||
_bin: obs
|
||
_github: https://github.com/Yakitrak/obsidian-cli
|
||
_name: Obsidian CLI
|
||
_pre:scoop: scoop bucket add scoop-yakitrak https://github.com/yakitrak/scoop-yakitrak.git
|
||
brew: megabyte-labs/tap/obs-cli
|
||
scoop: obs
|
||
oclif:
|
||
_bin: oclif
|
||
_desc: "[oclif](https://oclif.io/) is a framework for building CLIs in Node.js. This framework was built out of the Heroku CLI but generalized to build any custom CLI. It's designed both for single-file CLIs with a few flag options, or for very complex CLIs that have subcommands (like git or heroku)"
|
||
_docs: https://oclif.io/docs/
|
||
_github: https://github.com/oclif/oclif
|
||
_home: https://oclif.io/
|
||
_name: oclif
|
||
npm: oclif
|
||
octosql:
|
||
_bin: octosql
|
||
_github: https://github.com/cube2222/octosql
|
||
_name: OctoSQL
|
||
brew: cube2222/octosql/octosql
|
||
scoop: octosql
|
||
oh-my-posh:
|
||
_bin: oh-my-posh
|
||
_desc: A blazing fast cross platform/shell prompt renderer
|
||
_docs: https://ohmyposh.dev/docs
|
||
_github: https://github.com/jandedobbeleer/oh-my-posh
|
||
_home: https://ohmyposh.dev/
|
||
_name: oh-my-posh
|
||
_post:scoop: |
|
||
#!/usr/bin/env bash
|
||
clink autorun install
|
||
brew: jandedobbeleer/oh-my-posh/oh-my-posh
|
||
scoop:
|
||
- clink
|
||
- https://github.com/JanDeDobbeleer/oh-my-posh/releases/latest/download/oh-my-posh.json
|
||
onionshare:
|
||
_bin: onionshare
|
||
_desc: '[OnionShare](https://.onionshare.org/) is an open source tool that lets you securely and anonymously share files, host websites, and chat with friends using the Tor network.'
|
||
_docs: https://docs.onionshare.org/2.5/en/
|
||
_github: https://github.com/onionshare/onionshare
|
||
_home: https://onionshare.org/
|
||
_name: OnionShare
|
||
ansible: professormanhattan.onionshare
|
||
apt: onionshare
|
||
cask: onionshare
|
||
choco: onionshare
|
||
dnf: onionshare
|
||
flatpak: org.onionshare.OnionShare
|
||
snap: onionshare
|
||
onlykey:
|
||
_app: OnlyKey App.app
|
||
_bin: onlykey
|
||
_bin:snap: onlykey-app
|
||
_github: https://github.com/trustcrypto/OnlyKey-App
|
||
_name: onlykey
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
sudo curl -sSL https://raw.githubusercontent.com/trustcrypto/trustcrypto.github.io/pages/49-onlykey.rules -o /etc/udev/rules.d/49-onlykey.rules
|
||
sudo chmod 644 /etc/udev/rules.d/49-onlykey.rules
|
||
sudo udevadm control --reload-rules
|
||
sudo udevadm trigger
|
||
ansible:darwin: professormanhattan.onlykey
|
||
choco: onlykey
|
||
script:darwin: cd /tmp && curl -sSL https://github.com/trustcrypto/OnlyKey-App/releases/download/v5.3.6/OnlyKey.App.5.3.6.dmg > OnlyKey.dmg && hdiutil attach "/tmp/OnlyKey.dmg" && sudo cp -R "/Volumes/OnlyKey App/OnlyKey App.app" /Applications && sudo hdiutil detach "/Volumes/OnlyKey App" && rm -f "/tmp/OnlyKey.dmg"
|
||
snap: onlykey-app
|
||
onlykey-agent:
|
||
_bin: onlykey-agent
|
||
_deps:
|
||
- onlykey-cli-deps
|
||
_github: https://github.com/trustcrypto/onlykey-agent
|
||
_name: OnlyKey Agent
|
||
brew: onlykey-agent
|
||
pipx: onlykey-agent
|
||
onlykey-cli:
|
||
_bin: onlykey-cli
|
||
_deps:
|
||
- onlykey-cli-deps
|
||
_github: https://github.com/trustcrypto/python-onlykey
|
||
_name: OnlyKey CLI
|
||
pipx: onlykey
|
||
onlykey-cli-deps:
|
||
_github: false
|
||
_post:linux: |
|
||
#!/usr/bin/env bash
|
||
sudo curl -sSL https://raw.githubusercontent.com/trustcrypto/trustcrypto.github.io/pages/49-onlykey.rules -o /etc/udev/rules.d/49-onlykey.rules
|
||
sudo chmod 644 /etc/udev/rules.d/49-onlykey.rules
|
||
sudo udevadm control --reload-rules
|
||
sudo udevadm trigger
|
||
apt:
|
||
- python3-pip
|
||
- python3-tk
|
||
- libusb-1.0-0-dev
|
||
- libudev-dev
|
||
brew:darwin:
|
||
- libusb
|
||
dnf:
|
||
- python3-pip
|
||
- python3-devel
|
||
- python3-tkinter
|
||
- libusb-devel
|
||
- libudev-devel
|
||
- gcc
|
||
- redhat-rpm-config
|
||
pacman:
|
||
- git
|
||
- python3-setuptools
|
||
- python3
|
||
- libusb
|
||
- python3-pip
|
||
zypper:
|
||
- python3-pip
|
||
- python3-devel
|
||
- python3-tk
|
||
- libusb-1_0-devel
|
||
- libudev-devel
|
||
opencommit:
|
||
_bin: opencommit
|
||
_desc: GPT CLI to auto-generate impressive commits in 1 second
|
||
_docs: https://github.com/di-sukharev/opencommit
|
||
_github: https://github.com/di-sukharev/opencommit
|
||
_home: https://www.npmjs.com/package/opencommit
|
||
_name: OpenCommit
|
||
npm: opencommit
|
||
openinterminal:
|
||
_app: OpenInTerminal.app
|
||
_bin: null
|
||
_desc: Finder Toolbar app for macOS to open the current directory in Terminal, iTerm, Hyper or Alacritty
|
||
_docs: https://github.com/Ji4n1ng/OpenInTerminal
|
||
_github: https://github.com/Ji4n1ng/OpenInTerminal
|
||
_home: https://github.com/Ji4n1ng/OpenInTerminal
|
||
_name: OpenInTerminal
|
||
cask: openinterminal
|
||
openjdk:
|
||
_bin: javac
|
||
_desc: Latest version of the OpenJDK (Java Development Kit)
|
||
_docs: https://openjdk.org/groups/build/doc/building.html
|
||
_github: https://github.com/openjdk/jdk
|
||
_home: https://openjdk.org/
|
||
_name: OpenJDK
|
||
apt: default-jdk
|
||
brew: openjdk
|
||
choco: openjdk
|
||
dnf: java-latest-openjdk.x86_64
|
||
pacman: jdk-openjdk
|
||
openshift-cli:
|
||
_bin: oc
|
||
_desc: The OpenShift Command Line, part of OKD
|
||
_docs: https://docs.openshift.com/container-platform/4.8/cli_reference/openshift_cli/getting-started-cli.html
|
||
_github: https://github.com/openshift/oc
|
||
_home: https://www.redhat.com/en/technologies/cloud-computing/openshift
|
||
_name: OpenShift CLI
|
||
brew: openshift-cli
|
||
choco: openshift-cli
|
||
openssh-server:
|
||
_service: sshd
|
||
_github: false
|
||
_when: test -f /proc/version && ! grep Microsoft /proc/version > /dev/null && ! test -d /Applications'
|
||
apt: openssh-server
|
||
dnf: openssh-server
|
||
pacman: openssh
|
||
openssl:
|
||
_bin: openssl
|
||
_github: false
|
||
_name: OpenSSL
|
||
apt: openssl
|
||
brew: openssl
|
||
choco: openssl
|
||
dnf: openssl
|
||
pacman: openssl
|
||
port: openssl
|
||
scoop: openssl
|
||
openssl-osx-ca:
|
||
_bin: openssl-osx-ca
|
||
_github: https://github.com/raggi/openssl-osx-ca
|
||
_name: OpenSSL macOS CA
|
||
_service:brew:darwin:
|
||
- name: openssl-osx-ca
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
brew:darwin: raggi/ale/openssl-osx-ca
|
||
openvpn:
|
||
_bin: openvpn
|
||
_github: https://github.com/OpenVPN/openvpn
|
||
_name: OpenVPN
|
||
_service: openvpn
|
||
_service:brew:
|
||
- name: openvpn
|
||
sudo: true
|
||
apt: openvpn
|
||
brew: openvpn
|
||
choco: openvpn
|
||
dnf: openvpn
|
||
pacman: openvpn
|
||
opn-cli:
|
||
_bin: opn-cli
|
||
_github: https://github.com/andeman/opn-cli
|
||
_name: OPNSense CLI
|
||
pipx: opn-cli
|
||
oq:
|
||
_bin: oq
|
||
_desc: A performant, and portable jq wrapper to facilitate the consumption and output of formats other than JSON; using jq filters to transform the data
|
||
_github: https://github.com/Blacksmoke16/oq
|
||
_home: https://blacksmoke16.github.io/oq/
|
||
_name: oq
|
||
brew: oq
|
||
github: github.com/Blacksmoke16/oq
|
||
snap: oq
|
||
yay: oq
|
||
orbstack:
|
||
_app: OrbStack.app
|
||
_github: https://github.com/orbstack/orbstack
|
||
_bin: orb
|
||
_name: OrbStack
|
||
cask: orbstack
|
||
osquery:
|
||
_bin: osqueryctl
|
||
_desc: SQL powered operating system instrumentation, monitoring, and analytics
|
||
_docs: https://osquery.readthedocs.io/en/stable/
|
||
_github: https://github.com/osquery/osquery
|
||
_home: https://osquery.io/
|
||
_name: osquery
|
||
cask: osquery
|
||
choco: osquery
|
||
github: github.com/osquery/osquery
|
||
yay: osquery-git
|
||
osx-sign:
|
||
_bin: electron-osx-sign
|
||
_github: https://github.com/electron/osx-sign
|
||
_name: macOS Code Sign
|
||
npm: '@electron/osx-sign'
|
||
ots:
|
||
_bin: ots
|
||
_desc: Share end-to-end encrypted secrets with others via a one-time URL
|
||
_github: https://github.com/sniptt-official/ots
|
||
_home: https://ots.sniptt.com/
|
||
_name: ots
|
||
brew: ots
|
||
github: github.com/sniptt-official/ots
|
||
go: github.com/sniptt-official/ots@latest
|
||
p7zip:
|
||
_bin: p7zip
|
||
_name: p7zip
|
||
_github: https://github.com/p7zip-project/p7zip
|
||
apt: p7zip
|
||
brew: p7zip
|
||
dnf: p7zip
|
||
pacman: p7zip
|
||
package-size:
|
||
_bin: package-size
|
||
_desc: Get the bundle size of an npm package
|
||
_github: https://github.com/egoist/package-size
|
||
_name: package-size
|
||
npm: package-size
|
||
packer:
|
||
_bin: packer
|
||
_desc: '[Packer](https://www.packer.io/) is a free and open source tool for creating golden images for multiple platforms from a single source configuration. Packer is lightweight, runs on every major operating system, and is highly performant, creating machine images for multiple platforms in parallel. It is a [HashiCorp](https://www.hashicorp.com/) product.'
|
||
_docs: https://developer.hashicorp.com/packer/docs
|
||
_github: https://github.com/hashicorp/packer
|
||
_home: https://www.packer.io/
|
||
_name: Packer
|
||
ansible: professormanhattan.packer
|
||
apt: packer
|
||
brew: packer
|
||
choco: packer
|
||
pacman: packer
|
||
page-fetch:
|
||
_bin: page-fetch
|
||
_desc: Fetch web pages using headless Chrome, storing all fetched resources including JavaScript files
|
||
_github: https://github.com/detectify/page-fetch
|
||
_name: page-fetch
|
||
go: github.com/detectify/page-fetch@latest
|
||
pageres:
|
||
_bin: pageres
|
||
_desc: Capture website screenshots
|
||
_github: https://github.com/sindresorhus/pageres-cli
|
||
_name: pageres
|
||
npm: pageres-cli
|
||
pake:
|
||
_bin: pake
|
||
_github: https://github.com/tw93/Pake
|
||
npm: pake-cli
|
||
pandoc:
|
||
_bin: pandoc
|
||
_deps:
|
||
- python
|
||
_deps:darwin:
|
||
- basictex
|
||
- python
|
||
_desc: '[Pandoc](https://pandoc.org/) is a Haskell library for converting from one documentation markup format to another. If you need to convert files from one markup format into another, then look no further. Pandoc is your swiss-army knife. It converts from and to dozens of formats like HTML, markdown, docx, JSON, YAML, and CSV, to name a few.'
|
||
_docs: https://pandoc.org/getting-started.html
|
||
_github: https://github.com/jgm/pandoc
|
||
_home: https://pandoc.org/
|
||
_name: Pandoc
|
||
ansible: professormanhattan.pandoc
|
||
apt: pandoc
|
||
brew:
|
||
- pandoc
|
||
- librsvg
|
||
choco:
|
||
- pandoc
|
||
- rsvg-convert
|
||
- miktex
|
||
crew: pandoc
|
||
dnf: pandoc
|
||
nix: pandoc
|
||
pacman: pandoc
|
||
winget: pandoc
|
||
papertrail:
|
||
_bin: papertrail
|
||
_desc: Command-line client for Papertrail hosted log management service. Tails and searches app server logs and system syslog. Supports Boolean search and works with grep and pipe output (Unix)
|
||
_github: https://github.com/papertrail/papertrail-cli
|
||
_name: papertrail
|
||
gem: papertrail
|
||
parallels:
|
||
_app: Parallels Desktop.app
|
||
_bin: parallels
|
||
_github: false
|
||
_desc: '[Parallels Desktop for Mac](https://www.parallels.com/) is software providing hardware virtualization for Macintosh computers with Intel processors. It is developed by Parallels, since 2018 a subsidiary of Corel.'
|
||
_docs: https://kb.parallels.com/
|
||
_home: https://www.parallels.com/
|
||
_name: Parallels
|
||
_notes: On macOS, full disk access is required for Terminal. For Homebrew Cask, this requires the terminal to have full disk access
|
||
ansible:darwin: professormanhattan.parallels
|
||
cask: parallels
|
||
mas: 1085114709
|
||
pass:
|
||
_bin: pass
|
||
_desc: pass is a very simple password store that keeps passwords inside gpg2(1) encrypted files
|
||
_home: https://www.passwordstore.org/
|
||
_github: false
|
||
_name: pass
|
||
apt: pass
|
||
brew: pass
|
||
dnf: pass
|
||
pacman: pass
|
||
pkg: password-store
|
||
pastel:
|
||
_bin: pastel
|
||
_desc: A command-line tool to generate, analyze, convert and manipulate colors
|
||
_github: https://github.com/sharkdp/pastel
|
||
_name: pastel
|
||
brew: pastel
|
||
cargo: pastel
|
||
github: github.com/sharkdp/pastel
|
||
snap: pastel
|
||
yay: pastel
|
||
patch-package:
|
||
_bin: patch-package
|
||
_github: https://github.com/ds300/patch-package
|
||
_name: Patch Package
|
||
npm: patch-package
|
||
pb:
|
||
_app: PB for Desktop.app
|
||
_bin: pushbullet
|
||
_github: https://github.com/sidneys/pb-for-desktop
|
||
_name: Pushbullet for Desktop
|
||
appimage: sidneys/pb-for-desktop
|
||
cask: pb
|
||
choco: pushbullet
|
||
peco:
|
||
_bin: peco
|
||
_desc: '[peco](https://github.com/peco/peco) can be a great tool to filter stuff like logs, process stats, find files, because unlike grep, you can type as you think and look through the current results.'
|
||
_github: https://github.com/peco/peco
|
||
_home: https://peco.github.io/
|
||
_name: Peco
|
||
ansible: professormanhattan.peco
|
||
apt: peco
|
||
brew: peco
|
||
choco: peco
|
||
github: github.com/peco/peco
|
||
pacman: peco
|
||
peek:
|
||
_bin: peek
|
||
_desc: '[Peek](https://github.com/phw/peek) is an animated GIF screen recorder with an easy-to-use interface. It is available for Linux systems that are running GNOME. It is not a general purpose screencast app with extended features. It focuses on simply creating small screencasts of an area of the screen that are output as a GIF, WebM, or MP4 video.'
|
||
_github: https://github.com/phw/peek
|
||
_name: Peek
|
||
_rpmFusion: true
|
||
ansible:linux: professormanhattan.peek
|
||
apt:
|
||
- software-properties-common
|
||
- peek
|
||
dnf:
|
||
- ffmpeg
|
||
- gstreamer1-plugins-ugly
|
||
- peek
|
||
flatpak: com.uploadedlobster.peek
|
||
pacman:
|
||
- gst-plugins-good
|
||
- gst-plugins-ugly
|
||
- gifski
|
||
- peek
|
||
yay: peek-git
|
||
percol:
|
||
_bin: percol
|
||
_github: https://github.com/mooz/percol
|
||
_name: Percol
|
||
pipx: percol
|
||
pfsense-fauxapi:
|
||
_bin: fauxapi
|
||
_github: https://github.com/ndejong/pfsense_fauxapi_client_python
|
||
_name: pfSense CLI (fauxapi)
|
||
pipx: pfsense-fauxapi
|
||
pgcli:
|
||
_bin: pgcli
|
||
_desc: '[pgcli](https://www.pgcli.com/) is a free and open-source CLI for Postgres that does auto-completion and syntax highlighting.'
|
||
_docs: https://www.pgcli.com/docs
|
||
_github: https://github.com/dbcli/pgcli
|
||
_home: https://www.pgcli.com/
|
||
_name: pgcli
|
||
ansible: professormanhattan.pgcli
|
||
brew: pgcli
|
||
choco: pgcli
|
||
pipx: pgcli
|
||
port: pgcli
|
||
php:
|
||
_bin: php
|
||
_deps:
|
||
- php-extensions
|
||
_desc: '[PHP](https://www.php.net/) is a general-purpose scripting language especially suited to web development. It was originally created by Danish-Canadian programmer Rasmus Lerdorf in 1994. The PHP reference implementation is now produced by The PHP Group.'
|
||
_docs: https://www.php.net/docs.php
|
||
_github: https://github.com/php/php-src
|
||
_home: https://www.php.net/
|
||
_name: PHP
|
||
_service: php
|
||
ansible: professormanhattan.php
|
||
apt: php
|
||
brew: php
|
||
choco: php
|
||
dnf: php
|
||
pacman: php
|
||
port: php
|
||
scoop: php
|
||
php-extensions:
|
||
_deps:
|
||
- postgresql
|
||
_name: PHP Extensions
|
||
_github: false
|
||
_note: Needs testing
|
||
apt:
|
||
- libpcre3-dev
|
||
- libpq-dev
|
||
- php-apcu
|
||
- php-cgi
|
||
- php-cli
|
||
- php-common
|
||
- php-curl
|
||
- php-dev
|
||
- php-fpm
|
||
- php-gd
|
||
- php-intl
|
||
- php-imap
|
||
- php-json
|
||
- php-mbstring
|
||
- php-opcache
|
||
- php-pgsql
|
||
- php-redis
|
||
- php-snmp
|
||
- php-sqlite3
|
||
- php-xml
|
||
dnf:
|
||
- pcre-devel
|
||
- postgresql-devel
|
||
- php-apcu
|
||
- php-cgi
|
||
- php-cli
|
||
- php-common
|
||
- php-curl
|
||
- php-devel
|
||
- php-fpm
|
||
- php-gd
|
||
- php-intl
|
||
- php-json
|
||
- php-mbstring
|
||
- php-opcache
|
||
- php-pgsql
|
||
- php-redis
|
||
- php-snmp
|
||
- php-sqlite3
|
||
- php-xml
|
||
pacman:
|
||
- libpcre3-dev
|
||
- postgresql-libs
|
||
- php-apcu
|
||
- php-cgi
|
||
- php-cli
|
||
- php-common
|
||
- php-curl
|
||
- php-dev
|
||
- php-fpm
|
||
- php-gd
|
||
- php-intl
|
||
- php-imap
|
||
- php-json
|
||
- php-mbstring
|
||
- php-opcache
|
||
- php-redis
|
||
- php-snmp
|
||
- php-sqlite3
|
||
- php-xml
|
||
zypper:
|
||
- pcre-devel
|
||
- postgresql-devel
|
||
- php-apcu
|
||
- php-cgi
|
||
- php-cli
|
||
- php-common
|
||
- php-curl
|
||
- php-devel
|
||
- php-fpm
|
||
- php-gd
|
||
- php-intl
|
||
- php-json
|
||
- php-mbstring
|
||
- php-opcache
|
||
- php-redis
|
||
- php-snmp
|
||
- php-sqlite3
|
||
- php-xml
|
||
phpmon:
|
||
_app: PHP Monitor.app
|
||
_bin: phpmon
|
||
_github: https://github.com/nicoverbruggen/phpmon
|
||
_name: PHP Mon
|
||
_pre: |
|
||
#!/usr/bin/env bash
|
||
if ! command -v valet > /dev/null; then
|
||
if ! command -v composer > /dev/null; then
|
||
brew install composer
|
||
fi
|
||
composer global require laravel/valet
|
||
valet install
|
||
valet trust
|
||
fi
|
||
cask: nicoverbruggen/homebrew-cask/phpmon
|
||
pick:
|
||
_bin: pick
|
||
_github: https://github.com/mptre/pick
|
||
_name: Pick
|
||
apt: pick
|
||
brew: pick
|
||
dnf: pick
|
||
emerge: pick
|
||
pkg-freebsd: pick
|
||
pkg_add: pick
|
||
port: pick
|
||
xbps: pick
|
||
yay: pick
|
||
pidcat:
|
||
_bin: pidcat
|
||
_github: https://github.com/JakeWharton/pidcat
|
||
_name: PidCat
|
||
brew: pidcat
|
||
pieces:
|
||
_app: Pieces.app
|
||
_bin: pieces-for-developers
|
||
_desc: Pieces is a first-in-kind productivity suite that optimizes developer tools and eliminates the chaos of context switching.
|
||
_docs: https://docs.pieces.app/
|
||
_github: false
|
||
_home: https://pieces.app/
|
||
_name: Pieces
|
||
appinstaller: https://builds.pieces.app/stages/production/appinstaller/pieces_for_x.appinstaller
|
||
cask: pieces
|
||
exe: https://builds.pieces.app/stages/production/pieces_for_x/windows-exe/download
|
||
snap: pieces-for-developers
|
||
pieces-cli:
|
||
_bin: pieces
|
||
_desc: Pieces is a first-in-kind productivity suite that optimizes developer tools and eliminates the chaos of context switching.
|
||
_docs: https://docs.pieces.app/
|
||
_github: false
|
||
_home: https://pieces.app/
|
||
_name: Pieces CLI
|
||
cask: pieces-cli
|
||
pieces-os:
|
||
_app: Pieces.app
|
||
_bin: pieces-os
|
||
_docs: https://docs.pieces.app/
|
||
_env:
|
||
PIECES_OS_APPDATA:
|
||
cask: "$HOME/Library/Application Support/com.pieces.os"
|
||
snap: "TODO"
|
||
_github: false
|
||
_home: https://pieces.app/
|
||
_name: Pieces OS
|
||
_note: Waiting for choco package
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
sudo snap connect pieces-os:dotnet-runtime-aspnetcore
|
||
appinstaller: https://builds.pieces.app/stages/production/appinstaller/os_server.appinstaller
|
||
cask: pieces-os
|
||
exe: https://builds.pieces.app/stages/production/os_server/windows-exe/download
|
||
snap: pieces-os
|
||
pigz:
|
||
_bin: pigz
|
||
_github: https://github.com/madler/pigz
|
||
_name: PIGZ
|
||
apt: pigz
|
||
brew: pigz
|
||
dnf: pigz
|
||
pacman: pigz
|
||
pika:
|
||
_app: Pika.app
|
||
_bin: null
|
||
_desc: An open-source colour picker app for macOS
|
||
_docs: https://github.com/superhighfives/pika
|
||
_github: https://github.com/superhighfives/pika
|
||
_home: https://superhighfives.com/pika
|
||
_name: Pika
|
||
cask: pika
|
||
pinapp:
|
||
_bin: pinapp
|
||
_github: https://github.com/fabrialberio/PinApp
|
||
flatpak: io.github.fabrialberio.pinapp
|
||
pip:
|
||
_bin: pip
|
||
_desc: '[pip](https://pypi.org/project/pip/) is a package-management system written in Python used to install and manage software packages. It connects to an online repository of public and paid-for private packages, called the Python Package Index.'
|
||
_docs: https://pip.pypa.io/en/stable/user_guide/
|
||
_github: https://github.com/pypa/pip
|
||
_home: https://pip.pypa.io/en/stable/
|
||
_name: PIP
|
||
ansible: professormanhattan.pip
|
||
pipedream-cli:
|
||
_bin: pd
|
||
_desc: Connect APIs, remarkably fast. Free for developers.
|
||
_docs: https://pipedream.com/docs/cli/reference/
|
||
_github: https://github.com/PipedreamHQ/pipedream
|
||
_home: https://pipedream.com/
|
||
_name: Pipedream CLI
|
||
brew: pipedreamhq/pd-cli/pipedream
|
||
pipelight:
|
||
_bin: pipelight
|
||
_github: https://github.com/pipelight/pipelight
|
||
_name: Pipelight
|
||
cargo:linux: --git https://github.com/pipelight/pipelight
|
||
yay: pipelight
|
||
pipx:
|
||
_bin: pipx
|
||
_desc: "[pipx](https://pypi.org/project/pipx/) is a tool to help you install and run end-user applications written in Python. It's roughly similar to macOS's brew, JavaScript's npx, and Linux's apt"
|
||
_docs: https://pypa.github.io/pipx/
|
||
_github: https://github.com/pypa/pipx
|
||
_home: https://pypi.org/project/pipx/
|
||
_post:brew: |
|
||
#!/usr/bin/env bash
|
||
pipx ensurepath
|
||
brew: pipx
|
||
pkg:
|
||
_bin: pkg
|
||
_desc: This command line interface enables you to package your Node.js project into an executable that can be run even on devices without Node.js installed.
|
||
_github: https://github.com/vercel/pkg
|
||
_name: pkg
|
||
npm: pkg
|
||
pkgx:
|
||
_bin: pkgx
|
||
_desc: The next-generation, cross‐platform package manager
|
||
_docs: https://docs.pkgx.sh/
|
||
_github: https://github.com/pkgxdev/pkgx
|
||
_home: https://pkgx.sh/
|
||
_name: pkgx
|
||
brew: pkgxdev/made/pkgx
|
||
platformio:
|
||
_bin: platformio
|
||
_github: https://github.com/platformio/platformio-core
|
||
_name: PlatformIO
|
||
brew: platformio
|
||
pipx: platformio
|
||
playwright:
|
||
_bin: playwright
|
||
_desc: '[Playwright](https://playwright.dev) enables reliable end-to-end testing for modern web apps. It allows testing Chromium, Firefox and WebKit with a single API'
|
||
_docs: https://playwright.dev/docs/intro
|
||
_github: https://github.com/Microsoft/playwright
|
||
_home: https://playwright.dev
|
||
_name: Playwright
|
||
npm: playwright
|
||
please:
|
||
_bin: plz
|
||
_github: https://github.com/thought-machine/please
|
||
_name: Please
|
||
brew: thought-machine/please/please
|
||
plex:
|
||
_app: Plex.app
|
||
_bin: plex
|
||
_desc: '[Plex](https://www.plex.tv/) is a global streaming service of free ad-supported video, with TV shows and movies from distributors such as Crackle, Warner Bros., MGM, Endemol Shine Group, Lionsgate, and Legendary. Plex is also a client–server media player system plus an ancillary software suite.'
|
||
_github: false
|
||
_home: https://www.plex.tv/
|
||
_name: Plex
|
||
ansible: professormanhattan.plex
|
||
cask: plex
|
||
choco: plex
|
||
flatpak: tv.plex.PlexDesktop
|
||
plex-htpc:
|
||
_app: Plex HTPC.app
|
||
_bin: plex-htpc
|
||
_github: false
|
||
_home: https://www.plex.tv/
|
||
_name: Plex HTPC
|
||
cask: plex-htpc
|
||
choco: plex-home-theater
|
||
flatpak: tv.plex.PlexHTPC
|
||
snap: plex-htpc
|
||
plex-media-server:
|
||
_app: Plex Media Server.app
|
||
_bin: plex-media-server
|
||
_github: false
|
||
_name: Plex Media Server
|
||
_ports:
|
||
- port: 32400
|
||
proto: tcp
|
||
- port: 3005
|
||
proto: tcp
|
||
- port: 5353
|
||
proto: udp
|
||
- port: 8324
|
||
proto: tcp
|
||
- port: 32410-32414
|
||
proto: udp
|
||
- port: 1900
|
||
proto: udp
|
||
- port: 32469
|
||
proto: tcp
|
||
cask: plex-media-server
|
||
choco: plexmediaserver
|
||
snap: plexmediaserver
|
||
yay: plex-media-server
|
||
plumber:
|
||
_bin: plumber
|
||
_github: https://github.com/streamdal/plumber
|
||
_name: Plumber
|
||
brew: streamdal/public/plumber
|
||
exe: https://github.com/streamdal/plumber/releases/latest/download/plumber-windows.exe
|
||
plymouth:
|
||
_github: false
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Plymouth Theme / Configuration
|
||
# @brief Configures Plymouth to use a custom theme
|
||
# @description
|
||
# This script installs Plymouth and then configures it to use our custom Betelgeuse theme.
|
||
|
||
### Create /etc/plymouth/plymouthd.conf
|
||
if [ -f /etc/plymouth/plymouthd.conf ]; then
|
||
### Back up original plymouthd.conf
|
||
if [ ! -f /etc/plymouth/plymouthd.conf.bak ]; then
|
||
logg info 'Backing up /etc/plymouth/plymouthd.conf to /etc/plymouth/plymouthd.conf.bak'
|
||
sudo cp -f /etc/plymouth/plymouthd.conf /etc/plymouth/plymouthd.conf.bak
|
||
fi
|
||
|
||
### Create new plymouthd.conf
|
||
logg info 'Populating the /etc/plymouth/plymouthd.conf file'
|
||
echo "[Daemon]" | sudo tee /etc/plymouth/plymouthd.conf > /dev/null
|
||
echo "Theme={{ .theme }}" | sudo tee -a /etc/plymouth/plymouthd.conf > /dev/null
|
||
echo "ShowDelay=1" | sudo tee -a /etc/plymouth/plymouthd.conf > /dev/null
|
||
fi
|
||
|
||
### Apply update-alternatives
|
||
if command -v update-alternatives > /dev/null; then
|
||
if [ -f "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth" ]; then
|
||
sudo update-alternatives --install /usr/share/plymouth/themes/default.plymouth default.plymouth "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth" 100
|
||
logg success 'Installed default.plymouth'
|
||
# Required sometimes
|
||
sudo update-alternatives --set default.plymouth "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth"
|
||
logg success 'Set default.plymouth'
|
||
else
|
||
logg warn "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth does not exist!"
|
||
fi
|
||
else
|
||
logg warn 'update-alternatives is not available'
|
||
fi
|
||
|
||
### Update /etc/plymouth/plymouthd.conf
|
||
# Replaced by code above
|
||
# if [ -f /etc/plymouth/plymouthd.conf ]; then
|
||
# logg info 'Setting ShowDelay=1 in /etc/plymouth/plymouthd.conf'
|
||
# if cat /etc/plymouth/plymouthd.conf | grep ShowDelay; then
|
||
# sudo sed -i 's/^ShowDelay=.*/ShowDelay=1/' /etc/plymouth/plymouthd.conf
|
||
# else
|
||
# echo 'ShowDelay=1' | sudo tee -a /etc/plymouth/plymouthd.conf > /dev/null
|
||
# fi
|
||
# else
|
||
# logg warn '/etc/plymouth/plymouthd.conf does not exist!'
|
||
# fi
|
||
|
||
### Symlink /usr/local/share/plymouth/themes to /usr/share/plymouth/themes
|
||
if [ ! -d '/usr/share/plymouth/themes/{{ .theme }}' ]; then
|
||
logg info 'Symlinking /usr/local/share/plymouth/themes/{{ .theme }} to /usr/share/plymouth/themes/{{ .theme }}'
|
||
sudo ln -s '/usr/local/share/plymouth/themes/{{ .theme }}' '/usr/share/plymouth/themes/{{ .theme }}'
|
||
fi
|
||
|
||
### Set default Plymouth theme
|
||
if command -v plymouth-set-default-theme > /dev/null; then
|
||
sudo plymouth-set-default-theme -R '{{ .theme }}' || EXIT_CODE=$?
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg warn 'There may have been an issue while setting the Plymouth default theme with plymouth-set-default-theme'
|
||
else
|
||
logg success 'Set Plymouth default theme with plymouth-set-default-theme'
|
||
fi
|
||
else
|
||
logg warn 'Could not apply default Plymouth theme because plymouth-set-default-theme is missing'
|
||
fi
|
||
|
||
### Apply update-alternatives (again - required sometimes)
|
||
if command -v update-alternatives > /dev/null; then
|
||
if [ -f "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth" ]; then
|
||
# Required sometimes
|
||
sudo update-alternatives --set default.plymouth "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth"
|
||
logg success 'Set default.plymouth (second time is required sometimes)'
|
||
else
|
||
logg warn "/usr/local/share/plymouth/themes/{{ .theme }}/{{ .theme }}.plymouth does not exist!"
|
||
fi
|
||
else
|
||
logg warn 'update-alternatives is not available'
|
||
fi
|
||
|
||
### Update kernel / initrd images
|
||
# Set `export DEBUG_MODE=true` to bypass GRUB2 / Plymouth application
|
||
if [ "$DEBUG_MODE" != 'true' ]; then
|
||
if command -v update-initramfs > /dev/null; then
|
||
logg info 'Running sudo update-initramfs -u'
|
||
sudo update-initramfs -u
|
||
logg success 'Updated kernel / initrd images for Plymouth'
|
||
elif command -v dracut > /dev/null; then
|
||
logg info 'Running sudo dracut --regenerate-all -f'
|
||
sudo dracut --regenerate-all -f
|
||
logg success 'Updated kernel / initrd images for Plymouth'
|
||
else
|
||
logg warn 'Unable to update kernel / initrd images because neither update-initramfs or dracut are available'
|
||
fi
|
||
fi
|
||
apt:
|
||
- libplymouth5
|
||
- plymouth
|
||
- plymouth-themes
|
||
- plymouth-label
|
||
dnf:
|
||
- plymouth
|
||
# - plymouth-x11
|
||
- plymouth-plugin-script
|
||
pacman:
|
||
- plymouth
|
||
pm2:
|
||
_bin: pm2
|
||
_desc: PM2 is a production process manager for Node.js applications with a built-in load balancer. It allows you to keep applications alive forever, to reload them without downtime and to facilitate common system admin tasks
|
||
_docs: https://pm2.keymetrics.io/docs/usage/quick-start/
|
||
_github: https://github.com/Unitech/pm2
|
||
_home: https://pm2.keymetrics.io/
|
||
_name: pm2
|
||
npm: pm2
|
||
pnpm:
|
||
_bin: pnpm
|
||
_desc: '[pnpm](https://github.com/pnpm/pnpm) is a fast, disk space efficient package manager'
|
||
_docs: https://pnpm.io/motivation
|
||
_github: https://github.com/pnpm/pnpm
|
||
_home: https://pnpm.io/
|
||
_name: pnpm
|
||
ansible: professormanhattan.pnpm
|
||
brew: pnpm
|
||
npm: pnpm
|
||
scoop: pnpm
|
||
yay: pnpm
|
||
pnpm-lock-export:
|
||
_bin: pnpm-lock-export
|
||
_github: https://github.com/cvent/pnpm-lock-export
|
||
_desc: A CLI utility that reads a package.json and pnpm-lock.yaml, and outputs an npm ci compatible package-lock.json
|
||
npm: pnpm-lock-export
|
||
pock:
|
||
_app: Pock.app
|
||
_bin: null
|
||
_desc: Widgets manager for MacBook Touch Bar
|
||
_docs: https://github.com/pock/pock
|
||
_github: https://github.com/pock/pock
|
||
_home: https://pock.app/
|
||
_name: Pock
|
||
cask: pock
|
||
podman:
|
||
_bin: podman
|
||
_github: https://github.com/containers/podman
|
||
_name: Podman
|
||
apk: podman
|
||
apt: podman
|
||
bitbake: podman
|
||
brew: podman
|
||
dnf: podman
|
||
emerge: app-containers/podman
|
||
pacman: podman
|
||
zypper: podman
|
||
poetry:
|
||
_bin: poetry
|
||
_desc: '[Poetry](https://python-poetry.org) helps you declare, manage and install dependencies of Python projects, ensuring you have the right stack everywhere.'
|
||
_docs: https://python-poetry.org/docs/
|
||
_github: https://github.com/python-poetry/poetry
|
||
_home: https://python-poetry.org/
|
||
_name: Poetry
|
||
ansible: professormanhattan.poetry
|
||
brew: poetry
|
||
yay: python-poetry-git
|
||
polybar:
|
||
_bin: polybar
|
||
_github: https://github.com/polybar/polybar
|
||
_name: Polybar
|
||
apt: polybar
|
||
dnf: polybar
|
||
pacman: polybar
|
||
pkg-freebsd: polybar
|
||
xbps: polybar
|
||
zypper: polybar
|
||
pony:
|
||
_bin: pony
|
||
_desc: Local file-based password, API key, secret, recovery code store backed by GPG
|
||
_github: https://github.com/jessfraz/pony
|
||
_name: pony
|
||
github: github.com/jessfraz/pony
|
||
go: github.com/jessfraz/pony@latest
|
||
poppler:
|
||
_github: https://github.com/Belval/pdf2image
|
||
brew: poppler
|
||
portal:
|
||
_bin: portal
|
||
_desc: Portal is a quick and easy command-line file transfer utility from any computer to another
|
||
_docs: https://github.com/SpatiumPortae/portal
|
||
_github: https://github.com/SpatiumPortae/portal
|
||
_home: https://portal.spatiumportae.com/
|
||
_name: Portal
|
||
brew: portal
|
||
scoop: portal
|
||
winget: SpatiumPortae.portal
|
||
yay: portal-bin
|
||
porter:
|
||
_bin: porter
|
||
_desc: Porter enables you to package your application artifact, client tools, configuration and deployment logic together as an installer that you can distribute, and install with a single command.
|
||
_docs: https://getporter.org/docs/
|
||
_github: https://github.com/getporter/porter
|
||
_home: https://getporter.org/
|
||
_name: Porter
|
||
script:darwin: curl -L https://cdn.porter.sh/latest/install-mac.sh | bash
|
||
script:linux: curl -L https://cdn.porter.sh/latest/install-linux.sh | bash
|
||
script:windows: iwr "https://cdn.porter.sh/latest/install-windows.ps1" -UseBasicParsing | iex
|
||
portmaster:
|
||
_bin: null
|
||
_desc: "[Portmaster](https://safing.io/portmaster/) is a free and open-source application that puts you back in charge over all your computer's network connections."
|
||
_docs: https://docs.safing.io/portmaster/architecture/overview
|
||
_github: https://github.com/safing/portmaster
|
||
_home: https://safing.io/
|
||
_name: Portmaster
|
||
_when:linux: '! test -f /opt/safing/portmaster/portmaster-start'
|
||
ansible:linux: professormanhattan.portmaster
|
||
ansible:windows: professormanhattan.portmaster
|
||
apt: https://updates.safing.io/latest/linux_amd64/packages/portmaster-installer.deb
|
||
choco: portmaster
|
||
dnf: https://updates.safing.io/latest/linux_amd64/packages/portmaster-installer.rpm
|
||
exe: https://updates.safing.io/latest/windows_amd64/packages/portmaster-installer.exe
|
||
scoop: portmaster-np
|
||
postfix:
|
||
_bin: postfix
|
||
_desc: Postfix is an e-mail server that can be used to send e-mail
|
||
_docs: https://www.postfix.org/documentation.html
|
||
_github: https://github.com/vdukhovni/postfix
|
||
_home: https://www.postfix.org/
|
||
_name: Postfix
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file SendGrid Postfix Configuration
|
||
# @brief Configures Postfix to use SendGrid as a relay host so you can use the `mail` program to send e-mail from the command-line
|
||
# @description
|
||
# This script follows the instructions from [SendGrid's documentation on integrating Postfix](https://docs.sendgrid.com/for-developers/sending-email/postfix).
|
||
# After this script runs, you should be able to send outgoing e-mails using SendGrid as an SMTP handler. In other words, you will
|
||
# be able to use the `mail` CLI command to send e-mails. The following is an example mailing the contents of `~/.bashrc` to `name@email.com`:
|
||
#
|
||
# ```shell
|
||
# cat ~/.bashrc | mail -s "My subject" name@email.com
|
||
# ```
|
||
|
||
if [ -n "$SENDGRID_API_KEY" ] && [ "$SENDGRID_API_KEY" != "" ]; then
|
||
if command -v postfix > /dev/null; then
|
||
### Ensure dependencies are installed
|
||
if command -v apt-get > /dev/null; then
|
||
logg info 'Installing libsasl2-modules'
|
||
sudo apt-get update
|
||
sudo apt-get install -y libsasl2-modules || EXIT_CODE=$?
|
||
elif command -v dnf > /dev/null; then
|
||
sudo dnf install -y cyrus-sasl-plain || EXIT_CODE=$?
|
||
elif command -v yum > /dev/null; then
|
||
sudo yum install -y cyrus-sasl-plain || EXIT_CODE=$?
|
||
fi
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg warn 'There was an error ensuring the Postfix-SendGrid dependencies were installed'
|
||
fi
|
||
|
||
if [ -d /etc/postfix ]; then
|
||
### Add the SendGrid Postfix settings to the Postfix configuration
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/main.cf" ]; then
|
||
CONFIG_FILE=/etc/postfix/main.cf
|
||
if cat "$CONFIG_FILE" | grep '### INSTALL DOCTOR MANAGED' > /dev/null; then
|
||
logg info 'Removing Install Doctor-managed block of code in /etc/postfix/main.cf block'
|
||
START_LINE="$(echo `grep -n -m 1 "### INSTALL DOCTOR MANAGED ### START" "$CONFIG_FILE" | cut -f1 -d ":"`)"
|
||
END_LINE="$(echo `grep -n -m 1 "### INSTALL DOCTOR MANAGED ### END" "$CONFIG_FILE" | cut -f1 -d ":"`)"
|
||
if [ -n "$START_LINE" ] && [ -n "$END_LINE" ]; then
|
||
if command -v gsed > /dev/null; then
|
||
sudo gsed -i "${START_LINE},${END_LINE}d" "$CONFIG_FILE"
|
||
else
|
||
sudo sed -i "${START_LINE},${END_LINE}d" "$CONFIG_FILE"
|
||
fi
|
||
else
|
||
logg info 'No start-line or end-line detected - configuration appears to already be clean'
|
||
fi
|
||
fi
|
||
|
||
### Add Postfix main configuration
|
||
logg "Adding the following configuration from ${XDG_CONFIG_HOME:-$HOME/.config}/postfix/main.cf to /etc/postfix/main.cf"
|
||
cat "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/main.cf" | sudo tee -a "$CONFIG_FILE" > /dev/null
|
||
echo "" | sudo tee -a "$CONFIG_FILE" > /dev/null
|
||
fi
|
||
|
||
### Ensure proper permissions on `sasl_passwd` and update Postfix hashmaps
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/sasl_passwd" ]; then
|
||
logg info "Copying file from ${XDG_CONFIG_HOME:-$HOME/.config}/postfix/sasl_passwd to /etc/postfix/sasl_passwd"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/sasl_passwd" /etc/postfix/sasl_passwd
|
||
logg info 'Assigning proper permissions to /etc/postfix/sasl_passwd'
|
||
sudo chmod 600 /etc/postfix/sasl_passwd
|
||
logg info 'Updating Postfix hashmaps for /etc/postfix/sasl_passwd'
|
||
sudo postmap /etc/postfix/sasl_passwd
|
||
else
|
||
logg warn '~/.config/postfix/sasl_passwd file is missing'
|
||
fi
|
||
|
||
### Forward root e-mails
|
||
if [ -d /root ]; then
|
||
logg info "Forwarding root e-mails to $PRIMARY_EMAIL"
|
||
echo "$PRIMARY_EMAIL" | sudo tee /root/.forward > /dev/null || logg error 'Failed to set root user .forward file'
|
||
elif [ -d /var/root ]; then
|
||
logg info "Forwarding root e-mails to $PRIMARY_EMAIL"
|
||
echo "$PRIMARY_EMAIL" | sudo tee /var/root/.forward > /dev/null || logg error 'Failed to set root user .forward file'
|
||
else
|
||
logg warn 'Unable to identify root user home directory'
|
||
fi
|
||
|
||
### Ensure /etc/postfix/header_checks exists
|
||
if [ ! -d /etc/postfix/header_checks ]; then
|
||
logg info 'Creating /etc/postfix/header_checks since it does not exist'
|
||
sudo touch /etc/postfix/header_checks
|
||
fi
|
||
|
||
### Re-write header From for SendGrid
|
||
if ! cat /etc/postfix/header_checks | grep "no-reply@${PUBLIC_SERVICES_DOMAIN}" > /dev/null; then
|
||
logg info 'Added From REPLACE to /etc/postfix/header_checks'
|
||
echo "/^From:.*@${PUBLIC_SERVICES_DOMAIN}/ REPLACE From: no-reply@${PUBLIC_SERVICES_DOMAIN}" | sudo tee -a /etc/postfix/header_checks > /dev/null
|
||
fi
|
||
|
||
### Update aliases
|
||
if [ -f /etc/aliases ]; then
|
||
logg info "Forward root e-mails to $PRIMARY_EMAIL"
|
||
ALIASES_TMP="$(mktemp)"
|
||
logg info "Setting $PRIMARY_EMAIL as root e-mail in temporary file"
|
||
sudo sed "s/#root.*/root:\ $PRIMARY_EMAIL/" /etc/aliases > "$ALIASES_TMP"
|
||
logg info 'Moving temporary file to /etc/aliases'
|
||
sudo mv -f "$ALIASES_TMP" /etc/aliases
|
||
if ! cat /etc/aliases | grep "$USER_USERNAME: root" > /dev/null; then
|
||
logg info 'Forward user e-mail to root@localhost'
|
||
echo "$USER_USERNAME: root" | sudo tee -a /etc/aliases > /dev/null
|
||
fi
|
||
|
||
### Ensure old /etc/aliases.db is removed
|
||
if [ -f /etc/aliases.db ]; then
|
||
logg info 'Ensuring /etc/aliases.db is removed' && sudo rm -f /etc/aliases.db
|
||
else
|
||
logg info '/etc/aliases.db was not found'
|
||
fi
|
||
|
||
### Re-generate the /etc/aliases.db file
|
||
if [ -f /etc/aliases ]; then
|
||
logg info 'Ensuring proper permissions on the /etc/aliases file' && sudo chown $(stat -c "%U:%G" /etc/sudoers) /etc/aliases
|
||
logg info 'Generating Postfix aliases' && sudo postalias /etc/aliases > /dev/null
|
||
else
|
||
logg warn '/etc/aliases is missing which is required for Postfix'
|
||
fi
|
||
# The `sudo newaliases` mode is probably used to regenerate the /etc/aliases.db
|
||
# but since we are removing it to ensure proper permissions, this method is commented out.
|
||
# logg info 'Running newaliases to regenerate the alias database' && sudo newaliases
|
||
else
|
||
logg warn '/etc/aliases does not appear to exist'
|
||
fi
|
||
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS
|
||
# Source: https://budiirawan.com/install-mail-server-mac-osx/
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/com.apple.postfix.master.plist" ] && ! sudo launchctl list | grep 'postfix.master' > /dev/null; then
|
||
logg info 'Copying com.apple.postfix.master.plist'
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/postfix/com.apple.postfix.master.plist" /System/Library/LaunchDaemons/com.apple.postfix.master.plist
|
||
sudo launchctl load /System/Library/LaunchDaemons/com.apple.postfix.master.plist && logg success 'launchctl load of com.apple.postfix.master successful'
|
||
fi
|
||
if ! sudo postfix status > /dev/null; then
|
||
logg info 'Starting postfix'
|
||
sudo postfix start > /dev/null
|
||
else
|
||
logg info 'Reloading postfix'
|
||
sudo postfix reload > /dev/null
|
||
fi
|
||
else
|
||
### Enable / restart postfix on Linux
|
||
logg info 'Enabling / restarting postfix'
|
||
sudo systemctl enable postfix
|
||
sudo systemctl restart postfix
|
||
fi
|
||
else
|
||
logg warn '/etc/postfix is not a directory! Skipping SendGrid Postfix setup.'
|
||
fi
|
||
else
|
||
logg info 'Skipping Postfix configuration because Postfix is not installed'
|
||
fi
|
||
fi
|
||
apt: postfix
|
||
dnf: postfix
|
||
pacman: postfix
|
||
port: postfix
|
||
script:darwin: echo "Postfix is included by macOS already"
|
||
postgresql:
|
||
_bin: postgresql
|
||
_github: https://github.com/postgres/postgres
|
||
_name: PostgreSQL
|
||
_service: postgresql
|
||
_service:brew: postgresql@14
|
||
apt: postgresql
|
||
brew: postgresql
|
||
choco: postgresql
|
||
dnf: postgresql
|
||
pacman: postgresql
|
||
zypper: postgresql
|
||
postman:
|
||
_app: Postman.app
|
||
_bin: postman
|
||
_github: https://github.com/postmanlabs/postman-app-support
|
||
_desc: "[Postman](https://www.postman.com/) is a collaboration platform for API development. Postman's features simplify each step of building an API and streamline collaboration so you can create better APIs — faster."
|
||
_docs: https://learning.postman.com/docs/getting-started/introduction/
|
||
_home: https://www.postman.com/
|
||
_name: Postman
|
||
ansible: professormanhattan.postman
|
||
cask: postman
|
||
choco: postman
|
||
flatpak: com.getpostman.Postman
|
||
snap: postman
|
||
yay: postman-bin
|
||
powerline:
|
||
_bin: powerline
|
||
_github: https://github.com/powerline/powerline
|
||
apt: powerline
|
||
dnf: powerline
|
||
pacman: powerline
|
||
pipx: powerline-status
|
||
powershell:
|
||
_app: PowerShell.app
|
||
_bin: powershell
|
||
_github: https://github.com/PowerShell/PowerShell
|
||
_desc: '[PowerShell](https://docs.microsoft.com/en-us/powershell/scripting/overview?view=powershell-7.1) is a task automation and configuration management framework from Microsoft, consisting of a command-line shell and the associated scripting language. Initially a Windows component only, known as Windows PowerShell, it was made open-source and cross-platform in 2016 with the introduction of PowerShell Core.'
|
||
_docs: https://docs.microsoft.com/en-us/powershell/scripting/overview?view=powershell-7.1
|
||
_name: Powershell
|
||
_post:cask: |
|
||
#!/usr/bin/env bash
|
||
brew install mono-libgdiplus
|
||
ansible: professormanhattan.powershell
|
||
cask: powershell
|
||
snap: powershell --classic
|
||
pppc-utility:
|
||
_app: PPPC Utility.app
|
||
_bin: pppc-utility
|
||
_github: https://github.com/jamf/PPPC-Utility
|
||
_name: Privacy Preferences Policy Control (PPPC) Utility
|
||
cask: pppc-utility
|
||
pre-commit:
|
||
_bin: pre-commit
|
||
_desc: Automatically installs a git pre-commit script in your git repository which runs your `npm test` on pre-commit
|
||
_github: https://github.com/observing/pre-commit
|
||
_name: pre-commit
|
||
brew: pre-commit
|
||
pipx: pre-commit
|
||
prefsniff:
|
||
_bin: prefsniff
|
||
_github: https://github.com/zcutlip/prefsniff
|
||
_name: PrefSniff
|
||
pipx: prefsniff
|
||
prepare:
|
||
_bin: null
|
||
_github: false
|
||
_desc: An Ansible Role that prepares hosts for playbook execution
|
||
ansible: professormanhattan.prepare
|
||
prettier:
|
||
_bin: prettier
|
||
_desc: '[Prettier](https://prettier.io/docs/en/index.html) is an opinionated code formatter. It enforces a consistent style by parsing your code and re-printing it with its own rules that take the maximum line length into account, wrapping code when necessary'
|
||
_docs: https://prettier.io/docs/en/index.html
|
||
_github: https://github.com/prettier/prettier
|
||
_home: https://prettier.io/
|
||
_name: Prettier
|
||
brew: prettier
|
||
npm: prettier
|
||
prettierd:
|
||
_bin: prettierd
|
||
_desc: Prettier, as a daemon, for improved formatting speed.
|
||
_docs: https://github.com/fsouza/prettierd
|
||
_github: https://github.com/fsouza/prettierd
|
||
_home: https://github.com/fsouza/prettierd
|
||
_name: Prettierd
|
||
brew: fsouza/prettierd/prettierd
|
||
npm: '@fsouza/prettierd'
|
||
pretzel:
|
||
_app: Pretzel.app
|
||
# cask: pretzel
|
||
_bin: null
|
||
_desc: Pretzel is Mac desktop app that shows and find keyboard shortcuts based on your current app
|
||
_docs: https://github.com/amiechen/pretzel
|
||
_github: https://github.com/amiechen/pretzel
|
||
_home: https://github.com/amiechen/pretzel
|
||
_name: Pretzel
|
||
_todo: Waiting for SHASUM error on Homebrew cask to resolve
|
||
prezi-video:
|
||
_app: Prezi Video.app
|
||
_bin: prezi-video
|
||
_github: false
|
||
_name: Prezi Video
|
||
cask: prezi-video
|
||
privaxy:
|
||
_app: Privaxy.app
|
||
_bin: privaxy
|
||
_desc: Privaxy is the next generation tracker and advertisement blocker. It blocks ads and trackers by MITMing HTTP(s) traffic.
|
||
_docs: false
|
||
_github: https://github.com/Barre/privaxy
|
||
_home: false
|
||
_name: Privaxy
|
||
appimage: barre/privaxy
|
||
apt: https://github.com/Barre/privaxy/releases/download/v0.5.2/privaxy_0.5.2_amd64.deb
|
||
script:darwin: curl -sSL https://github.com/Barre/privaxy/releases/download/v0.5.2/Privaxy_0.5.2_universal.dmg > /tmp/Privaxy.dmg && sudo hdiutil attach /tmp/Privaxy.dmg && sudo cp -R /Volumes/Privaxy/Privaxy.app /Applications && sudo hdiutil detach /Volumes/Privaxy && rm -f /tmp/Privaxy.dmg
|
||
privileges:
|
||
_app: Privileges.app
|
||
_bin: privileges
|
||
_github: https://github.com/SAP/macOS-enterprise-privileges
|
||
_name: Privileges
|
||
cask: privileges
|
||
privoxy:
|
||
_bin: privoxy
|
||
_desc: Privoxy is a non-caching web proxy with advanced filtering capabilities for enhancing privacy, modifying web page data and HTTP headers, controlling access, and removing ads and other obnoxious Internet junk
|
||
_docs: https://www.privoxy.org/user-manual/index.html
|
||
_github: https://github.com/unisx/privoxy
|
||
_groups:
|
||
- privoxy
|
||
_home: https://www.privoxy.org/
|
||
_name: Privoxy
|
||
_post: "#!/usr/bin/env bash\n# @file Privoxy Configuration\n# @brief This script applies the Privoxy configuration stored at `${XDG_CONFIG_HOME:-HOME/.config}/privoxy/config` to the system and then restarts Privoxy\n# @description\n# Privoxy is a web proxy that can be combined with Tor to provide an HTTPS / HTTP proxy that can funnel all traffic\n# through Tor. This script:\n#\n# 1. Determines the system configuration file location\n# 2. Applies the configuration stored at `${XDG_CONFIG_HOME:-HOME/.config}/privoxy/config`\n# 3. Enables and restarts the Privoxy service with the new configuration\n#\n# ## Links\n#\n# * [Privoxy configuration](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_config/privoxy/config)\n\n### Define the Privoxy configuration location based on whether system is macOS or Linux\nif [ -d /Applications ] && [ -d /System ]; then\n ### macOS\n if [ -d \"/usr/local/etc/privoxy\" ]; then\n PRIVOXY_CONFIG_DIR=/usr/local/etc/privoxy\n elif [ -d \"${HOMEBREW_PREFIX:-/opt/homebrew}/etc/privoxy\" ]; then\n PRIVOXY_CONFIG_DIR=\"${HOMEBREW_PREFIX:-/opt/homebrew}/etc/privoxy\"\n else\n logg warn 'Unable to detect Privoxy configuration directory'\n fi\nelse\n ### Linux\n PRIVOXY_CONFIG_DIR=/etc/privoxy\nfi\nPRIVOXY_CONFIG=\"$PRIVOXY_CONFIG_DIR/config\"\n\n### Copy Privoxy configuration stored at `${XDG_CONFIG_HOME:-HOME/.config}/privoxy/config` to the system location\nif command -v privoxy > /dev/null; then\n if [ -d \"$PRIVOXY_CONFIG_DIR\" ]; then\n sudo cp -f \"${XDG_CONFIG_HOME:-HOME/.config}/privoxy/config\" \"$PRIVOXY_CONFIG\"\n sudo chmod 600 \"$PRIVOXY_CONFIG\"\n if command -v add-usergroup > /dev/null; then\n sudo add-usergroup \"$USER\" privoxy\n fi\n sudo chown privoxy:privoxy \"$PRIVOXY_CONFIG\" 2> /dev/null || sudo chown privoxy:$(id -g -n) \"$PRIVOXY_CONFIG\"\n \n ### Restart Privoxy after configuration is applied\n if [ -d /Applications ] && [ -d /System ]; then\n ### macOS\n brew services restart privoxy\n else\n if [[ ! \"$(test -d /proc && grep Microsoft /proc/version > /dev/null)\" ]]; then\n ### Linux\n sudo systemctl enable privoxy\n sudo systemctl restart privoxy\n else\n logg info 'The system is a WSL environment so the Privoxy systemd service will not be enabled / restarted'\n fi\n fi\n else\n logg warn 'The '\"$PRIVOXY_CONFIG_DIR\"' directory is missing'\n fi\nelse\n logg logg 'privoxy is missing from the PATH - skipping configuration'\nfi\n"
|
||
_service: privoxy
|
||
_serviceEnabled: true
|
||
apt: privoxy
|
||
brew: privoxy
|
||
dnf: privoxy
|
||
pacman: privoxy
|
||
port: privoxy
|
||
procs:
|
||
_bin: procs
|
||
_desc: A modern replacement for ps written in Rust
|
||
_github: https://github.com/dalance/procs
|
||
_name: procs
|
||
apk: procs
|
||
brew: procs
|
||
cargo: procs
|
||
dnf: procs
|
||
github: github.com/dalance/procs
|
||
pacman: procs
|
||
scoop: procs
|
||
snap: procs
|
||
profilecreator:
|
||
_app: ProfileCreator.app
|
||
_bin: null
|
||
_desc: Profile manifest creator GUI for macOS
|
||
_docs: https://github.com/ProfileCreator/ProfileCreator
|
||
_github: https://github.com/ProfileCreator/ProfileCreator
|
||
_home: https://github.com/ProfileCreator/ProfileCreator
|
||
_name: Profile Creator
|
||
cask: profilecreator
|
||
mas: 2141249187
|
||
progress:
|
||
_bin: progress
|
||
_github: https://github.com/Xfennec/progress
|
||
_name: Progress
|
||
apt: progress
|
||
brew: progress
|
||
dnf: progress
|
||
pacman: progress
|
||
port: progress
|
||
zypper: progress
|
||
projen:
|
||
_bin: projen
|
||
_github: https://github.com/projen/projen
|
||
_name: Projen
|
||
npm: projen
|
||
protonmail-bridge:
|
||
_app: Proton Mail Bridge.app
|
||
_github: https://github.com/ProtonMail/proton-bridge
|
||
_bin: protonmail-bridge
|
||
cask: protonmail-bridge
|
||
choco: protonmailbridge
|
||
flatpak: ch.protonmail.protonmail-bridge
|
||
yay: protonmail-bridge
|
||
protonmail-import-export:
|
||
_app: ProtonMail Import-Export app.app
|
||
_bin: protonmail-import-export
|
||
_github: false
|
||
cask: protonmail-import-export
|
||
flatpak: ch.protonmail.protonmail-import-export-app
|
||
protonvpn:
|
||
_app: ProtonVPN.app
|
||
_bin: protonvpn
|
||
_desc: '[Proton](https://www.proton.org/) is a free and open-source raster graphics editor used for image manipulation and image editing, free-form drawing, transcoding between different image file formats, and more specialized tasks. Proton is released under GPLv3+ license and is available for Linux, macOS, and Microsoft Windows.'
|
||
_docs: https://protonmail.com/support/
|
||
_github: https://github.com/ProtonVPN/linux-app
|
||
_home: https://protonmail.com/
|
||
_name: ProtonVPN
|
||
_post:dnf:fedora: |
|
||
#!/usr/bin/env bash
|
||
sudo dnf install -y python3-pip && pip3 install --user 'dnspython>=1.16.0'
|
||
_post:yay: |
|
||
#!/usr/bin/env bash
|
||
sudo pacman -Syu libappindicator-gtk3 gnome-shell-extension-appindicator
|
||
_pre:apt: |
|
||
#!/usr/bin/env bash
|
||
sudo apt-get install -y https://repo.protonvpn.com/debian/dists/stable/main/binary-all/protonvpn-stable-release_1.0.3_all.deb && sudo apt-get update
|
||
_pre:dnf: |
|
||
#!/usr/bin/env bash
|
||
sudo dnf install -y https://repo.protonvpn.com/fedora-36-stable/release-packages/protonvpn-stable-release-1.0.1-1.noarch.rpm && sudo dnf update
|
||
# ansible: professormanhattan.proton
|
||
apt:
|
||
- gir1.2-appindicator3-0.1
|
||
- gnome-shell-extension-appindicator
|
||
- protonvpn
|
||
cask: protonvpn
|
||
choco: protonvpn
|
||
dnf:fedora:
|
||
- gnome-extensions-app
|
||
- gnome-shell-extension-appindicator
|
||
- gnome-tweaks
|
||
- libappindicator-gtk3
|
||
- protonvpn
|
||
yay: protonvpn
|
||
protonvpn-cli:
|
||
_bin: protonvpn
|
||
_github: https://github.com/ProtonVPN/linux-cli
|
||
_deps:script:darwin:
|
||
- dialog
|
||
- openvpn
|
||
_desc: The ProtonVPN CLI official release for Linux along with an unofficial ProtonVPN CLI for macOS
|
||
_name: ProtonVPN CLI
|
||
_todo: Populate this once the ProtonVPN CLI is released to the package managers
|
||
apt: protonvpn-cli
|
||
dnf: protonvpn-cli
|
||
pacman: protonvpn-cli
|
||
script:darwin: |
|
||
sudo rm -rf /usr/local/src/protonvpn-cli
|
||
sudo git clone https://github.com/phx/protonvpn-cli-macos /usr/local/src/protonvpn-cli
|
||
cd /usr/local/src/protonvpn-cli && pip3 install -r requirements.txt
|
||
sudo python3 setup.py install
|
||
provisionql:
|
||
_github: https://github.com/ealeksandrov/ProvisionQL
|
||
_name: ProvisionQL
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/ProvisionQL.qlgenerator"'
|
||
cask: provisionql
|
||
proxyman:
|
||
_app: Proxyman.app
|
||
_bin: proxyman-cli
|
||
_github: https://github.com/ProxymanApp/Proxyman
|
||
_name: Proxyman
|
||
cask: proxyman
|
||
psi:
|
||
_bin: psi
|
||
_desc: Run mobile and desktop performance tests for your deployed site using Google PageSpeed Insights v5 with tidy reporting for your build process
|
||
_github: https://github.com/GoogleChromeLabs/psi
|
||
_name: psi
|
||
npm: psi
|
||
psscriptanalyzer:
|
||
_bin: psscriptanalyzer
|
||
_github: https://github.com/PowerShell/PSScriptAnalyzer
|
||
_name: PSScriptAnalyzer
|
||
choco: psscriptanalyzer
|
||
psu:
|
||
_bin: portainer-stack-utils
|
||
_desc: CLI client for Portainer
|
||
_docs: https://github.com/greenled/portainer-stack-utils
|
||
_github: https://github.com/greenled/portainer-stack-utils
|
||
_home: https://hub.docker.com/r/greenled/portainer-stack-utils/
|
||
_name: psu
|
||
go: github.com/greenled/portainer-stack-utils@master
|
||
pueue:
|
||
_bin: pueue
|
||
_github: https://github.com/Nukesor/pueue
|
||
_name: Pueue
|
||
_service: pueue
|
||
apk: pueue
|
||
apt: pueue
|
||
brew: pueue
|
||
cargo: pueue --locked
|
||
dnf: pueue
|
||
pacman: pueue
|
||
pulumi:
|
||
_bin: pulumi
|
||
_desc: Pulumi - Infrastructure as Code in any programming language. Build infrastructure intuitively on any cloud using familiar languages
|
||
_docs: https://www.pulumi.com/docs/quickstart/
|
||
_github: https://github.com/pulumi/pulumi
|
||
_home: https://www.pulumi.com/
|
||
_name: Pulumi
|
||
brew: pulumi/tap/pulumi
|
||
choco: pulumi
|
||
pup:
|
||
_bin: pup
|
||
_desc: '[pup](https://github.com/ericchiang/pup) is a command line tool for processing HTML. It reads from stdin, prints to stdout, and allows the user to filter parts of the page using CSS selectors.'
|
||
_github: https://github.com/ericchiang/pup
|
||
_name: pup
|
||
ansible: professormanhattan.pup
|
||
brew: pup
|
||
github: github.com/ericchiang/pup
|
||
go: github.com/ericchiang/pup@latest
|
||
pushpin:
|
||
_bin: pushpin
|
||
_github: https://github.com/fastly/pushpin
|
||
_name: Pushpin
|
||
brew: pushpin
|
||
pv:
|
||
_bin: pv
|
||
_github: https://github.com/icetee/pv
|
||
apt: pv
|
||
pwnat:
|
||
_bin: pwnat
|
||
_github: https://github.com/samyk/pwnat
|
||
_name: pwnat
|
||
brew: pwnat
|
||
python:
|
||
_bin: python3
|
||
_github: https://github.com/python/cpython
|
||
_post:brew: |
|
||
#!/usr/bin/env bash
|
||
python3 -m pip install --upgrade setuptools
|
||
python3 -m pip install --upgrade pip
|
||
apt: python3-pip
|
||
brew: python
|
||
dnf: python3-pip
|
||
pacman: python-pip
|
||
scoop: python
|
||
python2:
|
||
_bin: python2
|
||
_github: false
|
||
apt: python2
|
||
# Prepare an alternate method for installing python2 on macOS - python2 package no longer works
|
||
# brew: python2
|
||
choco: python2
|
||
dnf: python2
|
||
pacman: python2
|
||
scoop: python2
|
||
pywhat:
|
||
_bin: what
|
||
_desc: Identify anything. pyWhat easily lets you identify emails, IP addresses, and more. Feed it a .pcap file or some text and it'll tell you what it is!
|
||
_github: https://github.com/bee-san/pyWhat
|
||
brew: pywhat
|
||
pipx: pywhat
|
||
port: pywhat
|
||
pywin32:
|
||
_bin: pywin32
|
||
_github: https://github.com/mhammond/pywin32
|
||
_name: Pywin32
|
||
pipx:windows: pywin32
|
||
qbittorrent:
|
||
_app: qBittorrent.app
|
||
_bin: qbittorrent
|
||
_desc: '[qBittorrent](https://www.qbittorrent.org/) is a cross-platform free and open-source BitTorrent client. qBittorrent is a native application written in C++. It uses Boost, Qt 5 toolkit, and libtorrent-rasterbar library. Its optional search engine is written in Python.'
|
||
_docs: https://github.com/qbittorrent/qBittorrent/wiki
|
||
_github: https://github.com/qbittorrent/qBittorrent
|
||
_home: https://www.qbittorrent.org/
|
||
_name: qBittorrent
|
||
ansible: professormanhattan.qbittorrent
|
||
apt: qbittorrent
|
||
cask: qbittorrent
|
||
choco: qbittorrent
|
||
dnf: qbittorrent
|
||
flatpak: org.qbittorrent.qBittorrent
|
||
pacman: qbittorrent
|
||
yay: qbittorrent-git
|
||
qlcolorcode:
|
||
_github: https://github.com/n8gray/QLColorCode
|
||
_name: QLColorCode
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/QLColorCode.qlgenerator"'
|
||
cask: qlcolorcode
|
||
qlmarkdown:
|
||
_github: https://github.com/toland/qlmarkdown
|
||
_name: QLMarkdown
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/ProvisionQL.qlgenerator"'
|
||
cask: qlmarkdown
|
||
qlplugins:
|
||
_bin: null
|
||
_github: false
|
||
_deps:
|
||
- provisionql
|
||
- qlcolorcode
|
||
- qlmarkdown
|
||
- qlstephen
|
||
- qlvideo
|
||
- quicklook-json
|
||
- quicklookapk
|
||
- webpquicklook
|
||
_name: null
|
||
qlstephen:
|
||
_github: https://github.com/whomwah/qlstephen
|
||
_name: QLStephen
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/QLStephen.qlgenerator"'
|
||
cask: qlstephen
|
||
qlvideo:
|
||
_github: https://github.com/Marginal/QLVideo
|
||
_name: QLVideo
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/ProvisionQL.qlgenerator"'
|
||
cask: qlvideo
|
||
quark-engine:
|
||
_bin: quark
|
||
_desc: Dig Vulnerabilities in the BlackBox (requirement of APKLabs VSCode plugin)
|
||
_docs: https://quark-engine.readthedocs.io/en/latest/index.html
|
||
_github: https://github.com/quark-engine/quark-engine
|
||
_home: https://github.com/quark-engine/quark-engine
|
||
_name: Quark-Engine
|
||
pipx: quark-engine
|
||
quasar:
|
||
_bin: null
|
||
_desc: '[Quasar](https://github.com/quasar/Quasar) is a fast and light-weight remote administration tool coded in C#. The usage ranges from user support through day-to-day administrative work to employee monitoring. Providing high stability and an easy-to-use user interface, Quasar is the perfect remote administration solution for you.'
|
||
_docs: https://github.com/quasar/Quasar/wiki
|
||
_github: https://github.com/quasar/Quasar
|
||
_home: https://github.com/quasar/Quasar
|
||
_name: Quasar
|
||
ansible:windows: professormanhattan.quasar
|
||
quickemu:
|
||
_bin: quickemu
|
||
_github: https://github.com/quickemu-project/quickemu
|
||
_pre: |
|
||
#!/usr/bin/env bash
|
||
sudo apt-add-repository ppa:flexiondotorg/quickemu && sudo apt update
|
||
apt:ubuntu: quickemu
|
||
quickgui:
|
||
_github: https://github.com/quickemu-project/quickgui
|
||
_pre: |
|
||
#!/usr/bin/env bash
|
||
sudo add-apt-repository ppa:yannick-mauray/quickgui && sudo apt update
|
||
apt:ubuntu: quickgui
|
||
quicklook-json:
|
||
_github: false
|
||
_name: QLJSON
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/QuickLookJSON.qlgenerator"'
|
||
cask: quicklook-json
|
||
quicklookapk:
|
||
_github: https://github.com/hezi/QuickLookAPK
|
||
_name: QLAPK
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/QuickLookAPK.qlgenerator"'
|
||
cask: quicklookapk
|
||
quicktype:
|
||
_bin: quicktype
|
||
_github: https://github.com/quicktype/quicktype
|
||
_name: Quicktype
|
||
npm: quicktype
|
||
ramda:
|
||
_bin: ramda
|
||
_desc: A CLI tool for processing data with functional pipelines
|
||
_docs: https://github.com/raine/ramda-cli#synopsis
|
||
_github: https://github.com/raine/ramda-cli
|
||
_home: https://github.com/raine/ramda-cli
|
||
_name: Ramda
|
||
npm: ramda-cli
|
||
rancher-cli:
|
||
_bin: rancher
|
||
_desc: The Rancher Command Line Interface (CLI) is a unified tool for interacting with your Rancher Server
|
||
_docs: https://ranchermanager.docs.rancher.com/reference-guides/cli-with-rancher/rancher-cli
|
||
_github: https://github.com/rancher/cli
|
||
_name: rancher
|
||
brew: rancher-cli
|
||
github: github.com/rancher/cli
|
||
yay: rancher-cli-bin
|
||
rancher-desktop:
|
||
_github: https://github.com/rancher-sandbox/rancher-desktop/
|
||
cask: rancher
|
||
raspberry-pi-imager:
|
||
_app: Raspberry Pi Imager.app
|
||
_bin: rpi-imager
|
||
_desc: '[Raspberry Pi Imager](https://www.raspberrypi.org/software/) is the quick and easy way to install Raspberry Pi OS and other operating systems to a microSD card, ready to use with your Raspberry Pi.'
|
||
_docs: https://www.raspberrypi.com/documentation/computers/getting-started.html
|
||
_github: https://github.com/raspberrypi/rpi-imager
|
||
_home: https://www.raspberrypi.com/software/
|
||
_name: Raspberry Pi Imager
|
||
ansible: professormanhattan.raspberryimager
|
||
cask: raspberry-pi-imager
|
||
choco: rpi-imager
|
||
dnf: rpi-imager
|
||
flatpak: org.raspberrypi.rpi-imager
|
||
snap: rpi-imager
|
||
yay: rpi-imager
|
||
raycast:
|
||
_app: Raycast.app
|
||
_bin: null
|
||
_desc: Everything you need to extend Raycast (the search provider for macOS)
|
||
_docs: https://developers.raycast.com/
|
||
_env:
|
||
RAYCAST_APPDATA:
|
||
cask: "$HOME/Library/Application Support/com.raycast.macos"
|
||
_github: https://github.com/raycast/extensions
|
||
_home: https://www.raycast.com/
|
||
_name: Raycast
|
||
cask: raycast
|
||
rclone:
|
||
_bin: rclone
|
||
_desc: '[Rclone](https://rclone.org/) is an open source, multi threaded, command line computer program to manage content on cloud and other high latency storage. Its capabilities include sync, transfer, crypt, cache, union, compress and mount. The rclone website lists [fifty supported backends](https://rclone.org/overview/) including S3 services and Google Drive.'
|
||
_docs: https://rclone.org/docs/
|
||
_github: https://github.com/rclone/rclone
|
||
_groups:
|
||
- rclone
|
||
_home: https://rclone.org/
|
||
_name: Rclone
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Rclone S3 Mounts
|
||
# @brief This script configures Rclone to provide several S3-compliant mounts by leveraging CloudFlare R2
|
||
# @description
|
||
# Install Doctor leverages Rclone and CloudFlare R2 to provide S3-compliant bucket mounts that allow you to retain stateful files and configurations.
|
||
# In general, these buckets are used for backing up files like your browser profiles, Docker backup files, and other files that cannot be stored as
|
||
# as code in your Install Doctor fork.
|
||
#
|
||
# This script sets up Rclone to provide several folders that are synchronized with S3-compliant buckets (using CloudFlare R2 by default).
|
||
# The script ensures required directories are created and that proper permissions are applied. This script will only run if `rclone` is
|
||
# available in the `PATH`. It also requires the user to provide `CLOUDFLARE_R2_ID` and `CLOUDFLARE_R2_SECRET` as either environment variables
|
||
# or through the encrypted repository-fork-housed method detailed in the [Secrets documentation](https://install.doctor/docs/customization/secrets).
|
||
#
|
||
# ## Mounts
|
||
#
|
||
# The script will setup five mounts by default and enable / start `systemd` services on Linux systems so that the mounts are available
|
||
# whenever the device is turned on. The mounts are:
|
||
#
|
||
# | Mount Location | Description |
|
||
# |-----------------------|-----------------------------------------------------------------------------------------------------------------------|
|
||
# | `/mnt/Private` | Private system-wide bucket used for any private files that should not be able to be accessed publicly over HTTPS |
|
||
# | `/mnt/Public` | Public system-wide bucket that can be accessed by anyone over HTTPS with the bucket's URL (provided by CloudFlare R2) |
|
||
# | N/A | Private system-wide bucket used for storing Docker-related backups / files |
|
||
# | N/A | Private system-wide bucket similar to `/mnt/Private` but intended for system file backups |
|
||
# | `$HOME/Public` | Private user-specific bucket (used for backing up application settings) |
|
||
#
|
||
# ## Permissions
|
||
#
|
||
# The system files are all assigned proper permissions and are owned by the user `rclone` with the group `rclone`. The exception to this is the
|
||
# user-specific mount which uses the user's user name and user group.
|
||
#
|
||
# ## Samba
|
||
#
|
||
# If Samba is installed, then by default Samba will create two shares that are symlinked to the `/mnt/s3-private` and `/mnt/s3-public`
|
||
# buckets. This feature allows you to easily access the two buckets from other devices in your local network. If Rclone buckets are not
|
||
# available then the Samba setup script will just create regular empty folders as shares.
|
||
#
|
||
# ## Notes
|
||
#
|
||
# * The mount services all leverage the executable found at `$HOME/.local/bin/rclone-mount` to mount the shares.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Rclone mount script](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_local/bin/executable_rclone-mount)
|
||
# * [Rclone default configurations](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_config/rclone)
|
||
# * [Rclone documentation](https://rclone.org/docs/)
|
||
|
||
if command -v rclone > /dev/null; then
|
||
{{- if and (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID"))) (env "CLOUDFLARE_R2_ID")) (or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET"))) (env "CLOUDFLARE_R2_SECRET")) (ne .user.cloudflare.r2 "") }}
|
||
logg info 'Removing ~/.config/rclone/rclone.conf Install Doctor managed block'
|
||
CONFIG_FILE="${XDG_CONFIG_HOME:-$HOME/.config}/rclone/rclone.conf"
|
||
if cat "$CONFIG_FILE" | grep '# INSTALL DOCTOR MANAGED S3 START' > /dev/null; then
|
||
# TODO: Remove old block
|
||
START_LINE="$(echo `grep -n -m 1 "# INSTALL DOCTOR MANAGED S3 START" "$CONFIG_FILE" | cut -f1 -d ":"`)"
|
||
END_LINE="$(echo `grep -n -m 1 "# INSTALL DOCTOR MANAGED S3 END" "$CONFIG_FILE" | cut -f1 -d ":"`)"
|
||
if command -v gsed > /dev/null; then
|
||
gsed -i "$START_LINE,${END_LINE}d" "$CONFIG_FILE" > /dev/null
|
||
else
|
||
sed -i "$START_LINE,${END_LINE}d" "$CONFIG_FILE" > /dev/null
|
||
fi
|
||
fi
|
||
logg info 'Adding ~/.config/rclone/rclone.conf INSTALL DOCTOR managed block'
|
||
sudo tee -a "$CONFIG_FILE" > /dev/null <<EOT
|
||
# INSTALL DOCTOR MANAGED S3 START
|
||
[User-{{ .user.username}}]
|
||
access_key_id = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_ID_USER")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_ID_USER" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_ID_USER" -}}{{ end }}
|
||
acl = private
|
||
endpoint = {{ .user.cloudflare.r2 }}.r2.cloudflarestorage.com
|
||
provider = Cloudflare
|
||
region = auto
|
||
secret_access_key = {{ if (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "CLOUDFLARE_R2_SECRET_USER")) }}{{- includeTemplate "secrets/CLOUDFLARE_R2_SECRET_USER" | decrypt | trim -}}{{ else }}{{- env "CLOUDFLARE_R2_SECRET_USER" -}}{{ end }}
|
||
type = s3
|
||
# INSTALL DOCTOR MANAGED S3 END
|
||
EOT
|
||
{{- end }}
|
||
sudo chown -f root "$CONFIG_FILE"
|
||
sudo chmod -f 600 "$CONFIG_FILE"
|
||
|
||
logg info 'Ensuring /var/cache/rclone exists'
|
||
sudo mkdir -p /var/cache/rclone
|
||
sudo chmod 750 /var/cache/rclone
|
||
### Add user / group with script in ~/.local/bin/add-usergroup, if it is available
|
||
if command -v add-usergroup > /dev/null; then
|
||
sudo add-usergroup "$USER" rclone
|
||
fi
|
||
sudo chown -Rf rclone:rclone /var/cache/rclone
|
||
|
||
logg info 'Ensuring /var/log/rclone exists'
|
||
sudo mkdir -p /var/log/rclone
|
||
sudo chmod 750 /var/log/rclone
|
||
sudo chown -Rf rclone:rclone /var/log/rclone
|
||
|
||
logg info 'Adding ~/.local/bin/rclone-mount to /usr/local/bin'
|
||
sudo cp -f "$HOME/.local/bin/rclone-mount" /usr/local/bin/rclone-mount
|
||
sudo chmod +x /usr/local/bin/rclone-mount
|
||
|
||
logg info 'Adding ~/.config/rclone/rcloneignore to /etc/rcloneignore'
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/rcloneignore" /etc/rcloneignore
|
||
sudo chown -Rf rclone:rclone /etc/rcloneignore
|
||
sudo chmod 640 /etc/rcloneignore
|
||
|
||
logg info 'Adding ~/.config/rclone/system-rclone.conf to /etc/rclone.conf'
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/system-rclone.conf" /etc/rclone.conf
|
||
sudo chown -Rf rclone:rclone /etc/rclone.conf
|
||
sudo chmod 600 /etc/rclone.conf
|
||
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### Enable Rclone mounts
|
||
logg info 'Ensuring Rclone mount-on-reboot definitions are in place'
|
||
if [ -f "$HOME/Library/LaunchDaemons/rclone.private.plist" ] && [ ! -f "/Library/LaunchDaemons/rclone.private.plist" ]; then
|
||
logg info 'Adding /Volumes/Private as S3 bucket mount, enabled at boot'
|
||
sudo mkdir -p /Library/LaunchDaemons
|
||
sudo cp -f "$HOME/Library/LaunchDaemons/rclone.private.plist" '/Library/LaunchDaemons/rclone.private.plist'
|
||
sudo launchctl load '/Library/LaunchDaemons/rclone.private.plist' && logg success 'launchctl load successful'
|
||
fi
|
||
if [ -f "$HOME/Library/LaunchDaemons/rclone.public.plist" ] && [ ! -f "/Library/LaunchDaemons/rclone.public.plist" ]; then
|
||
logg info 'Adding /Volumes/Public as S3 bucket mount, enabled at boot'
|
||
sudo mkdir -p /Library/LaunchDaemons
|
||
sudo cp -f "$HOME/Library/LaunchDaemons/rclone.public.plist" '/Library/LaunchDaemons/rclone.public.plist'
|
||
sudo launchctl load '/Library/LaunchDaemons/rclone.public.plist' && logg success 'launchctl load successful'
|
||
fi
|
||
if [ -f "$HOME/Library/LaunchDaemons/rclone.user.plist" ] && ! launchctl list | grep 'rclone.user' > /dev/null; then
|
||
logg info 'Adding ~/Public as S3 bucket mount, enabled at boot'
|
||
launchctl load "$HOME/Library/LaunchDaemons/rclone.user.plist" && logg success 'user launchctl load successful'
|
||
fi
|
||
elif [ -d /etc/systemd/system ]; then
|
||
find "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/system" -mindepth 1 -maxdepth 1 -type f | while read RCLONE_SERVICE; do
|
||
### Add systemd service file
|
||
logg info "Adding S3 system mount service defined at $RCLONE_SERVICE"
|
||
FILENAME="$(basename "$RCLONE_SERVICE")"
|
||
SERVICE_ID="$(echo "$FILENAME" | sed 's/.service//')"
|
||
sudo cp -f "$RCLONE_SERVICE" "/etc/systemd/system/$(basename "$RCLONE_SERVICE")"
|
||
|
||
### Ensure mount folder is created
|
||
logg info "Ensuring /mnt/$SERVICE_ID is created with proper permissions"
|
||
sudo mkdir -p "/mnt/$SERVICE_ID"
|
||
sudo chmod 750 "/mnt/$SERVICE_ID"
|
||
|
||
### Enable / restart the service
|
||
logg info "Enabling / restarting the $SERVICE_ID S3 service"
|
||
sudo systemctl enable "$SERVICE_ID"
|
||
sudo systemctl restart "$SERVICE_ID"
|
||
done
|
||
|
||
### Add user Rclone mount
|
||
logg info 'Adding user S3 rclone mount (available at ~/.local/mnt/s3)'
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/rclone/s3-user.service" "/etc/systemd/system/s3-${USER}.service"
|
||
logg info 'Enabling / restarting the S3 user mount'
|
||
sudo systemctl enable "s3-${USER}"
|
||
sudo systemctl restart "s3-${USER}"
|
||
fi
|
||
else
|
||
logg info 'rclone is not available'
|
||
fi
|
||
ansible: professormanhattan.rclone
|
||
apt: rclone
|
||
brew:linux: rclone
|
||
choco:
|
||
- rclone
|
||
- winfsp
|
||
- nssm
|
||
dnf: rclone
|
||
pacman: rclone
|
||
port: rclone
|
||
scoop: rclone
|
||
script:darwin: |
|
||
#!/usr/bin/env bash
|
||
TMP="$(mktemp)"
|
||
curl https://rclone.org/install.sh > "$TMP"
|
||
sudo bash "$TMP"
|
||
rm -f "$TMP"
|
||
recoverpy:
|
||
_bin: recoverpy
|
||
_deps:
|
||
- coreutils
|
||
- grep
|
||
- progress
|
||
- util-linux
|
||
_desc: '[RecoverPy](https://github.com/PabloLec/RecoverPy) is a powerful tool that leverages your system capabilities to recover lost file. Unlike others, you can not only recover deleted files but also overwritten data.'
|
||
_docs: https://github.com/PabloLec/RecoverPy#usage
|
||
_github: https://github.com/PabloLec/RecoverPy
|
||
_home: https://github.com/PabloLec/RecoverPy
|
||
_name: RecoverPy
|
||
_when: echo '! pip3 list | grep recoverpy > /dev/null' | bash
|
||
ansible:linux: professormanhattan.recoverpy
|
||
script:linux: python3 -m pip install recoverpy
|
||
recuva:
|
||
_bin: recuva
|
||
_desc: Recuva recovers files from your Windows computer, recycle bin, digital camera card, or MP3 player!
|
||
_docs: https://www.ccleaner.com/recuva
|
||
_github: false
|
||
_home: https://www.ccleaner.com/recuva
|
||
_name: Recuva
|
||
choco: recuva
|
||
scoop: extras/recuva
|
||
redis-desktop-manager:
|
||
_bin: redis-desktop-manager
|
||
_desc: '[Redis Desktop Manager](https://rdm.dev/) is an open source cross-platform Desktop Manager for Redis based on Qt 5.'
|
||
_docs: https://docs.rdm.dev/en/docs-fix-edit-url/
|
||
_github: https://github.com/uglide/RedisDesktopManager
|
||
_home: https://resp.app/
|
||
_name: Redis Desktop Manager
|
||
ansible:linux: professormanhattan.rdm
|
||
flatpak: app.resp.RESP
|
||
snap: redis-desktop-manager
|
||
redis-insight:
|
||
_app: RedisInsight.app
|
||
_bin: redis-insight
|
||
_github: https://github.com/RedisInsight/RedisInsight
|
||
_name: Redis Insight
|
||
cask: redisinsight
|
||
flatpak: com.redis.RedisInsight
|
||
mas: 2142946629
|
||
reek:
|
||
_bin: reek
|
||
_github: https://github.com/troessner/reek
|
||
_name: Reek
|
||
gem: reek
|
||
remmina:
|
||
_bin: remmina
|
||
_github: https://github.com/FreeRDP/Remmina
|
||
_desc: Remmina is a GTK Remmina Remote Desktop Client which provides remote access, screen and file sharing to your desktop
|
||
_docs: https://gitlab.com/Remmina/Remmina/-/wikis/home
|
||
_env:
|
||
REMMINA_APPDATA:
|
||
flatpak: "$HOME/.var/app/org.remmina.Remmina/config/remmina/remmina.pref"
|
||
snap: "$HOME/snap/remmina/current/.config/remmina/remmina.pref"
|
||
_home: https://remmina.org/
|
||
_name: Remmina
|
||
apt: remmina
|
||
dnf: remmina
|
||
flatpak: org.remmina.Remmina
|
||
pacman: remmina
|
||
snap: remmina
|
||
yay: remmina-git
|
||
remote-desktop:
|
||
_github: false
|
||
_deps:
|
||
- gnome-boxes
|
||
- microsoft-remote-desktop
|
||
- remmina
|
||
- xrdp
|
||
repo:
|
||
_bin: repo
|
||
_github: false
|
||
_name: Repo
|
||
apt: repo
|
||
brew: repo
|
||
dnf: repo
|
||
pacman: repo
|
||
# TODO: Include Windows install method
|
||
responsively:
|
||
_app: ResponsivelyApp.app
|
||
_bin: null
|
||
_desc: A modified web browser that helps in responsive web development
|
||
_github: https://github.com/responsively-org/responsively-app
|
||
_name: Responsively
|
||
cask: responsively
|
||
choco: responsively
|
||
github: github.com/responsively-org/responsively-app
|
||
restic:
|
||
_bin: restic
|
||
_desc: '[Restic](https://restic.net/) is a modern backup program that can back up your files from Linux, BSD, Mac and Windows to many different storage types, including self-hosted and online services. It is a single executable that you can run without a server or complex setup. It can be used to only back-up the parts of files that actually changed. It uses cryptography in every part of the process. Restic is entirely free to use and completely open source.'
|
||
_docs: https://restic.readthedocs.io/en/latest/
|
||
_github: https://github.com/restic/restic
|
||
_home: https://restic.net/
|
||
_name: Restic
|
||
ansible: professormanhattan.restic
|
||
apk: restic
|
||
apt: restic
|
||
brew: restic
|
||
dnf: restic
|
||
eopkg: restic
|
||
nix: restic
|
||
pacman: restic
|
||
pkg-freebsd: restic
|
||
pkg_add: restic
|
||
port: restic
|
||
scoop: restic
|
||
zypper: restic
|
||
resume:
|
||
_bin: resume
|
||
_desc: CLI tool to easily setup a new resume
|
||
_docs: https://jsonresume.org/getting-started/
|
||
_github: https://github.com/jsonresume/resume-cli
|
||
_home: https://jsonresume.org/
|
||
_name: JSON Resume CLI
|
||
npm: resume-cli
|
||
ripgrep:
|
||
_bin: rg
|
||
_desc: '[ripgrep](https://github.com/BurntSushi/ripgrep) is a line-oriented search tool that recursively searches your current directory for a regex pattern. By default, ripgrep will respect your .gitignore and automatically skip hidden files/directories and binary files. This role also installs ripgrep-all. [ripgrep-all](https://github.com/phiresky/ripgrep-all) is just like ripgrep except it also searches in PDFs, E-Books, Office documents, zip, tar.gz, etc.'
|
||
_github: https://github.com/BurntSushi/ripgrep
|
||
_name: ripgrep
|
||
ansible: professormanhattan.ripgrep
|
||
apt: ripgrep
|
||
brew: ripgrep
|
||
cargo: ripgrep
|
||
choco: ripgrep
|
||
dnf: ripgrep
|
||
nix: ripgrep
|
||
pacman: ripgrep
|
||
pkg: ripgrep
|
||
port: ripgrep
|
||
scoop: ripgrep
|
||
zypper: ripgrep
|
||
ripgrep-all:
|
||
_bin: rga
|
||
_desc: rga is a line-oriented search tool that allows you to look for a regex in a multitude of file types. rga wraps the awesome ripgrep and enables it to search in pdf, docx, sqlite, jpg, movie subtitles (mkv, mp4), etc.
|
||
_github: https://github.com/phiresky/ripgrep-all
|
||
brew:
|
||
- ffmpeg
|
||
- pandoc
|
||
- poppler
|
||
- rga
|
||
- tesseract
|
||
choco: ripgrep-all
|
||
nix: ripgrep-all
|
||
pacman: ripgrep-all
|
||
rkhunter:
|
||
_bin: rkhunter
|
||
_desc: rkhunter is a Unix-based tool that scans for rootkits, backdoors and possible local exploits
|
||
_home: https://rkhunter.sourceforge.net/
|
||
_name: rkhunter
|
||
_github: false
|
||
_notes: The _post script removes an entry for VMware with a space in it that causes rkhunter to hiccup
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS
|
||
logg info 'Updating file "$(brew --prefix)/Cellar/rkhunter/1.4.6/etc/rkhunter.conf"' && gsed -i "s/^#WEB_CMD.*$/WEB_CMD=curl\ -L/" "$(brew --prefix)/Cellar/rkhunter/1.4.6/etc/rkhunter.conf"
|
||
else
|
||
### Linux
|
||
logg info 'Updating file /etc/rkhunter.conf' && sed -i "s/^#WEB_CMD.*$/WEB_CMD=curl\ -L/" /etc/rkhunter.conf
|
||
fi
|
||
export PATH="$(echo "$PATH" | sed 's/VMware Fusion.app/VMwareFusion.app/')"
|
||
sudo rkhunter --propupd || RK_PROPUPD_EXIT_CODE=$?
|
||
if [ -n "$RK_PROPUPD_EXIT_CODE" ]; then
|
||
echo "FIXME sudo rkhunter --propupd returned non-zero exit code"
|
||
fi
|
||
sudo rkhunter --update || RK_UPDATE_EXIT_CODE=$?
|
||
if [ -n "$RK_UPDATE_EXIT_CODE" ]; then
|
||
echo "FIXME sudo rkhunter --update returned non-zero exit code"
|
||
fi
|
||
_service:pacman: cronie
|
||
apt: rkhunter
|
||
brew: rkhunter
|
||
dnf: rkhunter
|
||
pacman:
|
||
- cronie
|
||
- rkhunter
|
||
- s-nail
|
||
rm-improved:
|
||
_bin: rip
|
||
_desc: A safe and ergonomic alternative to rm
|
||
_docs: https://github.com/nivekuil/rip
|
||
_github: https://github.com/nivekuil/rip
|
||
_home: https://github.com/nivekuil/rip
|
||
_name: rip (Rm ImProved)
|
||
brew: rm-improved
|
||
cargo: rm-improved
|
||
github: github.com/nivekuil/rip
|
||
yay: rm-improved
|
||
robotframework:
|
||
_bin: robot
|
||
_desc: Generic automation framework for acceptance testing and RPA
|
||
_docs: https://robotframework.org/robotframework/#user-guide
|
||
_github: https://github.com/robotframework/robotframework
|
||
_home: https://robotframework.org/
|
||
_name: Robot Framework
|
||
pipx: robotframework
|
||
rofi:
|
||
_bin: rofi
|
||
_desc: Rofi is a window switcher, application launcher and dmenu replacement
|
||
_docs: https://davatorium.github.io/rofi/
|
||
_github: https://github.com/davatorium/rofi
|
||
_home: https://davatorium.github.io/rofi/
|
||
_name: rofi
|
||
apt: rofi
|
||
dnf:fedora: rofi
|
||
pacman: rofi
|
||
pkg: rofi
|
||
port: rofi
|
||
zypper: rofi
|
||
rsync:
|
||
_bin: rsync
|
||
_desc: rsync is an open source utility that provides fast incremental file transfer.
|
||
_docs: https://rsync.samba.org/documentation.html
|
||
_github: https://github.com/WayneD/rsync
|
||
_home: https://rsync.samba.org/
|
||
_name: rsync
|
||
apt: rsync
|
||
brew: rsync
|
||
choco: rsync
|
||
dnf: rsync
|
||
rsyslog:
|
||
_bin: rsyslogd
|
||
_github: https://github.com/rsyslog/rsyslog
|
||
_name: RSyslog
|
||
_ports:
|
||
- port: 514
|
||
proto: tcp
|
||
_service: rsyslog
|
||
apt: rsyslog
|
||
brew: rsyslog
|
||
dnf: rsyslog
|
||
pacman: rsyslog
|
||
rtop:
|
||
_bin: rtop
|
||
_github: https://github.com/rapidloop/rtop
|
||
_name: rtop
|
||
go: github.com/rapidloop/rtop@latest
|
||
rubocop:
|
||
_bin: rubocop
|
||
_github: https://github.com/rubocop/rubocop
|
||
_name: Rubocop
|
||
gem: rubocop
|
||
ruby:
|
||
_bin: ruby
|
||
_desc: Ruby is an interpreted, high-level, general-purpose programming language which supports multiple programming paradigms. It was designed with an emphasis on programming productivity and simplicity. In Ruby, everything is an object, including primitive data types. It was developed in the mid-1990s in Japan.
|
||
_docs: https://www.ruby-lang.org/en/documentation/
|
||
_github: https://github.com/ruby/ruby
|
||
_home: https://www.ruby-lang.org/en/
|
||
_name: Ruby
|
||
ansible: professormanhattan.ruby
|
||
apt: ruby-dev
|
||
brew: ruby
|
||
choco: ruby
|
||
dnf: ruby-devel
|
||
pacman: ruby
|
||
port: ruby
|
||
scoop: ruby
|
||
ruff:
|
||
_bin: ruff
|
||
_desc: An extremely fast Python linter, written in Rust.
|
||
_docs: https://beta.ruff.rs/docs/
|
||
_github: https://github.com/charliermarsh/ruff
|
||
_home: https://beta.ruff.rs/docs/
|
||
_name: Ruff
|
||
apk: ruff
|
||
brew: ruff
|
||
pacman: ruff
|
||
pipx: ruff
|
||
runitor:
|
||
_bin: runitor
|
||
_github: https://github.com/bdd/runitor
|
||
_name: Runitor
|
||
go: bdd.fi/x/runitor/cmd/runitor@latest
|
||
runjs:
|
||
_app: RunJS.app
|
||
_bin: null
|
||
_desc: A JavaScript playground that auto-evaluates as you type
|
||
_github: https://github.com/lukehaas/RunJS
|
||
_name: RunJS
|
||
cask: runjs
|
||
choco: runjs
|
||
github: github.com/lukehaas/RunJS
|
||
yay: runjs-bin
|
||
rust:
|
||
_bin: rustc
|
||
_desc: '[Rust](https://www.rust-lang.org/) is a multi-paradigm programming language designed for performance and safety, especially safe concurrency.'
|
||
_docs: https://www.rust-lang.org/learn
|
||
_github: https://github.com/rust-lang/rust
|
||
_home: https://www.rust-lang.org/
|
||
_name: Rust
|
||
_post:snap: |
|
||
#!/usr/bin/env bash
|
||
rustup toolchain install stable
|
||
ansible: professormanhattan.rust
|
||
brew: rust
|
||
choco: rust
|
||
dnf:
|
||
- cargo
|
||
- rust
|
||
pacman: rust
|
||
port:
|
||
- cargo
|
||
- rust
|
||
scoop: rust
|
||
script:darwin: curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
||
script:linux: curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
||
rustdesk:
|
||
_app: RustDesk.app
|
||
_bin: rustdesk
|
||
_desc: Open source virtual / remote desktop infrastructure for everyone! The open source TeamViewer alternative. Display and control your PC and Android devices from anywhere at anytime.
|
||
_docs: https://rustdesk.com/docs/en/
|
||
_github: https://github.com/rustdesk/rustdesk
|
||
_home: https://rustdesk.com/
|
||
_name: RustDesk
|
||
apt: https://github.com/rustdesk/rustdesk/releases/download/1.1.9/rustdesk-1.1.9.deb
|
||
cask: rustdesk
|
||
choco: rustdesk
|
||
dnf: https://github.com/rustdesk/rustdesk/releases/download/1.1.9/rustdesk-1.1.9-fedora28-centos8.rpm
|
||
pacman: rustdesk
|
||
scoop: rustdesk
|
||
zypper: https://github.com/rustdesk/rustdesk/releases/download/1.1.9/rustdesk-1.1.9-suse.rpm
|
||
rustscan:
|
||
_bin: rustscan
|
||
_desc: An Nmap-based port scanner that scans all 65k ports in 3 seconds
|
||
_docs: https://rustscan.github.io/RustScan/
|
||
_github: https://github.com/RustScan/RustScan
|
||
_home: https://github.com/RustScan/RustScan
|
||
_name: RustScan
|
||
brew: rustscan
|
||
yay: rustscan
|
||
rusty:
|
||
_bin: rusty
|
||
_github: https://github.com/zahidkhawaja/rusty
|
||
_name: Rusty AI CLI
|
||
_todo: Get cargo crate link once this is resolved https://github.com/zahidkhawaja/rusty/issues/7
|
||
s-search:
|
||
_bin: s
|
||
_desc: Open a web search in your terminal.
|
||
_docs: https://github.com/zquestz/s
|
||
_github: https://github.com/zquestz/s
|
||
_home: https://github.com/zquestz/s
|
||
_name: s
|
||
brew: s-search
|
||
s5cmd:
|
||
_bin: s5cmd
|
||
_desc: '[s5cmd](https://github.com/peak/s5cmd) is a very fast S3 and local filesystem execution tool. It comes with support for a multitude of operations including tab completion and wildcard support for files, which can be very handy for your object storage workflow while working with large number of files. s5cmd is the fastest way of interacting with S3 buckets because it can utilize multiple threads unlike similar tools.'
|
||
_github: https://github.com/peak/s5cmd
|
||
_name: s5cmd
|
||
ansible: professormanhattan.s5cmd
|
||
brew: peak/tap/s5cmd
|
||
github: github.com/peak/s5cmd
|
||
go: github.com/peak/s5cmd@latest
|
||
sad:
|
||
_bin: sad
|
||
_desc: sad is a Batch File Edit tool. It will show you a really nice diff of proposed changes before you commit them
|
||
_github: https://github.com/ms-jpq/sad
|
||
brew: ms-jpq/sad/sad
|
||
pacman: sad
|
||
safe-rm:
|
||
_bin: safe-rm
|
||
_github: https://github.com/kaelzhang/shell-safe-rm
|
||
_name: safe-rm
|
||
npm: safe-rm
|
||
sake:
|
||
_bin: sake
|
||
_desc: Sake is a task runner for local and remote hosts
|
||
_docs: https://sakecli.com/examples
|
||
_github: https://github.com/alajmo/sake
|
||
_home: https://sakecli.com/
|
||
_name: Sake
|
||
brew: alajmo/sake/sake
|
||
go: github.com/alajmo/sake@latest
|
||
script:darwin: curl -sfL https://raw.githubusercontent.com/alajmo/sake/main/install.sh | sh
|
||
script:linux: curl -sfL https://raw.githubusercontent.com/alajmo/sake/main/install.sh | sh
|
||
samba:
|
||
_bin: smbd
|
||
_bin:dnf: smb
|
||
_desc: '[Samba](https://www.samba.org/) is a free and open-source software that allows files to be shared across Windows and Linux systems simply and easily. To be exact, it is an open-source implementation of the SMB/CIFS protocol.'
|
||
_docs: https://www.samba.org/samba/docs/
|
||
_github: https://github.com/samba-team/samba
|
||
_groups:
|
||
- sambausers
|
||
_home: https://www.samba.org/
|
||
_name: Samba
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Samba Configuration
|
||
# @brief This script configures Samba by applying the configuration stored in `${XDG_DATA_HOME:-$HOME/.config}/samba/config` if the `smbd` application is available
|
||
# @description
|
||
# This script applies the Samba configuration stored in `${XDG_DATA_HOME:-$HOME/.config}/samba/config` if Samba is installed.
|
||
# The script and default configuration set up two Samba shares.
|
||
#
|
||
# ## Security
|
||
#
|
||
# Both shares are configured by default to only accept connections
|
||
# from hosts with DNS that ends in `.local.PUBLIC_SERVICES_DOMAIN`, where `PUBLIC_SERVICES_DOMAIN` is an environment variable that
|
||
# can be passed into Install Doctor. So, if your `PUBLIC_SERVICES_DOMAIN` environment variable is set to `megabyte.space`, then
|
||
# a device with a FQDN of `alpha.local.megabyte.space` pointing to its LAN location will be able to connect but a device
|
||
# with a FQDN of `alpha.megabyte.space` will not be able to connect.
|
||
#
|
||
# ## Samba Shares / S3 Backup
|
||
#
|
||
# If CloudFlare R2 credentials are provided, Samba is configured to store its shared files in the Rclone mounts so that your
|
||
# Samba shares are synchronized to the S3 buckets. If not, new folders are created. Either way, the folder / symlink that the
|
||
# shares host data from are stored at `/mnt/Private` and `/mnt/Public` (*Note: Different paths are used on macOS*).
|
||
#
|
||
# 1. The **public** share (named "Public") can be accessed by anyone (including write permissions with the default settings)
|
||
# 2. The **private** share (named "Private") can be accessed by specifying the PAM credentials of anyone who has an account that is included in the `sambausers` group
|
||
#
|
||
# ## Symlinks
|
||
#
|
||
# Symlinks are disabled for security reasons. This is because, with symlinking enabled, people can create symlinks on the shares and use the symlinks to access system files outside of the
|
||
# Samba shares. There are commented-out lines in the default configuration that you can uncomment to enable the symlinks in shares.
|
||
#
|
||
# ## Printers
|
||
#
|
||
# Printer sharing is not enabled by default. There are commented lines in the default configuration that should provide a nice stepping
|
||
# stone if you want to use Samba for printer sharing (with CUPS).
|
||
#
|
||
# ## Environment Variables
|
||
#
|
||
# The following chart details some of the environment variables that are used to determine the configuration of the
|
||
# Samba shares:
|
||
#
|
||
# | Environment Variable | Description |
|
||
# |-----------------------------|-----------------------------------------------------------------------------------------------------|
|
||
# | `PUBLIC_SERVICES_DOMAIN` | Used to determine which hosts can connect to the Samba share (e.g. `.local.PUBLIC_SERVICES_DOMAIN`) |
|
||
# | `SAMBA_NETBIOS_NAME` | Determines the NetBIOS name (defaults to the `HOSTNAME` environment variable value) |
|
||
# | `SAMBA_WORKGROUP` | Controls Samba workgroup name (defaults to "BETELGEUSE") |
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Default Samba configuration](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_local/samba/config.tmpl)
|
||
# * [Secrets / Environment variables documentation](https://install.doctor/docs/customization/secrets)
|
||
|
||
### Configure Samba server
|
||
if command -v smbd > /dev/null; then
|
||
# Add user / group with script in ~/.local/bin/add-usergroup, if it is available
|
||
if command -v add-usergroup > /dev/null; then
|
||
sudo add-usergroup "$USER" rclone
|
||
fi
|
||
|
||
### Define share locations
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS does not have `/mnt` folder so use `/Volumes` location
|
||
MNT_FOLDER='Volumes'
|
||
else
|
||
MNT_FOLDER='mnt'
|
||
fi
|
||
PRIVATE_SHARE="/$MNT_FOLDER/Private"
|
||
PUBLIC_SHARE="/$MNT_FOLDER/Public"
|
||
|
||
logg info "Ensuring $PRIVATE_SHARE is created"
|
||
sudo mkdir -p "$PRIVATE_SHARE"
|
||
sudo chmod 750 "$PRIVATE_SHARE"
|
||
sudo chown -Rf root:rclone "$PRIVATE_SHARE"
|
||
|
||
logg info "Ensuring $PUBLIC_SHARE is created"
|
||
sudo mkdir -p "$PUBLIC_SHARE"
|
||
sudo chmod 755 "$PUBLIC_SHARE"
|
||
sudo chown -Rf root:rclone "$PUBLIC_SHARE"
|
||
|
||
logg info "Ensuring $HOME/Public is created"
|
||
mkdir -p "$HOME/Public"
|
||
chmod 755 "$HOME/Public"
|
||
chown -Rf "$USER":rclone "$HOME/Public"
|
||
|
||
### Copy the Samba server configuration file
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
sudo sharing -a "$PRIVATE_SHARE" -S "Private (System)" -n "Private (System)" -g 000 -s 001 -E 1 -R 1 && logg success "Configured $PRIVATE_SHARE as a private Samba share" || logg info 'sharing command failed - it is likely that the share was already set up'
|
||
sudo sharing -a "$PUBLIC_SHARE" -S "Public (System)" -n "Public (System)" -g 001 -s 001 -E 1 -R 0 && logg success "Configured $PUBLIC_SHARE as a public Samba share" || logg info 'sharing command failed - it is likely that the share was already set up'
|
||
sudo sharing -a "$HOME/Public" -S "Public (User)" -n "Public (User)" -g 001 -s 001 -E 1 -R 0 && logg success "Configured $HOME/Public as a public Samba share" || logg info 'sharing command failed - it is likely that the share was already set up'
|
||
else
|
||
logg info "Copying Samba server configuration to /etc/samba/smb.conf"
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/samba/config" "/etc/samba/smb.conf"
|
||
|
||
### Reload configuration file changes
|
||
logg info 'Reloading the smbd config'
|
||
smbcontrol smbd reload-config
|
||
fi
|
||
else
|
||
logg info "Samba server is not installed"
|
||
fi
|
||
_service: smbd
|
||
_service:dnf: smb
|
||
apt: samba
|
||
brew: samba
|
||
dnf: samba
|
||
pacman: samba
|
||
port: samba4
|
||
sanoid:
|
||
_bin: sanoid
|
||
_deps:
|
||
- pv
|
||
_desc: '[Sanoid](https://github.com/jimsalterjrs/sanoid/) is a free and open source snapshot management tool. Sanoid is a policy-driven snapshot management tool for ZFS filesystems. When combined with the Linux KVM hypervisor, you can use it to make your systems functionally immortal.'
|
||
_github: https://github.com/jimsalterjrs/sanoid/
|
||
_name: Sanoid
|
||
# Only install Sanoid when there are ZFS shares listed in the command `zfs list`
|
||
_when:linux: command -v zfs > /dev/null && ! zfs list
|
||
ansible:linux: professormanhattan.sanoid
|
||
apt:
|
||
- libcapture-tiny-perl
|
||
- libconfig-inifiles-perl
|
||
- libdata-dump-perl
|
||
# Unavailable on Ubuntu 22.04
|
||
# - mhash2
|
||
- sanoid
|
||
santa:
|
||
_bin: santactl
|
||
_desc: A binary authorization system for MacOS (santa) role is a daemon that makes execution decisions based on the contents of a local database, a GUI agent that notifies the user in case of a block decision and a command-line utility for managing the system and synchronizing the database with a server.
|
||
_docs: https://santa.dev/
|
||
_github: https://github.com/google/santa
|
||
_home: https://santa.dev/
|
||
_name: A binary authorization system for MacOS
|
||
cask: santa
|
||
sapling:
|
||
_bin: sl
|
||
_github: https://github.com/facebook/sapling
|
||
_name: Sapling
|
||
brew: sapling
|
||
pacman: sapling-scm-bin
|
||
script:windows: |
|
||
curl -sSL https://github.com/facebook/sapling/releases/latest > ~/Downloads/sapling_windows_0.2.20231113-145254+995db0d6_amd64.zip
|
||
Expand-Archive ~/Downloads/sapling_windows_0.2.20231113-145254+995db0d6_amd64.zip 'C:\Program Files'
|
||
setx PATH "$env:PATH;C:\Program Files\Sapling" -m
|
||
Set-Alias -Name sl -Value 'C:\Program Files\Sapling\sl.exe' -Force -Option Constant,ReadOnly,AllScope
|
||
scap-security-guide:
|
||
_bin: oscap
|
||
_github: https://github.com/ComplianceAsCode/content
|
||
_name: OpenSCAP
|
||
apt:
|
||
- ssg-debderived
|
||
- ssg-applications
|
||
apt:debian:
|
||
- ssg-debian
|
||
- ssg-applications
|
||
dnf: scap-security-guide
|
||
schema:
|
||
_bin: schema
|
||
_desc: A tool to infer and instantiate schemas and translate between data formats
|
||
_github: https://github.com/Confbase/schema
|
||
_name: schema
|
||
go: github.com/Confbase/schema@latest
|
||
scrcpy:
|
||
_bin: scrcpy
|
||
_desc: '[scrcpy](https://github.com/Genymobile/scrcpy) is a free and open-source application that provides display of Android devices connected on USB (or over TCP/IP). It also allows you to control the Android device. It does not require any root access.'
|
||
_github: https://github.com/Genymobile/scrcpy
|
||
_name: scrcpy
|
||
ansible: professormanhattan.scrcpy
|
||
apt: scrcpy
|
||
brew: scrcpy
|
||
choco: scrcpy
|
||
dnf: scrcpy
|
||
github: github.com/Genymobile/scrcpy
|
||
pkg: scrcpy
|
||
snap: scrcpy
|
||
yay: scrcpy
|
||
scrcpy-gui:
|
||
_bin: scrcpy-gui
|
||
_desc: A simple & beautiful GUI application for scrcpy
|
||
_github: https://github.com/Tomotoes/scrcpy-gui
|
||
_name: Scrcpy GUI
|
||
flatpak: in.srev.guiscrcpy
|
||
sd:
|
||
_bin: sd
|
||
_desc: Intuitive find & replace CLI (sed alternative)
|
||
_github: https://github.com/chmln/sd
|
||
_name: sd
|
||
apk: sd
|
||
brew: sd
|
||
cargo: sd
|
||
choco: sd-cli
|
||
dnf:fedora: sd
|
||
github: github.com/chmln/sd
|
||
pacman: sd
|
||
pkg: sd
|
||
sddm:
|
||
_bin: sddm
|
||
_github: https://github.com/sddm/sddm
|
||
_name: SDDM
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo systemctl set-default graphical.target
|
||
_service: sddm
|
||
apt: sddm
|
||
dnf: sddm
|
||
pacman: sddm
|
||
zypper: sddm
|
||
sdkman-cli:
|
||
_bin: sdk
|
||
_github: https://github.com/sdkman/sdkman-cli
|
||
_name: SDKMan
|
||
script: |
|
||
#!/usr/bin/env bash
|
||
# @file SDKMAN Install
|
||
# @brief Ensures SDKMAN is installed.
|
||
# @description
|
||
# This script ensures SDKMAN (a Java version manager) is installed using the method recommended on [their
|
||
# website](https://sdkman.io/).
|
||
|
||
### Re-source ~/.bashrc
|
||
if [ -z "$SDKMAN_DIR" ]; then
|
||
logg info 'SDKMAN_DIR is undefined so ~/.bashrc is being re-sourced' && source ~/.bashrc
|
||
fi
|
||
|
||
### SDKMan ~/.bashrc settings
|
||
if command -v brew > /dev/null && command -v sdkman-cli > /dev/null; then
|
||
export SDKMAN_DIR="$(brew --prefix sdkman-cli)/libexec"
|
||
. "$SDKMAN_DIR/bin/sdkman-init.sh"
|
||
elif [ -d "${XDG_DATA_HOME:-$HOME/.local/share}/sdkman" ]; then
|
||
export SDKMAN_DIR="${XDG_DATA_HOME:-$HOME/.local/share}/sdkman"
|
||
. "$SDKMAN_DIR/bin/sdkman-init.sh"
|
||
else
|
||
logg logg 'Unable to find SDKMAN instance'
|
||
fi
|
||
|
||
### Ensure SDKMan is installed (https://sdkman.io/)
|
||
if [ ! -d "$SDKMAN_DIR" ]; then
|
||
logg info 'Installing SDKMan via curl -s https://get.sdkman.io?rcupdate=false'
|
||
logg info "Install directory: $SDKMAN_DIR"
|
||
curl -s "https://get.sdkman.io?rcupdate=false" | bash
|
||
if [ -f "$SDKMAN_DIR/bin/sdkman-init.sh" ]; then
|
||
. "$SDKMAN_DIR/bin/sdkman-init.sh"
|
||
logg info 'Running sdk install java' && sdk install java
|
||
else
|
||
logg warn 'SDKMAN_DIR/bin/sdkman-init.sh is missing'
|
||
fi
|
||
else
|
||
logg info 'SDKMan appears to already be installed.'
|
||
logg info 'Running sdk update'
|
||
if command -v sdk > /dev/null; then
|
||
sdk update
|
||
else
|
||
logg warn 'Unable to run sdk update because the sdk command is unavailable'
|
||
fi
|
||
fi
|
||
seafile-client:
|
||
_app: Seafile Client.app
|
||
_github: https://github.com/haiwen/seafile-client
|
||
_bin: seafile-client
|
||
_todo: Look into integration of the full Seafile stack outlined [here](https://github.com/haiwen/seafile)
|
||
cask: seafile-client
|
||
choco: seafile-client
|
||
flatpak: com.seafile.Client
|
||
search-gpt:
|
||
_bin: searchgpt
|
||
_github: https://github.com/tobiasbueschel/search-gpt
|
||
_name: Search GPT
|
||
npm: search-gpt
|
||
secretive:
|
||
_app: Secretive.app
|
||
_bin: null
|
||
_desc: Store SSH keys in the Secure Enclave
|
||
_github: https://github.com/maxgoedjen/secretive
|
||
cask: secretive
|
||
security:
|
||
_bin: null
|
||
_github: false
|
||
_desc: This role turns on auto-updates and configures sudo, for instance.
|
||
_name: Security
|
||
ansible: professormanhattan.security
|
||
semantic-release:
|
||
_bin: semantic-release
|
||
_desc: '[semantic-release](https://semantic-release.gitbook.io) automates the whole package release workflow including: determining the next version number, generating the release notes, and publishing the package'
|
||
_docs: https://semantic-release.gitbook.io
|
||
_github: https://github.com/semantic-release/semantic-release
|
||
_home: https://semantic-release.gitbook.io
|
||
_name: semantic-release
|
||
npm: semantic-release
|
||
sentry-cli:
|
||
_bin: sentry-cli
|
||
_desc: sentry-cli can connect to the Sentry API and manage some data for your projects
|
||
_github: https://github.com/getsentry/sentry-cli/
|
||
_name: sentry-cli
|
||
brew:darwin: getsentry/tools/sentry-cli
|
||
github: github.com/getsentry/sentry-cli
|
||
npm: '@sentry/cli'
|
||
scoop: sentry-cli
|
||
yay: sentry-cli-bin
|
||
serve:
|
||
_bin: serve
|
||
_desc: serve helps you serve a static site, single page application or just a static file (no matter if on your device or on the local network). It also provides a neat interface for listing the directory's contents
|
||
_github: https://github.com/vercel/serve
|
||
_name: serve
|
||
npm: serve
|
||
serverless:
|
||
_bin: serverless
|
||
_github: https://github.com/serverless/serverless
|
||
_desc: Build applications with serverless architectures
|
||
_docs: https://www.serverless.com/framework/docs
|
||
_home: https://www.serverless.com/
|
||
_name: serverless
|
||
brew: serverless
|
||
npm: serverless
|
||
sftpgo:
|
||
_bin: sftpgo
|
||
_deps:
|
||
- sftpgo-plugin-auth
|
||
_desc: Fully featured and highly configurable SFTP server with optional HTTP/S, FTP/S and WebDAV support - S3, Google Cloud Storage, Azure Blob
|
||
_github: https://github.com/drakkan/sftpgo
|
||
_name: sftpgo
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo mkdir -p /usr/local/etc/sftpgo
|
||
sudo cp -f "$HOME/.local/etc/sftpgo/sftpgo.json" /usr/local/etc/sftpgo/sftpgo.json
|
||
sudo cp -f "$HOME/.local/etc/sftpgo/banner" /usr/local/etc/sftpgo/banner
|
||
sudo mkdir -p /usr/local/etc/branding
|
||
sudo cp -f "$HOME/.local/etc/branding/favicon.ico" /usr/local/etc/branding/favicon.ico
|
||
sudo cp -f "$HOME/.local/etc/branding/logo-color-256x256.png" /usr/local/etc/branding/logo-color-256x256.png
|
||
sudo cp -f "$HOME/.local/etc/branding/logo-color-900x900.png" /usr/local/etc/branding/logo-color-900x900.png
|
||
sudo sftpgo initprovider
|
||
_service: sftpgo
|
||
_service:brew:
|
||
- name: sftpgo
|
||
sudo: true
|
||
_serviceEnabled: true
|
||
brew: sftpgo
|
||
choco: sftpgo
|
||
github: github.com/drakkan/sftpgo
|
||
pkg: sftpgo
|
||
yay: sftpgo-bin
|
||
sftpgo-plugin-auth:
|
||
_bin: sftpgo-plugin-auth
|
||
_desc: A plugin for SFTPGo to enable LDAP/Active Directory authentication
|
||
_github: https://github.com/sftpgo/sftpgo-plugin-auth
|
||
_name: SFTPGo Authentication Plugin
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo mv -f $(which sftpgo-plugin-auth) /usr/local/bin/sftpgo-plugin-auth
|
||
go: github.com/sftpgo/sftpgo-plugin-auth@latest
|
||
share:
|
||
_bin: share
|
||
_desc: Quickly share files from your command line
|
||
_github: https://github.com/marionebl/share-cli
|
||
_name: share
|
||
npm: share-cli
|
||
sharex:
|
||
_bin: null
|
||
_desc: '[ShareX](https://getsharex.com/) is a free and open source program that lets you capture or record any area of your screen and share it with a single press of a key. It also allows uploading images, text or other types of files to many supported destinations you can choose from.'
|
||
_docs: https://getsharex.com/docs/faq
|
||
_github: https://github.com/ShareX/ShareX
|
||
_home: https://getsharex.com/
|
||
_name: ShareX
|
||
ansible:windows: professormanhattan.sharex
|
||
choco: sharex
|
||
sharp:
|
||
_bin: sharp
|
||
_desc: CLI for sharp (a Node.js image processing module)
|
||
_github: https://github.com/vseventer/sharp-cli
|
||
_name: sharp
|
||
npm: sharp-cli
|
||
shc:
|
||
_bin: shc
|
||
_desc: Shell script compiler
|
||
_docs: https://github.com/neurobin/shc
|
||
_github: https://github.com/neurobin/shc
|
||
_home: https://neurobin.org/projects/softwares/unix/shc/
|
||
_name: shc
|
||
ansible:darwin: professormanhattan.shc
|
||
ansible:linux: professormanhattan.shc
|
||
brew: shc
|
||
port: shc
|
||
shdoc:
|
||
_bin: shdoc
|
||
_deps:script:
|
||
- gawk
|
||
_desc: '[shdoc](https://github.com/reconquest/shdoc) is a tool to generate Documentation for shell scripts (bash, sh, zsh)'
|
||
_github: https://github.com/reconquest/shdoc
|
||
_name: shdoc
|
||
ansible:darwin: professormanhattan.shdoc
|
||
ansible:linux: professormanhattan.shdoc
|
||
script:darwin: cd /tmp && git clone --recursive https://github.com/reconquest/shdoc && cd shdoc && sudo make install && cd /tmp && sudo rm -rf shdoc
|
||
script:linux: cd /tmp && git clone --recursive https://github.com/reconquest/shdoc && cd shdoc && sudo make install && cd /tmp && sudo rm -rf shdoc
|
||
yay: shdoc-git
|
||
sheldon:
|
||
_bin: sheldon
|
||
_completions: sheldon completions --shell {SHELL}
|
||
_github: https://github.com/rossmacarthur/sheldon
|
||
_name: Sheldon
|
||
brew: sheldon
|
||
cargo: sheldon
|
||
shell-gpt:
|
||
_bin: sgpt
|
||
_github: https://github.com/TheR1D/shell_gpt
|
||
_name: Shell GPT
|
||
pipx: shell-gpt
|
||
shellcheck:
|
||
_bin: shellcheck
|
||
_desc: A static analysis tool for shell scripts
|
||
_docker: docker run --rm -v "$PWD:/mnt" koalaman/shellcheck:stable
|
||
_docs: https://github.com/koalaman/shellcheck/wiki/Directive
|
||
_github: https://github.com/koalaman/shellcheck
|
||
_home: https://www.shellcheck.net/
|
||
_name: Shellcheck
|
||
apt: shellcheck
|
||
brew: shellcheck
|
||
cabal: shellcheck
|
||
choco: shellcheck
|
||
dnf: shellcheck
|
||
emerge: shellcheck
|
||
eopkg: shellcheck
|
||
nix: nixpkgs.shellcheck
|
||
pacman: shellcheck
|
||
pkg-freebsd: shellcheck
|
||
pkg_add: shellcheck
|
||
port: shellcheck
|
||
scoop: shellcheck
|
||
snap: shellcheck
|
||
stack: shellcheck
|
||
zypper: shellcheck
|
||
shfmt:
|
||
_bin: shfmt
|
||
_desc: '[shfmt](https://github.com/mvdan/sh) is a shell parser, formatter, and interpreter with bash support that is written with [Go](https://gitlab.com/megabyte-labs/ansible-roles/go).'
|
||
_github: https://github.com/mvdan/sh
|
||
_home: https://pkg.go.dev/mvdan.cc/sh/v3
|
||
_name: shfmt
|
||
ansible: professormanhattan.shfmt
|
||
apk: shfmt
|
||
brew: shfmt
|
||
github: github.com/mvdan/sh
|
||
go: mvdan.cc/sh/v3/cmd/shfmt@latest
|
||
pacman: shfmt
|
||
pkg: shfmt
|
||
scoop: shfmt
|
||
snap: shfmt
|
||
shml:
|
||
_bin: shml
|
||
_github: https://github.com/odb/shml
|
||
_name: SHML
|
||
brew: shml
|
||
npm: shml
|
||
shotcut:
|
||
_app: Shotcut.app
|
||
_bin: shotcut
|
||
_desc: '[Shotcut](https://shotcut.org/) is a free and open-source cross-platform video editing application for FreeBSD, Linux, macOS and Windows. Started in 2011 by Dan Dennedy, Shotcut is developed on the MLT Multimedia Framework, in development since 2004 by the same author.'
|
||
_docs: https://shotcut.org/howtos/getting-started/
|
||
_github: https://github.com/mltframework/shotcut
|
||
_home: https://shotcut.org/
|
||
_name: Shotcut
|
||
ansible: professormanhattan.shotcut
|
||
apt: shotcut
|
||
cask: shotcut
|
||
choco: shotcut
|
||
dnf: shotcut
|
||
flatpak: org.shotcut.Shotcut
|
||
snap: shotcut --classic
|
||
shotwell:
|
||
_bin: shotwell
|
||
_desc: '[Shotwell](https://shotwell-project.org/doc/html/) is an image organizer designed to provide personal photo management for the GNOME desktop environment. In 2010, it replaced F-Spot as the standard image tool for several GNOME-based Linux distributions, including Fedora in version 13 and Ubuntu in its 10.10 Maverick Meerkat release.'
|
||
_docs: http://shotwell-project.org/doc/html/
|
||
_github: https://github.com/GNOME/shotwell
|
||
_home: https://wiki.gnome.org/Apps/Shotwell
|
||
_name: Shotwell
|
||
ansible:linux: professormanhattan.shotwell
|
||
apt: shotwell
|
||
dnf: shotwell
|
||
flatpak: org.gnome.Shotwell
|
||
pacman: shotwell
|
||
shuttle:
|
||
_bin: cargo-shuttle
|
||
_github: https://github.com/shuttle-hq/shuttle
|
||
_name: Shuttle
|
||
cargo: cargo-shuttle
|
||
pacman: cargo-shuttle
|
||
script: curl -sSfL https://www.shuttle.rs/install | bash
|
||
shx:
|
||
_bin: shx
|
||
_github: https://github.com/shelljs/shx
|
||
_name: shx
|
||
npm: shx
|
||
sidekick:
|
||
_app: Sidekick.app
|
||
_bin: sidekick
|
||
_github: false
|
||
_name: Sidekick
|
||
cask: pushplaylabs-sidekick
|
||
signal:
|
||
_app: Signal.app
|
||
_bin: signal
|
||
_desc: Signal is a cross-platform centralized encrypted instant messaging service developed by the non-profit Signal Foundation and its subsidiary, the Signal Messenger LLC. Users can send one-to-one and group messages, which can include files, voice notes, images, and videos.
|
||
_docs: https://support.signal.org/hc/en-us
|
||
_github: https://github.com/signalapp/Signal-Desktop
|
||
_home: https://signal.org
|
||
_name: Signal Desktop
|
||
cask: signal
|
||
choco: signal
|
||
flatpak: org.signal.Signal
|
||
scoop: signal
|
||
skaffold:
|
||
_bin: skaffold
|
||
_github: https://github.com/GoogleContainerTools/skaffold
|
||
_name: Skaffold
|
||
brew: skaffold
|
||
choco: skaffold
|
||
port: skaffold
|
||
scoop: extras/skaffold
|
||
skate:
|
||
_bin: skate
|
||
_desc: Skate is a personal key-value store. Use it to save and retrieve anything you’d like—even binary data. It’s fully encrypted, backed up to the cloud (that you can self-host if you want) and can be synced with all your machines
|
||
_github: https://github.com/charmbracelet/skate
|
||
_name: skate
|
||
brew: charmbracelet/tap/skate
|
||
go: github.com/charmbracelet/skate@latest
|
||
nix: nixpkgs.skate
|
||
pacman: skate
|
||
skhd:
|
||
_bin: skhd
|
||
_desc: Keyboard shortcut daemon for macOS
|
||
_docs: https://github.com/koekeishiya/skhd/issues/1
|
||
_github: https://github.com/koekeishiya/skhd
|
||
_home: https://github.com/koekeishiya/skhd
|
||
_name: skhd
|
||
_post:brew: |
|
||
#!/usr/bin/env bash
|
||
skhd --start-service
|
||
brew:darwin: koekeishiya/formulae/skhd
|
||
skm:
|
||
_bin: skm
|
||
_desc: A simple and powerful SSH keys manager
|
||
_github: https://github.com/TimothyYe/skm
|
||
_name: skm
|
||
github: github.com/TimothyYe/skm
|
||
go: github.com/TimothyYe/skm/cmd/skm@latest
|
||
skype:
|
||
_app: Skype.app
|
||
_bin: skype
|
||
_desc: '[Skype](https://www.skype.com/en/) is a proprietary telecommunications application that specializes in providing video chat and voice calls between computers, tablets, mobile devices, the Xbox One console, and smartwatches over the Internet. Skype also provides instant messaging services. Users may transmit text, video, audio and images.'
|
||
_description: Skype is for connecting with the people that matter most in your life and work
|
||
_docs: https://docs.microsoft.com/en-us/skype-sdk/skypeuris/skypeuriapireference
|
||
_github: Not open-source
|
||
_home: https://www.skype.com/en/
|
||
_name: Skype
|
||
ansible: professormanhattan.skype
|
||
cask: skype
|
||
choco: skype
|
||
flatpak: com.skype.Client
|
||
snap: skype
|
||
yay: skypeforlinux-stable-bin
|
||
slack:
|
||
_app: Slack.app
|
||
_bin: slack
|
||
_desc: '[Slack](https://slack.com/) is a proprietary business communication platform developed by American software company Slack Technologies. Slack offers many IRC-style features, including persistent chat rooms organized by topic, private groups, and direct messaging.'
|
||
_docs: https://api.slack.com/docs
|
||
_github: https://github.com/slackhq/SlackTextViewController
|
||
_home: https://slack.com/
|
||
_name: Slack
|
||
ansible: professormanhattan.slack
|
||
cask: slack
|
||
choco: slack
|
||
flatpak: com.slack.Slack
|
||
mas: 803453959
|
||
snap: slack
|
||
slack-term:
|
||
_bin: slack-term
|
||
_desc: '[slack-term](https://github.com/erroneousboat/slack-term) features a colorful interface as well as keyboard shortcuts. It is one of, if not the, most well-received [Slack](https://slack.com/) client available on GitHub.'
|
||
_github: https://github.com/erroneousboat/slack-term
|
||
_name: slack-term
|
||
ansible: professormanhattan.slackterm
|
||
go: github.com/erroneousboat/slack-term@latest
|
||
slides:
|
||
_bin: slides
|
||
_desc: A terminal application that allows you to present slides rendered from markdown
|
||
_docs: https://github.com/maaslalani/slides
|
||
_github: https://github.com/maaslalani/slides
|
||
_home: https://maaslalani.com/slides/
|
||
_name: Slides
|
||
brew: slides
|
||
go: github.com/maaslalani/slides@latest
|
||
nix-env: nixpkgs.slides
|
||
snap: slides
|
||
yay: slides
|
||
sloth:
|
||
_app: Sloth.app
|
||
_bin: null
|
||
_desc: Mac app that shows all open files, directories, sockets, pipes and devices in use by all running processes. Nice GUI for lsof.
|
||
_docs: https://github.com/sveinbjornt/Sloth
|
||
_github: https://github.com/sveinbjornt/Sloth
|
||
_home: https://sveinbjorn.org/sloth
|
||
_name: Sloth
|
||
cask: sloth
|
||
snapcraft:
|
||
_bin: snapcraft
|
||
_github: https://github.com/canonical/snapcraft
|
||
_deps:
|
||
- snapd
|
||
_name: Snapcraft
|
||
brew: snapcraft
|
||
snap: snapcraft --classic
|
||
snapd:
|
||
_bin: snap
|
||
_github: https://github.com/snapcore/snapd
|
||
_desc: '[Snap](https://snapcraft.io/) is a software packaging and deployment system developed by Canonical for operating systems that use the Linux kernel. The packages, called snaps, and the tool for using them, snapd, work across a range of Linux distributions and allow upstream software developers to distribute their applications directly to users. Snaps are self-contained applications running in a sandbox with mediated access to the host system.'
|
||
_home: https://snapcraft.io/
|
||
_name: Snap
|
||
# ansible:linux: professormanhattan.snapd
|
||
_service: snapd
|
||
snitch:
|
||
_app: Little Snitch.app
|
||
# Used for OpenSnitch, which is "temporarily" disabled until it works as expected
|
||
# _bin: opensnitchd
|
||
_desc: '[Little Snitch](https://www.obdev.at/products/littlesnitch/index.html) (macOS) and [OpenSnitch](https://github.com/evilsocket/opensnitch) (Linux) are application firewalls that make Internet connections visible. You can then configure which applications can access the internet (or LAN) as well as monitor the traffic patterns of applications.'
|
||
_docs: https://www.obdev.at/products/littlesnitch/getting-started.html
|
||
_github: https://github.com/evilsocket/opensnitch
|
||
_home: https://www.obdev.at/products/littlesnitch/index.html
|
||
_name: OpenSnitch/Little Snitch
|
||
# Not loading on Ubuntu 22.04
|
||
# ansible: professormanhattan.snitch
|
||
cask: little-snitch
|
||
social-analyzer:
|
||
_bin: social-analyzer
|
||
_desc: API, CLI, and Web App for analyzing and finding a person's profile in 1000 social media \ websites
|
||
_github: https://github.com/qeeqbox/social-analyzer
|
||
_name: social-analyzer
|
||
pipx: social-analyzer
|
||
soduto:
|
||
_app: Soduto.app
|
||
_github: https://github.com/soduto/Soduto
|
||
_name: Soduto
|
||
cask: soduto
|
||
soft-serve:
|
||
_bin: soft
|
||
_desc: A tasty, self-hostable Git server for the command line
|
||
_docs: https://github.com/charmbracelet/soft-serve
|
||
_github: https://github.com/charmbracelet/soft-serve
|
||
_home: https://charm.sh/
|
||
_name: Soft Serve
|
||
brew: charmbracelet/tap/soft-serve
|
||
go: github.com/charmbracelet/soft-serve/cmd/soft@latest
|
||
nix-env: nixpkgs.soft-serve
|
||
pacman: soft-serve
|
||
solargraph:
|
||
_bin: solargraph
|
||
_desc: Ruby language server
|
||
_docs: https://solargraph.org/guides/getting-started
|
||
_github: https://github.com/castwide/solargraph
|
||
_home: https://solargraph.org/
|
||
_name: Solargraph
|
||
brew: solargraph
|
||
gem: solargraph
|
||
solidity:
|
||
_bin: solcjs
|
||
_desc: Javascript bindings for the Solidity compiler
|
||
_github: https://github.com/ethereum/solc-js
|
||
_name: solcjs
|
||
npm: solc
|
||
sparkleshare:
|
||
_app: SparkleShare.app
|
||
_bin: sparkleshare
|
||
_github: https://github.com/hbons/SparkleShare
|
||
_name: Sparkle Share
|
||
cask: sparkleshare
|
||
choco: sparkleshare
|
||
flatpak: org.sparkleshare.SparkleShare
|
||
speed-test:
|
||
_bin: speed-test
|
||
_desc: Test your internet connection speed and ping using speedtest.net from the CLI
|
||
_github: https://github.com/sindresorhus/speed-test
|
||
_name: speed-test
|
||
npm: speed-test
|
||
speedtest-cli:
|
||
_bin: speedtest-cli
|
||
_desc: Command line interface for testing internet bandwidth using speedtest.net
|
||
_github: https://github.com/sivel/speedtest-cli
|
||
_name: speedtest-cli
|
||
pipx: speedtest-cli
|
||
sphinx:
|
||
_bin: sphinx-build
|
||
_github: https://github.com/sphinx-doc/sphinx
|
||
_name: Sphinx
|
||
apt: python3-sphinx
|
||
choco: sphinx
|
||
dnf: python-sphinx
|
||
pipx: sphinx
|
||
spotdl:
|
||
_bin: spotdl
|
||
_deps:
|
||
- ffmpeg
|
||
_desc: Download your Spotify playlists and songs along with album art and metadata
|
||
_docs: https://spotdl.readthedocs.io/en/latest/
|
||
_github: https://github.com/spotDL/spotify-downloader
|
||
_name: spotdl
|
||
pipx: spotdl
|
||
sql-language-server:
|
||
_bin: sql-language-server
|
||
_desc: An SQL language server
|
||
_docs: https://github.com/joe-re/sql-language-server
|
||
_github: https://github.com/joe-re/sql-language-server
|
||
_home: https://github.com/joe-re/sql-language-server
|
||
_name: SQL Language Server
|
||
brew: sql-language-server
|
||
npm: sql-language-server
|
||
sqlectron:
|
||
_app: sqlectron.app
|
||
_bin: null
|
||
_desc: A simple and lightweight SQL client desktop with cross database and platform support
|
||
_github: https://github.com/sqlectron/sqlectron-gui
|
||
_name: SQLectron
|
||
cask: sqlectron
|
||
github: github.com/sqlectron/sqlectron-gui
|
||
yay: sqlectron-gui
|
||
sqlite:
|
||
_bin: sqlite3
|
||
_desc: SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine.
|
||
_docs: https://sqlite.org/docs.html
|
||
_github: https://github.com/sqlite/sqlite
|
||
_home: https://sqlite.org/index.html
|
||
_name: SQLite
|
||
apt: sqlite3
|
||
brew: sqlite
|
||
choco: sqlite
|
||
dnf: sqlite
|
||
pacman: sqlite
|
||
port: sqlite3
|
||
scoop: sqlite
|
||
squid:
|
||
_bin: squid
|
||
_github: https://github.com/squid-cache/squid
|
||
_name: Squid
|
||
_preload: true
|
||
_service: squid
|
||
apt: squid
|
||
brew: squid
|
||
dnf: squid
|
||
pacman: squid
|
||
ssh:
|
||
_bin: null
|
||
_github: false
|
||
_desc: On top of tightening up SSH security settings, this role also installs fail2ban on Linux systems. If provided, the role will also populate all your SSH keys and set their permissions appropriately
|
||
_name: SSH
|
||
ansible: professormanhattan.ssh
|
||
ssh-vault:
|
||
_bin: ssh-vault
|
||
_desc: '[sshvault](https://ssh-vault.com/) lets you encrypt/decrypt using SSH private keys. It is written in Go and the documentation can be read in under a minute.'
|
||
_docs: https://ssh-vault.com/post/how-it-works/
|
||
_github: https://github.com/ssh-vault/ssh-vault
|
||
_home: https://ssh-vault.com/
|
||
_name: ssh-vault
|
||
ansible: professormanhattan.sshvault
|
||
brew: ssh-vault
|
||
github: github.com/ssh-vault/ssh-vault
|
||
sshfs:
|
||
_bin: sshfs
|
||
_name: SSHFS
|
||
_github: https://github.com/libfuse/sshfs
|
||
apt: sshfs
|
||
brew:linux: sshfs
|
||
choco: sshfs
|
||
dnf: sshfs
|
||
pacman: sshfs
|
||
port: sshfs
|
||
scoop: sshfs-np
|
||
sshpass:
|
||
_bin: sshpass
|
||
_github: https://github.com/kevinburke/sshpass
|
||
_desc: SSHPass is a tool for non-interactivly performing password authentication with SSH's so called "interactive keyboard password authentication". Most user should use SSH's more secure public key authentiaction instead.
|
||
_home: https://sourceforge.net/projects/sshpass/
|
||
_name: sshpass
|
||
apt: sshpass
|
||
brew: hudochenkov/sshpass/sshpass
|
||
dnf: sshpass
|
||
sshs:
|
||
_bin: sshs
|
||
_github: https://github.com/quantumsheep/sshs
|
||
_name: SSHS
|
||
brew: sshs
|
||
choco: sshs
|
||
sshuttle:
|
||
_bin: sshuttle
|
||
_github: https://github.com/sshuttle/sshuttle
|
||
_name: SShuttle
|
||
apt: sshuttle
|
||
brew: sshuttle
|
||
dnf: sshuttle
|
||
emerge: net-proxy/sshuttle
|
||
nix-env: nixos.sshuttle
|
||
nix-pkg: nixpkgs.sshuttle
|
||
pacman: sshuttle
|
||
pipx: sshuttle
|
||
port: sshuttle
|
||
zypper: sshuttle
|
||
ssl-proxy:
|
||
_bin: ssl-proxy
|
||
_desc: Simple zero-config SSL reverse proxy with real autogenerated certificates
|
||
_github: https://github.com/suyashkumar/ssl-proxy
|
||
_name: ssl-proxy
|
||
go: github.com/suyashkumar/ssl-proxy@latest
|
||
stacer:
|
||
_bin: stacer
|
||
_desc: Popular desktop GUI for monitoring and cleaning Linux systems.
|
||
_docs: https://github.com/oguzhaninan/Stacer/blob/native/README.md
|
||
_github: https://github.com/oguzhaninan/Stacer
|
||
_home: https://oguzhaninan.github.io/Stacer-Web/
|
||
_name: Stacer
|
||
appimage: https://github.com/oguzhaninan/Stacer/releases/download/v1.1.0/Stacer-1.1.0-x64.AppImage
|
||
apt: https://github.com/oguzhaninan/Stacer/releases/download/v1.1.0/stacer_1.1.0_amd64.deb
|
||
apt:debian: stacer
|
||
apt:ubuntu: stacer
|
||
dnf: https://github.com/oguzhaninan/Stacer/releases/download/v1.1.0/stacer-1.1.0-amd64.rpm
|
||
dnf:fedora: stacer
|
||
yay: stacer
|
||
standard-notes:
|
||
_app: Standard Notes.app
|
||
_bin: standard-notes
|
||
_desc: End-to-end encrypted notes app
|
||
_docs: https://standardnotes.com/help
|
||
_github: https://github.com/standardnotes/app
|
||
_home: https://standardnotes.com/
|
||
_name: Standard Notes
|
||
cask: standard-notes
|
||
flatpak: org.standardnotes.standardnotes
|
||
starred:
|
||
_bin: starred
|
||
_desc: Creates your own Awesome List sorted by GitHub stars by using the GitHub API
|
||
_docs: https://github.com/maguowei/starred
|
||
_github: https://github.com/maguowei/starred
|
||
_home: https://pypi.org/project/starred/
|
||
_name: Starred
|
||
pipx: starred
|
||
starship:
|
||
_bin: null
|
||
_github: https://github.com/starship/starship
|
||
_desc: '[Starship](https://starship.rs/) is the minimal, blazing fast, and extremely customizable prompt for any shell! It shows the information you need, while staying sleek and minimal. Unlike most other prompts, it is compatible with nearly every type of terminal. If you want to retain the same look and feel across different terminals, then look no further.'
|
||
_name: Starship
|
||
ansible: professormanhattan.starship
|
||
statcode:
|
||
_bin: statcode
|
||
_docs: Man pages for HTTP status codes
|
||
_github: https://github.com/shobrook/statcode
|
||
pipx: statcode
|
||
yay: statcode
|
||
staticcheck:
|
||
_bin: staticcheck
|
||
_desc: State of the art linter for the Go programming language
|
||
_docs: https://staticcheck.io/docs/
|
||
_github: https://github.com/dominikh/go-tools
|
||
_home: https://staticcheck.io/
|
||
_name: staticcheck
|
||
brew: staticcheck
|
||
dnf:fedora: golang-honnef-tools
|
||
go: honnef.co/go/tools/cmd/staticcheck@latest
|
||
pacman: staticcheck
|
||
port: staticcheck
|
||
scoop: staticcheck
|
||
stats:
|
||
_app: Stats.app
|
||
_bin: null
|
||
_desc: System monitor for the menu bar
|
||
_github: https://github.com/exelban/stats
|
||
_name: stats
|
||
_service: null
|
||
cask: stats
|
||
steam:
|
||
_app: Steam.app
|
||
_bin: steam
|
||
_github: false
|
||
_name: steam
|
||
cask: steam
|
||
choco: steam
|
||
flatpak: com.valvesoftware.Steam
|
||
steampipe:
|
||
_bin: steampipe
|
||
_github: https://github.com/turbot/steampipe
|
||
_name: Steampipe
|
||
brew: turbot/tap/steampipe
|
||
stegcloak:
|
||
_bin: stegcloak
|
||
_desc: StegCloak is a pure JavaScript steganography module designed in functional programming style, to hide secrets inside text by compressing and encrypting the secret before cloaking it with special unicode invisible characters
|
||
_github: https://github.com/KuroLabs/stegcloak
|
||
_home: https://stegcloak.surge.sh/
|
||
_name: stegcloak
|
||
npm: stegcloak
|
||
storybook:
|
||
_bin: storybook
|
||
_github: https://github.com/storybookjs/storybook
|
||
_name: Storybook
|
||
npm: storybook
|
||
sttr:
|
||
_bin: sttr
|
||
_desc: Cross-platform, CLI app to perform various operations on string
|
||
_docs: https://github.com/abhimanyu003/sttr
|
||
_github: https://github.com/abhimanyu003/sttr
|
||
_home: https://github.com/abhimanyu003/sttr
|
||
_name: sttr
|
||
brew: abhimanyu003/sttr/sttr
|
||
go: github.com/abhimanyu003/sttr@latest
|
||
snap: sttr
|
||
yay: sttr-bin
|
||
stubby:
|
||
_bin: stubby
|
||
_github: https://github.com/getdnsapi/stubby
|
||
_desc: DNS privacy enabled stub resolver service based on getdns
|
||
_docs: https://dnsprivacy.org/wiki/display/DP/DNS+Privacy+Daemon+-+Stubby
|
||
_name: Stubby
|
||
_post:brew:darwin: |
|
||
#!/usr/bin/env bash
|
||
bash "$(brew --prefix stubby)/sbin/stubby-setdns-macos.sh"
|
||
_service: stubby
|
||
brew:darwin: stubby
|
||
supervisor:
|
||
_bin: supervisord
|
||
_github: https://github.com/Supervisor/supervisor
|
||
_name: Supervisor
|
||
_service: supervisor
|
||
apt: supervisor
|
||
brew: supervisor
|
||
dnf: supervisor
|
||
pacman: supervisor
|
||
pipx: supervisor
|
||
zypper: supervisor
|
||
surge:
|
||
_bin: surge
|
||
_desc: CLI for the surge.sh CDN
|
||
_github: https://github.com/sintaxi/surge
|
||
_name: surge
|
||
npm: surge
|
||
svgo:
|
||
_bin: svgo
|
||
_desc: SVG Optimizer is a Node.js-based tool for optimizing SVG vector graphics files.
|
||
_github: https://github.com/svg/svgo
|
||
_name: svgo
|
||
brew: svgo
|
||
npm: svgo
|
||
swarm:
|
||
_bin: null
|
||
_desc: Docker Swarm is an orchestration management tool that runs Docker applications. It helps in creating and deploying a cluster of Docker nodes
|
||
_docs: https://docs.docker.com/engine/swarm/
|
||
_github: https://github.com/moby/swarmkit
|
||
_name: Docker Swarm
|
||
ansible: professormanhattan.swarm
|
||
swiftbar:
|
||
_app: SwiftBar.app
|
||
_github: https://github.com/swiftbar/SwiftBar
|
||
_name: SwiftBar
|
||
cask: swiftbar
|
||
swiftformat:
|
||
_bin: swiftformat
|
||
_github: https://github.com/nicklockwood/SwiftFormat
|
||
_name: SwiftFormat
|
||
brew: swiftformat
|
||
swifty:
|
||
_app: Swifty.app
|
||
_bin: swifty
|
||
_github: https://github.com/swiftyapp/swifty
|
||
_name: Swifty
|
||
appimage: swiftyapp/swifty
|
||
cask: swifty
|
||
exe: https://github.com/swiftyapp/swifty/releases/download/v0.6.13/Swifty-Setup-0.6.13.exe
|
||
swimat:
|
||
_app: Swimat.app
|
||
_bin: null
|
||
_desc: Swift code auto-formatter for Xcode
|
||
_docs: https://jintin.github.io/Swimat/
|
||
_github: https://github.com/Jintin/Swimat
|
||
_home: https://jintin.github.io/Swimat/
|
||
_name: Swimat
|
||
cask: swimat
|
||
switchhosts:
|
||
_app: SwitchHosts.app
|
||
_bin: null
|
||
_desc: '[SwitchHosts](https://github.com/oldj/SwitchHosts) is an application for managing the etc hosts file. It allows you to easily switch between different etc hosts file configurations.'
|
||
_docs: https://github.com/oldj/SwitchHosts
|
||
_github: https://github.com/oldj/SwitchHosts
|
||
_home: https://swh.app/
|
||
_name: SwitchHosts
|
||
ansible: professormanhattan.switchhosts
|
||
appimage: oldj/SwitchHosts
|
||
cask: switchhosts
|
||
choco: switchhosts
|
||
github: github.com/oldj/SwitchHosts
|
||
scoop: switchhosts
|
||
sync-ssh-keys:
|
||
_bin: sync-ssh-keys
|
||
_desc: Sync public ssh keys to ~/.ssh/authorized_keys, based on Github/Gitlab organization membership
|
||
_github: https://github.com/samber/sync-ssh-keys
|
||
_name: sync-ssh-keys
|
||
go: github.com/samber/sync-ssh-keys@latest
|
||
yay: sync-ssh-keys-bin
|
||
syncpack:
|
||
_bin: syncpack
|
||
_desc: Consistent dependency versions in large JavaScript Monorepos.
|
||
_docs: https://jamiemason.github.io/syncpack/installation
|
||
_github: https://github.com/JamieMason/syncpack
|
||
_home: https://jamiemason.github.io/syncpack/
|
||
_name: Syncpack
|
||
npm: syncpack
|
||
syncthing:
|
||
_bin: syncthing
|
||
_github: https://github.com/syncthing/syncthing
|
||
_name: Syncthing
|
||
_service: syncthing
|
||
_serviceEnabled: true
|
||
brew: syncthing
|
||
choco: syncthing
|
||
port: syncthing
|
||
scoop: syncthing
|
||
synp:
|
||
_bin: synp
|
||
_desc: Convert yarn.lock to package-lock.json and vice versa
|
||
_github: https://github.com/imsnif/synp
|
||
_name: synp
|
||
npm: synp
|
||
sysbench:
|
||
_bin: sysbench
|
||
_desc: System performance benchmark tool
|
||
_github: https://github.com/akopytov/sysbench
|
||
_name: sysbench
|
||
apk: sysbench
|
||
apt: sysbench
|
||
brew: sysbench
|
||
dnf:fedora: sysbench
|
||
pacman: sysbench
|
||
pkg: sysbench
|
||
sysdig:
|
||
_bin: sysdig
|
||
_desc: '[sysdig](https://www.sysdig.com/) is a simple tool for deep system visibility, exploration and troubleshooting, with native support for containers.'
|
||
_docs: https://docs.sysdig.com/
|
||
_github: https://github.com/draios
|
||
_groups:
|
||
- sysdig
|
||
_home: https://sysdig.com/
|
||
_name: sysdig
|
||
ansible: professormanhattan.sysdig
|
||
brew: sysdig
|
||
pacman:
|
||
- sysdig
|
||
- sysdig-dkms
|
||
sysget:
|
||
_bin: sysget
|
||
_desc: One package manager to rule them all
|
||
_github: https://github.com/emilengler/sysget
|
||
_name: sysget
|
||
_note: TODO
|
||
sysz:
|
||
_bin: sysz
|
||
_deps:
|
||
- fzf
|
||
_desc: An fzf terminal UI for systemctl
|
||
_docs: https://github.com/joehillen/sysz
|
||
_github: https://github.com/joehillen/sysz
|
||
_home: https://github.com/joehillen/sysz
|
||
_name: syz
|
||
bin: https://github.com/joehillen/sysz
|
||
nix-env: nixpkgs.sysz
|
||
pacman: sysz
|
||
script:linux: cd /tmp && git clone https://github.com/joehillen/sysz.git && cd sysz && sudo make install && cd /tmp && rm -rf sysz
|
||
t:
|
||
_bin: t
|
||
_desc: A command-line power tool for Twitter
|
||
_github: https://github.com/sferik/t
|
||
gem: t
|
||
t-rec:
|
||
_bin: t-rec
|
||
_deps:cargo:
|
||
- imagemagick
|
||
_desc: '[t-rec](https://github.com/sassman/t-rec-rs) is a blazingly fast terminal recorder that generates animated GIF images for the web written in Rust'
|
||
_docs: https://crates.io/crates/t-rec
|
||
_github: https://github.com/sassman/t-rec-rs
|
||
_home: https://crates.io/crates/t-rec
|
||
_name: t-rec
|
||
ansible: professormanhattan.trec
|
||
brew: t-rec
|
||
cargo: t-rec
|
||
port: t-rec
|
||
snap: t-rec --classic
|
||
yay: t-rec
|
||
tabby:
|
||
_app: Tabby.app
|
||
_bin: tabby
|
||
_desc: '[Tabby](https://eugeny.github.io/tabby/) is a highly configurable terminal emulator, SSH and serial client for Windows, macOS and Linux.'
|
||
_docs: https://openbase.com/js/tabby/documentation
|
||
_github: https://github.com/Eugeny/tabby
|
||
_home: https://tabby.sh/
|
||
_name: Tabby
|
||
_notes: TODO Update the direct links periodically and keep eye out for Snap / Flatpak
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Tabby Plugins
|
||
# @brief This script installs the default Tabby plugins which are defined in `${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package.json`
|
||
# @description
|
||
# This script pre-installs a handful of useful Tabby plugins which are defined in `${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package.json`.
|
||
# These default plugins can be customized by editting the `package.json` file stored in your Install Doctor fork in the Tabby `plugins/package.json`
|
||
# file.
|
||
#
|
||
# ## Default Plugins Configuration
|
||
#
|
||
# The script will install all the plugins defined in the `package.json` file by navigating to the `~/.config/tabby/plugins` folder
|
||
# and then run `npm install`. The default configuration will include the following plugins:
|
||
#
|
||
# ```json
|
||
# {
|
||
# ...
|
||
# // Notable dependencies listed below
|
||
# "dependencies": {
|
||
# "tabby-docker": "^0.2.0",
|
||
# "tabby-save-output": "^3.1.0",
|
||
# "tabby-search-in-browser": "^0.0.1",
|
||
# "tabby-workspace-manager": "^0.0.4"
|
||
# },
|
||
# ...
|
||
# }
|
||
# ```
|
||
#
|
||
# ## Default Plugin Descriptions
|
||
#
|
||
# The following chart provides a short description of the default plugins that are pre-installed alongside Tabby:
|
||
#
|
||
# | NPM Package | Description |
|
||
# |---------------------------|---------------------------------------------------------------------|
|
||
# | `tabby-docker` | Allows you to shell directly into Docker containers |
|
||
# | `tabby-save-output` | This plugin lets you stream console output into a file. |
|
||
# | `tabby-search-in-browser` | Allows you to open a internet browser and search for selected text. |
|
||
# | `tabby-workspace-manager` | Allows you to create multiple workspace profiles. |
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Tabby plugins `package.json`](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_config/tabby/plugins/package.json)
|
||
# * [Secrets / Environment variables documentation](https://install.doctor/docs/customization/secrets) which details how to store your Tabby configuration in as an encrypted file
|
||
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package.json" ]; then
|
||
if [ -d "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/node_modules" ]; then
|
||
logg info 'Skipping Tabby plugin installation because it looks like the plugins were already installed since node_modules is present in ~/.config/tabby/plugins'
|
||
else
|
||
logg info 'Installing Tabby plugins defined in '"${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins/package.json"''
|
||
cd "${XDG_CONFIG_HOME:-$HOME/.config}/tabby/plugins"
|
||
npm install --quiet
|
||
logg success 'Finished installing Tabby plugins'
|
||
fi
|
||
else
|
||
logg info 'Skipping Tabby plugin installation because is not present'
|
||
fi
|
||
ansible:linux: professormanhattan.tabby
|
||
apt: https://github.com/Eugeny/tabby/releases/download/v1.0.188/tabby-1.0.188-linux-x64.deb
|
||
cask: tabby
|
||
choco: tabby
|
||
dnf: https://github.com/Eugeny/tabby/releases/download/v1.0.188/tabby-1.0.188-linux-x64.rpm
|
||
github: github.com/Eugeny/tabby
|
||
pacman: https://github.com/Eugeny/tabby/releases/download/v1.0.188/tabby-1.0.188-linux-x64.pacman
|
||
tailscale:
|
||
_app: Tailscale.app
|
||
_bin: tailscale
|
||
_desc: '[Tailscale](https://tailscale.com/) lets you easily manage access to private resources, quickly SSH into devices on your network, and work securely from anywhere in the world.'
|
||
_docs: https://tailscale.com/kb/
|
||
_github: https://github.com/tailscale/tailscale
|
||
_home: https://tailscale.com/
|
||
_name: Tailscale
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Tailscale
|
||
# @brief Connects the Tailscale client with the Tailscale network
|
||
# @description
|
||
# This script ensures the `tailscaled` system daemon is installed on macOS. Then, on both macOS and Linux, it connects to the Tailscale
|
||
# network if the `TAILSCALE_AUTH_KEY` variable is provided.
|
||
|
||
### Install the Tailscale system daemon
|
||
if [ -d /Applications ] && [ -d System ]; then
|
||
### macOS
|
||
if command -v tailscaled > /dev/null; then
|
||
logg info 'Ensuring tailscaled system daemon is installed'
|
||
sudo tailscaled install-system-daemon
|
||
logg info 'tailscaled system daemon is now installed and will load on boot'
|
||
else
|
||
logg info 'tailscaled does not appear to be installed'
|
||
fi
|
||
fi
|
||
|
||
### Connect to Tailscale network
|
||
if command -v tailscale > /dev/null && [ "$TAILSCALE_AUTH_KEY" != "" ]; then
|
||
logg info 'Connecting to Tailscale with user-defined authentication key'
|
||
timeout 14 tailscale up --authkey="$TAILSCALE_AUTH_KEY" --accept-routes || EXIT_CODE=$?
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg warn 'tailscale up timed out'
|
||
else
|
||
logg success 'Connected to Tailscale network'
|
||
fi
|
||
fi
|
||
_service:brew: tailscale
|
||
_service:pacman: tailscaled
|
||
ansible: professormanhattan.tailscale
|
||
brew: tailscale
|
||
cask: tailscale
|
||
choco: tailscale
|
||
go: tailscale.com/cmd/tailscale{,d}@main
|
||
mas: 1475387142
|
||
pacman: tailscale
|
||
port: tailscale
|
||
talksheet:
|
||
_bin: talksheet
|
||
_github: https://github.com/danthelion/talksheet
|
||
_name: Talksheet
|
||
pipx: talksheet
|
||
taplo:
|
||
_bin: taplo
|
||
_desc: A TOML toolkit written in Rust that includes TOML formatting abilities
|
||
_docker: docker run tamasfe/taplo
|
||
_docs: https://taplo.tamasfe.dev/cli/introduction.html
|
||
_github: https://github.com/tamasfe/taplo
|
||
_home: https://taplo.tamasfe.dev/
|
||
_name: Taplo
|
||
cargo: taplo-cli --locked
|
||
npm: '@taplo/cli'
|
||
tart:
|
||
_bin: tart
|
||
_github: https://github.com/cirruslabs/tart
|
||
_todo: Verify that this installs properly (error on arm64 macOS)
|
||
brew:darwin: cirruslabs/cli/gitlab-tart-executor
|
||
task:
|
||
_bin: task
|
||
_desc: A task runner / simpler Make alternative written in Go
|
||
_docs: https://taskfile.dev/usage/
|
||
_github: https://github.com/go-task/task
|
||
_home: https://taskfile.dev
|
||
_name: Task
|
||
brew: go-task
|
||
choco: go-task
|
||
github: github.com/go-task/task
|
||
go: github.com/go-task/task/v3/cmd/task@latest
|
||
scoop: task
|
||
taskwarrior:
|
||
_bin: taskwarrior
|
||
_github: https://github.com/GothenburgBitFactory/taskwarrior
|
||
_name: Task Warrior
|
||
apt: taskwarrior
|
||
brew:
|
||
- task
|
||
- taskd
|
||
- tasksh
|
||
dnf: task
|
||
emerge: task
|
||
nix-env: taskwarrior
|
||
pacman: task
|
||
port: task
|
||
sbopkg: task
|
||
xbps: task
|
||
zypper: taskwarrior
|
||
teamviewer:
|
||
_app: TeamViewer.app
|
||
_bin: teamviewer
|
||
_desc: '[TeamViewer](https://www.teamviewer.com/en-us/) is a proprietary software for remote access to as well as remote control and maintenance of computers and other devices, which was first released in 2005. The functionality has been expanded step by step, most recently for example through the integration of TeamViewer Meeting.'
|
||
_docs: https://www.teamviewer.com/en-us/documents/
|
||
_github: Not open-source
|
||
_home: https://www.teamviewer.com/en-us/
|
||
_name: TeamViewer
|
||
ansible:linux: professormanhattan.teamviewer
|
||
apt: https://download.teamviewer.com/download/linux/teamviewer_amd64.deb
|
||
cask: teamviewer
|
||
choco: teamviewer
|
||
dnf: https://download.teamviewer.com/download/linux/teamviewer.x86_64.rpm
|
||
yay: teamviewer
|
||
zypper: https://download.teamviewer.com/download/linux/teamviewer-suse.x86_64.rpm
|
||
telegram:
|
||
_app: Telegram.app
|
||
_github: https://github.com/telegramdesktop/tdesktop
|
||
_bin: telegram
|
||
_name: Telegram
|
||
cask: telegram
|
||
choco: telegram
|
||
flatpak: org.telegram.desktop
|
||
mas: 747648890
|
||
teleport:
|
||
_bin: teleport
|
||
_desc: '[Teleport](https://goteleport.com/) is a free and open-source tool that allows engineers and security professionals to unify access for SSH servers, Kubernetes clusters, web applications, and databases across all environments. It is an identity-aware, multi-protocol access proxy which understands SSH, HTTPS, Kubernetes API, MySQL and PostgreSQL wire protocols.'
|
||
_github: https://github.com/gravitational/teleport
|
||
_name: Teleport
|
||
ansible: professormanhattan.teleport
|
||
brew: teleport
|
||
pkg: teleport
|
||
yay: teleport-bin
|
||
teller:
|
||
_bin: teller
|
||
_desc: Cloud native secrets management for developers - never leave your command line for secrets
|
||
_github: https://github.com/tellerops/teller
|
||
_name: teller
|
||
brew: spectralops/tap/teller
|
||
github: github.com/tellerops/teller
|
||
temps:
|
||
_bin: null
|
||
_desc: Simple menubar application based on Electron with actual weather information and forecast
|
||
_github: https://github.com/jackd248/temps
|
||
_name: Temps
|
||
github: github.com/jackd248/temps
|
||
terminal-notifier:
|
||
_bin: terminal-notifier
|
||
_github: https://github.com/julienXX/terminal-notifier
|
||
_name: Terminal Notifier
|
||
brew:darwin: terminal-notifier
|
||
terminalizer:
|
||
_bin: terminalizer
|
||
_desc: Record your terminal and generate animated gif images or share a web player
|
||
_github: https://github.com/faressoft/terminalizer
|
||
_home: https://www.terminalizer.com/
|
||
_name: terminalizer
|
||
npm: terminalizer
|
||
termius:
|
||
_bin: termius
|
||
_desc: '[Termius](https://www.termius.com/) is the SSH client that works on Desktop and Mobile.'
|
||
_home: https://www.termius.com/
|
||
_name: Termius
|
||
_github: false
|
||
_post:binary:windows: |
|
||
# TODO
|
||
# TODO
|
||
ansible: professormanhattan.termius
|
||
binary:windows: https://autoupdate.termius.com/windows/Termius.exe
|
||
brew: termius
|
||
pipx: termius
|
||
snap: termius-app
|
||
yay: termius
|
||
terraform:
|
||
_github: https://github.com/hashicorp/terraform
|
||
_deps:
|
||
- tfenv
|
||
terraform-ls:
|
||
_bin: terraform-ls
|
||
_desc: '[terraform-ls](https://github.com/tfutils/tfenv) is the official Terraform language server maintained by HashiCorp that provides IDE features to any LSP-compatible editor.'
|
||
_docs: https://github.com/hashicorp/terraform-ls
|
||
_github: https://github.com/hashicorp/terraform-ls
|
||
_home: https://github.com/hashicorp/terraform-ls
|
||
_name: terraform-ls
|
||
_service: false
|
||
brew: terraform-ls
|
||
textql:
|
||
_bin: textql
|
||
_desc: CLI that allows you to execute SQL against structured text like CSV or TSV
|
||
_docs: https://github.com/dinedal/textql
|
||
_github: https://github.com/dinedal/textql
|
||
_home: https://github.com/dinedal/textql
|
||
_name: TextQL
|
||
brew: textql
|
||
go: github.com/dinedal/textql@master
|
||
yay: textql-git
|
||
tfenv:
|
||
_bin: tfenv
|
||
_desc: '[tfenv](https://github.com/tfutils/tfenv) is a Terraform version manager inspired by [rbenv](https://github.com/rbenv/rbenv). It supports macOS, Linux, and Windows.'
|
||
_docs: https://github.com/tfutils/tfenv#usage
|
||
_github: https://github.com/tfutils/tfenv
|
||
_home: https://github.com/tfutils/tfenv
|
||
_name: tfenv
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
if command -v tfenv > /dev/null; then
|
||
tfenv use latest
|
||
fi
|
||
ansible:darwin: professormanhattan.tfenv
|
||
ansible:linux: professormanhattan.tfenv
|
||
brew: tfenv
|
||
port: tfenv
|
||
yay: tfenv
|
||
tflint:
|
||
_bin: tflint
|
||
_desc: '[tflint](https://github.com/terraform-linters/tflint) is a framework that can help in finding possible errors for major cloud providers, warn about deprecated syntax and unused declarations and enforce best practices. This role installs tflint on nearly any platform.'
|
||
_github: https://github.com/terraform-linters/tflint
|
||
_name: tflint
|
||
ansible: professormanhattan.tflint
|
||
brew: tflint
|
||
choco: tflint
|
||
github: github.com/terraform-linters/tflint
|
||
tfsec:
|
||
_bin: tfsec
|
||
_github: https://github.com/aquasecurity/tfsec
|
||
_name: Aqua TFSec
|
||
brew: tfsec
|
||
choco: tfsec
|
||
scoop: tfsec
|
||
tgpt:
|
||
_bin: tgpt
|
||
_github: https://github.com/aandrew-me/tgpt
|
||
_name: Terminal GPT
|
||
go: github.com/aandrew-me/tgpt/v2@latest
|
||
scoop: https://raw.githubusercontent.com/aandrew-me/tgpt/main/tgpt.json
|
||
yay: tgpt-bin
|
||
thefuck:
|
||
_bin: fuck
|
||
_desc: Magnificent CLI tool that corrects your previous console command whenever something fails due to misspelling.
|
||
_docs: https://github.com/nvbn/thefuck
|
||
_github: https://github.com/nvbn/thefuck
|
||
_home: https://github.com/nvbn/thefuck
|
||
_name: The Fuck
|
||
brew: thefuck
|
||
crew: thefuck
|
||
pacman: thefuck
|
||
pipx: thefuck
|
||
pkg-freebsd: thefuck
|
||
thunderbird:
|
||
_app: Thunderbird.app
|
||
_bin: thunderbird
|
||
_github: false
|
||
cask: thunderbird
|
||
choco: thunderbird
|
||
flatpak: org.mozilla.Thunderbird
|
||
tig:
|
||
_bin: tig
|
||
_desc: Tig is an ncurses-based text-mode interface for git. It functions mainly as a Git repository browser, but can also assist in staging changes for commit at chunk level and act as a pager for output from various Git commands
|
||
_github: https://github.com/jonas/tig
|
||
_home: https://jonas.github.io/tig/
|
||
_name: tig
|
||
brew: tig
|
||
nix: tig
|
||
pkg: tig
|
||
tigervnc:
|
||
_bin: tigervncpasswd
|
||
_github: https://github.com/TigerVNC/tigervnc
|
||
_name: TigerVNC Server
|
||
_ports:
|
||
- port: 5900-5904
|
||
proto: tcp
|
||
apt: tigervnc-standalone-server
|
||
dnf: tigervnc-server
|
||
pacman: tigervnc
|
||
zypper: tigervnc
|
||
tilt:
|
||
_bin: tilt
|
||
_desc: Define your dev environment as code. For microservice apps on Kubernetes
|
||
_docs: https://docs.tilt.dev/
|
||
_github: https://github.com/tilt-dev/tilt
|
||
_home: https://tilt.dev/
|
||
_name: tilt
|
||
brew: tilt
|
||
github: github.com/tilt-dev/tilt
|
||
yay: tilt-bin
|
||
timeshift:
|
||
_bin: timeshift
|
||
_desc: '[Timeshift](https://github.com/teejee2008/timeshift) is a free and open source system restore tool for Linux. Timeshift for Linux is an application that provides functionality similar to the System Restore feature in Windows and the Time Machine tool in Mac OS. Timeshift protects your system by taking incremental snapshots of the file system at regular intervals. These snapshots can be restored at a later date to undo all changes to the system.'
|
||
_github: https://github.com/teejee2008/timeshift
|
||
_home: https://teejeetech.com/timeshift/
|
||
_name: Timeshift
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Timeshift Configuration
|
||
# @brief Updates the Timeshift system configuration with the Timeshift configuration stored in the `home/dot_config/timeshift/timeshift.json` location.
|
||
# @description
|
||
# This script applies a Timeshift configuration that defines how Timeshift should maintain system backups.
|
||
if command -v timeshift > /dev/null; then
|
||
logg info 'Ensuring /etc/timeshift is a directory'
|
||
sudo mkdir -p /etc/timeshift
|
||
TIMESHIFT_CONFIG="${XDG_CONFIG_HOME:-$HOME/.config}/timeshift/timeshift.json"
|
||
logg info "Copying $TIMESHIFT_CONFIG to /etc/timeshift/timeshift.json"
|
||
sudo cp -f "$TIMESHIFT_CONFIG" /etc/timeshift/timeshift.json
|
||
else
|
||
logg info 'The timeshift executable is not available'
|
||
fi
|
||
# Unavailable on CentOS Stream 9
|
||
# ansible:linux: professormanhattan.timeshift
|
||
apt: timeshift
|
||
dnf:fedora: timeshift
|
||
yay: timeshift
|
||
timewarrior:
|
||
_bin: timew
|
||
_github: https://github.com/GothenburgBitFactory/timewarrior
|
||
_name: Time Warrior
|
||
apt: timewarrior
|
||
brew: timewarrior
|
||
dnf: timew
|
||
emerge: app-misc/timew
|
||
nix-env: timewarrior
|
||
pacman: timew
|
||
tinypng:
|
||
_bin: tinypng
|
||
_desc: Handy command line tool for shrinking PNG images using the TinyPNG API
|
||
_github: https://github.com/websperts/tinypng-cli
|
||
_name: tinypng
|
||
_service: null
|
||
npm: tinypng-cli
|
||
tldr:
|
||
_bin: tldr
|
||
_desc: Simplified and community-driven man pages
|
||
_github: https://github.com/tldr-pages/tldr
|
||
_home: https://tldr.sh/
|
||
_name: tldr
|
||
brew: tldr
|
||
npm: tldr
|
||
tmate:
|
||
_bin: tmate
|
||
_github: https://github.com/tmate-io/tmate
|
||
_name: tmate
|
||
apt: tmate
|
||
brew: tmate
|
||
dnf: tmate
|
||
emerge: app-misc/tmate
|
||
opkg: tmate
|
||
pacman: tmate
|
||
pkg-freebsd: tmate
|
||
pkg_add: tmate
|
||
zypper: tmate
|
||
tmux:
|
||
_bin: tmux
|
||
_desc: '[Tmux](https://github.com/tmux/tmux/wiki) is a terminal multiplexer. It enables a number of terminals to be created, accessed, and controlled from a single screen. Tmux may be detached from a screen and continue running in the background, then later reattached.'
|
||
_docs: https://github.com/tmux/tmux/wiki
|
||
_github: https://github.com/tmux/tmux
|
||
_name: tmux
|
||
ansible: professormanhattan.tmux
|
||
apt: tmux
|
||
brew:
|
||
- awk
|
||
- gnu-sed
|
||
- perl
|
||
- tmux
|
||
tmuxinator:
|
||
_bin: tmuxinator
|
||
_desc: Manage complex tmux sessions easily
|
||
_docs: https://github.com/tmuxinator/tmuxinator
|
||
_github: https://github.com/tmuxinator/tmuxinator
|
||
_home: https://github.com/tmuxinator/tmuxinator
|
||
_name: Tmuxinator
|
||
brew: tmuxinator
|
||
tokei:
|
||
_bin: tokei
|
||
_desc: Tokei is a program that displays statistics about the code
|
||
_github: https://github.com/XAMPPRocky/tokei
|
||
_name: tokei
|
||
apk: tokei
|
||
brew: tokei
|
||
cargo: tokei
|
||
dnf:fedora: tokei
|
||
github: github.com/XAMPPRocky/tokei
|
||
pacman: tokei
|
||
pkg: tokei
|
||
scoop: tokei
|
||
tomcat:
|
||
_bin: catalina
|
||
_github: https://github.com/apache/tomcat
|
||
_name: Tomcat
|
||
_post:darwin: |
|
||
#!/usr/bin/env bash
|
||
sed 's/8080/8180/g' /usr/local/etc/tomcat/server.xml > /usr/local/etc/tomcat/server.xml
|
||
_post:linux: |
|
||
#!/usr/bin/env bash
|
||
sed 's/8080/8180/g' /usr/local/etc/tomcat/server.xml > /usr/local/etc/tomcat/server.xml
|
||
_service: tomcat
|
||
apt: tomcat
|
||
brew: tomcat
|
||
choco: tomcat
|
||
dnf: tomcat
|
||
pacman: tomcat
|
||
toml-sort:
|
||
_bin: toml-sort
|
||
_desc: A Python module that auto-formats TOML files
|
||
_docs: https://pypi.org/project/toml-sort/
|
||
_github: https://github.com/pappasam/toml-sort
|
||
_home: https://pypi.org/project/toml-sort/
|
||
_name: TOML Sort
|
||
pipx: toml-sort
|
||
tor:
|
||
_bin: tor
|
||
_desc: "[Tor](https://www.torproject.org/) is free and open-source software for enabling anonymous communication by directing Internet traffic through a free, worldwide, volunteer overlay network consisting of more than seven thousand relays in order to conceal a user's location and usage from anyone conducting network surveillance or traffic analysis. On Linux you can combine Tor with [Privoxy](https://www.privoxy.org/) which allows you to tunnel all of your traffic through the Tor network."
|
||
_docs: https://tb-manual.torproject.org/
|
||
_github: https://github.com/TheTorProject
|
||
_home: https://www.torproject.org/
|
||
_name: TOR
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file Tor Configuration
|
||
# @brief This script applies the Tor configuration stored at `${XDG_CONFIG_HOME:-HOME/.config}/tor/torrc` to the system and then restarts Tor
|
||
# @description
|
||
# Tor is a network that uses onion routing, originally published by the US Navy. It is leveraged by privacy enthusiasts
|
||
# and other characters that deal with sensitive material, like journalists and people buying drugs on the internet.
|
||
# This script:
|
||
#
|
||
# 1. Determines the system configuration file location
|
||
# 2. Applies the configuration stored at `${XDG_CONFIG_HOME:-HOME/.config}/tor/torrc`
|
||
# 3. Enables and restarts the Tor service with the new configuration
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Tor configuration](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_config/tor/torrc)
|
||
|
||
### Determine the Tor configuration location by checking whether the system is macOS or Linux
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS
|
||
TORRC_CONFIG_DIR=/usr/local/etc/tor
|
||
else
|
||
### Linux
|
||
TORRC_CONFIG_DIR=/etc/tor
|
||
fi
|
||
TORRC_CONFIG="$TORRC_CONFIG_DIR/torrc"
|
||
|
||
### Apply the configuration if the `torrc` binary is available in the `PATH`
|
||
if command -v toron > /dev/null; then
|
||
if [ -d "$TORRC_CONFIG_DIR" ]; then
|
||
### Copy the configuration from `${XDG_CONFIG_HOME:-$HOME/.config}/tor/torrc` to the system configuration file location
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/tor/torrc" "$TORRC_CONFIG"
|
||
sudo chmod 600 "$TORRC_CONFIG"
|
||
### Enable and restart the Tor service
|
||
if [ -d /Applications ] && [ -d /System ]; then
|
||
### macOS
|
||
brew services restart tor
|
||
else
|
||
if [[ ! "$(test -d /proc && grep Microsoft /proc/version > /dev/null)" ]]; then
|
||
### Linux
|
||
sudo systemctl enable tor
|
||
sudo systemctl restart tor
|
||
else
|
||
logg info 'Environment is WSL so the Tor systemd service will not be enabled / restarted'
|
||
fi
|
||
fi
|
||
else
|
||
logg warn 'The '"$TORRC_CONFIG_DIR"' directory is missing'
|
||
fi
|
||
else
|
||
logg warn 'toron is missing from the PATH'
|
||
fi
|
||
_restricted: true
|
||
_service: tor
|
||
_serviceEnabled: true
|
||
ansible:linux: professormanhattan.tor
|
||
apt: tor
|
||
brew: tor
|
||
dnf: tor
|
||
pacman: tor
|
||
port: tor
|
||
tor-browser:
|
||
_app: Tor Browser.app
|
||
_bin: tor-browser
|
||
_desc: Tor, short for The Onion Router, is free and open-source software for enabling anonymous communication. It directs Internet traffic through a free, worldwide, volunteer overlay network, consisting of more than seven thousand relays, to conceal a user's location and usage.
|
||
_docs: https://www.torproject.org/docs/documentation.html.en
|
||
_env:
|
||
TOR_BROWSER_APPDATA:
|
||
cask: "$HOME/Library/Application Support/TorBrowser-Data/Tor"
|
||
choco: "TODO"
|
||
flatpak: "TODO"
|
||
_github: https://github.com/TheTorProject/gettorbrowser
|
||
_home: https://www.torproject.org/
|
||
_name: Tor Browser
|
||
_restricted: true
|
||
cask: tor-browser
|
||
choco: tor-browser
|
||
flatpak: com.github.micahflee.torbrowser-launcher
|
||
tradingview:
|
||
_app: TradingView.app
|
||
_bin: tradingview
|
||
_github: https://github.com/tradingview/lightweight-charts
|
||
_name: Trading View
|
||
cask: tradingview
|
||
msix: https://tvd-packages.tradingview.com/stable/latest/win32/TradingView.msix
|
||
snap: tradingview
|
||
translate:
|
||
_bin: trans
|
||
_desc: '[Translate Shell](https://github.com/soimort/translate-shell) (formerly Google Translate CLI) is a command-line translator powered by Google Translate (default), Bing Translator, Yandex.Translate, and Apertium. It gives you easy access to these translation engines in your terminal. It is feature-rich and, although there is some overlap, it complements [Normit](https://gitlab.com/megabyte-labs/ansible-roles/normit) well.'
|
||
_github: https://github.com/soimort/translate-shell
|
||
_name: Translate Shell
|
||
ansible:darwin: professormanhattan.translate
|
||
ansible:linux: professormanhattan.translate
|
||
apt:ubuntu: translate-shell
|
||
brew: translate-shell
|
||
dnf: translate-shell
|
||
pacman: translate-shell
|
||
trayscale:
|
||
_bin: trayscale
|
||
_desc: Unofficial Menu Bar for Tailscale on Linux
|
||
_github: https://github.com/DeedleFake/trayscale
|
||
_name: Trayscale
|
||
flatpak: dev.deedles.Trayscale
|
||
tree:
|
||
_bin: tree
|
||
_desc: '[tree-cli](https://github.com/MrRaindrop/tree-cli) is a recursive directory listing program that produces a depth indented listing of files. With no arguments, tree lists the files in the current directory. When directory arguments are given, tree lists all the files and/or directories found in the given directories each in turn. Upon completion of listing all files/directories found, tree returns the total number of files and/or directories listed.'
|
||
_name: tree-cli
|
||
_github: https://github.com/MrRaindrop/tree-cli
|
||
ansible: professormanhattan.tree
|
||
apt: tree
|
||
brew: tree
|
||
choco: tree
|
||
dnf: tree
|
||
pacman: tree
|
||
tree-sitter:
|
||
_bin: tree-sitter
|
||
_desc: CLI tool for creating and testing tree-sitter parsers
|
||
_github: https://github.com/tree-sitter/tree-sitter-cli
|
||
_name: tree-sitter-cli
|
||
cargo: tree-sitter-cli
|
||
trellis:
|
||
_bin: trellis
|
||
_desc: A CLI to manage Trellis projects
|
||
_github: https://github.com/roots/trellis-cli
|
||
_home: https://roots.io/trellis/
|
||
_name: trellis
|
||
brew: roots/tap/trellis-cli
|
||
trivy:
|
||
_bin: trivy
|
||
_desc: Scanner for vulnerabilities in container images, file systems, and Git repositories, as well as for configuration issues
|
||
_github: https://github.com/aquasecurity/trivy
|
||
_name: trivy
|
||
brew: trivy
|
||
github: github.com/aquasecurity/trivy
|
||
yay: trivy-bin
|
||
trufflehog:
|
||
_bin: trufflehog
|
||
_desc: Find credentials all over the place
|
||
_github: https://github.com/trufflesecurity/trufflehog
|
||
_home: https://trufflesecurity.com/trufflehog/
|
||
_name: trufflehog
|
||
brew: trufflesecurity/trufflehog/trufflehog
|
||
trunk:
|
||
_bin: trunk
|
||
_desc: An all-in-one linter / code auto-fixer augmented by a freemium web service
|
||
_docs: https://docs.trunk.io/
|
||
_github: false
|
||
_home: https://trunk.io/
|
||
cask: trunk-io
|
||
npm: '@trunkio/launcher'
|
||
script: curl https://get.trunk.io -fsSL | bash -s -- -y
|
||
ts2c:
|
||
_bin: ts2c
|
||
_desc: Convert Javascript/TypeScript to C
|
||
_github: https://github.com/andrei-markeev/ts2c
|
||
_name: ts2c
|
||
npm: ts2c
|
||
tunnelblick:
|
||
_app: Tunnelblick.app
|
||
_desc: Tunnelblick is a macOS menubar tray application that helps you control OpenVPN.
|
||
_docs: https://tunnelblick.net/documents.html
|
||
_github: https://github.com/Tunnelblick/Tunnelblick
|
||
_home: https://tunnelblick.net/
|
||
_name: Tunnelblick
|
||
cask: tunnelblick
|
||
turbo:
|
||
_bin: turbo
|
||
_github: https://github.com/vercel/turbo
|
||
_name: Turbo
|
||
npm: turbo
|
||
typescript:
|
||
_bin: tsc
|
||
_desc: TypeScript is a strongly typed programming language that builds on JavaScript, giving you better tooling at any scale.
|
||
_docs: https://www.typescriptlang.org/docs/
|
||
_github: https://github.com/microsoft/TypeScript
|
||
_home: https://www.typescriptlang.org/
|
||
_name: TypeScript
|
||
brew: typescript
|
||
npm: tsc
|
||
typescript-to-lua:
|
||
_bin: tstl
|
||
_github: https://github.com/TypeScriptToLua/TypeScriptToLua
|
||
_name: TypeScript to Lua Converter
|
||
npm: typescript-to-lua
|
||
ugm:
|
||
_bin: ugm
|
||
_desc: A terminal based UNIX user and group browser
|
||
_docs: https://github.com/ariasmn/ugm
|
||
_github: https://github.com/ariasmn/ugm
|
||
_home: https://github.com/ariasmn/ugm
|
||
_name: ugm
|
||
go: github.com/ariasmn/ugm@latest
|
||
ulauncher:
|
||
_bin: ulauncher
|
||
_desc: '[Ulauncher](https://ulauncher.io/) is a software packaging and deployment system developed by Canonical for operating systems that use the Linux kernel. The packages, called ulaunchers, and the tool for using them, ulauncher, work across a range of Linux distributions and allow upstream software developers to distribute their applications directly to users. Ulaunchers are self-contained applications running in a sandbox with mediated access to the host system.'
|
||
_docs: https://docs.ulauncher.io/
|
||
_github: https://github.com/Ulauncher/Ulauncher/
|
||
_home: https://ulauncher.io/
|
||
_name: Ulauncher
|
||
ansible: professormanhattan.ulauncher
|
||
ultra:
|
||
_bin: ultra
|
||
_desc: Ultra fast monorepo script runner and build tool
|
||
_docs: https://github.com/folke/ultra-runner
|
||
_github: https://github.com/folke/ultra-runner
|
||
_home: https://www.npmjs.com/package/ultra-runner
|
||
_name: Ultra Task Runner
|
||
npm: ultra-runner
|
||
unbuffer:
|
||
_bin: unbuffer
|
||
_name: Unbuffer
|
||
_github: false
|
||
apt: unbuffer
|
||
# expect package on Homebrew contains unbuffer
|
||
brew: expect
|
||
dnf: unbuffer
|
||
pacman: unbuffer
|
||
unikraft:
|
||
_bin: kraft
|
||
_github: https://github.com/unikraft/unikraft
|
||
_name: Unikraft
|
||
brew: unikraft/cli/kraftkit
|
||
script: curl --proto '=https' --tlsv1.2 -sSf https://get.kraftkit.sh | sh
|
||
unison:
|
||
_bin: unison
|
||
_github: https://github.com/bcpierce00/unison
|
||
_name: Unison
|
||
brew: unison
|
||
choco: unison
|
||
up:
|
||
_bin: up
|
||
_desc: up, which is short for [Ultimate Plumber](https://github.com/akavel/up), is a tool for writing Linux pipes in a terminal-based UI interactively, with an instant live preview of command results.
|
||
_github: https://github.com/akavel/up
|
||
_name: Ultimate Plumber (up)
|
||
ansible: professormanhattan.up
|
||
brew: up
|
||
github: github.com/akavel/up
|
||
pkg: up
|
||
yay: up
|
||
upscayl:
|
||
_bin: upscayl
|
||
_github: https://github.com/upscayl/upscayl
|
||
_name: Upscayl
|
||
_todo: Recheck for Homebrew Cask
|
||
appimage: Upscayl
|
||
choco: upscayl
|
||
flatpak: org.upscayl.Upscayl
|
||
snap: upscayl
|
||
upt:
|
||
_bin: upt
|
||
_desc: Universal package-management tool for Windows, macOS and Linux
|
||
_github: https://github.com/sigoden/upt
|
||
_name: upt
|
||
cargo: upt
|
||
'cargo:': upt
|
||
upx:
|
||
_bin: upx
|
||
_desc: '[UPX](https://upx.github.io/) is an advanced executable file compressor. UPX will typically reduce the file size of programs and DLLs by around 50%-70%, thus reducing disk space, network load times, download times and other distribution and storage costs. It supports compressing a wide variety of binary-like files. Surprisingly, it even compresses executables better than WinZip. Best of all, it is free and open source.'
|
||
_docs: https://github.com/upx/upx
|
||
_github: https://github.com/upx/upx
|
||
_home: https://upx.github.io/
|
||
_name: UPX
|
||
ansible: professormanhattan.upx
|
||
apt: upx
|
||
brew: upx
|
||
choco: upx
|
||
dnf:fedora: upx
|
||
pacman: upx
|
||
port: upx
|
||
scoop: upx
|
||
usql:
|
||
_bin: usql
|
||
_github: https://github.com/xo/usql
|
||
_name: Universal SQL CLI
|
||
brew: xo/xo/usql
|
||
choco: usql
|
||
go: github.com/xo/usql@latest
|
||
scoop: usql
|
||
util-linux:
|
||
_github: false
|
||
_bin:
|
||
- cal
|
||
- chmem
|
||
- hexdump
|
||
apt: util-linux
|
||
dnf: util-linux
|
||
pacman: util-linux
|
||
utm:
|
||
_app: UTM.app
|
||
_bin: utm
|
||
_github: https://github.com/utmapp/UTM
|
||
_name: UTM
|
||
cask: utm
|
||
vagrant:
|
||
_bin: vagrant
|
||
_desc: '[Vagrant](https://www.vagrantup.com/) is an open-source software product for building and maintaining portable virtual software development environments (e.g., for VirtualBox, KVM, Hyper-V, Docker containers, VMware, and AWS).'
|
||
_docs: https://www.vagrantup.com/docs
|
||
_github: https://github.com/hashicorp/vagrant
|
||
_home: https://www.vagrantup.com/
|
||
_name: Vagrant
|
||
ansible: professormanhattan.vagrant
|
||
apt: vagrant
|
||
brew: hashicorp/tap/vagrant
|
||
cask: vagrant
|
||
choco: vagrant
|
||
dnf:fedora: vagrant
|
||
pacman: vagrant
|
||
scoop: vagrant
|
||
vagrant-manager:
|
||
_app: Vagrant Manager.app
|
||
_bin: null
|
||
_desc: Status bar menu application that allows you to manage Vagrant available on macOS and Windows
|
||
_docs: https://github.com/lanayotech/vagrant-manager
|
||
_github: https://github.com/lanayotech/vagrant-manager
|
||
_home: https://www.vagrantmanager.com/
|
||
_name: Vagrant Manager
|
||
cask: vagrant-manager
|
||
choco: vagrant-manager
|
||
vagrant-vmware-utility:
|
||
_bin: false
|
||
_name: Vagrant VMWare Utility
|
||
_github: https://github.com/hashicorp/vagrant-vmware-desktop
|
||
_post:cask: |
|
||
#!/usr/bin/env bash
|
||
sudo ln -s /opt/vagrant-vmware-desktop/bin/vagrant-vmware-utility /usr/local/bin/vagrant-vmware-utility
|
||
_when:cask: '! test -f /opt/vagrant-vmware-desktop/bin/vagrant-vmware-utility'
|
||
ansible: professormanhattan.vmware
|
||
cask: vagrant-vmware-utility
|
||
choco: vagrant-vmware-utility
|
||
script: rm -rf /tmp/vagrant-vmware-utility_1.0.21_linux_amd64.zip && curl https://releases.hashicorp.com/vagrant-vmware-utility/1.0.21/vagrant-vmware-utility_1.0.21_linux_amd64.zip -o /tmp/vagrant-vmware-utility_1.0.21_linux_amd64.zip && unzip /tmp/vagrant-vmware-utility_1.0.21_linux_amd64.zip && sudo mv -f /tmp/vagrant-vmware-utility /usr/local/bin/vagrant-vmware-utility && sudo chmod +x /usr/local/bin/vagrant-vmware-utility
|
||
vale:
|
||
_bin: vale
|
||
_github: https://github.com/errata-ai/vale
|
||
_name: Vale
|
||
brew: vale
|
||
choco: vale
|
||
go: github.com/errata-ai/vale@latest
|
||
vault:
|
||
_bin: vault
|
||
_desc: '[HashiCorp Vault](https://www.vaultproject.io/) secures, stores, and tightly controls access to tokens, passwords, certificates, API keys, and other secrets. Basically, it is a tool for managing any data that you want to tightly control access to. It also has some advanced integrations with systems like AWS.'
|
||
_docs: https://developer.hashicorp.com/vault/docs
|
||
_github: https://github.com/hashicorp/vault
|
||
_home: https://vaultproject.io/
|
||
_name: HashiCorp Vault
|
||
_service: vault
|
||
_service:brew: hashicorp/tap/vault
|
||
ansible: professormanhattan.vault
|
||
brew: hashicorp/tap/vault
|
||
yay: vault-cli
|
||
vdirsyncer:
|
||
_bin: vdirsyncer
|
||
_github: https://github.com/pimutils/vdirsyncer
|
||
_name: vdirsyncer
|
||
_todo: echo "TODO - Implement the following command after automating the process of setting up contact groups / calendars to sync" && echo "vdirsyncer discover contacts" && echo "vdirsyncer sync contacts" && echo "TODO - Add to cron" && echo "*/30 * * * * /usr/local/bin/vdirsyncer sync > /dev/null" && echo "This should be in _post instead of _pre - it is here for testing purposes"
|
||
pipx: vdirsyncer
|
||
vector:
|
||
_bin: vector
|
||
_desc: Vector is a lightweight, ultra-fast tool for building observability pipelines that lets you collect, transform, and route all your logs and metrics with one simple tool.
|
||
_docs: https://vector.dev/docs
|
||
_github: https://github.com/vectordotdev/vector
|
||
_home: https://vector.dev/
|
||
_name: Vector
|
||
_service: vector
|
||
# Unlisted on their website and formulae didn't seem to be registering the bin in the PATH
|
||
brew: vectordotdev/brew/vector
|
||
helm: https://helm.vector.dev
|
||
pacman: vector
|
||
script:darwin: curl --proto '=https' --tlsv1.2 -sSf https://sh.vector.dev | bash
|
||
script:linux: curl --proto '=https' --tlsv1.2 -sSf https://sh.vector.dev | bash
|
||
velero:
|
||
_bin: velero
|
||
_desc: '[Velero](https://velero.io/) gives you tools to back up and restore your Kubernetes cluster resources and persistent volumes'
|
||
_docs: https://velero.io/docs/
|
||
_github: https://github.com/vmware-tanzu/velero
|
||
_home: https://velero.io/
|
||
_name: velero
|
||
brew: velero
|
||
choco: velero
|
||
github: github.com/vmware-tanzu/velero
|
||
yay: velero-bin
|
||
vermin:
|
||
_bin: vermin
|
||
_github: https://github.com/mhewedy/vermin
|
||
_name: Vermin
|
||
go: github.com/mhewedy/vermin@latest
|
||
vhs:
|
||
_bin: vhs
|
||
_desc: Your CLI home video recorder
|
||
_docs: https://github.com/charmbracelet/vhs
|
||
_github: https://github.com/charmbracelet/vhs
|
||
_home: https://charm.sh/
|
||
_name: VHS
|
||
brew: vhs
|
||
go: github.com/charmbracelet/vhs@latest
|
||
nix-env: nixpkgs.vhs
|
||
pacman: vhs
|
||
port: vhs
|
||
scoop: vhs
|
||
xbps: vhs
|
||
vidmerger:
|
||
_bin: vidmerger
|
||
_deps:
|
||
- ffmpeg
|
||
_desc: Merge video & audio files via CLI
|
||
_docs: https://github.com/tgotwig/vidmerger
|
||
_github: https://github.com/tgotwig/vidmerger
|
||
_home: https://github.com/tgotwig/vidmerger
|
||
_name: VidMerger
|
||
brew: tgotwig/vidmerger/vidmerger
|
||
choco: vidmerger
|
||
vim:
|
||
_bin: vim
|
||
_desc: '[Vim](https://www.vim.org/) is a greatly improved version of the good old UNIX editor Vi'
|
||
_docs: https://www.vim.org/docs.php
|
||
_github: https://github.com/vim/vim
|
||
_home: https://www.vim.org/
|
||
_name: VIM
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
logg info "Installing VIM plugins" && vim +'PlugInstall --sync' +qall
|
||
# @description This script installs the extensions defined in `${XDG_CONFIG_HOME:-$HOME/.config}/coc/extensions/package.json`
|
||
# which should correlate to the Coc extensions defined in `${XDG_CONFIG_HOME:-$HOME/.config}/vim/vimrc`.
|
||
installCocExtensions() {
|
||
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/coc/extensions/package.json" ]; then
|
||
logg info "Running npm i --no-package-lock in ${XDG_CONFIG_HOME:-$HOME/.config}/coc/extensions"
|
||
cd "${XDG_CONFIG_HOME:-$HOME/.config}/coc/extensions" && npm i --no-package-lock
|
||
logg info "Running vim +CocUpdateSync +qall" && vim +CocUpdateSync +qall
|
||
else
|
||
logg info "Skipping Coc extension installation because ${XDG_CONFIG_HOME:-$HOME/.config}/coc/extensions/package.json is missing"
|
||
fi
|
||
}
|
||
logg info "Updating VIM coc extensions" && installCocExtensions
|
||
ansible: professormanhattan.vim
|
||
apt: vim
|
||
brew: vim
|
||
choco: vim
|
||
dnf: vim
|
||
pacman: vim
|
||
port: vim
|
||
scoop: vim
|
||
virtualbox:
|
||
_app: VirtualBox.app
|
||
_bin: null
|
||
_desc: '[VirtualBox](https://www.virtualbox.org/) is a free and open-source hosted hypervisor for x86 virtualization, developed by Oracle Corporation. Created by Innotek, it was acquired by Sun Microsystems in 2008, which was in turn acquired by Oracle in 2010. VirtualBox may be installed on Windows, macOS, Linux, Solaris and OpenSolaris.'
|
||
_docs: https://www.virtualbox.org/wiki/Documentation
|
||
_github: https://github.com/mirror/vbox
|
||
_home: https://www.virtualbox.org/
|
||
_name: VirtualBox
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file VirtualBox Extension Pack
|
||
# @brief Ensures the VirtualBox extension pack is installed.
|
||
# @description
|
||
# This script ensures the VirtualBox extension pack that corresponds with VirtualBox's version is properly installed.
|
||
|
||
### Run logic if VirtualBox is installed
|
||
if command -v VirtualBox > /dev/null; then
|
||
### Install VirtualBox extension pack if it is not installed already
|
||
if [ ! -d /usr/lib/virtualbox/ExtensionPacks/Oracle_VM_VirtualBox_Extension_Pack ] && [ ! -d /Applications/VirtualBox.app/Contents/MacOS/ExtensionPacks/Oracle_VM_VirtualBox_Extension_Pack ]; then
|
||
logg info 'Acquiring VirtualBox version information'
|
||
VBOX_VERSION="$(VirtualBox --help | head -n 1 | cut -f 6 -d' ')"
|
||
VBOX_VERSION="${VBOX_VERSION//v}"
|
||
|
||
### Set up folders
|
||
# Check for macOS installation before creating ExtensionPacks folder on Linux machines
|
||
if [ ! -d /Applications/VirtualBox.app ]; then
|
||
sudo mkdir -p /usr/lib/virtualbox/ExtensionPacks
|
||
fi
|
||
mkdir -p /tmp/vbox
|
||
cd /tmp/vbox
|
||
|
||
### Download extension pack
|
||
logg info 'Downloading VirtualBox extension pack'
|
||
curl -sSL https://download.virtualbox.org/virtualbox/$VBOX_VERSION/Oracle_VM_VirtualBox_Extension_Pack-$VBOX_VERSION.vbox-extpack -o /tmp/vbox/Oracle_VM_VirtualBox_Extension_Pack-$VBOX_VERSION.vbox-extpack || logg error 'Failed to download the VirtualBox extension pack so the extension pack installation will be skipped'
|
||
|
||
### Install extension pack
|
||
if [ -f /tmp/vbox/Oracle_VM_VirtualBox_Extension_Pack-$VBOX_VERSION.vbox-extpack ]; then
|
||
logg info 'Installing VirtualBox extension pack'
|
||
echo 'y' | sudo VBoxManage extpack install --replace /tmp/vbox/Oracle_VM_VirtualBox_Extension_Pack-$VBOX_VERSION.vbox-extpack
|
||
logg success 'Successfully installed VirtualBox extension pack'
|
||
fi
|
||
else
|
||
logg info 'VirtualBox Extension pack is already installed'
|
||
fi
|
||
else
|
||
logg info 'VirtualBox is not installed so VirtualBox Extension pack will not be installed'
|
||
fi
|
||
_post:choco: |
|
||
# TODO
|
||
# TODO
|
||
# TODO
|
||
# TODO
|
||
cd C:/Program Files/Oracle/VirtualBox/
|
||
# TODOFigure out how to get version without Ansible here and download / install the extpack
|
||
wget https://download.virtualbox.org/virtualbox/' + vbox_version + '/Oracle_VM_VirtualBox_Extension_Pack-' + vbox_version + '.vbox-extpack'
|
||
echo y | VBoxManage extpack install --replace ./Oracle_VM_VirtualBox_Extension_Pack.vbox-extpack
|
||
_pre:dnf: |
|
||
#!/usr/bin/env bash
|
||
. /etc/os-release
|
||
cat <<EOF | sudo tee /etc/yum.repos.d/virtualbox.repo
|
||
[virtualbox]
|
||
name=Fedora $releasever - $basearch - VirtualBox
|
||
baseurl=http://download.virtualbox.org/virtualbox/rpm/$ID/$VERSION_ID/\$basearch
|
||
enabled=1
|
||
gpgcheck=1
|
||
repo_gpgcheck=1
|
||
gpgkey=https://www.virtualbox.org/download/oracle_vbox.asc
|
||
EOF
|
||
sudo dnf -y install @development-tools
|
||
sudo dnf -y install kernel-headers kernel-devel dkms elfutils-libelf-devel qt5-qtx11extras
|
||
_todo: Add support for arm64 - currently brew install --cask virtualbox requires intel 64 bit
|
||
ansible: professormanhattan.virtualbox
|
||
apt: virtualbox
|
||
cask: virtualbox
|
||
choco: virtualbox
|
||
dnf: virtualbox
|
||
pacman: virtualbox
|
||
virtualenv:
|
||
_bin: virtualenv
|
||
_desc: Tool for creating isolated virtual python environments
|
||
_docs: https://virtualenv.pypa.io/en/latest/
|
||
_github: https://github.com/pypa/virtualenv
|
||
_name: virtualenv
|
||
brew: virtualenv
|
||
pipx: virtualenv
|
||
visual-studio:
|
||
# TODO - Figure out why we included this _post script
|
||
# _post:cask: 'APP_LINK="$(find "${HOMEBREW_PREFIX:-/opt/homebrew}/Caskroom/visual-studio" -mindepth 2 -maxdepth 2 -name "*.app*" | head -n1)" && open "$APP_LINK"'
|
||
_app: Visual Studio.app
|
||
_bin: null
|
||
_desc: '[Microsoft Visual Studio](https://visualstudio.microsoft.com/) is an integrated development environment from Microsoft. It is used to develop computer programs, as well as websites, web apps, web services and mobile apps.'
|
||
_docs: https://docs.microsoft.com/en-us/visualstudio/windows/?view=vs-2022
|
||
_github: Not open-source
|
||
_home: https://visualstudio.microsoft.com/
|
||
_name: Visual Studio
|
||
ansible:windows: professormanhattan.visualstudio
|
||
cask: visual-studio
|
||
choco: visualstudio2022community
|
||
vlc:
|
||
_app: VLC.app
|
||
_bin: vlc
|
||
_desc: '[VLC](https://www.videolan.org/) media player is a free and open-source, portable, cross-platform media player software, and streaming media server developed by the VideoLAN project. VLC is available for desktop operating systems, and mobile platforms, such as Android, iOS, iPadOS, Tizen, Windows 10 Mobile, and Windows Phone.'
|
||
_docs: https://www.videolan.org/doc/
|
||
_github: https://github.com/videolan/vlc
|
||
_home: https://www.videolan.org/vlc/
|
||
_name: VLC Media Player
|
||
ansible: professormanhattan.vlc
|
||
apt: vlc
|
||
cask: vlc
|
||
choco: vlc
|
||
flatpak: org.videolan.VLC
|
||
snap: vlc
|
||
vmware:
|
||
_app: VMware Fusion.app
|
||
_bin: vmware
|
||
_bin:cask: vmware-id
|
||
_github: false
|
||
_desc: '[VMWare Workstation](https://www.vmware.com/products/workstation-pro.html) (or [VMWare Fusion](https://www.vmware.com/products/fusion.html) in the case of macOS) is a hosted hypervisor that runs on x64 versions of Windows and Linux operating systems. It enables users to set up virtual machines on a single physical machine and use them simultaneously along with the host machine. It is similar to [VirtualBox](https://gitlab.com/megabyte-labs/ansible-roles/virtualbox).'
|
||
_docs: https://docs.vmware.com/
|
||
_home: https://www.vmware.com/
|
||
_name: VMWare
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file VMWare Configuration
|
||
# @brief Installs VMWare Workstation Pro on Linux devices, applies a "publicly-retrieved" license key (see disclaimer), and automatically accepts the terms and conditions
|
||
# @description
|
||
# This script ensures the user included `vmware` in their software installation list. It then checks for presence of the `vmware` utility. If it is not present, then the script:
|
||
#
|
||
# 1. Downloads the [VMWare Workstation Pro](https://www.vmware.com/content/vmware/vmware-published-sites/us/products/workstation-pro.html.html) Linux installer
|
||
# 2. Installs VMWare Workstation Pro
|
||
# 3. Passes options to the installation script that automatically apply a publicly retrived license key and accept the Terms & Conditions
|
||
#
|
||
# This script first checks if `vagrant`, `vmware`, and `vagrant-vmware-utility` are available in the `PATH`. If they are present, then the script
|
||
# configures the [`vagrant-vmware-utility`](https://developer.hashicorp.com/vagrant/docs/providers/vmware/vagrant-vmware-utility) by generating the required security certificates and enabling the service.
|
||
# This system package enables the capability of controlling both VMWare Workstation and VMWare Fusion with Vagrant.
|
||
#
|
||
# Since this script runs only when `vagrant`, `vmware`, and `vagrant-vmware-utility` are in the `PATH`, this means that it will run
|
||
# when you use an installation template that includes all three pieces of software in the software list defined in
|
||
# `home/.chezmoidata.yaml`.
|
||
#
|
||
# **DISCLAIMER:** If you plan on using VMWare Workstation for anything but evaluation purposes, then we highly suggest purchasing a copy
|
||
# of VMWare Workstation. The "publicly-retrived" license keys are scattered throughout GitHub and we are not exactly
|
||
# sure why they work. You can pass in your own key by utilizing the `VMWARE_WORKSTATION_LICENSE_KEY` environment variable. More details on
|
||
# using environment variables or repository-housed encrypted secrets can be found in our [Secrets documentation](https://install.doctor/docs/customization/secrets).
|
||
#
|
||
# ## VMWare on macOS
|
||
#
|
||
# This script only installs VMWare Workstation on Linux. The macOS-variant titled VMWare Fusion can be installed using a Homebrew
|
||
# cask so a "work-around" script does not have to be used.
|
||
#
|
||
# ## VMWare vs. Parallels vs. VirtualBox vs. KVM vs. Hyper-V
|
||
#
|
||
# There are a handful of VM virtualization providers you can choose from. VMWare is a nice compromise between OS compatibility and performance.
|
||
# Parallels, on the hand, might be better for macOS since it is designed specifically for macOS. Finally, VirtualBox is a truly free,
|
||
# open-source option that does not come with the same optimizations that VMWare and Parallels provide.
|
||
#
|
||
# Other virtualization options include KVM (Linux / macOS) and Hyper-V (Windows). These options are better used for headless
|
||
# systems.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [VMWare Workstation homepage](https://www.vmware.com/content/vmware/vmware-published-sites/us/products/workstation-pro.html.html)
|
||
# * [Vagrant VMWare Utility on GitHub](https://github.com/hashicorp/vagrant-vmware-desktop)
|
||
# * [`home/.chezmoidata.yaml`](https://github.com/megabyte-labs/install.doctor/blob/master/home/.chezmoidata.yaml)
|
||
# * [Default license key gist](https://gist.github.com/PurpleVibe32/30a802c3c8ec902e1487024cdea26251)
|
||
|
||
### Run logic if VMware is installed
|
||
if command -v vmware > /dev/null; then
|
||
### Build kernel modules if they are not present
|
||
if [ ! -f "/lib/modules/$(uname -r)/misc/vmmon.ko" ] || [ ! -f "/lib/modules/$(uname -r)/misc/vmnet.ko" ]; then
|
||
### Build VMWare host modules
|
||
logg info 'Building VMware host modules'
|
||
if sudo vmware-modconfig --console --install-all; then
|
||
logg success 'Built VMWare host modules successfully with sudo vmware-modconfig --console --install-all'
|
||
else
|
||
logg info 'Acquiring VMware version from CLI'
|
||
VMW_VERSION="$(vmware --version | cut -f 3 -d' ')"
|
||
mkdir -p /tmp/vmw_patch
|
||
cd /tmp/vmw_patch
|
||
logg info 'Downloading VMware host module patches' && curl -sSL "https://github.com/mkubecek/vmware-host-modules/archive/workstation-$VMW_VERSION.tar.gz" -o /tmp/vmw_patch/workstation.tar.gz
|
||
tar -xzf /tmp/vmw_patch/workstation.tar.gz
|
||
cd vmware*
|
||
logg info 'Running sudo make and sudo make install'
|
||
sudo make
|
||
sudo make install
|
||
logg success 'Successfully configured VMware host module patches'
|
||
fi
|
||
|
||
### Sign VMware host modules if Secure Boot is enabled
|
||
if [ -f /sys/firmware/efi ]; then
|
||
logg info 'Signing host modules'
|
||
mkdir -p /tmp/vmware
|
||
cd /tmp/vmware
|
||
openssl req -new -x509 -newkey rsa:2048 -keyout MOK.priv -outform DER -out MOK.der -nodes -days 36500 -subj "/CN=VMware/"
|
||
"/usr/src/linux-headers-$(uname -r)/scripts/sign-file" sha256 ./MOK.priv ./MOK.der "$(modinfo -n vmmon)"
|
||
"/usr/src/linux-headers-$(uname -r)/scripts/sign-file" sha256 ./MOK.priv ./MOK.der "$(modinfo -n vmnet)"
|
||
echo '' | mokutil --import MOK.der
|
||
logg success 'Successfully signed VMware host modules. Reboot the host before powering on VMs'
|
||
fi
|
||
|
||
### Patch VMware with Unlocker
|
||
if [ ! -f /usr/lib/vmware/isoimages/darwin.iso ]; then
|
||
logg info 'Acquiring VMware Unlocker latest release version'
|
||
UNLOCKER_URL="$(curl -sSL 'https://api.github.com/repos/DrDonk/unlocker/releases/latest' | jq -r '.assets[0].browser_download_url')"
|
||
mkdir -p /tmp/vmware-unlocker
|
||
cd /tmp/vmware-unlocker
|
||
logg info 'Downloading unlocker.zip'
|
||
curl -sSL "$UNLOCKER_URL" -o unlocker.zip
|
||
unzip unlocker.zip
|
||
cd linux
|
||
logg info 'Running the unlocker'
|
||
echo "y" | sudo ./unlock
|
||
logg success 'Successfully unlocked VMware for macOS compatibility'
|
||
else
|
||
logg info '/usr/lib/vmware/isoimages/darwin.iso is already present on the system so VMware macOS unlocking will not be performed'
|
||
fi
|
||
|
||
if [[ ! "$(test -d /proc && grep Microsoft /proc/version > /dev/null)" ]]; then
|
||
### Start / enable VMWare service
|
||
logg info 'Ensuring vmware.service is enabled and running'
|
||
sudo systemctl enable vmware.service
|
||
sudo systemctl restart vmware.service
|
||
|
||
### Start / enable VMWare Workstation Server service
|
||
logg info 'Ensuring vmware-workstation-server.service is enabled and running'
|
||
sudo systemctl enable vmware-workstation-server.service
|
||
sudo systemctl restart vmware-workstation-server.service
|
||
|
||
### Start / enable VMWare USB Arbitrator service
|
||
if command -v vmware-usbarbitrator.service > /dev/null; then
|
||
logg info 'Ensuring vmware-usbarbitrator.service is enabled and running'
|
||
sudo systemctl enable vmware-usbarbitrator.service
|
||
sudo systemctl restart vmware-usbarbitrator.service
|
||
else
|
||
logg warn 'vmware-usbarbitrator does not exist in the PATH'
|
||
fi
|
||
fi
|
||
else
|
||
logg info 'VMware host modules are present'
|
||
fi
|
||
else
|
||
logg warn 'VMware Workstation is not installed so the VMware Unlocker will not be installed'
|
||
fi
|
||
|
||
# @description Only run logic if both Vagrant and VMWare are installed
|
||
if command -v vagrant > /dev/null && command -v vmware-id > /dev/null; then
|
||
# @description Vagrant VMWare Utility configuration
|
||
if command -v vagrant-vmware-utility > /dev/null; then
|
||
if [ -f /usr/local/bin/certificates/vagrant-utility.key ]; then
|
||
logg info 'Assuming Vagrant VMWare Utility certificates have been properly generated since /usr/local/bin/certificates/vagrant-utility.key is present'
|
||
else
|
||
logg info 'Generating Vagrant VMWare Utility certificates'
|
||
sudo vagrant-vmware-utility certificate generate
|
||
logg success 'Generated Vagrant VMWare Utility certificates via vagrant-vmware-utility certificate generate'
|
||
fi
|
||
logg info 'Ensuring the Vagrant VMWare Utility service is enabled'
|
||
sudo vagrant-vmware-utility service install || EXIT_CODE=$?
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg info 'The Vagrant VMWare Utility command vagrant-vmware-utility service install failed. It is probably already setup.'
|
||
fi
|
||
fi
|
||
else
|
||
logg info 'Vagrant is not installed so the Vagrant plugins will not be installed'
|
||
logg info 'Vagrant or VMWare is not installed so the Vagrant VMWare utility will not be configured'
|
||
fi
|
||
ansible: professormanhattan.vmware
|
||
cask: vmware-fusion
|
||
script:linux: |
|
||
if ! command -v vmware > /dev/null; then
|
||
### Download VMWare Workstation
|
||
VMWARE_WORKSTATION_URL=https://www.vmware.com/go/getworkstation-linux
|
||
VMWARE_WORKSTATION_DIR=/tmp/workstation-downloads
|
||
mkdir -p "$VMWARE_WORKSTATION_DIR"
|
||
logg info 'Downloading VMware Workstation Installer' && curl -sSLA "Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20220101 Firefox/102.0" "$VMWARE_WORKSTATION_URL" -o "$VMWARE_WORKSTATION_DIR/tryworkstation-linux-64.sh"
|
||
### Register product key / license
|
||
if [ -n "$VMWARE_WORKSTATION_LICENSE_KEY" ]; then
|
||
logg info 'Registering VMware Workstation Pro license with serial number' && sudo "$VMWARE_WORKSTATION_DIR/tryworkstation-linux-64.sh" --eulas-agreed --console --required --set-setting vmware-workstation serialNumber "$VMWARE_WORKSTATION_LICENSE_KEY"
|
||
else
|
||
logg info 'Agreeing to VMWare Workstation Pro license (without serial number)' && sudo "$VMWARE_WORKSTATION_DIR/tryworkstation-linux-64.sh" --eulas-agreed --console --required
|
||
fi
|
||
logg success 'VMware Workstation installed successfully'
|
||
else
|
||
logg info 'VMware Workstation is already installed'
|
||
fi
|
||
volta:
|
||
_bin: volta
|
||
_desc: '[Volta](https://volta.sh/) is a hassle-free Javascript Tool Manager. It is a fast, reliable and universal tool manager. It supports multiple package managers and provides extensibility hooks for site-specific customization.'
|
||
_docs: https://docs.volta.sh/
|
||
_github: https://github.com/volta-cli/volta
|
||
_home: https://volta.sh
|
||
_name: volta-vm
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
export VOLTA_HOME="${XDG_DATA_HOME:-$HOME/.local/share}/volta"
|
||
export PATH="$VOLTA_HOME/bin:$PATH"
|
||
volta setup
|
||
volta install node@latest
|
||
volta install yarn@latest
|
||
ansible: professormanhattan.volta
|
||
brew: volta
|
||
scoop: volta
|
||
vpn:
|
||
_bin: null
|
||
_github: false
|
||
_desc: You can populate a configuration to power this role. When configured properly, the system's built-in VPN client will be configured with your desired settings.
|
||
_name: System VPN
|
||
ansible: professormanhattan.vpn
|
||
vscode:
|
||
_app: Visual Studio Code.app
|
||
_bin: code
|
||
_desc: '[Visual Studio Code](https://code.visualstudio.com/) is a freeware source-code editor made by Microsoft for Windows, Linux and macOS. Features include support for debugging, syntax highlighting, intelligent code completion, snippets, code refactoring, and embedded Git.'
|
||
_docs: https://code.visualstudio.com/api/references/vscode-api
|
||
_github: https://github.com/microsoft/vscode
|
||
_home: https://code.visualstudio.com/
|
||
_name: Visual Studio Code
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file VSCode Extensions / Global NPM Modules Fallback
|
||
# @brief Installs all of the Visual Studio Code extensions specified in the [`home/dot_config/Code/User/extensions.json`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User/extensions.json) file and installs NPM packages to the system `/` directory as a catch-all for tools that recursively search upwards for shared NPM configurations.
|
||
# @description
|
||
# This script loops through all the extensions listed in the [`home/dot_config/Code/User/extensions.json`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User/extensions.json)
|
||
# file. It installs the extensions when either Visual Studio Code or VSCodium is installed. If both are installed, then both will
|
||
# have the plugins automatically installed.
|
||
#
|
||
# The `extensions.json` file is used to house the plugin list so that if you decide to remove this auto-installer script then
|
||
# VSCode will retain some functionality from the file. It will show a popover card that recommends installing any plugins in the
|
||
# list that are not already installed.
|
||
#
|
||
# ## Plugin Settings
|
||
#
|
||
# Most of the plugin settings have been configured and optimized to work properly with the other default settings
|
||
# included by Install Doctor. These settings can be found in the [`home/dot_config/Code/User/settings.json` file](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User/settings.json).
|
||
# If you manage to come up with an improvement, please open a pull request so other users can benefit from your work.
|
||
#
|
||
# ## Default Extensions
|
||
#
|
||
# The default plugins in the `extensions.json` list are catered mostly towards full-stack web development. The technologies
|
||
# that are catered to by the default extensions relate to TypeScript, JavaScript, Go, Python, Rust, and many more technologies.
|
||
# Most of the plugins are not language-specific.
|
||
#
|
||
# ## Global NPM Modules Fallback
|
||
#
|
||
# This script makes fallback linter and code auto-fixer configurations globally available. Normally, configurations, like
|
||
# the ones used for ESLint, are installed at the project level by specifying the NPM package configuration
|
||
# in the `package.json` file (or via an `.eslintrc` file). However, whenever no configuration is present, IDEs like
|
||
# Visual Studio Code will recursively search upwards in the directory tree, trying to find an ESLint configuration.
|
||
#
|
||
# This script addresses this issue by installing a set of shared NPM packages that enhance the functionality of tools like ESLint
|
||
# by placing a `package.json` with all the necessary settings into the highest directory possible and then installing the package's
|
||
# modules. This normally results in a `package.json` file and `node_modules/` folder at the root of the system.
|
||
#
|
||
# ## NPM Packages Included
|
||
#
|
||
# To reduce clutter, all the configurations are mapped out in the `package.json` file. Our default `package.json` file includes
|
||
# the following configuration:
|
||
#
|
||
# ```json
|
||
# <!-- AUTO-GENERATED:START (REMOTE:url=https://gitlab.com/megabyte-labs/install.doctor/-/raw/master/home/dot_config/Code/User/package.json) -->
|
||
# {
|
||
# ...
|
||
# // Notable dependencies listed below
|
||
# "dependencies": {
|
||
# "eslint-config-strictlint": "latest",
|
||
# "jest-preset-ts": "latest",
|
||
# "prettier-config-strictlint": "latest",
|
||
# "remark-preset-strictlint": "latest",
|
||
# "stylelint-config-strictlint": "latest"
|
||
# },
|
||
# ...
|
||
# }
|
||
# <!-- AUTO-GENERATED:END -->
|
||
# ```
|
||
#
|
||
# ## Strict Lint
|
||
#
|
||
# More details on the shared configurations can be found at [StrictLint.com](https://strictlint.com).
|
||
# Strict Lint is another brand maintained by Megabyte Labs that is home to many of the well-crafted
|
||
# shared configurations that are included in our default NPM configuration fallback settings.
|
||
#
|
||
# ## Notes
|
||
#
|
||
# * If the system root directory is not writable (even with `sudo`), then the shared modules are installed to the provisioning user's `$HOME` directory
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [`package.json` configuration file](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User/package.json)
|
||
# * [StrictLint.com documentation](https://strictlint.com/docs)
|
||
# * [Visual Studio Code settings folder](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User)
|
||
# * [Visual Studio Code `extensions.json`](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/Code/User/extensions.json)
|
||
|
||
### Hides useless error during extension installations
|
||
# Error looks like:
|
||
# (node:53151) [DEP0005] DeprecationWarning: Buffer() is deprecated due to security and usability issues. Please use the Buffer.alloc(), Buffer.allocUnsafe(), or Buffer.from() methods instead.
|
||
# (Use `Electron --trace-deprecation ...` to show where the warning was created)
|
||
export NODE_OPTIONS=--throw-deprecation
|
||
|
||
# @description Install Visual Studio Code extensions if they are not already installed (by checking the `code --list-extensions` output)
|
||
if command -v code > /dev/null; then
|
||
EXTENSIONS="$(code --list-extensions)"
|
||
jq -r '.recommendations[]' "${XDG_CONFIG_HOME:-$HOME/.config}/Code/User/extensions.json" | while read EXTENSION; do
|
||
if ! echo "$EXTENSIONS" | grep -iF "$EXTENSION" > /dev/null; then
|
||
logg info 'Installing Visual Studio Code extension '"$EXTENSION"'' && code --install-extension "$EXTENSION"
|
||
logg success 'Installed '"$EXTENSION"''
|
||
else
|
||
logg info ''"$EXTENSION"' already installed'
|
||
fi
|
||
done
|
||
else
|
||
logg info 'code executable not available - skipping plugin install process for it'
|
||
fi
|
||
|
||
if command -v code > /dev/null && command -v npm > /dev/null && [ -f "${XDG_DATA_HOME:-$HOME/.local/share}/vscode/package.json" ]; then
|
||
### Install linter fallback node_modules / package.json to system or home directory
|
||
if sudo cp -f "${XDG_DATA_HOME:-$HOME/.local/share}/vscode/package.json" /package.json; then
|
||
logg info 'Successfully copied linter fallback configurations package.json to /package.json'
|
||
logg info 'Installing system root directory node_modules'
|
||
cd / && sudo npm i --quiet --no-package-lock || EXIT_CODE=$?
|
||
else
|
||
logg warn 'Unable to successfully copy linter fallback configurations package.json to /package.json'
|
||
logg info 'Installing linter fallback configurations node_modules to home directory instead'
|
||
cp -f "${XDG_DATA_HOME:-$HOME/.local/share}/vscode/package.json" "$HOME/package.json"
|
||
cd ~ && npm i --quiet --no-package-lock || EXIT_CODE=$?
|
||
fi
|
||
|
||
### Log message if install failed
|
||
if [ -n "$EXIT_CODE" ]; then
|
||
logg warn 'Possible error(s) were detected while installing linter fallback configurations to the home directory.'
|
||
logg info "Exit code: $EXIT_CODE"
|
||
else
|
||
logg info 'Installed linter fallback configuration node_modules'
|
||
fi
|
||
else
|
||
logg info 'Skipping installation of fallback linter configurations because one or more of the dependencies is missing.'
|
||
fi
|
||
ansible: professormanhattan.vscode
|
||
cask: visual-studio-code
|
||
choco: vscode
|
||
flatpak: com.visualstudio.code
|
||
snap: code --classic
|
||
yay: visual-studio-code-bin
|
||
vscodium:
|
||
_app: VSCodium.app
|
||
_bin: codium
|
||
_github: https://github.com/VSCodium/vscodium
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @brief See `_post` entry for `vscode` for a description
|
||
export NODE_OPTIONS=--throw-deprecation
|
||
# @description Check for the presence of the `codium` command in the `PATH` and install extensions for VSCodium if it is present
|
||
if command -v codium > /dev/null; then
|
||
EXTENSIONS="$(codium --list-extensions)"
|
||
jq -r '.recommendations[]' "${XDG_CONFIG_HOME:-$HOME/.config}/Code/User/extensions.json" | while read EXTENSION; do
|
||
if ! echo "$EXTENSIONS" | grep -iF "$EXTENSION" > /dev/null; then
|
||
logg info 'Installing VSCodium extension '"$EXTENSION"'' && codium --install-extension "$EXTENSION" && logg success 'Installed '"$EXTENSION"''
|
||
else
|
||
logg info ''"$EXTENSION"' already installed'
|
||
fi
|
||
done
|
||
else
|
||
logg info 'codium executable not available - skipping plugin install process for it'
|
||
fi
|
||
appimage: vscodium/vscodium
|
||
cask: vscodium
|
||
choco: vscodium
|
||
flatpak: com.vscodium.codium
|
||
nix: nixpkgs.vscodium
|
||
scoop: vscodium
|
||
snap: codium --classic
|
||
winget: vscodium
|
||
yay: vscodium-bin
|
||
vup:
|
||
_bin: vup
|
||
_github: https://github.com/vup-app/vup
|
||
flatpak: app.vup.Vup
|
||
w3m:
|
||
_bin: w3m
|
||
_desc: w3m is a pager/text-based WWW browser. You can browse local documents and/or documents on the WWW using a terminal emulator.
|
||
_docs: https://w3m.sourceforge.net/MANUAL
|
||
_github: https://github.com/tats/w3m
|
||
_home: https://tracker.debian.org/pkg/w3m
|
||
_name: w3m
|
||
apt: w3m
|
||
brew: w3m
|
||
dnf: w3m
|
||
pacman: w3m
|
||
port: w3m
|
||
zypper: w3m
|
||
wails:
|
||
_bin: wails
|
||
_desc: '[Wails](https://github.com/wailsapp/wails) offers a different approach to providing web interfaces to Go programs: it provides the ability to wrap both Go code and a web frontend into a single binary.'
|
||
_name: Wails
|
||
_github: https://github.com/wailsapp/wails
|
||
ansible: professormanhattan.wails
|
||
go: github.com/wailsapp/wails/cmd/wails@latest
|
||
wallpaper-cli:
|
||
_bin: wallpaper
|
||
_github: https://github.com/sindresorhus/wallpaper-cli
|
||
_name: Wallpaper CLI
|
||
npm: wallpaper-cli
|
||
warp:
|
||
_app: Cloudflare WARP.app
|
||
_bin: warp-cli
|
||
_github: false
|
||
_desc: '[Cloudflare WARP Client](https://cloudflarewarp.com/) is a free app that makes your Internet safer'
|
||
_home: https://cloudflarewarp.com/
|
||
_name: Cloudflare WARP Client
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file CloudFlare WARP
|
||
# @brief Installs CloudFlare WARP, ensures proper security certificates are in place, and connects the device to CloudFlare WARP.
|
||
# @description
|
||
# This script is intended to connect the device to CloudFlare's Zero Trust network with nearly all of its features unlocked.
|
||
# Homebrew is used to install the `warp-cli` on macOS. On Linux, it can install `warp-cli` on most Debian systems and some RedHat
|
||
# systems. CloudFlare WARP's [download page](https://pkg.cloudflareclient.com/packages/cloudflare-warp) is somewhat barren.
|
||
#
|
||
# ## MDM Configuration
|
||
#
|
||
# If CloudFlare WARP successfully installs, it first applies MDM configurations (managed configurations). If you would like CloudFlare
|
||
# WARP to connect completely headlessly (while losing some "user-posture" settings), then you can populate the following three secrets:
|
||
#
|
||
# 1. `CLOUDFLARE_TEAMS_CLIENT_ID` - The ID from a CloudFlare Teams service token. See [this article](https://developers.cloudflare.com/cloudflare-one/identity/service-tokens/).
|
||
# 2. `CLOUDFLARE_TEAMS_CLIENT_SECRET` - The secret from a CloudFlare Teams service token.
|
||
# 3. `CLOUDFLARE_TEAMS_ORG` - The ID of your Zero Trust organization. This variable must be passed in as an environment variable and is housed in the `home/.chezmoi.yaml.tmpl` file. If you do not want to pass an environment variable, you can change the default value in `home/.chezmoi.yaml.tmpl` on your own fork.
|
||
#
|
||
# The two variables above can be passed in using either of the methods described in the [Secrets documentation](https://install.doctor/docs/customization/secrets).
|
||
#
|
||
# ## Headless CloudFlare WARP Connection
|
||
#
|
||
# Even if you do not provide the two variables mentioned above, the script will still headlessly connect your device to the public CloudFlare WARP
|
||
# network, where you will get some of the benefits of a VPN for free. Otherwise, if they were passed in, then the script
|
||
# finishes by connecting to CloudFlare Teams.
|
||
#
|
||
# ## Application Certificates
|
||
#
|
||
# This script applies the techniques described on the [CloudFlare Zero Trust Install certificate manually page](https://developers.cloudflare.com/cloudflare-one/connections/connect-devices/warp/user-side-certificates/install-cloudflare-cert/)
|
||
# to configure the following utilities that leverage seperate certificate authorities:
|
||
#
|
||
# * Python
|
||
# * NPM
|
||
# * Git
|
||
# * Google Cloud SDK
|
||
# * AWS CLI
|
||
# * Google Drive for desktop
|
||
#
|
||
# Settings used to configure Firefox are housed inside of the Firefox configuration files stored as seperate configuration files
|
||
# outside of this script. **Note: The scripts that enable CloudFlare certificates for all these programs are currently commented out
|
||
# in this script.**
|
||
#
|
||
# ## Notes
|
||
#
|
||
# According to CloudFlare Teams [documentation on MDM deployment](https://developers.cloudflare.com/cloudflare-one/connections/connect-devices/warp/deployment/mdm-deployment/),
|
||
# on macOS the `com.cloudflare.warp.plist` file gets erased on reboot. Also, according to the documentation, the only way around this is to leverage
|
||
# an MDM SaaS provider like JumpCloud.
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [Linux managed configuration](https://github.com/megabyte-labs/install.doctor/tree/master/home/dot_config/warp/private_mdm.xml.tmpl)
|
||
# * [macOS managed configuration](https://github.com/megabyte-labs/install.doctor/tree/master/home/Library/Managed%20Preferences/private_com.cloudflare.warp.plist.tmpl)
|
||
|
||
SSL_CERT_PATH="/etc/ssl/cert.pem"
|
||
|
||
### Install CloudFlare WARP (on non-WSL *nix systems)
|
||
if [[ ! "$(test -d /proc && grep Microsoft /proc/version > /dev/null)" ]]; then
|
||
if [ -d /System ] && [ -d /Applications ]; then
|
||
### Install on macOS
|
||
if [ ! -d "/Applications/Cloudflare WARP.app" ]; then
|
||
brew install --cask --no-quarantine --quiet cloudflare-warp
|
||
else
|
||
logg info 'Cloudflare WARP already installed'
|
||
fi
|
||
elif [ '{{ .host.distro.id }}' = 'debian' ]; then
|
||
### Add CloudFlare WARP desktop app apt-get source
|
||
if [ ! -f /etc/apt/sources.list.d/cloudflare-client.list ]; then
|
||
logg info 'Adding CloudFlare WARP keyring'
|
||
curl https://pkg.cloudflareclient.com/pubkey.gpg | sudo gpg --yes --dearmor --output /usr/share/keyrings/cloudflare-warp-archive-keyring.gpg
|
||
logg info 'Adding apt source reference'
|
||
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/cloudflare-warp-archive-keyring.gpg] https://pkg.cloudflareclient.com/ $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/cloudflare-client.list
|
||
fi
|
||
|
||
### Update apt-get and install the CloudFlare WARP CLI
|
||
sudo apt-get update && sudo apt-get install -y cloudflare-warp
|
||
elif [ '{{ .host.distro.id }}' = 'ubuntu' ]; then
|
||
### Add CloudFlare WARP desktop app apt-get source
|
||
if [ ! -f /etc/apt/sources.list.d/cloudflare-client.list ]; then
|
||
logg info 'Adding CloudFlare WARP keyring'
|
||
curl https://pkg.cloudflareclient.com/pubkey.gpg | sudo gpg --yes --dearmor --output /usr/share/keyrings/cloudflare-warp-archive-keyring.gpg
|
||
logg info 'Adding apt source reference'
|
||
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/cloudflare-warp-archive-keyring.gpg] https://pkg.cloudflareclient.com/ $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/cloudflare-client.list
|
||
fi
|
||
|
||
### Update apt-get and install the CloudFlare WARP CLI
|
||
sudo apt-get update && sudo apt-get install -y cloudflare-warp
|
||
elif command -v dnf > /dev/null && command -v rpm > /dev/null; then
|
||
### This is made for CentOS 8 and works on Fedora 36 (hopefully 36+ as well) with `nss-tools` as a dependency
|
||
sudo dnf instal -y nss-tools || NSS_TOOL_EXIT=$?
|
||
if [ -n "$NSS_TOOL_EXIT" ]; then
|
||
logg warn 'Unable to install nss-tools which was a requirement on Fedora 36 and assumed to be one on other systems as well.'
|
||
fi
|
||
### According to the download site, this is the only version available for RedHat-based systems
|
||
sudo rpm -ivh https://pkg.cloudflareclient.com/cloudflare-release-el8.rpm || RPM_EXIT_CODE=$?
|
||
if [ -n "$RPM_EXIT_CODE" ]; then
|
||
logg error 'Unable to install CloudFlare WARP using RedHat 8 RPM package'
|
||
fi
|
||
fi
|
||
fi
|
||
|
||
|
||
### Ensure certificate is installed
|
||
# Source: https://developers.cloudflare.com/cloudflare-one/static/documentation/connections/Cloudflare_CA.crt
|
||
# Source: https://developers.cloudflare.com/cloudflare-one/static/documentation/connections/Cloudflare_CA.pem
|
||
if [ -d /System ] && [ -d /Applications ] && command -v warp-cli > /dev/null; then
|
||
### Ensure certificate installed on macOS
|
||
if [ -z "$SSH_CONNECTION" ]; then
|
||
# if [ -z "$HEADLESS_INSTALL" ]; then
|
||
# logg info '**macOS Manual Security Permission** Requesting security authorization for Cloudflare trusted certificate'
|
||
# sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.crt"
|
||
# fi
|
||
logg info 'Updating the OpenSSL CA Store to include the Cloudflare certificate'
|
||
echo | sudo tee -a "$SSL_CERT_PATH" < "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" > /dev/null
|
||
echo "" | sudo tee -a "$SSL_CERT_PATH"
|
||
else
|
||
logg warn 'Session is SSH so adding Cloudflare encryption key to trusted certificates via the security program is being bypassed since it requires Touch ID / Password verification.'
|
||
fi
|
||
if [ -f "/usr/local/opt/openssl@3/bin/c_rehash" ]; then
|
||
# Location on Intel macOS
|
||
logg info 'Ensuring /usr/local/etc/openssl@3/certs directory exists' && mkdir -p /usr/local/etc/openssl@3/certs
|
||
logg info 'Adding Cloudflare certificate to /usr/local/etc/openssl@3/certs/Cloudflare_CA.pem'
|
||
echo | sudo cat - "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" >> /usr/local/etc/openssl@3/certs/Cloudflare_CA.pem
|
||
logg info 'Running /usr/local/opt/openssl@3/bin/c_rehash'
|
||
/usr/local/opt/openssl@3/bin/c_rehash > /dev/null && logg info 'OpenSSL certificate rehash successful'
|
||
elif [ -f "${HOMEBREW_PREFIX:-/opt/homebrew}/opt/openssl@3/bin/c_rehash" ]; then
|
||
# Location on arm64 macOS and custom Homebrew locations
|
||
logg info "Ensuring ${HOMEBREW_PREFIX:-/opt/homebrew}/etc/openssl@3/certs directory exists" && mkdir -p "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/openssl@3/certs"
|
||
logg info "Adding Cloudflare certificate to ${HOMEBREW_PREFIX:-/opt/homebrew}/etc/openssl@3/certs/Cloudflare_CA.pem"
|
||
echo | sudo cat - "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" >> "${HOMEBREW_PREFIX:-/opt/homebrew}/etc/openssl@3/certs/Cloudflare_CA.pem"
|
||
logg info "Running ${HOMEBREW_PREFIX:-/opt/homebrew}/opt/openssl@3/bin/c_rehash"
|
||
"${HOMEBREW_PREFIX:-/opt/homebrew}/opt/openssl@3/bin/c_rehash" > /dev/null && logg info 'OpenSSL certificate rehash successful'
|
||
else
|
||
logg warn 'Unable to add Cloudflare_CA.pem because /usr/local/etc/openssl@3/certs and /opt/homebrew/etc/openssl@3/certs do not exist!'
|
||
fi
|
||
elif command -v warp-cli > /dev/null; then
|
||
# System is Linux
|
||
if command -v dpkg-reconfigure > /dev/null; then
|
||
if [ -d /usr/local/share/ca-certificates ]; then
|
||
logg info 'Copying CloudFlare Teams PEM file to /usr/local/share/ca-certificates/Cloudflare_CA.crt'
|
||
sudo cp -f "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" /usr/local/share/ca-certificates/Cloudflare_CA.crt
|
||
logg info 'dpkg-reconfigure executable detected so using Debian/Ubuntu method of updating system trusted certificates to include CloudFlare Teams certificate'
|
||
sudo dpkg-reconfigure ca-certificates -p high
|
||
SSL_CERT_PATH="/etc/ssl/certs/ca-certificates.crt"
|
||
else
|
||
logg warn 'No /usr/local/share/ca-certificates folder present'
|
||
fi
|
||
elif command -v update-ca-trust > /dev/null; then
|
||
if [ -d /etc/pki/ca-trust/source/anchors ]; then
|
||
logg info 'Copying CloudFlare Teams certificates to /etc/pki/ca-trust/source/anchors'
|
||
sudo cp -f "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.crt" "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" /etc/pki/ca-trust/source/anchors
|
||
logg info 'update-ca-trust executable detected so using CentOS/Fedora method of updating system trusted certificates to include CloudFlare Teams certificate'
|
||
sudo update-ca-trust
|
||
SSL_CERT_PATH="/etc/pki/tls/certs/ca-bundle.crt"
|
||
else
|
||
logg warn '/etc/pki/ca-trust/source/anchors does not exist so skipping the system certificate update process'
|
||
fi
|
||
fi
|
||
fi
|
||
|
||
if command -v warp-cli > /dev/null; then
|
||
### Application certificate configuration
|
||
# Application-specific certificate authority modification is currently commented out because
|
||
# it is merely for traffic inspection and `npm install` fails when configured to use the CloudFlare
|
||
# certificate and the WARP client is not running.
|
||
### Git
|
||
if command -v git > /dev/null; then
|
||
logg info "Configuring git to use $SSL_CERT_PATH"
|
||
git config --global http.sslcainfo "$SSL_CERT_PATH"
|
||
fi
|
||
|
||
### NPM
|
||
if command -v npm > /dev/null; then
|
||
logg info "Configuring npm to use $SSL_CERT_PATH"
|
||
npm config set cafile "$SSL_CERT_PATH"
|
||
fi
|
||
|
||
### Python
|
||
if command -v python3 > /dev/null; then
|
||
### Ensure Certifi package is available globally
|
||
if ! pip3 list | grep certifi > /dev/null; then
|
||
if command -v brew > /dev/null; then
|
||
logg info 'Ensuring Python certifi is installed via Homebrew'
|
||
brew install --quiet certifi
|
||
else
|
||
logg info 'Ensuring certifi is installed globally for Python 3'
|
||
pip3 install certifi
|
||
fi
|
||
fi
|
||
|
||
### Copy CloudFlare PEM file to Python 3 location
|
||
logg info "Configuring python3 / python to use "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem""
|
||
echo | cat - "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" >> $(python3 -m certifi)
|
||
fi
|
||
|
||
### Google Cloud SDK
|
||
if command -v gcloud > /dev/null; then
|
||
logg info "Configuring gcloud to use "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" and "$HOME/.local/etc/ssl/gcloud/ca.pem""
|
||
mkdir -p "$HOME/.local/etc/ssl/gcloud"
|
||
cat "$HOME/.local/etc/ssl/curl/cacert.pem" "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" > "$HOME/.local/etc/ssl/gcloud/ca.pem"
|
||
gcloud config set core/custom_ca_certs_file "$HOME/.local/etc/ssl/gcloud/ca.pem"
|
||
fi
|
||
|
||
### Google Drive for desktop (macOS)
|
||
if [ -d "/Applications/Google Drive.app" ]; then
|
||
if [ -d "/Applications/Google Drive.app/Contents/Resources" ]; then
|
||
logg info "Combining Google Drive roots.pem with CloudFlare certificate"
|
||
mkdir -p "$HOME/.local/etc/ssl/google-drive"
|
||
cat "$HOME/.local/etc/ssl/cloudflare/Cloudflare_CA.pem" "/Applications/Google Drive.app/Contents/Resources/roots.pem" >> "$HOME/.local/etc/ssl/google-drive/roots.pem"
|
||
sudo defaults write /Library/Preferences/com.google.drivefs.settings TrustedRootsCertsFile -string "$HOME/.local/etc/ssl/google-drive/roots.pem"
|
||
else
|
||
logg warn 'Google Drive.app installed but roots.pem is not available yet'
|
||
fi
|
||
fi
|
||
|
||
|
||
### Ensure MDM settings are applied (deletes after reboot on macOS)
|
||
### TODO: Ensure `.plist` can be added to `~/Library/Managed Preferences` and not just `/Library/Managed Preferences`
|
||
# Source: https://developers.cloudflare.com/cloudflare-one/connections/connect-devices/warp/deployment/mdm-deployment/
|
||
# Source for JumpCloud: https://developers.cloudflare.com/cloudflare-one/static/documentation/connections/CloudflareWARP.mobileconfig
|
||
if [ -d /System ] && [ -d /Applications ]; then
|
||
sudo cp -f "$HOME/Library/Managed Preferences/com.cloudflare.warp.plist" '/Library/Managed Preferences/com.cloudflare.warp.plist'
|
||
sudo plutil -convert binary1 '/Library/Managed Preferences/com.cloudflare.warp.plist'
|
||
|
||
### Enable CloudFlare WARP credentials auto-populate (since file is deleted when not managed with MDM)
|
||
if [ -f "$HOME/Library/LaunchDaemons/com.cloudflare.warp.plist" ] && [ ! -f "/Library/LaunchDaemons/com.cloudflare.warp.plist" ]; then
|
||
sudo mkdir -p /Library/LaunchDaemons
|
||
sudo cp -f "$HOME/Library/LaunchDaemons/com.cloudflare.warp.plist" '/Library/LaunchDaemons/com.cloudflare.warp.plist'
|
||
sudo launchctl load "/Library/LaunchDaemons/com.cloudflare.warp.plist"
|
||
fi
|
||
elif [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/warp/mdm.xml" ]; then
|
||
sudo mkdir -p /var/lib/cloudflare-warp
|
||
sudo cp -f "${XDG_CONFIG_HOME:-$HOME/.config}/warp/mdm.xml" /var/lib/cloudflare-warp/mdm.xml
|
||
fi
|
||
|
||
### Register CloudFlare WARP
|
||
if warp-cli --accept-tos status | grep 'Registration missing' > /dev/null; then
|
||
logg info 'Registering CloudFlare WARP'
|
||
warp-cli --accept-tos register
|
||
else
|
||
logg info 'Either there is a misconfiguration or the device is already registered with CloudFlare WARP'
|
||
fi
|
||
|
||
### Connect CloudFlare WARP
|
||
if warp-cli --accept-tos status | grep 'Disconnected' > /dev/null; then
|
||
logg info 'Connecting to CloudFlare WARP'
|
||
warp-cli --accept-tos connect > /dev/null && logg success 'Connected to CloudFlare WARP'
|
||
else
|
||
logg info 'Either there is a misconfiguration or the device is already connected with CloudFlare WARP'
|
||
fi
|
||
else
|
||
logg warn 'warp-cli was not installed so CloudFlare WARP cannot be joined'
|
||
fi
|
||
# Needs tuning - possibly unrelated, but internet wasn't working on Ubuntu after installing this and removed it during debugging
|
||
# ansible: professormanhattan.warp
|
||
apt: cloudflare-warp
|
||
cask: cloudflare-warp
|
||
choco: warp
|
||
warp-terminal:
|
||
_app: Warp.app
|
||
_bin: warp
|
||
_desc: Warp is a blazingly-fast modern Rust based GPU-accelerated terminal built to make you and your team more productive.
|
||
_docs: https://docs.warp.dev/getting-started/readme
|
||
_env:
|
||
WARP_TERMINAL_APPDATA:
|
||
cask: "$HOME/Library/Application Support/dev.warp.Warp-Stable"
|
||
_github: https://github.com/warpdotdev/Warp
|
||
_home: https://www.warp.dev/
|
||
_name: Warp Terminal
|
||
appimage: https://app.warp.dev/get_warp?linux=true&package=appimage
|
||
apt: https://app.warp.dev/get_warp?package=deb
|
||
cask: warp
|
||
dnf: https://app.warp.dev/get_warp?package=rpm
|
||
pacman: https://app.warp.dev/get_warp?linux=true&package=pacman
|
||
warp-transfer:
|
||
_bin: warp-transfer
|
||
_github: false
|
||
flatpak: app.drey.Warp
|
||
watchexec:
|
||
_bin: watchexec
|
||
_desc: Executes commands in response to file modifications.
|
||
_docs: https://watchexec.github.io/docs/glob-patterns.html
|
||
_github: https://github.com/watchexec/watchexec
|
||
_home: https://watchexec.github.io/
|
||
_name: Watchexec
|
||
apk: watchexec
|
||
# Apt is from an unofficial channel
|
||
# apt: watchexec
|
||
baulk: watchexec
|
||
brew: watchexec
|
||
cargo: watchexec-cli
|
||
choco: watchexec
|
||
emerge: watchexec
|
||
nix: watchexec
|
||
pacman: watchexec
|
||
scoop: watchexec
|
||
xbps: watchexec
|
||
watchman:
|
||
_bin: watchman
|
||
_desc: '[Watchman](https://github.com/facebook/watchman), an open-source Facebook product, can be used to watch files and record when they change. It can also trigger actions when matching files change.'
|
||
_github: https://github.com/facebook/watchman
|
||
_name: Watchman
|
||
ansible: professormanhattan.watchman
|
||
brew: watchman
|
||
choco: watchman
|
||
port: watchman
|
||
scoop: watchman
|
||
waypoint:
|
||
_bin: waypoint
|
||
_desc: '[HashiCorp Waypoint](https://www.waypointproject.io/) allows developers to deploy, manage, and observe their applications through a consistent abstraction of underlying infrastructure. Waypoint works with Kubernetes, ECS and many other platforms.'
|
||
_docs: https://developer.hashicorp.com/waypoint/docs
|
||
_github: https://github.com/hashicorp/waypoint
|
||
_home: https://www.waypointproject.io/
|
||
_name: HashiCorp Waypoint
|
||
ansible: professormanhattan.waypoint
|
||
brew: hashicorp/tap/waypoint
|
||
scoop: waypoint
|
||
wazuh:
|
||
# TODO: Add logic to .chezmoiscripts that ensures the proper Wazuh settings are in place
|
||
_bin: wazuh-agentd
|
||
_desc: '[Wazuh](https://wazuh.com/) is a free, open source and enterprise-ready security monitoring solution for threat detection, integrity monitoring, incident response and compliance.'
|
||
_docs: https://documentation.wazuh.com/current/index.html
|
||
_github: https://github.com/wazuh/wazuh
|
||
_home: https://wazuh.com/
|
||
_name: Wazuh
|
||
_service:linux: wazuh-agent
|
||
_service:windows: wazuh-agent
|
||
_when:darwin: '! test -f /Library/Ossec/bin/agent-auth'
|
||
_when:linux: '! test -f /var/ossec/bin/agent-auth'
|
||
_when:windows: '! test -f "C:\Program Files (x86)\ossec-agent\agent-auth.exe"'
|
||
choco: wazuh-agent
|
||
script:darwin: if ! csrutil status | grep enabled > /dev/null; then cd /tmp && curl -sSL https://packages.wazuh.com/4.x/macos/wazuh-agent-4.4.4-1.pkg > wazuh-agent.pkg && sudo launchctl setenv WAZUH_MANAGER "$WAZUH_MANAGER" && sudo installer -pkg wazuh-agent.pkg -target / && sudo chmod 755 /Library/Ossec && sudo chmod 755 /Library/Ossec/bin && rm /tmp/wazuh-agent.pkg && sudo wazuh-control start; else echo "WARNING - Skipping Wazuh Agent installation because System Integrity Protection is enabled. Disabling it requires booting into recovery and running csrutil disable, installing Wazuh Agent normally, and then re-enabling it again in recovery mode."; fi
|
||
script:linux: if command -v apt-get > /dev/null; then curl -s https://packages.wazuh.com/key/GPG-KEY-WAZUH | sudo gpg --no-default-keyring --keyring gnupg-ring:/usr/share/keyrings/wazuh.gpg --import && sudo chmod 644 /usr/share/keyrings/wazuh.gpg && echo "deb [signed-by=/usr/share/keyrings/wazuh.gpg] https://packages.wazuh.com/4.x/apt/ stable main" | sudo tee -a /etc/apt/sources.list.d/wazuh.list && sudo apt-get update && sudo apt-get install -y wazuh-agent; elif command -v dnf > /dev/null; then echo "[wazuh]" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "gpgcheck=1" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "gpgkey=https://packages.wazuh.com/key/GPG-KEY-WAZUH" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "enabled=1" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "name=EL-\$releasever - Wazuh" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "baseurl=https://packages.wazuh.com/4.x/yum/" | sudo tee -a /etc/yum.repos.d/wazuh.repo && echo "protect=1" | sudo tee -a /etc/yum.repos.d/wazuh.repo && sudo rpm --import https://packages.wazuh.com/key/GPG-KEY-WAZUH && sudo dnf install -y wazuh-agent; elif command -v zypper > /dev/null; then echo "[wazuh]" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "gpgcheck=1" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "gpgkey=https://packages.wazuh.com/key/GPG-KEY-WAZUH" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "enabled=1" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "name=EL-$releasever - Wazuh" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "baseurl=https://packages.wazuh.com/4.x/yum/" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && echo "protect=1" | sudo tee -a /etc/zypp/repos.d/wazuh.repo && sudo rpm --import https://packages.wazuh.com/key/GPG-KEY-WAZUH && sudo zypper install -y wazuh-agent; elif command -v apk > /dev/null; then sudo wget -O /etc/apk/keys/alpine-devel@wazuh.com-633d7457.rsa.pub https://packages.wazuh.com/key/alpine-devel%40wazuh.com-633d7457.rsa.pub && echo "https://packages.wazuh.com/4.x/alpine/v3.12/main" | sudo tee -a /etc/apk/repositories && sudo apk update && sudo apk add wazuh-agent; fi
|
||
web-ext:
|
||
_bin: web-ext
|
||
_github: https://github.com/mozilla/web-ext
|
||
_name: Web Extension CLI by Mozilla
|
||
npm: web-ext
|
||
web-font-generator:
|
||
_bin: web-font-generator
|
||
_github: https://github.com/rafaelmardojai/webfont-kit-generator
|
||
flatpak: com.rafaelmardojai.WebfontKitGenerator
|
||
webpquicklook:
|
||
_github: https://github.com/emin/WebPQuickLook
|
||
_name: QLWebP
|
||
_when:cask: '! test -d "$HOME/Library/QuickLook/WebpQuickLook.qlgenerator"'
|
||
cask: webpquicklook
|
||
websocat:
|
||
_bin: websocat
|
||
_desc: CLI for interacting with web sockets
|
||
_github: https://github.com/vi/websocat
|
||
_name: websocat
|
||
brew: websocat
|
||
cargo: websocat
|
||
github: github.com/vi/websocat
|
||
pkg: websocat
|
||
port: websocat
|
||
webtorrent:
|
||
_app: WebTorrent.app
|
||
_bin: webtorrent
|
||
_desc: Streaming torrent app for Mac, Windows, and Linux
|
||
_github: https://github.com/webtorrent/webtorrent-desktop
|
||
_home: webtorrent.io/desktop
|
||
_name: WebTorrent Desktop
|
||
cask: webtorrent
|
||
choco: webtorrent-desktop
|
||
flatpak: io.webtorrent.WebTorrent
|
||
github: github.com/webtorrent/webtorrent-desktop
|
||
yay: webtorrent-desktop
|
||
wego:
|
||
_bin: wego
|
||
_github: https://github.com/schachmat/wego
|
||
_name: WeGo
|
||
brew: wego
|
||
go: github.com/schachmat/wego@latest
|
||
wetty:
|
||
_bin: wetty
|
||
_github: https://github.com/butlerx/wetty
|
||
_name: Wetty
|
||
npm: wetty
|
||
wget:
|
||
_bin: wget
|
||
_desc: The [wget](https://www.gnu.org/software/wget/) command is a command line utility for downloading files from the Internet. It supports downloading multiple files, downloading in the background, resuming downloads, limiting the bandwidth used for downloads and viewing headers.
|
||
_home: https://www.gnu.org/software/wget/
|
||
_name: wget
|
||
_github: false
|
||
ansible: professormanhattan.wget
|
||
apk: wget
|
||
apt: wget
|
||
brew: wget
|
||
dnf: wget
|
||
# whalebrew: whalebrew/wget # Temporarily commentted out for debugging
|
||
whalebrew:
|
||
_bin: whalebrew
|
||
_desc: Homebrew, but with Docker images (see https://github.com/whalebrew/whalebrew-packages for available packages)
|
||
_docs: https://github.com/whalebrew/whalebrew#usage
|
||
_github: https://github.com/whalebrew/whalebrew
|
||
_home: https://github.com/whalebrew/whalebrew
|
||
_name: Whalebrew
|
||
brew: whalebrew
|
||
script:darwin: curl -L "https://github.com/whalebrew/whalebrew/releases/download/0.4.0/whalebrew-$(uname -s)-$(uname -m)" -o /usr/local/bin/whalebrew; chmod +x /usr/local/bin/whalebrew
|
||
script:linux: curl -L "https://github.com/whalebrew/whalebrew/releases/download/0.4.0/whalebrew-$(uname -s)-$(uname -m)" -o /usr/local/bin/whalebrew; chmod +x /usr/local/bin/whalebrew
|
||
what-ip:
|
||
_bin: whatip
|
||
_github: false
|
||
_gitlab: https://gitlab.gnome.org/GabMus/whatip
|
||
flatpak: org.gabmus.whatip
|
||
whereami:
|
||
_bin: whereami
|
||
_github: https://github.com/rafaelrinaldi/whereami
|
||
_name: Where Am I?
|
||
npm: '@rafaelrinaldi/whereami'
|
||
wifi-password:
|
||
_bin: wifi-password
|
||
_desc: Get the password of the wifi you're on
|
||
_github: https://github.com/rauchg/wifi-password
|
||
_name: wifi-password
|
||
bpkg: rauchg/wifi-password
|
||
brew:darwin: wifi-password
|
||
npm: wifi-password-cli
|
||
windows-adk:
|
||
_bin: null
|
||
_desc: >-
|
||
[Windows ADK](https://www.microsoft.com/en-us/windows-server/windows-admin-center) was unveiled by Microsoft on September 14, 2017 as the necessary evolution of the Windows Server graphical user interface. Windows ADK offers a flexible, locally-deployed, browser-based management platform and tools. The idea behind this project is to help simplify the management of servers by placing a majority of the frequently referenced tools used by system administrators in one spot. You can run it on both Windows 10 and Windows Server.
|
||
_docs: https://learn.microsoft.com/en-us/windows-hardware/get-started/adk-install
|
||
_github: false
|
||
_home: https://learn.microsoft.com/en-us/windows-hardware/get-started/adk-install
|
||
_name: Windows ADK
|
||
ansible:windows: professormanhattan.windowsadk
|
||
choco: windows-adk
|
||
windows-admin-center:
|
||
_bin: null
|
||
_desc: >-
|
||
[Windows Admin Center](https://www.microsoft.com/en-us/windows-server/windows-admin-center) was unveiled by Microsoft on September 14, 2017 as the necessary evolution of the Windows Server graphical user interface. Windows Admin Center offers a flexible, locally-deployed, browser-based management platform and tools. The idea behind this project is to help simplify the management of servers by placing a majority of the frequently referenced tools used by system administrators in one spot. You can run it on both Windows 10 and Windows Server.
|
||
_docs: https://github.com/MicrosoftDocs/windowsserverdocs/blob/main/WindowsServerDocs/manage/windows-admin-center/overview.md
|
||
_github: false
|
||
_home: https://www.microsoft.com/en-us/windows-server/windows-admin-center
|
||
_name: Windows Admin Center
|
||
ansible:windows: professormanhattan.windowsadmincenter
|
||
choco: windows-admin-center
|
||
windows-power-toys:
|
||
_bin: null
|
||
_desc: '[Microsoft PowerToys](https://docs.microsoft.com/en-us/windows/powertoys/) is a set of utilities for Windows power-users to tune and streamline their Windows 10 experience for greater productivity. It includes tools like a Color Picker, File Explorer add-ons, Keyboard Manager, Shortcut Guide, and more.'
|
||
_docs: https://learn.microsoft.com/en-us/windows/powertoys/
|
||
_github: https://github.com/microsoft/PowerToys
|
||
_home: https://learn.microsoft.com/en-us/windows/powertoys/
|
||
_name: Microsoft PowerToys
|
||
ansible:windows: professormanhattan.windowspowertoys
|
||
choco: powertoys
|
||
scoop: powertoys
|
||
winrm-cli:
|
||
_bin: winrm-cli
|
||
_desc: Command-line tool to remotely execute commands on Windows machines through WinRM
|
||
_docs: https://github.com/masterzen/winrm-cli
|
||
_github: https://github.com/masterzen/winrm-cli
|
||
_home: https://github.com/masterzen/winrm-cli
|
||
_name: winrm-cli
|
||
go: github.com/masterzen/winrm-cli@latest
|
||
yay: winrm-cli-git
|
||
winui-gallery:
|
||
_github: https://github.com/microsoft/WinUI-Gallery
|
||
_name: WinUI Gallery
|
||
winapp: winui-3-gallery/9P3JFPWWDZRC
|
||
wipe-modules:
|
||
_bin: wipe-modules
|
||
_github: https://github.com/bntzio/wipe-modules
|
||
_name: wipe-modules
|
||
npm: wipe-modules
|
||
wireguard-client:
|
||
_app: WireGuard.app
|
||
_bin: wireguard-client
|
||
_github: https://github.com/WireGuard/wireguard-monolithic-historical
|
||
_deps:
|
||
- wireguard-tools
|
||
_name: WireGuard Client
|
||
choco: wireguard
|
||
mas: 1451685025
|
||
scoop: wireguard-np
|
||
wireguard-tools:
|
||
_bin: wg
|
||
_name: WireGuard Tools
|
||
_github: https://github.com/WireGuard/wireguard-tools
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
# @file macOS WireGuard Profiles
|
||
# @brief Installs WireGuard VPN profiles on macOS devices
|
||
# @description
|
||
# This script installs WireGuard VPN profiles on macOS. It scans `${XDG_CONFIG_HOME:-$HOME/.config}/vpn` for all the `*.conf` files
|
||
# and then copies those profiles to `/etc/wireguard`. It also performs a couple preparation tasks like ensuring the target
|
||
# WireGuard system configuration file directory exists and is assigned the proper permissions.
|
||
#
|
||
# ## Creating VPN Profiles
|
||
#
|
||
# More details on embedding your VPN profiles into your Install Doctor fork can be found by reading the [Secrets documentation](https://install.doctor/docs/customization/secrets#vpn-profiles).
|
||
#
|
||
# ## TODO
|
||
#
|
||
# * Populate Tunnelblick on macOS using the VPN profiles located in `${XDG_CONFIG_HOME:-$HOME/.config}/vpn`
|
||
# * For the Tunnelblick integration, ensure the username / password is populated from the `OVPN_USERNAME` and `OVPN_PASSWORD` variables
|
||
#
|
||
# ## Links
|
||
#
|
||
# * [VPN profile folder](https://github.com/megabyte-labs/install.doctor/blob/master/home/dot_config/vpn)
|
||
# * [VPN profile documentation](https://install.doctor/docs/customization/secrets#vpn-profiles)
|
||
|
||
# TODO - Populate Tunnelblick on macOS using the .ovpn profiles located in $HOME/.config/vpn (execpt in the `openvpn` entry of software.yml)
|
||
# along with the secrets for the protonVPN OpenVPN (check vpn-linux.tmpl)
|
||
|
||
### Backs up previous network settings to `/Library/Preferences/com.apple.networkextension.plist.old` before applying new VPN profiles
|
||
if [ -f /Library/Preferences/com.apple.networkextension.plist ] && [ ! -f "/Library/Preferences/com.apple.networkextension.plist.old" ]; then
|
||
logg info 'Backing up /Library/Preferences/com.apple.networkextension.plist to /Library/Preferences/com.apple.networkextension.plist.old'
|
||
sudo cp -f /Library/Preferences/com.apple.networkextension.plist /Library/Preferences/com.apple.networkextension.plist.old
|
||
else
|
||
logg info 'The /Library/Preferences/com.apple.networkextension.plist does not exist or is already backed up to com.apple.networkextension.plist.old'
|
||
fi
|
||
|
||
### Ensures the `/etc/wireguard` directory exists and has the lowest possible permission-level
|
||
if [ ! -d /etc/wireguard ]; then
|
||
logg info 'Creating /etc/wireguard since it does not exist yet'
|
||
sudo mkdir -p /etc/wireguard
|
||
sudo chmod 600 /etc/wireguard
|
||
fi
|
||
|
||
### TODO - Should adding the .conf files to /etc/wireguard only be done on macOS or is this useful on Linux as well?
|
||
### Cycles through the `*.conf` files in `${XDG_CONFIG_HOME:-$HOME/.config}/vpn` and adds them to the `/etc/wireguard` folder
|
||
find "${XDG_CONFIG_HOME:-$HOME/.config}/vpn" -mindepth 1 -maxdepth 1 -type f -name "*.conf" | while read WG_CONF; do
|
||
WG_FILE="$(basename "$WG_CONF")"
|
||
logg info 'Adding '"$WG_FILE"' to /etc/wireguard'
|
||
sudo cp -f "$WG_CONF" "/etc/wireguard/$WG_FILE"
|
||
done
|
||
apk: wireguard-tools
|
||
apt: wireguard
|
||
brew: wireguard-tools
|
||
dnf: wireguard-tools
|
||
emerge: wireguard-tools
|
||
nix: nixpkgs.wireguard-tools
|
||
opkg: wireguard
|
||
pacman: wireguard-tools
|
||
port: wireguard-tools
|
||
slackpkg: wireguard-tools
|
||
zypper: wireguard-tools
|
||
wireshark:
|
||
_app: Wireshark.app
|
||
_bin: wireshark-gui
|
||
_desc: '[Wireshark](https://www.wireshark.org/) is a free and open-source packet analyzer. It is used for network troubleshooting, analysis, software and communications protocol development, and education. Originally named Ethereal, the project was renamed Wireshark in May 2006 due to trademark issues.'
|
||
_docs: https://www.wireshark.org/docs/
|
||
_github: https://github.com/wireshark/wireshark
|
||
_home: https://www.wireshark.org/
|
||
_name: Wireshark
|
||
_pre:cask: |
|
||
#!/usr/bin/env bash
|
||
if command -v idl2wrs > /dev/null; then brew uninstall wireshark; fi
|
||
apt: wireshark
|
||
cask: wireshark
|
||
choco: wireshark
|
||
dnf:
|
||
- wireshark
|
||
- wireshark-cli
|
||
flatpak: org.wireshark.Wireshark
|
||
pacman:
|
||
- wireshark-cli
|
||
- wireshark-qt
|
||
wishlist:
|
||
_bin: wishlist
|
||
_desc: TUI for listing definitions defined in the SSH directory
|
||
_docs: https://github.com/charmbracelet/wishlist
|
||
_github: https://github.com/charmbracelet/wishlist
|
||
_home: https://charm.sh
|
||
_name: Wishlist
|
||
brew: charmbracelet/tap/wishlist
|
||
nix-env: nixpkgs.wishlist
|
||
scoop: wishlist
|
||
yay: wishlist-bin
|
||
wkhtmltopdf:
|
||
_bin: wkhtmltopdf
|
||
_desc: '[wkhtmltopdf](https://github.com/wkhtmltopdf/wkhtmltopdf) is a command line tool to render HTML into PDF and various image formats using the QT Webkit rendering engine.'
|
||
_github: https://github.com/wkhtmltopdf/wkhtmltopdf
|
||
_name: wkhtmltopdf
|
||
# CentOS Stream 9 does not have a supported GitHub release available
|
||
# ansible: professormanhattan.wkhtmltopdf
|
||
apt: wkhtmltopdf
|
||
cask: wkhtmltopdf
|
||
choco: wkhtmltopdf
|
||
github: github.com/wkhtmltopdf/wkhtmltopdf
|
||
pacman: wkhtmltopdf
|
||
wordops:
|
||
_bin: wo
|
||
_desc: Install and manage a high performance WordPress stack with a few keystrokes
|
||
_docs: https://docs.wordops.net/
|
||
_github: https://github.com/WordOps/WordOps
|
||
_home: https://wordops.net/
|
||
_name: WordOps
|
||
script:debian: wget -qO wo wops.cc && sudo bash wo
|
||
wordpressify:
|
||
_bin: wordpressify
|
||
_desc: A build system designed to automate your WordPress development workflow
|
||
_docs: https://www.wordpressify.co/docs
|
||
_github: https://github.com/luangjokaj/wordpressify
|
||
_home: https://www.wordpressify.co/
|
||
_name: wordpressify
|
||
npm: wordpressify
|
||
wp-cli:
|
||
_bin: wp
|
||
_desc: '[WP-CLI](https://wp-cli.org/) is the command-line interface for [WordPress](https://wordpress.org/). You can update plugins, configure multisite installations and much more. You can do all this without using a web browser.'
|
||
_github: https://github.com/wp-cli/wp-cli
|
||
_home: https://wp-cli.org/
|
||
_name: WP-CLI
|
||
ansible:darwin: professormanhattan.wpcli
|
||
ansible:linux: professormanhattan.wpcli
|
||
brew: wp-cli
|
||
wpfui:
|
||
_github: https://github.com/lepoco/wpfui
|
||
_name: WPF UI
|
||
winapp: wpf-ui/9N9LKV8R9VGM
|
||
winget: WPF UI
|
||
wrangler:
|
||
_bin: wrangler
|
||
_desc: wrangler is a CLI tool designed for folks who are interested in using Cloudflare Workers. Deploy serverless code instantly across the globe to give it exceptional performance, reliability, and scale.
|
||
_docs: https://developers.cloudflare.com/workers/
|
||
_github: https://github.com/cloudflare/wrangler
|
||
_home: https://workers.cloudflare.com/
|
||
_name: wrangler
|
||
brew: cloudflare-wrangler2
|
||
npm: wrangler
|
||
wrk:
|
||
_bin: wrk
|
||
_desc: '[wrk](https://github.com/reconquest/wrk) is a modern HTTP benchmarking tool capable of generating significant load when run on a single multi-core CPU. It combines a multithreaded design with scalable event notification systems such as epoll and kqueue'
|
||
_docs: https://github.com/blangel/wrk
|
||
_github: https://github.com/wg/wrk
|
||
_home: https://github.com/blangel/wrk
|
||
_name: wrk
|
||
ansible: professormanhattan.wrk
|
||
apt: wrk
|
||
brew: wrk
|
||
pacman: wrk
|
||
port: wrk
|
||
xbps: wrk
|
||
wsl:
|
||
_bin: null
|
||
_desc: Sets up Windows Subsystem For Linux
|
||
_github: false
|
||
_name: wsl
|
||
ansible: professormanhattan.wsl
|
||
x64dbg:
|
||
_bin: x64dbg
|
||
_desc: An open-source user mode debugger for Windows. Optimized for reverse engineering and malware analysis.
|
||
_docs: https://github.com/x64dbg/x64dbg/wiki
|
||
_github: https://github.com/x64dbg/x64dbg
|
||
_home: https://x64dbg.com/
|
||
_name: x64dbg
|
||
choco: x64dbg.portable
|
||
scoop: extras/x64dbg
|
||
xcode:
|
||
_app: Xcode.app
|
||
_bin: xcode
|
||
_deps:script:darwin:
|
||
- xcodeinstall
|
||
_desc: "[Xcode](https://developer.apple.com/xcode/) is Apple's integrated development environment for macOS, used to develop software for macOS, iOS, iPadOS, watchOS, and tvOS."
|
||
_docs: https://developer.apple.com/documentation/xcode
|
||
_github: false
|
||
_home: https://developer.apple.com/xcode/
|
||
_name: XCode
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo xcodebuild -license accept && sudo xcodebuild -runFirstLaunch
|
||
mas: 497799835
|
||
#script:darwin: |
|
||
# echo "NOTE - This may not work headlessly due to requirement of 2FA"
|
||
# ### Load AWS secrets
|
||
# source "${XDG_CONFIG_HOME:-$HOME/.config}/shell/private.sh"
|
||
# ### Setup passwordless sudo
|
||
# if ! sudo cat /etc/sudoers | grep '# TEMPORARY FOR INSTALL DOCTOR XCODEINSTALL' > /dev/null; then
|
||
# if [ -n "$SUDO_PASSWORD" ]; then
|
||
# printf '%s\n' "$SUDO_PASSWORD" | sudo -p "" -S echo "$(whoami) ALL=(ALL:ALL) NOPASSWD: ALL # TEMPORARY FOR INSTALL DOCTOR XCODEINSTALL" | sudo tee -a /etc/sudoers
|
||
# else
|
||
# echo "$(whoami) ALL=(ALL:ALL) NOPASSWD: ALL # TEMPORARY FOR INSTALL DOCTOR XCODEINSTALL" | sudo tee -a /etc/sudoers
|
||
# fi
|
||
# fi
|
||
# ### Remove old files
|
||
# echo "Removing old ~/.xcodeinstall folder"
|
||
# rm -rf ~/.xcodeinstall
|
||
# ### Authenticate
|
||
# echo "Authenticating"
|
||
# xcodeinstall authenticate -s "$AWS_DEFAULT_REGION"
|
||
# ### Download files
|
||
# while read XCODE_DOWNLOAD_ITEM; do
|
||
# if [[ "$XCODE_DOWNLOAD_ITEM" != *"Command Line Tools"* ]]; then
|
||
# DOWNLOAD_ID="$(echo "$XCODE_DOWNLOAD_ITEM" | sed 's/^\[\(.*\)\] .*/\1/')"
|
||
# echo "Downloading $XCODE_DOWNLOAD_ITEM"
|
||
# echo "$DOWNLOAD_ID" | xcodeinstall download -s "$AWS_DEFAULT_REGION"
|
||
# fi
|
||
# done < <(xcodeinstall list -s "$AWS_DEFAULT_REGION" | grep --invert-match 'Release Candidate' | grep --invert-match ' beta ' | grep ' Xcode \d\d ')
|
||
# ### Install Xcode
|
||
# echo "Installing Xcode"
|
||
# xcodeinstall install --name "$(basename "$(find ~/.xcodeinstall/download -maxdepth 1 -name "*.xip")")"
|
||
# ### Install Command Line Tools
|
||
# # Commentted out because it is already installed by xcode-select in the provision.sh script
|
||
# # xcodeinstall install --name "$(basename "$(find ~/.xcodeinstall/download -maxdepth 1 -name "*Command Line Tools*")")"
|
||
# ### Install Additional Tools
|
||
# echo "Installing Additional Tools"
|
||
# while read ADDITIONAL_TOOLS; do
|
||
# hdiutil attach "$ADDITIONAL_TOOLS"
|
||
# rm -rf "/Applications/Additional Tools"
|
||
# cp -rf "/Volumes/Additional Tools" "/Applications/Additional Tools"
|
||
# hdiutil detach "$(find /Volumes -name "Additional Tools")"
|
||
# done < <(find ~/.xcodeinstall/download -name "Additional Tools*")
|
||
# ### Install Font Tools
|
||
# echo "Installing Font Tools"
|
||
# while read FONT_TOOLS; do
|
||
# hdiutil attach "$FONT_TOOLS"
|
||
# cd "$(find /Volumes -maxdepth 1 -name "*Font Tools*")"
|
||
# sudo installer -pkg "$(find . -maxdepth 1 -name "*Font Tools*.pkg")" -target /
|
||
# cd / && hdiutil detach "$(find /Volumes -maxdepth 1 -name "*Font Tools*")"
|
||
# done < <(find ~/.xcodeinstall/download -name "Font Tools*")
|
||
# ### Remove cache / downloaded files
|
||
# rm -rf ~/.xcodeinstall
|
||
# ### Remove passwordless sudo
|
||
# if ! command -v gsed > /dev/null; then
|
||
# brew install gnu-sed
|
||
# fi
|
||
# sudo gsed -i '/# TEMPORARY FOR INSTALL DOCTOR XCODEINSTALL/d' /etc/sudoers
|
||
xcodeinstall:
|
||
_bin: xcodeinstall
|
||
_github: https://github.com/sebsto/xcodeinstall
|
||
_name: Xcode Install
|
||
brew: sebsto/macos/xcodeinstall
|
||
xcodes:
|
||
_bin: xcodes
|
||
_desc: CLI utility to download, install, and switch to alternate versions of Xcode
|
||
_docs: https://github.com/XcodesOrg/xcodes
|
||
_github: https://github.com/XcodesOrg/xcodes
|
||
_home: https://github.com/XcodesOrg/xcodes
|
||
_name: Xcodes
|
||
brew:darwin: xcodesorg/made/xcodes
|
||
xcodes-app:
|
||
_app: Xcodes.app
|
||
_bin: null
|
||
_desc: macOS desktop app that allows you to download, install, and switch to alternate versions of Xcode
|
||
_docs: https://github.com/XcodesOrg/XcodesApp
|
||
_github: https://github.com/XcodesOrg/XcodesApp
|
||
_home: https://github.com/XcodesOrg/XcodesApp
|
||
_name: Xcodes App
|
||
cask: xcodes
|
||
xcpretty:
|
||
_bin: xcpretty
|
||
_github: https://github.com/xcpretty/xcpretty
|
||
_name: xcpretty
|
||
gem:darwin: xcpretty
|
||
xdotool:
|
||
_bin: xdotool
|
||
_github: https://github.com/jordansissel/xdotool
|
||
_name: xdotool
|
||
_post:brew:darwin: |
|
||
#!/usr/bin/env bash
|
||
defaults write org.x.X11 enable_test_extensions -boolean true
|
||
apt: xdotool
|
||
brew: xdotool
|
||
dnf: xdotool
|
||
pacman: xdotool
|
||
pkg-freebsd: xdotool
|
||
port: xdotool
|
||
zypper: xdotool
|
||
xh:
|
||
_bin: xh
|
||
_github: https://github.com/ducaale/xh
|
||
_name: XH
|
||
apk: xh
|
||
apt: xh
|
||
brew: xh
|
||
cargo: xh
|
||
choco: xh
|
||
nix-env: nixpkgs.xh
|
||
pacman: xh
|
||
pkg-android: xh
|
||
pkg-freebsd: xh
|
||
scoop: xh
|
||
xhyve:
|
||
_bin: xhyve
|
||
_github: https://github.com/machyve/xhyve
|
||
_name: xhyve
|
||
_notes: Has not been modified for several years and has been disabled on Homebrew
|
||
brew:darwin: xhyve
|
||
port: xhyve
|
||
xpanes:
|
||
_bin: xpanes
|
||
_github: https://github.com/greymd/tmux-xpanes
|
||
_name: xpanes
|
||
apt: https://github.com/greymd/tmux-xpanes/releases/download/v4.1.4/tmux-xpanes_v4.1.4.deb
|
||
brew: tmux-xpanes
|
||
dnf: xpanes
|
||
script: curl -sSL --compressed https://raw.githubusercontent.com/greymd/tmux-xpanes/v4.1.4/bin/xpanes > /tmp/xpanes && sudo mv /tmp/xpanes /usr/local/bin/xpanes
|
||
xpra:
|
||
_app: Xpra.app
|
||
_bin: xpra
|
||
_github: https://github.com/Xpra-org/xpra
|
||
_name: xpra
|
||
cask: xpra
|
||
choco: xpra
|
||
exe: https://xpra.org/dists/windows/Xpra-x86_64_Setup.exe
|
||
flatpak: org.xpra.xpra
|
||
msi: https://xpra.org/dists/windows/Xpra-x86_64.msi
|
||
xrdp:
|
||
_bin: xrdp
|
||
_github: https://github.com/neutrinolabs/xrdp
|
||
_home: http://www.xrdp.org/
|
||
_name: xrdp
|
||
_note: Should work like professormanhattan.remotedesktop
|
||
_ports:
|
||
- port: 3389
|
||
proto: tcp
|
||
_post: |
|
||
#!/usr/bin/env bash
|
||
sudo adduser xrdp ssl-cert
|
||
_service: xrdp
|
||
_service:yay:
|
||
- xrdp
|
||
- xrdp-sesman
|
||
apt: xrdp
|
||
dnf: xrdp
|
||
pacman: xrdp
|
||
yay: xrdp
|
||
zypper: xrdp
|
||
xsv:
|
||
_bin: xsv
|
||
_github: https://github.com/BurntSushi/xsv
|
||
_name: xsv
|
||
brew: xsv
|
||
cargo: xsv
|
||
nix-env: xsv
|
||
port: xsv
|
||
xurls:
|
||
_bin: xurls
|
||
_desc: Extract urls from text
|
||
_github: https://github.com/mvdan/xurls
|
||
_name: xurls
|
||
brew: xurls
|
||
go: mvdan.cc/xurls/v2/cmd/xurls@latest
|
||
xxh:
|
||
_bin: xxh
|
||
_github: https://github.com/xxh/xxh
|
||
_name: xxh
|
||
brew: xxh
|
||
pipx: xxh-xxh
|
||
port: xxh
|
||
xz:
|
||
_bin: xz
|
||
_github: https://github.com/xz-mirror/xz
|
||
_name: xz
|
||
apk: xz
|
||
apt: xz
|
||
brew: xz
|
||
choco: xz
|
||
dnf: xz
|
||
pacman: xz
|
||
port: xz
|
||
scoop: xz
|
||
yamllint:
|
||
_bin: yamllint
|
||
_desc: A linter for YAML files. yamllint does not only check for syntax validity, but also for weirdnesses like key repetition and cosmetic problems such as lines length, trailing spaces, indentation, etc.
|
||
_github: https://github.com/adrienverge/yamllint
|
||
_name: yamllint
|
||
_service: null
|
||
brew: yamllint
|
||
pipx: yamllint
|
||
yank:
|
||
_bin: yank
|
||
_bin:apt: yank-cli
|
||
_desc: '[yank](https://github.com/mptre/yank) is a terminal agnostic solution which allows copying output from Termial easily, without the need to use Terminal multiplexers.'
|
||
_github: https://github.com/mptre/yank
|
||
_name: yank
|
||
ansible: professormanhattan.yank
|
||
apt: yank
|
||
brew: yank
|
||
choco: win32yank
|
||
dnf: yank
|
||
nix: yank
|
||
pacman: yank
|
||
pkg-freebsd: yank
|
||
pkg_add: yank
|
||
port: yank
|
||
scoop: win32yank
|
||
zypper: yank
|
||
yapf:
|
||
_bin: yapf
|
||
_desc: A formatter for Python files maintained by Google
|
||
_docs: false
|
||
_github: https://github.com/google/yapf
|
||
_home: false
|
||
_name: YAPF
|
||
pipx: yapf
|
||
yarn:
|
||
_bin: yarn
|
||
_desc: "[Yarn](https://yarnpkg.com/) is a relatively new and open source JavaScript package manager developed by Facebook. Yarn is fully compatible with the npm registry (i.e. [npmjs.com](https://www.npmjs.com/)) and can work alongside npm, but it's aim it to be a safer, more secure and more reliable alternative."
|
||
_docs: https://yarnpkg.com/getting-started
|
||
_github: https://github.com/yarnpkg/berry
|
||
_home: https://yarnpkg.com/
|
||
_name: Yarn
|
||
_preload: true
|
||
ansible: professormanhattan.yarn
|
||
brew: yarn
|
||
choco: yarn
|
||
npm: yarn
|
||
pacman: yarn
|
||
port: yarn
|
||
scoop: yarn
|
||
script: curl -o- -L https://yarnpkg.com/install.sh | bash
|
||
yarnhook:
|
||
_bin: yarnhook
|
||
_desc: yarnhook keeps your node_modules up-to-date when your yarn.lock, package-lock.json or shrinkwrap.yaml changes due to git operations like checkout, merge, rebase, pull etc.
|
||
_github: https://github.com/frontsideair/yarnhook
|
||
_name: Yarnhook
|
||
npm: yarnhook
|
||
yj:
|
||
_bin: yj
|
||
_desc: CLI program that allows you to convert between YAML, TOML, JSON, and HCL.
|
||
_docker: docker run sclevine/yj
|
||
_docs: https://github.com/sclevine/yj
|
||
_github: https://github.com/sclevine/yj
|
||
_home: https://github.com/sclevine/yj
|
||
_name: YJ
|
||
brew: yj
|
||
go: github.com/sclevine/yj/v5@v5.1.0
|
||
you-get:
|
||
_bin: you-get
|
||
_github: https://github.com/soimort/you-get
|
||
_name: You-Get
|
||
brew: you-get
|
||
pipx: you-get
|
||
pkg-freebsd: you-get
|
||
youtube-dl:
|
||
_bin: youtube-dl
|
||
_desc: '[youtube-dl](https://github.com/ytdl-org/youtube-dl) is an open-source download manager for video and audio from YouTube and over 1000 other video hosting websites. It is released under the Unlicense software license and is one of the most popular projects on GitHub.'
|
||
_docs: https://github.com/ytdl-org/youtube-dl/blob/master/README.md#readme
|
||
_github: https://github.com/ytdl-org/youtube-dl
|
||
_home: https://youtube-dl.org/
|
||
_name: youtube-dl
|
||
ansible: professormanhattan.youtubedl
|
||
brew: youtube-dl
|
||
pipx: youtube-dl
|
||
port: youtube-dl
|
||
youtube-music:
|
||
_app: YouTube Music.app
|
||
_desc: YouTube Music desktop app bundled with custom plugins (and built-in ad blocker / downloader)
|
||
_github: https://github.com/th-ch/youtube-music
|
||
_home: https://th-ch.github.io/youtube-music/
|
||
_todo: Might have to add _post cask xattr -cr /Applications/YouTube\ Music.app to fix permissions
|
||
appimage: th-ch/youtube-music
|
||
apt: https://github.com/th-ch/youtube-music/releases/download/v1.19.0/youtube-music_1.19.0_amd64.deb
|
||
exe: https://github.com/th-ch/youtube-music/releases/download/v1.19.0/YouTube-Music-Setup-1.19.0.exe
|
||
scoop: extras/youtube-music
|
||
script:darwin: |
|
||
DL_URL="https://github.com/th-ch/youtube-music/releases/download/v1.20.0/YouTube-Music-1.20.0.dmg"
|
||
if [ $(arch) = 'arm64' ]; then
|
||
DL_URL="https://github.com/th-ch/youtube-music/releases/download/v1.20.0/YouTube-Music-1.20.0-arm64.dmg"
|
||
fi
|
||
echo "Downloading YouTube Music" && curl -sSL "$DL_URL" > /tmp/YouTube-Music.dmg
|
||
echo "Attaching volume" && sudo hdiutil attach /tmp/YouTube-Music.dmg
|
||
echo "Copying to /Applications"
|
||
if [ -d "/Volumes/YouTube Music 1.20.0" ]; then
|
||
sudo cp -R "/Volumes/YouTube Music 1.20.0/YouTube Music.app" /Applications
|
||
echo "Detaching" && sudo hdiutil detach "/Volumes/YouTube Music 1.20.0"
|
||
elif [ -d "/Volumes/YouTube Music 1.20.0-arm64" ]; then
|
||
sudo cp -R "/Volumes/YouTube Music 1.20.0-arm64/YouTube Music.app" /Applications
|
||
echo "Detaching" && sudo hdiutil detach "/Volumes/YouTube Music 1.20.0-arm64"
|
||
fi
|
||
echo "Removing /tmp/YouTube-Music.dmg" && rm -f /tmp/YouTube-Music.dmg
|
||
winget: th-ch.YouTubeMusic
|
||
yay: youtube-music-bin
|
||
yq:
|
||
_bin: yq
|
||
_desc: '[yq](https://github.com/mikefarah/yq) is a free, open-source command-line YAML processor. It aims to be like [jq](https://gitlab.com/megabyte-labs/ansible-roles/jq) except for YAML files. It can read and write values to YAML files.'
|
||
_docs: https://mikefarah.gitbook.io/yq/how-it-works
|
||
_github: https://github.com/mikefarah/yq
|
||
_home: https://mikefarah.gitbook.io/yq/
|
||
_name: yq
|
||
_preload: true
|
||
ansible: professormanhattan.yq
|
||
apk: yq
|
||
brew: yq
|
||
choco: yq
|
||
github: github.com/stedolan/jq
|
||
go: github.com/mikefarah/yq/v4@latest
|
||
snap: yq
|
||
yt-dlp:
|
||
_bin: yt-dlp
|
||
_github: https://github.com/yt-dlp/yt-dlp/wiki/Installation
|
||
_name: YouTube Download
|
||
brew: yt-dlp
|
||
choco: yt-dlp
|
||
pacman: yt-dlp
|
||
pipx: yt-dlp
|
||
port: yt-dlp
|
||
scoop: yt-dlp
|
||
winget: yt-dlp
|
||
yubikey-agent:
|
||
_bin: yubikey-agent
|
||
_docs: https://github.com/FiloSottile/yubikey-agent
|
||
_github: https://github.com/FiloSottile/yubikey-agent
|
||
_home: https://github.com/FiloSottile/yubikey-agent
|
||
_name: OpenSSL
|
||
_service: yubikey-agent
|
||
_todo: Experiment with this to see if it is worthwhile adding to the stack
|
||
brew: yubikey-agent
|
||
yubikey-authenticator:
|
||
_app: Yubico Authenticator.app
|
||
_bin: yubioath
|
||
_docs: The Yubico Authenticator app works across Windows, macOS, Linux, iOS and Android. Get the same set of codes across all Yubico Authenticator apps for desktops as well as for all leading mobile platforms. Portable credentials across devices.
|
||
_home: https://www.yubico.com/products/yubico-authenticator/
|
||
_github: https://github.com/Yubico/yubioath-flutter
|
||
_name: Yubico Authenticator
|
||
cask: yubico-authenticator
|
||
choco: yubico-authenticator
|
||
flatpak: com.yubico.yubioath
|
||
mas: 1497506650
|
||
script:darwin: curl -sSL https://developers.yubico.com/yubioath-flutter/Releases/yubico-authenticator-latest-mac.dmg > "/tmp/Yubico Authenticator.dmg" && hdiutil attach "/tmp/Yubico Authenticator.dmg" && sudo cp -R "/Volumes/Yubico Authenticator/Yubico Authenticator.app" /Applications && sudo hdiutil detach "/Volumes/Yubico Authenticator" && rm -f "/tmp/Yubico Authenticator.dmg"
|
||
yubikey-manager:
|
||
_bin: ykman
|
||
_desc: Use the YubiKey Manager to configure FIDO2, OTP and PIV functionality on your YubiKey on Windows, macOS, and Linux operating systems.
|
||
_github: https://github.com/Yubico/yubikey-manager
|
||
_home: https://www.yubico.com/support/download/yubikey-manager/
|
||
_name: Yubikey Manager
|
||
brew: ykman
|
||
dnf:fedora: yubikey-manager
|
||
pacman: yubikey-manager
|
||
pipx: yubikey-manager
|
||
yubikey-manager-qt:
|
||
_app: YubiKey Manager.app
|
||
_bin: yubikey-manager-qt
|
||
_desc: Cross-platform application for configuring any YubiKey over all USB interfaces.
|
||
_github: https://github.com/Yubico/yubikey-manager-qt
|
||
_home: https://developers.yubico.com/yubikey-manager-qt/
|
||
_name: YubiKey Manager
|
||
appimage: Yubico/yubikey-manager-qt
|
||
cask: yubico-yubikey-manager
|
||
choco: yubikey-manager
|
||
dnf:fedora: yubikey-manager-qt
|
||
pacman: yubikey-manager-qt
|
||
scoop: yubikey-manager-qt
|
||
zap:
|
||
_bin: zap
|
||
_desc: Delightful AppImage package manager
|
||
_docs: https://zap.srev.in/
|
||
_github: https://github.com/srevinsaju/zap
|
||
_home: https://zap.srev.in/
|
||
_name: Zap
|
||
_preload: true
|
||
ansible:linux: professormanhattan.zap
|
||
binary:linux: https://github.com/srevinsaju/zap/releases/download/continuous/zap-amd64
|
||
script:linux: curl https://raw.githubusercontent.com/srevinsaju/zap/main/install.sh | sudo bash -s
|
||
zaproxy:
|
||
_app: ZAP.app
|
||
_bin: zaproxy
|
||
_desc: The world’s most widely used web app scanner. Free and open source. Actively maintained by a dedicated international team of volunteers. A GitHub Top 1000 project.
|
||
_docs: https://www.zaproxy.org/docs/
|
||
_github: https://github.com/zaproxy/zaproxy
|
||
_home: https://www.zaproxy.org/
|
||
_name: OWASP ZAP
|
||
cask: zap
|
||
choco: zap
|
||
flatpak: org.zaproxy.ZAP
|
||
pkg-freebsd: zaproxy
|
||
scoop: zaproxy
|
||
snap: zaproxy --classic
|
||
zenity:
|
||
_bin: zenity
|
||
_github: https://github.com/ncruces/zenity
|
||
_name: Zenity
|
||
brew: ncruces/tap/zenity
|
||
go: github.com/ncruces/zenity/cmd/zenity@latest
|
||
scoop: https://ncruces.github.io/scoop/zenity.json
|
||
zola:
|
||
_bin: zola
|
||
_desc: A static site generator built with Rust
|
||
_github: https://github.com/getzola/zola
|
||
apk: zola
|
||
brew: zola
|
||
choco: zola
|
||
flatpak: org.getzola.zola
|
||
pacman: zola
|
||
pkg-freebsd: zola
|
||
pkg_add: zola
|
||
pkgin: zola
|
||
port: zola
|
||
scoop: zola
|
||
snap: zola
|
||
xbps: zola
|
||
zoom:
|
||
_app: zoom.us.app
|
||
_bin: zoom
|
||
_desc: '[Zoom](https://zoom.us/) is a videotelephony software program developed by Zoom Video Communications. This role installs Zoom on nearly any platform. The Zoom free plan provides a video chatting service that allows up to 100 participants concurrently, with a 40-minute time restriction.'
|
||
_docs: https://support.zoom.us/hc/en-us/categories/200101697-Getting-Started-with-Zoom
|
||
_github: Not open-source
|
||
_home: https://zoom.us/
|
||
_name: Zoom
|
||
ansible: professormanhattan.zoom
|
||
cask: zoom
|
||
choco: zoom
|
||
flatpak: us.zoom.Zoom
|
||
snap: zoom
|
||
yay: zoom
|
||
zoxide:
|
||
_bin: zoxide
|
||
_desc: '[zoxide](https://github.com/ajeetdsouza/zoxide) is a blazing fast replacement for your cd command, inspired by z and autojump'
|
||
_github: https://github.com/ajeetdsouza/zoxide
|
||
_name: zoxide
|
||
_preload: true
|
||
ansible: professormanhattan.zoxide
|
||
brew: zoxide
|
||
zsh:
|
||
_bin: zsh
|
||
_desc: '[Oh My Zsh](https://ohmyz.sh/) is a delightful, open source, community-driven framework for managing your Zsh configurations. It comes bundled with thousands of helpful functions, helpers, plugins, themes, and a few things that make you shout oh my zsh! This role also installs some CLI tools that accompany Oh My Zsh! to make it even more amazing.'
|
||
_github: https://github.com/zsh-users/zsh
|
||
_name: Zsh
|
||
_preload: true
|
||
ansible:darwin: professormanhattan.zsh
|
||
ansible:linux: professormanhattan.zsh
|
||
apt: zsh
|
||
brew: zsh
|
||
dnf: zsh
|
||
pacman: zsh
|
||
port: zsh
|
||
zsh-completions:
|
||
_github: https://github.com/zsh-users/zsh-completions
|
||
_name: ZSH Completions
|
||
brew: zsh-completions
|
||
zx:
|
||
_bin: zx
|
||
_desc: Bash is great, but when it comes to writing more complex scripts, many people prefer a more convenient programming language. JavaScript is a perfect choice, but the Node.js standard library requires additional hassle before using. The zx package provides useful wrappers around child_process, escapes arguments and gives sensible defaults.
|
||
_github: https://github.com/google/zx
|
||
_name: zx
|
||
_preload: true
|
||
brew: zx
|
||
npm: zx
|