From c5cd492449844c3351fead503c0a9d78f1407474 Mon Sep 17 00:00:00 2001 From: JMARyA Date: Mon, 4 Dec 2023 11:02:23 +0100 Subject: [PATCH] init --- Meta.md | 43 + MetaIndex.md | 90 ++ schema.json | 169 +++ science/Science.md | 11 + science/biology/Biology.md | 5 + science/chemistry/Chemistry.md | 4 + science/math/Binary System.md | 26 + science/math/Decimal System.md | 10 + science/math/Hexadecimal System.md | 30 + science/math/Math.md | 5 + science/philosophy/Philosophy.md | 5 + science/physics/Physics.md | 4 + science/physics/SI Units.md | 6 + science/physics/units/Volt.md | 11 + science/psychology/Psychology.md | 5 + technology/Cryptography/AES.md | 71 + technology/Cryptography/Cryptography.md | 17 + technology/Cryptography/RSA.md | 63 + technology/Cryptography/SHA.md | 17 + technology/applications/3d/Blender.md | 16 + technology/applications/Feather Wallet.md | 17 + technology/applications/MongoDB Compass.md | 27 + technology/applications/MongoDB.md | 122 ++ technology/applications/OpenSSL.md | 134 ++ technology/applications/SSH.md | 130 ++ technology/applications/SurrealDB.md | 10 + technology/applications/Teleport.md | 198 +++ technology/applications/backup/Vorta.md | 19 + technology/applications/backup/borg.md | 42 + technology/applications/clamav.md | 34 + technology/applications/cli/Core Utils.md | 629 +++++++++ technology/applications/cli/Loop.md | 27 + technology/applications/cli/Shell.md | 339 +++++ technology/applications/cli/alacritty.md | 154 +++ technology/applications/cli/aria2.md | 89 ++ technology/applications/cli/bash.md | 10 + technology/applications/cli/bat.md | 16 + technology/applications/cli/chattr.md | 31 + technology/applications/cli/choose.md | 24 + technology/applications/cli/crunch.md | 23 + technology/applications/cli/curl.md | 32 + technology/applications/cli/diff.md | 20 + technology/applications/cli/diskonaut.md | 9 + technology/applications/cli/doas.md | 71 + technology/applications/cli/duf.md | 54 + technology/applications/cli/eza.md | 20 + technology/applications/cli/fd.md | 22 + technology/applications/cli/file.md | 15 + technology/applications/cli/glow.md | 10 + technology/applications/cli/handlr.md | 34 + technology/applications/cli/hashcat.md | 8 + technology/applications/cli/hck.md | 28 + technology/applications/cli/hexyl.md | 17 + technology/applications/cli/huniq.md | 20 + technology/applications/cli/hyperfine.md | 81 ++ technology/applications/cli/intermodal.md | 38 + technology/applications/cli/jless.md | 6 + technology/applications/cli/joshuto.md | 8 + technology/applications/cli/jq.md | 157 +++ technology/applications/cli/just.md | 1141 +++++++++++++++++ technology/applications/cli/losetup.md | 63 + technology/applications/cli/lsblk.md | 92 ++ technology/applications/cli/man.md | 17 + technology/applications/cli/micro.md | 799 ++++++++++++ technology/applications/cli/netcat.md | 56 + technology/applications/cli/netdiscover.md | 33 + technology/applications/cli/nmap.md | 122 ++ technology/applications/cli/p7zip.md | 36 + technology/applications/cli/patch.md | 29 + technology/applications/cli/pueue.md | 159 +++ technology/applications/cli/ripgrep.md | 10 + technology/applications/cli/rnr.md | 20 + technology/applications/cli/rsync.md | 47 + technology/applications/cli/sd.md | 14 + technology/applications/cli/skim.md | 15 + technology/applications/cli/smbmap.md | 73 ++ technology/applications/cli/tailspin.md | 21 + technology/applications/cli/tar.md | 31 + technology/applications/cli/tmux.md | 38 + technology/applications/cli/tokei.md | 18 + technology/applications/cli/wget.md | 79 ++ technology/applications/cli/zsh.md | 13 + .../applications/communication/Discord.md | 12 + .../applications/communication/Element.md | 81 ++ .../applications/communication/Gmail.md | 8 + .../applications/communication/ProtonMail.md | 9 + .../applications/communication/Thunderbird.md | 12 + .../applications/desktops/KDE Plasma.md | 24 + technology/applications/desktops/dwm.md | 16 + technology/applications/desktops/hyprland.md | 747 +++++++++++ technology/applications/desktops/picom.md | 16 + .../development/DB Browser for SQLite.md | 28 + technology/applications/development/Ghidra.md | 8 + .../development/GitHub Actions.md | 629 +++++++++ .../development/GitHub Desktop.md | 10 + technology/applications/development/GitHub.md | 12 + technology/applications/development/HTTPie.md | 417 ++++++ .../development/Podman Desktop.md | 13 + .../development/Visual Studio Code.md | 43 + technology/applications/development/xh.md | 34 + .../applications/documents/Tachiyomi.md | 18 + .../applications/media/DaVinci Resolve.md | 12 + technology/applications/media/Findroid.md | 11 + technology/applications/media/ImageMagick.md | 138 ++ technology/applications/media/MKVToolnix.md | 191 +++ technology/applications/media/MPV.md | 674 ++++++++++ technology/applications/media/Natron.md | 27 + technology/applications/media/NewPipe.md | 17 + technology/applications/media/OBS.md | 127 ++ technology/applications/media/Plexamp.md | 13 + technology/applications/media/Steam.md | 7 + technology/applications/media/images/GIMP.md | 31 + technology/applications/media/images/pywal.md | 25 + technology/applications/media/kdenlive.md | 12 + technology/applications/media/kid3.md | 13 + technology/applications/media/yt-dlp.md | 293 +++++ technology/applications/mobile/Google Maps.md | 9 + technology/applications/mobile/Monero GUI.md | 12 + technology/applications/mobile/N26.md | 7 + technology/applications/mobile/Termux.md | 288 +++++ technology/applications/network/DAVx5.md | 13 + technology/applications/network/FileZilla.md | 12 + .../applications/network/JDownloader.md | 11 + .../applications/network/KDE Connect.md | 32 + .../applications/network/Mullvad VPN.md | 8 + .../applications/network/NetworkManager.md | 87 ++ technology/applications/network/OnionShare.md | 24 + technology/applications/network/Privoxy.md | 29 + technology/applications/network/SnapDrop.md | 12 + technology/applications/network/Syncthing.md | 31 + technology/applications/network/Wireguard.md | 94 ++ technology/applications/network/Wireshark.md | 7 + .../applications/network/browsers/Brave.md | 14 + .../applications/network/browsers/Firefox.md | 31 + .../network/browsers/Mullvad Browser.md | 17 + technology/applications/network/iperf.md | 37 + technology/applications/network/qBittorent.md | 10 + technology/applications/network/rclone.md | 150 +++ technology/applications/network/smb4k.md | 11 + technology/applications/network/ufw.md | 35 + .../applications/office/Google Calendar.md | 10 + .../applications/office/Google Contacts.md | 10 + technology/applications/office/LibreOffice.md | 21 + technology/applications/office/Obsidian.md | 34 + .../package managers/Aurora Store.md | 12 + .../applications/package managers/Brew.md | 13 + .../applications/package managers/Flatpak.md | 30 + .../applications/package managers/PKGBUILD.md | 49 + .../package managers/Package Managers.md | 9 + .../applications/package managers/Pacman.md | 61 + .../applications/package managers/makepkg.md | 59 + technology/applications/utilities/Aegis.md | 14 + technology/applications/utilities/Bottles.md | 12 + technology/applications/utilities/Czkawka.md | 24 + technology/applications/utilities/Dunst.md | 8 + .../applications/utilities/Filelight.md | 14 + technology/applications/utilities/Flatseal.md | 11 + .../applications/utilities/Hyprpaper.md | 41 + .../applications/utilities/KeePassXC.md | 15 + .../applications/utilities/Kleopatra.md | 13 + technology/applications/utilities/Lutris.md | 15 + .../applications/utilities/Mission Center.md | 12 + technology/applications/utilities/Rofi.md | 8 + .../utilities/Steam ROM Manager.md | 12 + technology/applications/utilities/Waybar.md | 6 + technology/applications/web/AdGuard.md | 34 + technology/applications/web/Authelia.md | 560 ++++++++ technology/applications/web/Bitwarden.md | 29 + technology/applications/web/Frigate.md | 7 + technology/applications/web/Gitea.md | 46 + technology/applications/web/Grocy.md | 41 + technology/applications/web/Guacamole.md | 11 + technology/applications/web/Home Assistant.md | 26 + technology/applications/web/IPFS.md | 32 + technology/applications/web/Jellyfin.md | 28 + technology/applications/web/Kavita.md | 29 + technology/applications/web/Matrix.md | 58 + technology/applications/web/Minio.md | 40 + technology/applications/web/Overseerr.md | 44 + technology/applications/web/Plex.md | 29 + technology/applications/web/Portainer.md | 54 + technology/applications/web/Radicale.md | 32 + technology/applications/web/Samba.md | 98 ++ technology/applications/web/Uptime Kuma.md | 38 + technology/applications/web/Vikunja.md | 61 + technology/applications/web/dufs.md | 172 +++ technology/applications/web/mitmproxy.md | 34 + technology/applications/web/nginx.md | 86 ++ technology/applications/web/traefik.md | 794 ++++++++++++ technology/applications/web/zigbee2mqtt.md | 6 + technology/bsd/FreeBSD.md | 10 + technology/bsd/OPNsense.md | 9 + technology/bsd/OpenBSD.md | 7 + technology/bsd/bhyve.md | 5 + technology/bsd/geli.md | 24 + technology/bsd/ggate.md | 5 + technology/bsd/gmirror.md | 34 + technology/bsd/gpart.md | 5 + technology/bsd/graid.md | 5 + technology/bsd/gstripe.md | 39 + technology/bsd/pfSense.md | 9 + technology/dev/Development.md | 12 + technology/dev/Git.md | 97 ++ technology/dev/gitmoji.md | 88 ++ technology/devices/Raspberry Pi 4.md | 19 + technology/devices/Steam Deck.md | 27 + technology/devices/YubiKey.md | 43 + technology/emulation/Cemu.md | 16 + technology/emulation/Citra.md | 12 + technology/emulation/Dolphin Emulator.md | 12 + technology/emulation/Emulation.md | 18 + technology/emulation/PCSX2.md | 16 + technology/emulation/RPCS3.md | 17 + technology/emulation/Ryujinx.md | 19 + technology/emulation/Yuzu.md | 19 + technology/files/ASCII.md | 140 ++ technology/files/BSON.md | 14 + technology/files/Base64.md | 89 ++ technology/files/CSV.md | 17 + technology/files/Comic Book Archive.md | 16 + technology/files/Desktop Entry.md | 55 + technology/files/File Formats.md | 59 + technology/files/JSON Pointer.md | 25 + technology/files/JSON.md | 36 + technology/files/MIME.md | 131 ++ technology/files/Markdown.md | 259 ++++ technology/files/MessagePack.md | 380 ++++++ technology/files/PDF.md | 13 + technology/files/TOML.md | 407 ++++++ technology/files/Unicode.md | 58 + technology/files/XML.md | 32 + technology/files/XPath.md | 34 + technology/files/YAML.md | 62 + technology/files/ZIP.md | 59 + technology/internet/CSS.md | 6 + technology/internet/Cookie.md | 77 ++ technology/internet/DHCP.md | 37 + technology/internet/DNS.md | 53 + technology/internet/Data URLs.md | 17 + technology/internet/Domain.md | 20 + technology/internet/FTP.md | 8 + technology/internet/HTML.md | 552 ++++++++ technology/internet/HTMX.md | 274 ++++ technology/internet/HTTP.md | 395 ++++++ technology/internet/JWT.md | 73 ++ technology/internet/MQTT.md | 52 + technology/internet/NTP.md | 80 ++ technology/internet/OSI Model.md | 21 + technology/internet/Power over Ethernet.md | 32 + technology/internet/QUIC.md | 29 + technology/internet/SMTP.md | 31 + technology/internet/TCP.md | 35 + technology/internet/TailwindCSS.md | 7 + technology/internet/UDP.md | 41 + technology/internet/URL.md | 48 + technology/internet/Wake on LAN.md | 69 + technology/internet/WebSocket.md | 23 + technology/internet/Webhook.md | 12 + technology/internet/eMail.md | 37 + technology/internet/websites/Links.md | 23 + .../internet/websites/clearnet/Amazon.md | 9 + .../internet/websites/clearnet/Apple.md | 16 + .../internet/websites/clearnet/BS.to.md | 12 + .../internet/websites/clearnet/ChangeNow.md | 12 + .../internet/websites/clearnet/ChatGPT.md | 8 + .../internet/websites/clearnet/Cloudflare.md | 8 + .../internet/websites/clearnet/Crunchyroll.md | 10 + .../internet/websites/clearnet/Fandom.md | 8 + technology/internet/websites/clearnet/IGDB.md | 12 + .../websites/clearnet/Instant Gaming.md | 8 + .../websites/clearnet/Internet Archive.md | 12 + .../internet/websites/clearnet/Microsoft.md | 13 + .../internet/websites/clearnet/Mozilla.md | 12 + .../internet/websites/clearnet/Mullvad.md | 12 + .../internet/websites/clearnet/MyAnimeList.md | 8 + .../internet/websites/clearnet/Netflix.md | 8 + technology/internet/websites/clearnet/Nyaa.md | 12 + .../internet/websites/clearnet/Odysee.md | 8 + .../websites/clearnet/OpenStreetMap.md | 8 + .../websites/clearnet/PsychonautWiki.md | 16 + .../internet/websites/clearnet/Reddit.md | 9 + .../internet/websites/clearnet/SendGrid.md | 8 + .../internet/websites/clearnet/SoundCloud.md | 8 + .../internet/websites/clearnet/SteamGridDB.md | 8 + technology/internet/websites/clearnet/TMDB.md | 12 + .../internet/websites/clearnet/Twitch.md | 12 + .../internet/websites/clearnet/Unsplash.md | 12 + .../internet/websites/clearnet/Wikipedia.md | 12 + .../internet/websites/clearnet/YouTube.md | 11 + .../internet/websites/clearnet/crates.io.md | 12 + .../internet/websites/clearnet/deps.rs.md | 12 + .../internet/websites/clearnet/docs.rs.md | 12 + .../internet/websites/clearnet/lainchan.md | 12 + .../internet/websites/clearnet/nsw2u.md | 8 + .../internet/websites/clearnet/wallhaven.md | 12 + .../internet/websites/clearnet/wired-7.md | 12 + technology/internet/websites/i2p/AlphaBay.md | 9 + .../internet/websites/i2p/Based Cooking.md | 12 + technology/internet/websites/i2p/Cannabia.md | 9 + .../internet/websites/i2p/Coffeechan.md | 9 + .../internet/websites/i2p/DarknetBible.md | 12 + technology/internet/websites/i2p/Identiguy.md | 12 + technology/internet/websites/i2p/Postman.md | 12 + technology/internet/websites/i2p/Registry.md | 12 + technology/internet/websites/i2p/SocksCat.md | 12 + technology/internet/websites/i2p/cake.i2p.md | 12 + technology/internet/websites/i2p/i2pd.md | 12 + technology/internet/websites/onion/DarkEye.md | 12 + technology/internet/websites/onion/DarkTea.md | 12 + .../internet/websites/onion/DarknetHome.md | 12 + technology/internet/websites/onion/Dread.md | 8 + .../internet/websites/onion/DuckDuckGo.md | 12 + .../internet/websites/onion/MegaLinks.md | 8 + .../internet/websites/onion/PirateBay.md | 12 + .../websites/onion/The Hidden Wiki.md | 12 + technology/linux/Alpine Linux.md | 21 + technology/linux/Arch Linux.md | 12 + technology/linux/Command Line Tools.md | 56 + technology/linux/Environment Variables.md | 34 + technology/linux/Kali Linux.md | 14 + technology/linux/Linux.md | 10 + technology/linux/Loop Device.md | 8 + technology/linux/Proxmox.md | 20 + technology/linux/Systemd-Mounts.md | 27 + technology/linux/Systemd-Timers.md | 61 + technology/linux/Systemd.md | 149 +++ technology/linux/filesystems/Btrfs.md | 105 ++ technology/linux/filesystems/Ext4.md | 23 + technology/linux/filesystems/Filesystems.md | 13 + technology/linux/filesystems/LUKS.md | 42 + technology/linux/filesystems/LVM.md | 141 ++ .../linux/filesystems/MergerFS Tools.md | 179 +++ technology/linux/filesystems/MergerFS.md | 192 +++ technology/linux/filesystems/RAID.md | 44 + technology/linux/filesystems/SSHFS.md | 26 + technology/linux/filesystems/SquashFS.md | 25 + technology/linux/filesystems/ZFS.md | 177 +++ technology/linux/filesystems/exFAT.md | 9 + technology/linux/mkinitcpio.md | 63 + technology/linux/openrc.md | 10 + technology/linux/qemu.md | 8 + technology/linux/systemd-boot.md | 59 + technology/macos/macOS.md | 7 + technology/media/Codecs.md | 19 + technology/media/Matroska.md | 32 + technology/media/audio/FLAC.md | 20 + technology/media/audio/Opus.md | 17 + technology/media/audio/WAV.md | 10 + technology/media/ffmpeg.md | 227 ++++ technology/media/image/AVIF.md | 47 + technology/media/image/PNG.md | 15 + technology/media/video/AV1.md | 22 + technology/media/video/H.264.md | 7 + technology/media/video/H.265.md | 8 + technology/media/video/VP9.md | 7 + technology/programming/Godot.md | 10 + technology/programming/SQLite.md | 9 + technology/programming/frameworks/Flutter.md | 6 + technology/programming/languages/Lua.md | 7 + technology/programming/languages/Python.md | 9 + technology/programming/languages/Rust.md | 21 + technology/programming/languages/SQL.md | 685 ++++++++++ .../patterns/Programming Patterns.md | 34 + .../patterns/behavioral/Iterator Pattern.md | 17 + .../patterns/behavioral/Memento Pattern.md | 93 ++ .../behavioral/Null Object Pattern.md | 53 + .../patterns/behavioral/Observer Patterns.md | 89 ++ .../patterns/behavioral/State Patterns.md | 82 ++ .../patterns/behavioral/Strategy Pattern.md | 73 ++ .../behavioral/Template Method Pattern.md | 75 ++ .../patterns/behavioral/Visitor Pattern.md | 96 ++ .../creational/Abstract Factory Pattern.md | 41 + .../patterns/creational/Builder Pattern.md | 27 + .../Dependency Injection Pattern.md | 46 + .../creational/Factory Method Pattern.md | 87 ++ .../creational/Lazy Instantiation Pattern.md | 51 + .../patterns/creational/Multiton Pattern.md | 54 + .../creational/Object Pool Pattern.md | 87 ++ .../patterns/creational/Prototype Pattern.md | 79 ++ .../patterns/creational/RAII Pattern.md | 57 + .../patterns/creational/Singleton Pattern.md | 71 + .../patterns/structural/Adapter Pattern.md | 64 + .../patterns/structural/Bridge Patterns.md | 107 ++ .../patterns/structural/Composite Pattern.md | 93 ++ .../patterns/structural/Decorator Pattern.md | 106 ++ .../patterns/structural/Facade Pattern.md | 66 + .../patterns/structural/Flyweight Pattern.md | 84 ++ .../patterns/structural/Proxy Pattern.md | 83 ++ technology/systems/Android.md | 19 + technology/systems/GrapheneOS.md | 9 + technology/systems/QubesOS.md | 51 + technology/systems/Tails.md | 43 + technology/tools/Ansible/Ansible.md | 23 + .../tools/Ansible/filters/Ansible Filters.md | 37 + .../filters/ansible.builtin.b64decode.md | 11 + .../filters/ansible.builtin.b64encode.md | 11 + .../filters/ansible.builtin.basename.md | 8 + .../filters/ansible.builtin.combine.md | 15 + .../filters/ansible.builtin.comment.md | 13 + .../filters/ansible.builtin.commonpath.md | 9 + .../filters/ansible.builtin.difference.md | 11 + .../filters/ansible.builtin.dirname.md | 8 + .../filters/ansible.builtin.from_json.md | 11 + .../filters/ansible.builtin.from_yaml.md | 11 + .../Ansible/filters/ansible.builtin.hash.md | 10 + .../filters/ansible.builtin.human_readable.md | 14 + .../filters/ansible.builtin.human_to_bytes.md | 14 + .../filters/ansible.builtin.intersect.md | 11 + .../Ansible/filters/ansible.builtin.md5.md | 8 + .../filters/ansible.builtin.path_join.md | 20 + .../filters/ansible.builtin.permutations.md | 8 + .../filters/ansible.builtin.regex_findall.md | 17 + .../filters/ansible.builtin.regex_replace.md | 20 + .../filters/ansible.builtin.regex_search.md | 17 + .../filters/ansible.builtin.relpath.md | 9 + .../filters/ansible.builtin.shuffle.md | 8 + .../Ansible/filters/ansible.builtin.split.md | 11 + .../filters/ansible.builtin.splitext.md | 14 + .../filters/ansible.builtin.strftime.md | 37 + .../filters/ansible.builtin.to_datetime.md | 21 + .../filters/ansible.builtin.to_json.md | 11 + .../filters/ansible.builtin.to_yaml.md | 17 + .../Ansible/filters/ansible.builtin.unique.md | 10 + .../filters/ansible.builtin.urlsplit.md | 33 + .../filters/community.general.json_query.md | 76 ++ .../Ansible/lookups/Ansible Lookup Plugins.md | 9 + .../lookups/ansible.builtin.csvfile.md | 32 + .../Ansible/lookups/ansible.builtin.env.md | 26 + .../Ansible/lookups/ansible.builtin.file.md | 22 + .../Ansible/lookups/ansible.builtin.ini.md | 28 + .../lookups/ansible.builtin.template.md | 22 + .../Ansible/lookups/ansible.builtin.url.md | 32 + .../lookups/community.mongodb.mongodb.md | 78 ++ .../tools/Ansible/modules/Ansible Modules.md | 126 ++ .../Ansible/modules/ansible.builtin.assert.md | 42 + .../modules/ansible.builtin.blockinfile.md | 81 ++ .../Ansible/modules/ansible.builtin.copy.md | 100 ++ .../Ansible/modules/ansible.builtin.cron.md | 75 ++ .../Ansible/modules/ansible.builtin.debug.md | 37 + .../Ansible/modules/ansible.builtin.fail.md | 15 + .../Ansible/modules/ansible.builtin.fetch.md | 39 + .../modules/ansible.builtin.lineinfile.md | 107 ++ .../modules/ansible.builtin.package.md | 30 + .../Ansible/modules/ansible.builtin.pause.md | 37 + .../modules/ansible.builtin.replace.md | 88 ++ .../Ansible/modules/ansible.builtin.shell.md | 78 ++ .../ansible.builtin.systemd_service.md | 70 + .../modules/ansible.builtin.tempfile.md | 35 + .../modules/ansible.builtin.template.md | 66 + .../Ansible/modules/ansible.builtin.uri.md | 171 +++ .../Ansible/modules/ansible.builtin.user.md | 101 ++ .../modules/ansible.builtin.wait_for.md | 100 ++ .../Ansible/tests/Ansible Test Plugins.md | 7 + .../Ansible/tests/ansible.builtin.exists.md | 9 + .../Ansible/tests/ansible.builtin.search.md | 16 + .../Ansible/tests/ansible.builtin.success.md | 8 + .../Ansible/tests/ansible.builtin.url.md | 19 + technology/tools/BitTorrent.md | 9 + technology/tools/Docker Compose.md | 383 ++++++ technology/tools/Docker.md | 105 ++ technology/tools/GPG.md | 69 + technology/tools/I2P.md | 44 + technology/tools/JSON Schema.md | 479 +++++++ technology/tools/JSONPatch.md | 106 ++ technology/tools/Jinja.md | 431 +++++++ technology/tools/Monero.md | 71 + technology/tools/Podman.md | 109 ++ technology/tools/QR Code.md | 8 + technology/tools/RSS.md | 35 + technology/tools/Regex.md | 115 ++ technology/tools/Tor.md | 31 + technology/tools/Virtual Machine.md | 14 + technology/tools/WebDAV.md | 6 + technology/windows/Windows.md | 12 + technology/windows/Wine.md | 21 + 475 files changed, 27928 insertions(+) create mode 100644 Meta.md create mode 100644 MetaIndex.md create mode 100644 schema.json create mode 100644 science/Science.md create mode 100644 science/biology/Biology.md create mode 100644 science/chemistry/Chemistry.md create mode 100644 science/math/Binary System.md create mode 100644 science/math/Decimal System.md create mode 100644 science/math/Hexadecimal System.md create mode 100644 science/math/Math.md create mode 100644 science/philosophy/Philosophy.md create mode 100644 science/physics/Physics.md create mode 100644 science/physics/SI Units.md create mode 100644 science/physics/units/Volt.md create mode 100644 science/psychology/Psychology.md create mode 100644 technology/Cryptography/AES.md create mode 100644 technology/Cryptography/Cryptography.md create mode 100644 technology/Cryptography/RSA.md create mode 100644 technology/Cryptography/SHA.md create mode 100644 technology/applications/3d/Blender.md create mode 100644 technology/applications/Feather Wallet.md create mode 100644 technology/applications/MongoDB Compass.md create mode 100644 technology/applications/MongoDB.md create mode 100644 technology/applications/OpenSSL.md create mode 100644 technology/applications/SSH.md create mode 100644 technology/applications/SurrealDB.md create mode 100644 technology/applications/Teleport.md create mode 100644 technology/applications/backup/Vorta.md create mode 100644 technology/applications/backup/borg.md create mode 100644 technology/applications/clamav.md create mode 100644 technology/applications/cli/Core Utils.md create mode 100644 technology/applications/cli/Loop.md create mode 100644 technology/applications/cli/Shell.md create mode 100644 technology/applications/cli/alacritty.md create mode 100644 technology/applications/cli/aria2.md create mode 100644 technology/applications/cli/bash.md create mode 100644 technology/applications/cli/bat.md create mode 100644 technology/applications/cli/chattr.md create mode 100644 technology/applications/cli/choose.md create mode 100644 technology/applications/cli/crunch.md create mode 100644 technology/applications/cli/curl.md create mode 100644 technology/applications/cli/diff.md create mode 100644 technology/applications/cli/diskonaut.md create mode 100644 technology/applications/cli/doas.md create mode 100644 technology/applications/cli/duf.md create mode 100644 technology/applications/cli/eza.md create mode 100644 technology/applications/cli/fd.md create mode 100644 technology/applications/cli/file.md create mode 100644 technology/applications/cli/glow.md create mode 100644 technology/applications/cli/handlr.md create mode 100644 technology/applications/cli/hashcat.md create mode 100644 technology/applications/cli/hck.md create mode 100644 technology/applications/cli/hexyl.md create mode 100644 technology/applications/cli/huniq.md create mode 100644 technology/applications/cli/hyperfine.md create mode 100644 technology/applications/cli/intermodal.md create mode 100644 technology/applications/cli/jless.md create mode 100644 technology/applications/cli/joshuto.md create mode 100644 technology/applications/cli/jq.md create mode 100644 technology/applications/cli/just.md create mode 100644 technology/applications/cli/losetup.md create mode 100644 technology/applications/cli/lsblk.md create mode 100644 technology/applications/cli/man.md create mode 100644 technology/applications/cli/micro.md create mode 100644 technology/applications/cli/netcat.md create mode 100644 technology/applications/cli/netdiscover.md create mode 100644 technology/applications/cli/nmap.md create mode 100644 technology/applications/cli/p7zip.md create mode 100644 technology/applications/cli/patch.md create mode 100644 technology/applications/cli/pueue.md create mode 100644 technology/applications/cli/ripgrep.md create mode 100644 technology/applications/cli/rnr.md create mode 100644 technology/applications/cli/rsync.md create mode 100644 technology/applications/cli/sd.md create mode 100644 technology/applications/cli/skim.md create mode 100644 technology/applications/cli/smbmap.md create mode 100644 technology/applications/cli/tailspin.md create mode 100644 technology/applications/cli/tar.md create mode 100644 technology/applications/cli/tmux.md create mode 100644 technology/applications/cli/tokei.md create mode 100644 technology/applications/cli/wget.md create mode 100644 technology/applications/cli/zsh.md create mode 100644 technology/applications/communication/Discord.md create mode 100644 technology/applications/communication/Element.md create mode 100644 technology/applications/communication/Gmail.md create mode 100644 technology/applications/communication/ProtonMail.md create mode 100644 technology/applications/communication/Thunderbird.md create mode 100644 technology/applications/desktops/KDE Plasma.md create mode 100644 technology/applications/desktops/dwm.md create mode 100644 technology/applications/desktops/hyprland.md create mode 100644 technology/applications/desktops/picom.md create mode 100644 technology/applications/development/DB Browser for SQLite.md create mode 100644 technology/applications/development/Ghidra.md create mode 100644 technology/applications/development/GitHub Actions.md create mode 100644 technology/applications/development/GitHub Desktop.md create mode 100644 technology/applications/development/GitHub.md create mode 100644 technology/applications/development/HTTPie.md create mode 100644 technology/applications/development/Podman Desktop.md create mode 100644 technology/applications/development/Visual Studio Code.md create mode 100644 technology/applications/development/xh.md create mode 100644 technology/applications/documents/Tachiyomi.md create mode 100644 technology/applications/media/DaVinci Resolve.md create mode 100644 technology/applications/media/Findroid.md create mode 100644 technology/applications/media/ImageMagick.md create mode 100644 technology/applications/media/MKVToolnix.md create mode 100644 technology/applications/media/MPV.md create mode 100644 technology/applications/media/Natron.md create mode 100644 technology/applications/media/NewPipe.md create mode 100644 technology/applications/media/OBS.md create mode 100644 technology/applications/media/Plexamp.md create mode 100644 technology/applications/media/Steam.md create mode 100644 technology/applications/media/images/GIMP.md create mode 100644 technology/applications/media/images/pywal.md create mode 100644 technology/applications/media/kdenlive.md create mode 100644 technology/applications/media/kid3.md create mode 100644 technology/applications/media/yt-dlp.md create mode 100644 technology/applications/mobile/Google Maps.md create mode 100644 technology/applications/mobile/Monero GUI.md create mode 100644 technology/applications/mobile/N26.md create mode 100644 technology/applications/mobile/Termux.md create mode 100644 technology/applications/network/DAVx5.md create mode 100644 technology/applications/network/FileZilla.md create mode 100644 technology/applications/network/JDownloader.md create mode 100644 technology/applications/network/KDE Connect.md create mode 100644 technology/applications/network/Mullvad VPN.md create mode 100644 technology/applications/network/NetworkManager.md create mode 100644 technology/applications/network/OnionShare.md create mode 100644 technology/applications/network/Privoxy.md create mode 100644 technology/applications/network/SnapDrop.md create mode 100644 technology/applications/network/Syncthing.md create mode 100644 technology/applications/network/Wireguard.md create mode 100644 technology/applications/network/Wireshark.md create mode 100644 technology/applications/network/browsers/Brave.md create mode 100644 technology/applications/network/browsers/Firefox.md create mode 100644 technology/applications/network/browsers/Mullvad Browser.md create mode 100644 technology/applications/network/iperf.md create mode 100644 technology/applications/network/qBittorent.md create mode 100644 technology/applications/network/rclone.md create mode 100644 technology/applications/network/smb4k.md create mode 100644 technology/applications/network/ufw.md create mode 100644 technology/applications/office/Google Calendar.md create mode 100644 technology/applications/office/Google Contacts.md create mode 100644 technology/applications/office/LibreOffice.md create mode 100644 technology/applications/office/Obsidian.md create mode 100644 technology/applications/package managers/Aurora Store.md create mode 100644 technology/applications/package managers/Brew.md create mode 100644 technology/applications/package managers/Flatpak.md create mode 100644 technology/applications/package managers/PKGBUILD.md create mode 100644 technology/applications/package managers/Package Managers.md create mode 100644 technology/applications/package managers/Pacman.md create mode 100644 technology/applications/package managers/makepkg.md create mode 100644 technology/applications/utilities/Aegis.md create mode 100644 technology/applications/utilities/Bottles.md create mode 100644 technology/applications/utilities/Czkawka.md create mode 100644 technology/applications/utilities/Dunst.md create mode 100644 technology/applications/utilities/Filelight.md create mode 100644 technology/applications/utilities/Flatseal.md create mode 100644 technology/applications/utilities/Hyprpaper.md create mode 100644 technology/applications/utilities/KeePassXC.md create mode 100644 technology/applications/utilities/Kleopatra.md create mode 100644 technology/applications/utilities/Lutris.md create mode 100644 technology/applications/utilities/Mission Center.md create mode 100644 technology/applications/utilities/Rofi.md create mode 100644 technology/applications/utilities/Steam ROM Manager.md create mode 100644 technology/applications/utilities/Waybar.md create mode 100644 technology/applications/web/AdGuard.md create mode 100644 technology/applications/web/Authelia.md create mode 100644 technology/applications/web/Bitwarden.md create mode 100644 technology/applications/web/Frigate.md create mode 100644 technology/applications/web/Gitea.md create mode 100644 technology/applications/web/Grocy.md create mode 100644 technology/applications/web/Guacamole.md create mode 100644 technology/applications/web/Home Assistant.md create mode 100644 technology/applications/web/IPFS.md create mode 100644 technology/applications/web/Jellyfin.md create mode 100644 technology/applications/web/Kavita.md create mode 100644 technology/applications/web/Matrix.md create mode 100644 technology/applications/web/Minio.md create mode 100644 technology/applications/web/Overseerr.md create mode 100644 technology/applications/web/Plex.md create mode 100644 technology/applications/web/Portainer.md create mode 100644 technology/applications/web/Radicale.md create mode 100644 technology/applications/web/Samba.md create mode 100644 technology/applications/web/Uptime Kuma.md create mode 100644 technology/applications/web/Vikunja.md create mode 100644 technology/applications/web/dufs.md create mode 100644 technology/applications/web/mitmproxy.md create mode 100644 technology/applications/web/nginx.md create mode 100644 technology/applications/web/traefik.md create mode 100644 technology/applications/web/zigbee2mqtt.md create mode 100644 technology/bsd/FreeBSD.md create mode 100644 technology/bsd/OPNsense.md create mode 100644 technology/bsd/OpenBSD.md create mode 100644 technology/bsd/bhyve.md create mode 100644 technology/bsd/geli.md create mode 100644 technology/bsd/ggate.md create mode 100644 technology/bsd/gmirror.md create mode 100644 technology/bsd/gpart.md create mode 100644 technology/bsd/graid.md create mode 100644 technology/bsd/gstripe.md create mode 100644 technology/bsd/pfSense.md create mode 100644 technology/dev/Development.md create mode 100644 technology/dev/Git.md create mode 100644 technology/dev/gitmoji.md create mode 100644 technology/devices/Raspberry Pi 4.md create mode 100644 technology/devices/Steam Deck.md create mode 100644 technology/devices/YubiKey.md create mode 100644 technology/emulation/Cemu.md create mode 100644 technology/emulation/Citra.md create mode 100644 technology/emulation/Dolphin Emulator.md create mode 100644 technology/emulation/Emulation.md create mode 100644 technology/emulation/PCSX2.md create mode 100644 technology/emulation/RPCS3.md create mode 100644 technology/emulation/Ryujinx.md create mode 100644 technology/emulation/Yuzu.md create mode 100644 technology/files/ASCII.md create mode 100644 technology/files/BSON.md create mode 100644 technology/files/Base64.md create mode 100644 technology/files/CSV.md create mode 100644 technology/files/Comic Book Archive.md create mode 100644 technology/files/Desktop Entry.md create mode 100644 technology/files/File Formats.md create mode 100644 technology/files/JSON Pointer.md create mode 100644 technology/files/JSON.md create mode 100644 technology/files/MIME.md create mode 100644 technology/files/Markdown.md create mode 100644 technology/files/MessagePack.md create mode 100644 technology/files/PDF.md create mode 100644 technology/files/TOML.md create mode 100644 technology/files/Unicode.md create mode 100644 technology/files/XML.md create mode 100644 technology/files/XPath.md create mode 100644 technology/files/YAML.md create mode 100644 technology/files/ZIP.md create mode 100644 technology/internet/CSS.md create mode 100644 technology/internet/Cookie.md create mode 100644 technology/internet/DHCP.md create mode 100644 technology/internet/DNS.md create mode 100644 technology/internet/Data URLs.md create mode 100644 technology/internet/Domain.md create mode 100644 technology/internet/FTP.md create mode 100644 technology/internet/HTML.md create mode 100644 technology/internet/HTMX.md create mode 100644 technology/internet/HTTP.md create mode 100644 technology/internet/JWT.md create mode 100644 technology/internet/MQTT.md create mode 100644 technology/internet/NTP.md create mode 100644 technology/internet/OSI Model.md create mode 100644 technology/internet/Power over Ethernet.md create mode 100644 technology/internet/QUIC.md create mode 100644 technology/internet/SMTP.md create mode 100644 technology/internet/TCP.md create mode 100644 technology/internet/TailwindCSS.md create mode 100644 technology/internet/UDP.md create mode 100644 technology/internet/URL.md create mode 100644 technology/internet/Wake on LAN.md create mode 100644 technology/internet/WebSocket.md create mode 100644 technology/internet/Webhook.md create mode 100644 technology/internet/eMail.md create mode 100644 technology/internet/websites/Links.md create mode 100644 technology/internet/websites/clearnet/Amazon.md create mode 100644 technology/internet/websites/clearnet/Apple.md create mode 100644 technology/internet/websites/clearnet/BS.to.md create mode 100644 technology/internet/websites/clearnet/ChangeNow.md create mode 100644 technology/internet/websites/clearnet/ChatGPT.md create mode 100644 technology/internet/websites/clearnet/Cloudflare.md create mode 100644 technology/internet/websites/clearnet/Crunchyroll.md create mode 100644 technology/internet/websites/clearnet/Fandom.md create mode 100644 technology/internet/websites/clearnet/IGDB.md create mode 100644 technology/internet/websites/clearnet/Instant Gaming.md create mode 100644 technology/internet/websites/clearnet/Internet Archive.md create mode 100644 technology/internet/websites/clearnet/Microsoft.md create mode 100644 technology/internet/websites/clearnet/Mozilla.md create mode 100644 technology/internet/websites/clearnet/Mullvad.md create mode 100644 technology/internet/websites/clearnet/MyAnimeList.md create mode 100644 technology/internet/websites/clearnet/Netflix.md create mode 100644 technology/internet/websites/clearnet/Nyaa.md create mode 100644 technology/internet/websites/clearnet/Odysee.md create mode 100644 technology/internet/websites/clearnet/OpenStreetMap.md create mode 100644 technology/internet/websites/clearnet/PsychonautWiki.md create mode 100644 technology/internet/websites/clearnet/Reddit.md create mode 100644 technology/internet/websites/clearnet/SendGrid.md create mode 100644 technology/internet/websites/clearnet/SoundCloud.md create mode 100644 technology/internet/websites/clearnet/SteamGridDB.md create mode 100644 technology/internet/websites/clearnet/TMDB.md create mode 100644 technology/internet/websites/clearnet/Twitch.md create mode 100644 technology/internet/websites/clearnet/Unsplash.md create mode 100644 technology/internet/websites/clearnet/Wikipedia.md create mode 100644 technology/internet/websites/clearnet/YouTube.md create mode 100644 technology/internet/websites/clearnet/crates.io.md create mode 100644 technology/internet/websites/clearnet/deps.rs.md create mode 100644 technology/internet/websites/clearnet/docs.rs.md create mode 100644 technology/internet/websites/clearnet/lainchan.md create mode 100644 technology/internet/websites/clearnet/nsw2u.md create mode 100644 technology/internet/websites/clearnet/wallhaven.md create mode 100644 technology/internet/websites/clearnet/wired-7.md create mode 100644 technology/internet/websites/i2p/AlphaBay.md create mode 100644 technology/internet/websites/i2p/Based Cooking.md create mode 100644 technology/internet/websites/i2p/Cannabia.md create mode 100644 technology/internet/websites/i2p/Coffeechan.md create mode 100644 technology/internet/websites/i2p/DarknetBible.md create mode 100644 technology/internet/websites/i2p/Identiguy.md create mode 100644 technology/internet/websites/i2p/Postman.md create mode 100644 technology/internet/websites/i2p/Registry.md create mode 100644 technology/internet/websites/i2p/SocksCat.md create mode 100644 technology/internet/websites/i2p/cake.i2p.md create mode 100644 technology/internet/websites/i2p/i2pd.md create mode 100644 technology/internet/websites/onion/DarkEye.md create mode 100644 technology/internet/websites/onion/DarkTea.md create mode 100644 technology/internet/websites/onion/DarknetHome.md create mode 100644 technology/internet/websites/onion/Dread.md create mode 100644 technology/internet/websites/onion/DuckDuckGo.md create mode 100644 technology/internet/websites/onion/MegaLinks.md create mode 100644 technology/internet/websites/onion/PirateBay.md create mode 100644 technology/internet/websites/onion/The Hidden Wiki.md create mode 100644 technology/linux/Alpine Linux.md create mode 100644 technology/linux/Arch Linux.md create mode 100644 technology/linux/Command Line Tools.md create mode 100644 technology/linux/Environment Variables.md create mode 100644 technology/linux/Kali Linux.md create mode 100644 technology/linux/Linux.md create mode 100644 technology/linux/Loop Device.md create mode 100644 technology/linux/Proxmox.md create mode 100644 technology/linux/Systemd-Mounts.md create mode 100644 technology/linux/Systemd-Timers.md create mode 100644 technology/linux/Systemd.md create mode 100644 technology/linux/filesystems/Btrfs.md create mode 100644 technology/linux/filesystems/Ext4.md create mode 100644 technology/linux/filesystems/Filesystems.md create mode 100644 technology/linux/filesystems/LUKS.md create mode 100644 technology/linux/filesystems/LVM.md create mode 100644 technology/linux/filesystems/MergerFS Tools.md create mode 100644 technology/linux/filesystems/MergerFS.md create mode 100644 technology/linux/filesystems/RAID.md create mode 100644 technology/linux/filesystems/SSHFS.md create mode 100644 technology/linux/filesystems/SquashFS.md create mode 100644 technology/linux/filesystems/ZFS.md create mode 100644 technology/linux/filesystems/exFAT.md create mode 100644 technology/linux/mkinitcpio.md create mode 100644 technology/linux/openrc.md create mode 100644 technology/linux/qemu.md create mode 100644 technology/linux/systemd-boot.md create mode 100644 technology/macos/macOS.md create mode 100644 technology/media/Codecs.md create mode 100644 technology/media/Matroska.md create mode 100644 technology/media/audio/FLAC.md create mode 100644 technology/media/audio/Opus.md create mode 100644 technology/media/audio/WAV.md create mode 100644 technology/media/ffmpeg.md create mode 100644 technology/media/image/AVIF.md create mode 100644 technology/media/image/PNG.md create mode 100644 technology/media/video/AV1.md create mode 100644 technology/media/video/H.264.md create mode 100644 technology/media/video/H.265.md create mode 100644 technology/media/video/VP9.md create mode 100644 technology/programming/Godot.md create mode 100644 technology/programming/SQLite.md create mode 100644 technology/programming/frameworks/Flutter.md create mode 100644 technology/programming/languages/Lua.md create mode 100644 technology/programming/languages/Python.md create mode 100644 technology/programming/languages/Rust.md create mode 100644 technology/programming/languages/SQL.md create mode 100644 technology/programming/patterns/Programming Patterns.md create mode 100644 technology/programming/patterns/behavioral/Iterator Pattern.md create mode 100644 technology/programming/patterns/behavioral/Memento Pattern.md create mode 100644 technology/programming/patterns/behavioral/Null Object Pattern.md create mode 100644 technology/programming/patterns/behavioral/Observer Patterns.md create mode 100644 technology/programming/patterns/behavioral/State Patterns.md create mode 100644 technology/programming/patterns/behavioral/Strategy Pattern.md create mode 100644 technology/programming/patterns/behavioral/Template Method Pattern.md create mode 100644 technology/programming/patterns/behavioral/Visitor Pattern.md create mode 100644 technology/programming/patterns/creational/Abstract Factory Pattern.md create mode 100644 technology/programming/patterns/creational/Builder Pattern.md create mode 100644 technology/programming/patterns/creational/Dependency Injection Pattern.md create mode 100644 technology/programming/patterns/creational/Factory Method Pattern.md create mode 100644 technology/programming/patterns/creational/Lazy Instantiation Pattern.md create mode 100644 technology/programming/patterns/creational/Multiton Pattern.md create mode 100644 technology/programming/patterns/creational/Object Pool Pattern.md create mode 100644 technology/programming/patterns/creational/Prototype Pattern.md create mode 100644 technology/programming/patterns/creational/RAII Pattern.md create mode 100644 technology/programming/patterns/creational/Singleton Pattern.md create mode 100644 technology/programming/patterns/structural/Adapter Pattern.md create mode 100644 technology/programming/patterns/structural/Bridge Patterns.md create mode 100644 technology/programming/patterns/structural/Composite Pattern.md create mode 100644 technology/programming/patterns/structural/Decorator Pattern.md create mode 100644 technology/programming/patterns/structural/Facade Pattern.md create mode 100644 technology/programming/patterns/structural/Flyweight Pattern.md create mode 100644 technology/programming/patterns/structural/Proxy Pattern.md create mode 100644 technology/systems/Android.md create mode 100644 technology/systems/GrapheneOS.md create mode 100644 technology/systems/QubesOS.md create mode 100644 technology/systems/Tails.md create mode 100644 technology/tools/Ansible/Ansible.md create mode 100644 technology/tools/Ansible/filters/Ansible Filters.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.b64decode.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.b64encode.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.basename.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.combine.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.comment.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.commonpath.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.difference.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.dirname.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.from_json.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.from_yaml.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.hash.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.human_readable.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.human_to_bytes.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.intersect.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.md5.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.path_join.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.permutations.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.regex_findall.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.regex_replace.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.regex_search.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.relpath.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.shuffle.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.split.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.splitext.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.strftime.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.to_datetime.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.to_json.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.to_yaml.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.unique.md create mode 100644 technology/tools/Ansible/filters/ansible.builtin.urlsplit.md create mode 100644 technology/tools/Ansible/filters/community.general.json_query.md create mode 100644 technology/tools/Ansible/lookups/Ansible Lookup Plugins.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.csvfile.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.env.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.file.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.ini.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.template.md create mode 100644 technology/tools/Ansible/lookups/ansible.builtin.url.md create mode 100644 technology/tools/Ansible/lookups/community.mongodb.mongodb.md create mode 100644 technology/tools/Ansible/modules/Ansible Modules.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.assert.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.blockinfile.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.copy.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.cron.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.debug.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.fail.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.fetch.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.lineinfile.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.package.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.pause.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.replace.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.shell.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.systemd_service.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.tempfile.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.template.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.uri.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.user.md create mode 100644 technology/tools/Ansible/modules/ansible.builtin.wait_for.md create mode 100644 technology/tools/Ansible/tests/Ansible Test Plugins.md create mode 100644 technology/tools/Ansible/tests/ansible.builtin.exists.md create mode 100644 technology/tools/Ansible/tests/ansible.builtin.search.md create mode 100644 technology/tools/Ansible/tests/ansible.builtin.success.md create mode 100644 technology/tools/Ansible/tests/ansible.builtin.url.md create mode 100644 technology/tools/BitTorrent.md create mode 100644 technology/tools/Docker Compose.md create mode 100644 technology/tools/Docker.md create mode 100644 technology/tools/GPG.md create mode 100644 technology/tools/I2P.md create mode 100644 technology/tools/JSON Schema.md create mode 100644 technology/tools/JSONPatch.md create mode 100644 technology/tools/Jinja.md create mode 100644 technology/tools/Monero.md create mode 100644 technology/tools/Podman.md create mode 100644 technology/tools/QR Code.md create mode 100644 technology/tools/RSS.md create mode 100644 technology/tools/Regex.md create mode 100644 technology/tools/Tor.md create mode 100644 technology/tools/Virtual Machine.md create mode 100644 technology/tools/WebDAV.md create mode 100644 technology/windows/Windows.md create mode 100644 technology/windows/Wine.md diff --git a/Meta.md b/Meta.md new file mode 100644 index 0000000..5f0a501 --- /dev/null +++ b/Meta.md @@ -0,0 +1,43 @@ +--- +obj: meta +--- + +# Frontmatter +[Index](MetaIndex.md) +## Common Frontmatter Tags +- `website` - Website +- `repo` - Repository +- `source` - Source +- `wiki` - Wiki link +- `arch-wiki` - Arch Wiki link +- `rfc` - RFC Document link +- `obj` - Object Type + +## Common Frontmatter Tags for Object Types +### `Application` + `Emulator` +- `android-id` - Android Application ID +- `flatpak-id` - Flatpak Application ID +- `f-droid` - F-Droid URL + +### `Website` +- `category` - Website Category +- `status` - Website Status + +# Object Types +- `Application` - Any application +- `OS` - Operating System +- `Codec` - Media Codec +- `FileSystem` - File System +- `Emulator` - Emulator System +- `Concept` - Concept +- `Meta` - Lists, Collections, Metadata + - `Meta/Collection` - Collection of notes +- `Device` - Physical Device +- `Website` - Website +- `Science` - Scientific Notes + - `Science/Unit` - Scientific measurement unit + +## Notes without Object set +```dataview +table obj as "Type" from "knowledge" where obj = null +``` \ No newline at end of file diff --git a/MetaIndex.md b/MetaIndex.md new file mode 100644 index 0000000..4e7ea69 --- /dev/null +++ b/MetaIndex.md @@ -0,0 +1,90 @@ +--- +obj: meta +--- + +# Index +## Frontmatter +### Notes with websites +```dataview +table website from "/" where website != null +``` + +### Notes with repositories +```dataview +table repo from "/" where repo != null +``` + +### Notes with Sources +```dataview +table source from "/" where source != null +``` + +### Notes with Wiki +```dataview +table wiki from "/" where wiki != null +``` + +### Notes with Arch Wiki +```dataview +table arch-wiki from "/" where arch-wiki != null +``` + +### Notes with RFC +```dataview +table rfc from "/" where rfc != null +``` + +### Notes with Object Type +```dataview +table obj from "/" where obj != null +``` + +## Object Type +### Applications +```dataview +table android-id, flatpak-id from "/" where startswith(lower(obj), "application") +``` + +### Operating Systems +```dataview +list from "/" where startswith(lower(obj), "os") +``` + +### Codecs +```dataview +list from "/" where startswith(lower(obj), "codec") +``` + +### Filesystems +```dataview +list from "/" where startswith(lower(obj), "filesystem") +``` + +### Emulators +```dataview +list from "/" where startswith(lower(obj), "emulator") +``` + +### Concepts +```dataview +list from "/" where startswith(lower(obj), "concept") +``` + +### Meta Notes +```dataview +list from "/" where startswith(lower(obj), "meta") +``` + +### Device Notes +```dataview +list from "/" where startswith(lower(obj), "device") +``` + +### Science Notes +```dataview +list from "/" where startswith(lower(obj), "science") +``` +### Website Notes +```dataview +table website, category, status from "/" where startswith(lower(obj), "website") +``` \ No newline at end of file diff --git a/schema.json b/schema.json new file mode 100644 index 0000000..741bea5 --- /dev/null +++ b/schema.json @@ -0,0 +1,169 @@ +{ + "type": "object", + "title": "Markdown Note", + "description": "Knowledge Base Markdown note on a topic", + "$schema": "http://json-schema.org/draft-07/schema#", + "required": ["obj"], + "properties": { + "tags": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Note Tags", + "description": "List of tags asssociated with the note" + }, + "aliases": { + "type": "array", + "items": { + "type": "string" + }, + "title": "Note Aliases", + "description": "List of aliases of the note" + }, + "website": { + "title": "Website", + "description": "Associated website with the note", + "type": [ + "string", + "array" + ], + "items": { + "type": "string", + "format": "uri" + }, + "format": "uri" + }, + "repo": { + "title": "Repository", + "description": "Associated repository with the note", + "type": "string", + "format": "uri" + }, + "source": { + "title": "Source", + "description": "Source the note is based on", + "type": "string", + "format": "uri" + }, + "wiki": { + "title": "Wikipedia", + "description": "Wikipedia link about the note", + "type": "string", + "format": "uri" + }, + "arch-wiki": { + "title": "Arch Wiki", + "description": "Arch Wiki link about the note", + "type": "string", + "format": "uri" + }, + "rfc": { + "title": "RFC", + "description": "Link to RFC this note is about", + "type": "string", + "format": "uri" + }, + "obj": { + "title": "Object Type", + "description": "Meta information about the notes general classification", + "type": "string", + "enum": [ + "application", + "os", + "codec", + "filesystem", + "emulator", + "concept", + "meta", + "meta/collection", + "device", + "website", + "science", + "science/unit" + ] + } + }, + "allOf": [ + { + "if": { + "properties": { + "obj": { + "pattern": "^(application|emulator)" + } + } + }, + "then": { + "properties": { + "android-id": { + "title": "Android Application ID", + "description": "The Android Application ID of the note", + "type": "string" + }, + "flatpak-id": { + "title": "Flatpak Application ID", + "description": "The Flatpak Application ID of the note", + "type": "string" + }, + "f-droid": { + "title": "F-Droid Page", + "description": "Link to the F-Droid Page of the note", + "type": "string", + "format": "uri" + } + } + } + }, + { + "if": { + "properties": { + "obj": { + "pattern": "^website" + } + } + }, + "then": { + "properties": { + "category": { + "title": "Category", + "description": "General category the website falls into", + "type": "string", + "enum": [ + "server", + "finance", + "social", + "service", + "development", + "search", + "information", + "market", + "knowledge", + "board", + "company", + "shop", + "content", + "images", + "link-registry", + "api" + ] + }, + "status": { + "title": "Website Status", + "description": "Wether the website is up or down", + "type": [ + "string", + "null" + ], + "enum": [ + "down", + "up" + ] + } + }, + "required": [ + "category" + ] + } + } + ] +} diff --git a/science/Science.md b/science/Science.md new file mode 100644 index 0000000..4361525 --- /dev/null +++ b/science/Science.md @@ -0,0 +1,11 @@ +--- +tags: ["meta"] +obj: meta/collection +--- +# Science Fields +- [Math](math/Math.md) +- [Physics](physics/Physics.md) +- [Chemistry](chemistry/Chemistry.md) +- [Biology](biology/Biology.md) +- [Philosophy](philosophy/Philosophy.md) +- [Psychology](psychology/Psychology.md) \ No newline at end of file diff --git a/science/biology/Biology.md b/science/biology/Biology.md new file mode 100644 index 0000000..578916a --- /dev/null +++ b/science/biology/Biology.md @@ -0,0 +1,5 @@ +--- +obj: meta +--- + +#wip #🐇 #notnow \ No newline at end of file diff --git a/science/chemistry/Chemistry.md b/science/chemistry/Chemistry.md new file mode 100644 index 0000000..033bf12 --- /dev/null +++ b/science/chemistry/Chemistry.md @@ -0,0 +1,4 @@ +--- +obj: meta +--- +#wip #🐇 #notnow \ No newline at end of file diff --git a/science/math/Binary System.md b/science/math/Binary System.md new file mode 100644 index 0000000..37b59d4 --- /dev/null +++ b/science/math/Binary System.md @@ -0,0 +1,26 @@ +--- +obj: concept +--- +# Binary System +The base-2 numeral system is a positional notation with a radix of 2. Each digit is referred to as a bit, or binary digit. Because of its straightforward implementation in digital electronic circuitry using logic gates, the binary system is used by almost all modern computers and computer-based devices, as a preferred system of use, over various other human techniques of communication, because of the simplicity of the language and the noise immunity in physical implementation. + +Negative numbers are commonly represented in binary using two's complement. + +## Two's complement +Two's complement of an integer number is achieved by: +- Step 1: Start with the absolute value of the number. +- Step 2: inverting (or flipping) all bits – changing every 0 to 1, and every 1 to 0; +- Step 3: adding 1 to the entire inverted number, ignoring any overflow. Accounting for overflow will produce the wrong value for the result. + +For example, to calculate the decimal number **−6** in binary: +- Step 1: _+6_ in decimal is _0110_ in binary; the leftmost significant bit (the first 0) is the sign (just _110_ in binary would be -2 in decimal). +- Step 2: flip all bits in _0110_, giving _1001_. +- Step 3: add the place value 1 to the flipped number _1001_, giving _1010_. + +To verify that _1010_ indeed has a value of _−6_, add the place values together, but _subtract_ the sign value from the final calculation. Because the most significant value is the sign value, it must be subtracted to produce the correct result: **1010** = **−**(**1**×23) + (**0**×22) + (**1**×21) + (**0**×20) = **1**×−8 + **0** + **1**×2 + **0** = −6. + +| Bits: | 1 | 0 | 1 | 0 | +| -------------------- | --------------- | ---------- | ---------- | ---------- | +| Decimal bit value: | **−**8 | 4 | 2 | 1 | +| Binary calculation: | **−**(**1**×23) | (**0**×22) | (**1**×21) | (**0**×20) | +| Decimal calculation: | **−**(**1**×8) | **0** | **1**×2 | **0** | \ No newline at end of file diff --git a/science/math/Decimal System.md b/science/math/Decimal System.md new file mode 100644 index 0000000..b3c943f --- /dev/null +++ b/science/math/Decimal System.md @@ -0,0 +1,10 @@ +--- +obj: concept +wiki: https://en.wikipedia.org/wiki/Decimal +--- +# Decimal System +The decimal numeral system (also called the base-ten positional numeral system and decanary) is the standard system for denoting integer and non-integer numbers. It is the extension to non-integer numbers (decimal fractions) of the Hindu–Arabic numeral system. The way of denoting numbers in the decimal system is often referred to as decimal notation. + +A decimal numeral (also often just decimal or, less correctly, decimal number), refers generally to the notation of a number in the decimal numeral system. Decimals may sometimes be identified by a decimal separator (usually "." or "," as in 25.9703 or 3,1415). Decimal may also refer specifically to the digits after the decimal separator, such as in "3.14 is the approximation of π to two decimals". Zero-digits after a decimal separator serve the purpose of signifying the precision of a value. + +The decimal system uses the following symbols: `0`, `1`, `2`, `3`, `4`, `5`, `6`, `7`, `8`, `9` \ No newline at end of file diff --git a/science/math/Hexadecimal System.md b/science/math/Hexadecimal System.md new file mode 100644 index 0000000..4f068b5 --- /dev/null +++ b/science/math/Hexadecimal System.md @@ -0,0 +1,30 @@ +--- +obj: concept +--- +# Hexadecimal System +The hexadecimal numbering system, often referred to as "hex," is a base-16 numeral system widely used in computing and digital electronics. It provides a convenient way to represent binary-coded values with a more human-friendly and compact notation. In the hexadecimal system, numbers are represented using 16 different digits: 0-9 and A-F, where A stands for 10, B for 11, and so on up to F for 15. + +## Representation +In hexadecimal, each digit represents a power of 16. The rightmost digit represents $16^0$ (1), the next digit to the left represents $16^1$ (16), the next $16^2$ (256), and so forth. For example: + +- **1F in hexadecimal** is equal to $1×16^1+15×16^0$, which is 31 in decimal. +- **2A3 in hexadecimal** is equal to $2×16^2+10×16^1+3×16^0,$, which is 675 in decimal. + +## Hexadecimal Digits +The hexadecimal system uses the following digits: + +- **0, 1, 2, 3, 4, 5, 6, 7, 8, 9**: Represent values 0 to 9. +- **A, B, C, D, E, F**: Represent values 10 to 15. + +## Uses in Computing +### Memory Addresses +In computer programming, memory addresses are often expressed in hexadecimal. Each byte of memory can be represented by two hexadecimal digits, providing a concise way to denote memory locations. +`Example: 0x1A3F` + +### Color Representation +Hexadecimal is commonly used to represent colors in web development and digital graphics. In this context, a hexadecimal color code consists of three pairs of digits representing the intensities of red, green, and blue. +`Example: #FFA500 (RGB: 255, 165, 0)` + +### Binary Representation +Hexadecimal is closely related to [binary](Binary%20System.md) representation. Each hexadecimal digit corresponds to four bits in binary. This relationship makes it easier to convert between hexadecimal and binary. +`Example: Binary 1010 is equivalent to Hex A.` \ No newline at end of file diff --git a/science/math/Math.md b/science/math/Math.md new file mode 100644 index 0000000..801f46c --- /dev/null +++ b/science/math/Math.md @@ -0,0 +1,5 @@ +--- +obj: meta +--- +# Math +#wip #🐇 #notnow \ No newline at end of file diff --git a/science/philosophy/Philosophy.md b/science/philosophy/Philosophy.md new file mode 100644 index 0000000..33ab948 --- /dev/null +++ b/science/philosophy/Philosophy.md @@ -0,0 +1,5 @@ +--- +obj: meta +--- +# Philosophy +#wip #🐇 #notnow \ No newline at end of file diff --git a/science/physics/Physics.md b/science/physics/Physics.md new file mode 100644 index 0000000..033bf12 --- /dev/null +++ b/science/physics/Physics.md @@ -0,0 +1,4 @@ +--- +obj: meta +--- +#wip #🐇 #notnow \ No newline at end of file diff --git a/science/physics/SI Units.md b/science/physics/SI Units.md new file mode 100644 index 0000000..c3fada2 --- /dev/null +++ b/science/physics/SI Units.md @@ -0,0 +1,6 @@ +--- +obj: meta/collection +--- + +#wip #🐇 #notnow +- [Volt](units/Volt.md) \ No newline at end of file diff --git a/science/physics/units/Volt.md b/science/physics/units/Volt.md new file mode 100644 index 0000000..a51a255 --- /dev/null +++ b/science/physics/units/Volt.md @@ -0,0 +1,11 @@ +--- +wiki: https://en.wikipedia.org/wiki/Volt +obj: science/unit +--- +# Volt +The volt (symbol: V) is the unit of electric potential, electric potential difference (voltage), and electromotive force in the International System of Units (SI). + +| Name | Value | +| ------------- | ------------- | +| Symbol | V | +| SI base units | $$kg⋅m^2⋅s^{-3}⋅A^{−1}$$ | diff --git a/science/psychology/Psychology.md b/science/psychology/Psychology.md new file mode 100644 index 0000000..d199ee4 --- /dev/null +++ b/science/psychology/Psychology.md @@ -0,0 +1,5 @@ +--- +obj: meta +--- +# Psychology +#wip #🐇 #notnow \ No newline at end of file diff --git a/technology/Cryptography/AES.md b/technology/Cryptography/AES.md new file mode 100644 index 0000000..4bcf5d0 --- /dev/null +++ b/technology/Cryptography/AES.md @@ -0,0 +1,71 @@ +--- +obj: concept +--- + +# AES +The Advanced Encryption Standard (AES) is a widely adopted symmetric encryption algorithm used to secure sensitive data. It was established as a standard by the U.S. National Institute of Standards and Technology (NIST) in 2001, following a public competition to select a successor to the Data Encryption Standard (DES). AES is known for its efficiency, security, and versatility, making it a popular choice for various applications, including data encryption, secure communications, and cryptographic protocols. + +## Key Features +### 1. **Symmetric Encryption** +AES is a symmetric encryption algorithm, meaning the same key is used for both encryption and decryption. This key is kept secret between the communicating parties. + +### 2. **Block Cipher** +AES operates on fixed-size blocks of data, encrypting and decrypting data in blocks of 128 bits. It supports key sizes of 128, 192, or 256 bits. + +### 3. **Key Expansion** +The key expansion process in AES generates a set of round keys derived from the original key. These round keys are used in the multiple rounds of encryption and provide a high level of security. + +### 4. **Rounds of Encryption** +AES performs a series of transformations known as rounds. The number of rounds depends on the key size: 10 rounds for a 128-bit key, 12 rounds for a 192-bit key, and 14 rounds for a 256-bit key. + +### 5. **Substitution-Permutation Network (SPN) Structure** +AES employs an SPN structure, combining substitution (replacing each byte with another) and permutation (rearranging bytes) operations to achieve confusion and diffusion, enhancing the algorithm's security. + +## Encryption Process +1. **Key Expansion:** Generate a set of round keys from the original key. +2. **Initial Round:** Add the initial round key to the plaintext. +3. **Main Rounds:** Perform a series of substitution, permutation, and mixing operations for the specified number of rounds. +4. **Final Round:** The final round excludes the mixing operation. +5. **Output:** The result is the ciphertext. + +## Decryption Process +1. **Key Expansion:** Generate the round keys from the original key. +2. **Initial Round:** Add the initial round key to the ciphertext. +3. **Main Rounds:** Perform the inverse operations of the encryption process in reverse order. +4. **Final Round:** The final round excludes the mixing operation. +5. **Output:** The result is the decrypted plaintext. + +## Strengths of AES +- **Security:** AES has withstood extensive cryptanalysis and is considered highly secure when implemented correctly. +- **Efficiency:** It is computationally efficient and well-suited for both hardware and software implementations. +- **Versatility:** AES is used in various applications, including securing data at rest, data in transit, and cryptographic protocols like TLS. + +## Variants of AES +- **AES-128:** Uses a 128-bit key and 10 rounds of encryption. +- **AES-192:** Uses a 192-bit key and 12 rounds of encryption. +- **AES-256:** Uses a 256-bit key and 14 rounds of encryption. + +## Usage +One can use AES with [OpenSSL](../applications/OpenSSL.md) or [GPG](../tools/GPG.md): + +### OpenSSL +Encrypt: +```shell +openssl enc -aes-256-cbc -salt -in plaintext.txt -out encrypted_file.enc +``` + +Decrypt: +```shell +openssl enc -aes-256-cbc -d -in encrypted_file.enc -out decrypted_file.txt +``` + +### GnuPG +Encrypt: +```shell +gpg -c --cipher-algo AES256 file.txt +``` + +Decrypt: +```shell +gpg -d file.txt.gpg -o decrypted_file.txt +``` \ No newline at end of file diff --git a/technology/Cryptography/Cryptography.md b/technology/Cryptography/Cryptography.md new file mode 100644 index 0000000..fd52521 --- /dev/null +++ b/technology/Cryptography/Cryptography.md @@ -0,0 +1,17 @@ +--- +obj: concept +--- + +# Cryptography +Cryptography is the science and art of securing communication and information through the use of mathematical techniques and algorithms. It plays a crucial role in ensuring confidentiality, integrity, and authenticity of data in various applications, including communication systems, financial transactions, and information storage. + +## Cryptographic Algorithms +### 1. **Symmetric-Key Algorithms** +Symmetric-key algorithms use the same key for both encryption and decryption. They are efficient and fast, making them suitable for bulk data encryption. See [AES](AES.md). + +### 2. **Asymmetric-Key Algorithms** +Asymmetric-key algorithms use a pair of public and private keys. The public key is shared openly, while the private key is kept secret. Data encrypted with the public key can only be decrypted with the corresponding private key, and vice versa. See [RSA](RSA.md). + +### 3. **Hash Functions** + +Hash functions take input data and produce a fixed-size hash value, typically a string of characters. They are fundamental for data integrity verification. See [SHA](SHA.md). \ No newline at end of file diff --git a/technology/Cryptography/RSA.md b/technology/Cryptography/RSA.md new file mode 100644 index 0000000..ee16d18 --- /dev/null +++ b/technology/Cryptography/RSA.md @@ -0,0 +1,63 @@ +--- +obj: concept +--- + +# RSA +RSA (Rivest-Shamir-Adleman) is a widely used asymmetric encryption algorithm that enables secure communication and digital signatures. Named after its inventors, Ron Rivest, Adi Shamir, and Leonard Adleman, RSA relies on the mathematical properties of large prime numbers for its security. + +## Key Concepts +### 1. **Asymmetric Encryption** +RSA is an asymmetric algorithm, meaning it uses a pair of keys: a public key for encryption and a private key for decryption. The public key is widely distributed, while the private key is kept secret. + +### 2. **Key Generation** +- **Key Pair:** The RSA key pair consists of a public key and a corresponding private key. +- **Public Key:** Composed of a modulus $N$ and an exponent $e$. +- **Private Key:** Composed of the same modulus $N$ and a private exponent $d$. +- **Key Generation Process:** + 1. Select two large prime numbers, $p$ and $q$. + 2. Compute $N = pq$. + 3. Compute $ϕ(N) = (p - 1)(q - 1)$. + 4. Choose $e$ such that $1 < e < ϕ(N)$ and $e$ is coprime to $ϕ(N)$. + 5. Calculate $d$ as the modular multiplicative inverse of $e$ modulo $ϕ(N)$. + 6. The public key is $(N, e)$ and the private key is $(N, d)$. + +### 3. **Encryption and Decryption** +- **Encryption:** Given the public key $(N,e)$, a plaintext message $M$ is encrypted as $C = M^e \mod N$. +- **Decryption:** Using the private key $(N,d)$, the ciphertext $C$ is decrypted as $M = C^d \mod N$. + +### 4. **Digital Signatures** +RSA is commonly used for digital signatures to verify the authenticity and integrity of messages. The sender signs a message with their private key, and the recipient can verify the signature using the sender's public key. + +## Security Considerations +- The security of RSA relies on the difficulty of factoring the product of two large prime numbers $(N = porque)$. +- The key length is crucial for security; longer keys provide higher security but may be computationally more expensive. + +## Using RSA in Practice +Using RSA can be done either with [OpenSSL](../applications/OpenSSL.md) or [GPG](../tools/GPG.md). + +### 1. **Key Generation:** +```shell +# Generate a 2048-bit RSA private key +openssl genpkey -algorithm RSA -out private_key.pem -aes256 + +# Derive the corresponding public key +openssl rsa -pubout -in private_key.pem -out public_key.pem +``` + +### 2. **Encryption and Decryption:** +```shell +# Encrypt a message with the public key +openssl rsautl -encrypt -in plaintext.txt -out ciphertext.enc -pubin -inkey public_key.pem + +# Decrypt the ciphertext with the private key +openssl rsautl -decrypt -in ciphertext.enc -out decrypted.txt -inkey private_key.pem +``` + +### 3. **Digital Signatures:** +```shell +# Sign a message with the private key +openssl dgst -sha256 -sign private_key.pem -out signature.bin message.txt + +# Verify the signature with the public key +openssl dgst -sha256 -verify public_key.pem -signature signature.bin message.txt +``` \ No newline at end of file diff --git a/technology/Cryptography/SHA.md b/technology/Cryptography/SHA.md new file mode 100644 index 0000000..6895161 --- /dev/null +++ b/technology/Cryptography/SHA.md @@ -0,0 +1,17 @@ +--- +obj: concept +--- + +# SHA +SHA-2 (Secure Hash Algorithm 2) is a set of cryptographic hash functions designed by the United States National Security Agency (NSA) and first published in 2001. They are built using the Merkle–Damgård construction, from a one-way compression function itself built using the Davies–Meyer structure from a specialized block cipher. + +SHA-2 includes significant changes from its predecessor, SHA-1. The SHA-2 family consists of six hash functions with digests (hash values) that are 224, 256, 384 or 512 bits: SHA-224, SHA-256, SHA-384, SHA-512, SHA-512/224, SHA-512/256. SHA-256 and SHA-512 are novel hash functions computed with eight 32-bit and 64-bit words, respectively. They use different shift amounts and additive constants, but their structures are otherwise virtually identical, differing only in the number of rounds. SHA-224 and SHA-384 are truncated versions of SHA-256 and SHA-512 respectively, computed with different initial values. SHA-512/224 and SHA-512/256 are also truncated versions of SHA-512, but the initial values are generated using the method described in Federal Information Processing Standards (FIPS) PUB 180-4. + +SHA has libraries for many programming languages and can be used with [OpenSSL](../applications/OpenSSL.md) or the `shasum` command. + +## Purpose +Hash functions play a crucial role in [cryptography](Cryptography.md) and information security. They take an input (or message) and produce a fixed-size string of characters, which is typically a digest or hash value. The primary purposes of SHA hash functions include: + +1. **Data Integrity**: Hash functions ensure the integrity of data by generating a unique hash value for a given input. Any change in the input data will result in a completely different hash, making it easy to detect alterations. +2. **Digital Signatures**: SHA is often used in conjunction with digital signatures to create a secure and verifiable way of confirming the origin and integrity of a message or document. +3. **Password Storage**: Hash functions are employed to store passwords securely. Instead of storing the actual password, systems store the hash of the password, making it more challenging for attackers to obtain the original passwords. \ No newline at end of file diff --git a/technology/applications/3d/Blender.md b/technology/applications/3d/Blender.md new file mode 100644 index 0000000..ea937c2 --- /dev/null +++ b/technology/applications/3d/Blender.md @@ -0,0 +1,16 @@ +--- +obj: application +os: + - macos + - linux + - windows +website: https://www.blender.org +wiki: https://en.wikipedia.org/wiki/Blender_(software) +flatpak-id: org.blender.Blender +--- +# Blender +Blender is a free and open-source 3D computer graphics software tool set used for creating animated films, visual effects, art, 3D-printed models, motion graphics, interactive 3D applications, virtual reality, and, formerly, video games. Blender's features include 3D modelling, UV mapping, texturing, digital drawing, raster graphics editing, rigging and skinning, fluid and smoke simulation, particle simulation, soft body simulation, sculpting, animation, match moving, rendering, motion graphics, video editing, and compositing. + +![Screenshot][Screenshot] + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/Feather Wallet.md b/technology/applications/Feather Wallet.md new file mode 100644 index 0000000..757e0a2 --- /dev/null +++ b/technology/applications/Feather Wallet.md @@ -0,0 +1,17 @@ +--- +obj: application +flatpak-id: org.featherwallet.Feather +website: https://featherwallet.org +repo: https://github.com/feather-wallet/feather +--- +# Feather Wallet +Feather is a free, open-source [Monero](../tools/Monero.md) wallet for [Linux](../linux/Linux.md), [Tails](../systems/Tails.md), [Windows](../windows/Windows.md) and [macOS](../macos/macOS.md). + +![Screenshot][Screenshot] + +## Features +- Contacts +- Proxy Support ([Tor](../tools/Tor.md), [I2P](../tools/I2P.md)) +- Transactions + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/MongoDB Compass.md b/technology/applications/MongoDB Compass.md new file mode 100644 index 0000000..82aa23f --- /dev/null +++ b/technology/applications/MongoDB Compass.md @@ -0,0 +1,27 @@ +--- +obj: application +website: https://www.mongodb.com/products/tools/compass +repo: https://github.com/mongodb-js/compass +--- + +# MongoDB Compass +Compass is a free interactive tool for querying, optimizing, and analyzing your [MongoDB](MongoDB.md) data. Get key insights, drag and drop to build pipelines, and more. + +![Screenshot][Screenshot] + +### 1. **Intuitive User Interface** +MongoDB Compass features an intuitive and user-friendly interface, making it accessible to both beginners and experienced MongoDB users. The GUI simplifies complex database interactions, allowing users to perform various tasks with ease. +### 2. **Visual Data Exploration** +- **Graphical Schema View:** Visualize the structure of your MongoDB collections and relationships between documents. +- **Real-time Performance Statistics:** Monitor the performance of your queries and operations with visual feedback. +### 3. **Query Building and Execution** +- **Query Builder:** Construct MongoDB queries using a visual drag-and-drop interface. +- **Real-time Query Execution:** Execute queries and view results instantly, helping users fine-tune their queries. +### 4. **Index Management** +- **Index Optimization:** Analyze and optimize indexes for improved query performance. +- **Index Creation:** Create and manage indexes directly within the Compass interface. +### 5. **Aggregation Pipeline Builder** +- **Visual Aggregation Pipeline:** Build and analyze [MongoDB](MongoDB.md) aggregation pipelines using a visual interface. +- **Pipeline Execution:** Execute aggregation pipelines and observe results in real-time. + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/MongoDB.md b/technology/applications/MongoDB.md new file mode 100644 index 0000000..5a159f2 --- /dev/null +++ b/technology/applications/MongoDB.md @@ -0,0 +1,122 @@ +--- +website: https://www.mongodb.com +obj: application +--- + +#wip #🐇 #notnow +MongoDB is a popular NoSQL database that is document-oriented and designed for scalability and flexibility + +## Docker-Compose +```yml +version: '3' +services: + mongo: + image: mongo + container_name: mongo + restart: always + environment: + MONGO_INITDB_ROOT_USERNAME: root + MONGO_INITDB_ROOT_PASSWORD: password + volumes: + - mongodb_data:/data/db + ports: + - "27017:27017" +``` + +## Usage +### **Connecting to MongoDB** +To connect to MongoDB using the `mongo` shell: +`mongo mongodb://:@:/` + +Replace ``, ``, ``, ``, and `` with your own values. + +### **Working with Databases** +To create a new database: `use ` +To show a list of all databases: `show dbs` +To switch to a different database: `use ` +To drop a database: `use ; db.dropDatabase()` + +### **Working with Collections** +To create a new collection: `db.createCollection("")` +To show a list of all collections in the current database: `show collections` +To drop a collection: `db..drop()` + +### **Inserting Data** +To insert a single document: `db..insertOne()` +To insert multiple documents: `db..insertMany([, , ...])` + +### **Querying Data** +To find all documents in a collection: `db..find()` +To find documents that match a specific condition: `db..find()` +To limit the number of documents returned: `db..find().limit()` +To sort documents by a field: `db..find().sort({: <1 or -1>})` +To count the number of documents: `db..count()` + +### **Updating Data** +To update a single document: `db..updateOne(, )` +To update multiple documents: `db..updateMany(, )` +To replace a document: `db..replaceOne(, )` + +### **Deleting Data** +To delete a single document: `db..deleteOne()` +To delete multiple documents: `db..deleteMany()` +To delete all documents in a collection: `db..deleteMany({})` + +### Filters +- $eq: The $eq operator matches documents where the value of a field equals a specified value. +- $ne: The $ne operator matches documents where the value of a field is not equal to a specified value. +- $gt: The $gt operator matches documents where the value of a field is greater than a specified value. +- $gte: The $gte operator matches documents where the value of a field is greater than or equal to a specified value. +- $lt: The $lt operator matches documents where the value of a field is less than a specified value. +- $lte: The $lte operator matches documents where the value of a field is less than or equal to a specified value. +- $in: The $in operator matches documents where the value of a field equals any value in a specified array. +- $nin: The $nin operator matches documents where the value of a field does not equal any value in a specified array. +- $and: The $and operator performs a logical AND operation on an array of two or more expressions and selects the documents that satisfy all the expressions. +- $or: The $or operator performs a logical OR operation on an array of two or more expressions and selects the documents that satisfy at least one of the expressions. +- $not: The $not operator performs a logical NOT operation on the specified expression and selects the documents that do not match the expression. +- $exists: The $exists operator matches documents where a specified field exists or does not exist. +- $type: The $type operator matches documents where a specified field has a specific BSON type. +- $regex: The $regex operator matches documents where a specified field matches a regular expression. +- $text: The $text operator performs a text search on the specified field(s). +- $elemMatch: The $elemMatch operator matches documents where a specified array field contains at least one element that matches all the specified conditions. +- $size: The $size operator matches documents where a specified array field has a specific size. + +**Example:** +```js +db.users.find( +{ + $and: [ + { status: "active" }, + { age: { $gt: 28 } } + ] +} +) +``` + +### Update Modifiers +- $set: The $set operator updates the value of a field in a document. +- $unset: The $unset operator removes a field from a document. +- $inc: The $inc operator increments the value of a field in a document. +- $mul: The $mul operator multiplies the value of a field in a document. +- $min: The $min operator updates the value of a field in a document if the new value is lower than the existing value. +- $max: The $max operator updates the value of a field in a document if the new value is higher than the existing value. +- $rename: The $rename operator renames a field in a document. +- $addToSet: The $addToSet operator adds a value to an array field in a document if the value does not already exist in the array. +- $push: The $push operator appends a value to an array field in a document. +- $pull: The $pull operator removes a value from an array field in a document. +- $currentDate: The $currentDate operator sets the value of a field in a document to the current date and time. +- $each: The $each operator can be used with $addToSet and $push to append multiple values to an array field in a document. +- $sort: The $sort operator can be used with $push to sort the elements in an array field in a document. +- $addToSet: Add an element to an array + +**Example:** +```js +db.users.updateOne( + { name: "John Doe" }, + { + $set: { age: 35 }, + $addToSet: { interests: "Hiking" }, + $unset: { status: "" } + } +) +``` \ No newline at end of file diff --git a/technology/applications/OpenSSL.md b/technology/applications/OpenSSL.md new file mode 100644 index 0000000..52d1054 --- /dev/null +++ b/technology/applications/OpenSSL.md @@ -0,0 +1,134 @@ +--- +website: +- https://www.openssl.org +- https://www.libressl.org +obj: application +--- + +# OpenSSL +OpenSSL is a [cryptography](../Cryptography/Cryptography.md) toolkit implementing the Secure Sockets Layer (SSL) and Transport Layer Security (TLS) network protocols and related [cryptography](../Cryptography/Cryptography.md) standards required by them. + +The openssl program is a command line program for using the various [cryptography](../Cryptography/Cryptography.md) functions of OpenSSL's crypto library from the [shell](cli/Shell.md). It can be used for: +- Creation and management of private keys, public keys and parameters +- Public key cryptographic operations +- Creation of X.509 certificates, CSRs and CRLs +- Calculation of Message Digests and Message Authentication Codes +- Encryption and Decryption with Ciphers +- SSL/TLS Client and Server Tests +- Handling of S/MIME signed or encrypted mail +- Timestamp requests, generation and verification + +## Usage +```shell +openssl [command] [options] +``` + +### Certificates (`openssl req`, `openssl x509`) +#### Generate a certificate +Usage: `openssl req -x509 -key private_key.pem -out certificate.pem -days 365` + +#refactor -> infos on signed certificates with CAs + +#### Show information about a certificate +Usage: `openssl x509 -in certificate.pem -text -noout` + +### Digest (`openssl dgst`) +Use digest (hash) functions. (Use `openssl dgst -list` for a list of all available digests) +Usage: `openssl dgst [options] [file]` + +#### Options +| Option | Description | +| ------------- | ----------------------------------- | +| `-c` | Print digest with seperating colons | +| `-r` | Print digest in coreutils format | +| `-out ` | Output to filename | +| `-hex` | Output as hex | +| `-binary` | Output in binary | +| `-` | Use \ | + +### Encryption (`openssl enc`) +Encrypt and decrypt using ciphers (Use `openssl enc -ciphers` for a list of all available ciphers) +Usage: `openssl enc [options]` + +#### Options +| Option | Description | +| --------------- | ----------------------------------------------- | +| `-e` | Do Encryption | +| `-d` | Do Decryption | +| `-` | Use \ | +| `-in ` | Input file | +| `-k ` | Passphrase | +| `-kfile ` | Read passphrase from file | +| `-out ` | Output file | +| `-a, -base64` | [Base64](../files/Base64.md) decode/encode data | +| `-pbkdf2` | Use password-based key derivation function 2 | +| `-iter ` | Change iterations of `-pbkdf2` | + +### [RSA](../Cryptography/RSA.md) (`openssl genrsa`, `openssl rsa`, `openssl pkeyutl`) +#### Generate [RSA](../Cryptography/RSA.md) Private Key (`openssl genrsa`) +```shell +openssl genrsa -out [-] [-verbose] [-quiet] +``` + +The `-` option lets you protect the key with a password using the specified cipher algo (See `openssl enc -ciphers` for a list of available ciphers). + +#### Generate [RSA](../Cryptography/RSA.md) Public Key (`openssl rsa`) +```shell +openssl rsa -pubout -in [-passin file:] -out +``` + +#### Working with [RSA](../Cryptography/RSA.md) (`openssl pkeyutl`) +```shell +# Sign with Private Key +openssl pkeyutl -sign -in -inkey [-passin file:] -out [-digest algo] + +# Verify with Public Key +openssl pkeyutl -verify -in -pubin -inkey -sigfile + +# Encrypt with Public Key +openssl pkeyutl -encrypt -pubin -inkey -in -out + +# Decrypt with Private Key +openssl pkeyutl -decrypt -inkey [-passin file:] -in -out +``` + +### Password Hash (`openssl passwd`) +Generate hashed passwords +Usage: `openssl passwd [options] [password]` + +### Options +| Option | Description | +| ------------ | ------------------------------------------------ | +| `-in infile` | Read passwords from file | +| `-noverify` | Never verify when reading password from terminal | +| `-stdin` | Read passwords from stdin | +| `-salt val` | Use provided salt | +| `-6` | SHA512-based password algorithm | +| `-5` | SHA256-based password algorithm | +| `-apr1` | MD5-based password algorithm, Apache variant | +| `-1` | MD5-based password algorithm | +| `-aixmd5` | AIX MD5-based password algorithm | + +### Prime Numbers (`openssl prime`) +Generate and verify prime numbers +Usage: `openssl prime [options] [num]` + +#### Options +| Option | Description | +| ------------ | ------------------------------------------------- | +| `-bits +int` | Size of number in bits | +| `-hex` | Hex output | +| `-generate` | Generate a prime | +| `-safe` | When used with `-generate`, generate a safe prime | + +### Random Data (`openssl rand`) +Generate random data. +Usage: `openssl rand [options] num` + +#### Options +| Option | Description | +| -------------- | ------------------------------------------------------- | +| `-out outfile` | Output file | +| `-base64` | [Base64](../files/Base64.md) encode output | +| `-hex` | Hex encode output | +| `-rand val` | Load the given file(s) into the random number generator | \ No newline at end of file diff --git a/technology/applications/SSH.md b/technology/applications/SSH.md new file mode 100644 index 0000000..7e32021 --- /dev/null +++ b/technology/applications/SSH.md @@ -0,0 +1,130 @@ +--- +aliases: + - OpenSSH +website: https://www.openssh.com/ +obj: application +repo: https://github.com/openssh/openssh-portable +--- +# SSH +#refactor add ssh suite applications, etc +-> https://www.openssh.com/ +Secure Shell (SSH) is a cryptographic network protocol for operating network services securely over an unsecured network. Typical applications include remote command-line login and remote command execution, but any network service can be secured with SSH. + +Examples of services that can use SSH are [Git](../dev/Git.md), [rsync](rsync.md) and X11 forwarding. Services that always use SSH are SCP and SFTP. + +An SSH server, by default, listens on the standard TCP port 22. An SSH client program is typically used for establishing connections to an sshd daemon accepting remote connections. Both are commonly present on most modern operating systems, including [macOS](../macos/macOS.md), GNU/[Linux](../linux/Linux.md), Solaris and OpenVMS. Proprietary, freeware and open source versions of various levels of complexity and completeness exist. + +## Client +### Usage +Connecting to a server +```shell +ssh -p port user@server-address +``` + +Port forwarding: +```shell +# Forward Remote -> Local +ssh -N -f -L local_port:127.0.0.1:remote_port host +# Forward Local -> Remote +ssh -N -f -R remote_port:127.0.0.1:local_port host +``` + +Copying files (works with [rsync](cli/rsync.md) as well): +```shell +scp -r files remote:/path +``` + +Copy ssh key to host: +```shell +ssh-copy-id user@remote +``` + +Pipes work too over SSH: +```shell +ssh remote "cat /log" | grep denied +cat ~/.ssh/id_rsa.pub | ssh remote 'cat >> .ssh/authorized_keys' +``` + +Use a jump host: +```shell +ssh -J jump_server remote +``` + +### Configuration +Client can be configured by the file `~/.ssh/config` +``` +# global options +User user + +# host-specific options +Host myserver + Hostname server-address + Port port + IdentityFile ~/.ssh/id_rsa + ProxyJump host + ProxyCommand corkscrew %h %p # HTTP Proxy +``` + +With this configuration the client command can be redacted to +```shell +ssh myserver +``` + +Corkscrew is a additional programm to tunnel SSH through HTTP proxies: +```shell +`ssh -o "ProxyCommand corkscrew %h %p" @` +``` + +## Server +`sshd` is the OpenSSH server daemon, configured with `/etc/ssh/sshd_config` and managed by `sshd.service`. Whenever changing the configuration, use `sshd` in test mode before restarting the service to ensure it will be able to start cleanly. Valid configurations produce no output. +```shell +sshd -t +``` + +### Configuration +Limit users: +``` +AllowUsers user1 user2 +DenyUser user3 user4 +``` + +To allow access only for some groups: +``` +AllowGroups group1 group2 +DenyGroups group3 group4 +``` + +Disable password authentification: +``` +PasswordAuthentication no +PermitEmptyPasswords no +``` + +Disable root login: +``` +PermitRootLogin no +PermitRootLogin prohibit-password +``` + +Allow port forwarding: +``` +AllowTcpForwarding yes +``` + +Allow only certain commands: +``` +ForceCommand command +``` + +Limit port forwarding: +``` +PermitListen host:port +PermitOpen host:port +``` + +User-based settings (everything here only applies to `user1`): +``` +Match User user1 + PasswordAuthentication no + AllowTcpForwarding yes +``` \ No newline at end of file diff --git a/technology/applications/SurrealDB.md b/technology/applications/SurrealDB.md new file mode 100644 index 0000000..2107bf8 --- /dev/null +++ b/technology/applications/SurrealDB.md @@ -0,0 +1,10 @@ +--- +obj: application +os: linux +website: https://surrealdb.com/ +repo: https://github.com/surrealdb/surrealdb +--- +# SurrealDB +#wip +#🐇 +#notnow \ No newline at end of file diff --git a/technology/applications/Teleport.md b/technology/applications/Teleport.md new file mode 100644 index 0000000..6a90d9f --- /dev/null +++ b/technology/applications/Teleport.md @@ -0,0 +1,198 @@ +--- +obj: application +website: https://goteleport.com +repo: https://github.com/gravitational/teleport +--- +# Teleport +Teleport provides connectivity, authentication, access controls and audit for infrastructure. + +It includes an identity-aware access proxy, a CA that issues short-lived certificates, a unified access control system and a tunneling system to access resources behind the firewall. + +Teleport understands the [SSH](SSH.md), HTTPS, RDP, Kubernetes API, MySQL, [MongoDB](MongoDB.md) and PostgreSQL wire protocols, plus many others. It can integrate with Single Sign-On providers and enables you to apply access policies using infrastructure-as-code and GitOps tools. + +## Setup +You need a [domain](../internet/Domain.md) pointing at your teleport proxy instance. + +Docker-Compose: +```yml +version: '3' +services: + teleport: + image: public.ecr.aws/gravitational/teleport:14 + restart: unless-stopped + hostname: + ports: + - "3080:3080" # Web UI + - "3022:3022" # SSH + - "8443:8443" # HTTPS + volumes: + - ./config/teleport.yaml:/etc/teleport/teleport.yaml + - ./data:/var/lib/teleport +``` + +teleport.yml: +```yml +version: v3 +teleport: + nodename: + data_dir: /var/lib/teleport + log: + output: stderr + severity: INFO + format: + output: text + ca_pin: "" + diag_addr: "" +auth_service: + enabled: "yes" + listen_addr: 0.0.0.0:3025 + proxy_listener_mode: multiplex + authentication: + type: local + second_factor: true + webauthn: + rp_id: + connector_name: passwordless +ssh_service: + enabled: "no" +proxy_service: + enabled: "yes" + public_addr: :443 + https_keypairs: [] + https_keypairs_reload_interval: 0s + acme: {} +``` + +## [SSH](SSH.md) Agent Setup +1. Install teleport on your host: + ```shell + curl https://goteleport.com/static/install.sh | bash -s 14.2.0 + ``` +2. On your teleport proxy, create a join token: + ```shell + tctl tokens add --type=node --format=text > token.file + ``` +3. Join the server to the cluster: + ```shell + sudo teleport node configure \ + --output=file:///etc/teleport.yaml \ + --token=/path/to/token.file \ + --proxy=tele.example.com:443 + ``` + + +## `tctl` +Admin tool for the Teleport Access Platform +Usage: `tctl [] [ ...]` + +### Commands +#### users add +Generate a user invitation token. +Usage: `tctl users add --roles=ROLES [] ` + +##### Options +| Option | Description | +| -------- | ------------------------------------------- | +| --logins | List of allowed SSH logins for the new user | + +#### users update +Update user account. +Usage: `tctl users update [] ` + +##### Options +| Option | Description | +| -------------- | ---------------------------------------------------------------- | +| `--set-roles` | List of roles for the user to assume, replaces current roles | +| `--set-logins` | List of allowed SSH logins for the user, replaces current logins | + +#### users ls +Lists all user accounts. +Usage: `tctl users ls` + +#### users rm +Deletes user accounts. +Usage: `tctl users rm ` + +#### users reset +Reset user password and generate a new token. +Usage: `tctl users reset ` + +#### nodes add +Generate a node invitation token. +Usage: `tctl nodes add []` + +##### Options +| Option | Description | +| --------- | -------------------------------------------------------- | +| `--roles` | Comma-separated list of roles for the new node to assume | +| `--ttl` | Time to live for a generated token | + +#### nodes ls +List all active SSH nodes within the cluster. +Usage: `tctl nodes ls [] []` + +#### tokens add +Create a invitation token. +Usage: `tctl tokens add --type=TYPE []` + +##### Options +| Option | Description | +| ---------- | ------------------------------------------------------------ | +| `--type` | Type(s) of token to add, e.g. `--type=node,app,db,proxy,etc` | +| `--labels` | Set token labels, e.g. `env=prod,region=us-west` | +| `--ttl` | Set expiration time for token, default is 30 minutes | +| `--format` | Output format, 'text', 'json', or 'yaml' | + +#### tokens rm +Delete/revoke an invitation token. +Usage: `tctl tokens rm []` + +#### tokens ls +List node and user invitation tokens. +Usage: `tctl tokens ls` + +#### status +Report cluster status. +Usage: `tctl status` + +## `tsh` +Teleport Command Line client for interacting with your infrastructure. +Usage: `tsh [options...] [ ...]` + +### Options +| Option | Description | +| --------- | --------------------------------------------- | +| `--proxy` | Teleport proxy address | +| `--user` | Teleport user, defaults to current local user | + +### Commands +#### ssh +Run shell or execute a command on a remote SSH node. +Usage: `tsh ssh [] <[user@]host> [...]` + +##### scp +Transfer files to a remote SSH node. +Usage: `tsh scp [] ...` + +##### ls +List remote SSH nodes. +Usage: `tsh ls [] []` + +##### login +Log in to a cluster and retrieve the session certificate. +Usage: `tsh login [] []` + +##### logout +Delete a cluster certificate. +Usage: `tsh logout` + +##### status +Display the list of proxy servers and retrieved certificates. +Usage: `tsh status` + +##### config +Print [SSH](SSH.md) config details. +This allows you to use regular `ssh` command to connect to teleport servers. +```shell +tsh config >> ~/.ssh/config +``` \ No newline at end of file diff --git a/technology/applications/backup/Vorta.md b/technology/applications/backup/Vorta.md new file mode 100644 index 0000000..e0f25ad --- /dev/null +++ b/technology/applications/backup/Vorta.md @@ -0,0 +1,19 @@ +--- +obj: application +flatpak-id: com.borgbase.Vorta +website: https://vorta.borgbase.com +repo: https://github.com/borgbase/vorta +--- +# Vorta +Vorta is a graphical user interface (GUI) for the popular backup tool, [Borg](borg.md) Backup. It allows users to easily configure and manage backups of their data with a simple and intuitive interface. + +## Features + +Vorta includes a range of features to make backup management easy and accessible: +- Backup configuration: Vorta allows users to configure backup jobs with a simple wizard interface. Users can specify the data to be backed up, the backup destination, and other backup settings. +- Backup scheduling: Users can schedule backups to occur automatically at regular intervals or specific times. +- Backup monitoring: Vorta provides real-time feedback on backup progress, allowing users to monitor the status of their backups. +- Backup restoration: Vorta makes it easy to restore data from backups. Users can browse backups and select the data they want to restore. +- Encryption and compression: [Borg](borg.md) Backup supports encryption and compression of backups, and Vorta makes it easy to configure these options. +- Multiple backup repositories: Vorta allows users to manage multiple backup repositories and switch between them easily. +- Backup reporting: Vorta provides detailed reports on backup history and status, allowing users to track changes over time. \ No newline at end of file diff --git a/technology/applications/backup/borg.md b/technology/applications/backup/borg.md new file mode 100644 index 0000000..06c20b4 --- /dev/null +++ b/technology/applications/backup/borg.md @@ -0,0 +1,42 @@ +--- +obj: application +website: https://www.borgbackup.org/ +repo: https://github.com/borgbackup/borg +--- +# Borg Backup +#refactor add options + actions +BorgBackup (short: Borg) is a deduplicating backup program. Optionally, it supports compression and authenticated encryption. + +The main goal of Borg is to provide an efficient and secure way to backup data. The data deduplication technique used makes Borg suitable for daily backups since only changes are stored. The authenticated encryption technique makes it suitable for backups to not fully trusted targets. + +## Usage +Create a new repo: +```shell +borg init -e repokey /path/to/repo +``` + +Create a backup: +```shell +borg create -v --progress --stats /path/to/repo::ARCHIVE_NAME ~/Documents +``` + +List contents: +```shell +borg list /path/to/repo # List all archives +borg list /path/to/repo::ARCHIVE # List content of Archive +``` + +Extract archive: +```shell +borg extract /path/to/repo::ARCHIVE +``` + +Delete archive: +```shell +borg delete /path/to/repo::ARCHIVE +``` + +Garbage Collect Repo: +```shell +borg compact /path/to/repo +``` \ No newline at end of file diff --git a/technology/applications/clamav.md b/technology/applications/clamav.md new file mode 100644 index 0000000..cfc9be4 --- /dev/null +++ b/technology/applications/clamav.md @@ -0,0 +1,34 @@ +--- +obj: application +os: linux +arch-wiki: https://wiki.archlinux.org/title/ClamAV +website: https://www.clamav.net/ +--- +#refactor +# ClamAV +[Arch Wiki](https://wiki.archlinux.org/title/ClamAV) +Clam AntiVirus is an open source (GPL) anti-virus toolkit for UNIX. It provides a number of utilities including a flexible and scalable multi-threaded daemon, a command line scanner and advanced tool for automatic database updates. Because ClamAV's main use is on file/mail servers for [Windows](../windows/Windows.md) desktops, it primarily detects [Windows](../windows/Windows.md) viruses and malware with its built-in signatures. + +## Usage +### Updating database +Update the virus definitions with: +```shell +freshclam +``` + +The database files are saved in: +``` +/var/lib/clamav/daily.cvd +/var/lib/clamav/main.cvd +/var/lib/clamav/bytecode.cvd +``` + +Start/Enable`clamav-freshclam.service` so that the virus definitions are kept recent. + +### Starting the daemon + +**Note:** +- You will need to run `freshclam` before starting the service for the first time or you will run into trouble/errors which will prevent ClamAV from starting correctly. +- The daemon is not needed if you only want to perform stand-alone scans. See [Scan for viruses](https://wiki.archlinux.org/title/ClamAV#Scan_for_viruses) below. + +The service is called `clamav-daemon.service`. \ No newline at end of file diff --git a/technology/applications/cli/Core Utils.md b/technology/applications/cli/Core Utils.md new file mode 100644 index 0000000..5e7cd22 --- /dev/null +++ b/technology/applications/cli/Core Utils.md @@ -0,0 +1,629 @@ +--- +obj: application +website: https://www.gnu.org/software/coreutils/ +repo: https://git.savannah.gnu.org/git/coreutils.git +wiki: https://en.wikipedia.org/wiki/GNU_Core_Utilities +--- +# GNU Core Utils +The GNU Core Utilities or coreutils is a package of GNU software containing implementations for many of the basic tools, such as cat, ls, and rm, which are used on Unix-like operating systems. + +## base64 +[base64](../../files/Base64.md) encode/decode data and print to standard output + +Usage: `base64 [OPTION]... [FILE]` +### Flags +| Flag | Description | +| ---------------------- | --------------------------------------------- | +| `-d, --decode` | Decode Input | +| `-i, --ignore-garbage` | when decoding, ignore non-alphabet characters | + +## basename +strip directory and suffix from filenames +Usage: `basename NAME` + +## cat +concatenate files and print on the standard output +Usage: `cat [OPTION]... [FILE]...` + +### Flags +| Flag | Description | +| ----------------------- | -------------------------------------------- | +| `-b, --number-nonblank` | number nonempty output lines, overrides `-n` | +| `-n, --number` | number all output lines | + +## chmod +change file mode (permissions) bits +Usage: `chmod [OPTION]... OCTAL-MODE FILE...` + +### Options +| Option | Description | +| ----------------------- | ----------------------------------------------------------------------------------------------------- | +| `-c, --changes` | like verbose but report only when a change is made | +| `-f, --silent, --quiet` | suppress most error messages | +| `-v, --verbose` | output a diagnostic for every file processed | +| `--reference=RFILE` | use RFILE's mode instead of specifying MODE values. RFILE is always dereferenced if a symbolic link. | +| `-R, --recursive` | change files and directories recursively | | + +## chown +change file owner and group +Usage: `chown [OPTION]... [OWNER][:[GROUP]] FILE...` + +### Options +| Option | Description | +| ----------------------- | ----------------------------------------------------------------------------------------------------- | +| `-c, --changes` | like verbose but report only when a change is made | +| `-f, --silent, --quiet` | suppress most error messages | +| `-v, --verbose` | output a diagnostic for every file processed | +| `--reference=RFILE` | use RFILE's owner and group rather than specifying OWNER:GROUP values. RFILE is always dereferenced. | +| `-R, --recursive` | operate on files and directories recursively | + +## chroot +run command or interactive shell with special root directory +Usage: `chroot [OPTION] NEWROOT [COMMAND [ARG]...]` + +## cksum +compute and verify file checksums +Usage: `cksum [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ---------------------- | ----------------------------- | +| `-a, --algorithm=TYPE` | select the digest type to use | + +### Digests +- crc +- md5 +- sha1 +- sha224 +- sha256 +- sha384 +- sha512 +- blake2b + +## cp +copy files and directories +Usage: `cp [OPTION]... SOURCE DEST` + +### Options +| Option | Description | +| ---------------------------------- | --------------------------------------------------------------------------- | +| `-l, --link` | hard link files instead of copying | +| `-R, -r, --recursive` | copy directories recursively | +| `-s, --symbolic-link` | make symbolic links instead of copying | +| `-S, --suffix=SUFFIX` | override the usual backup suffix | +| `-t, --target-directory=DIRECTORY` | copy all SOURCE arguments into DIRECTORY | +| `--update[=UPDATE]` | control which existing files are updated; UPDATE={all,none,older(default)}. | +| `-u` | equivalent to `--update[=older]` | +| `-v, --verbose` | explain what is being done | +| `-x, --one-file-system` | stay on this file system | +| `-b` | Create a backup file if destination already exists | + +## cut +remove sections from each line of files +Usage: `cut OPTION... [FILE]...` + +### Options +| Option | Description | +| --------------------------- | ------------------------------------------------------------------------------------------------------------------------ | +| `-d, --delimiter=DELIM` | use DELIM instead of TAB for field delimiter | +| `-f, --fields=LIST` | select only these fields; also print any line that contains no delimiter character, unless the `-s` option is specified | +| `-s, --only-delimited` | do not print lines not containing delimiters | +| `--output-delimiter=STRING` | use STRING as the output delimiter the default is to use the input delimiter | + +## date +print or set the system date and time +Usage: `date [OPTION]... [+FORMAT]` + +### Options +| Option | Description | +| ---------------------- | ------------------------------------------ | +| `-d, --date=STRING` | display time described by STRING | +| `-r, --reference=FILE` | display the last modification time of FILE | +| `-s, --set=STRING` | set time described by STRING | + +## dd +convert and copy a file +Usage: `dd [OPERAND]...` + +### Operands +| Operand | Description | +| -------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `bs=BYTES` | read and write up to BYTES bytes at a time (default: 512) | +| `count=N` | copy only N input blocks | +| `if=FILE` | read from FILE instead of stdin | +| `of=FILE` | write to FILE instead of stdout | +| `status=LEVEL` | The LEVEL of information to print to stderr; 'none' suppresses everything but error messages, 'noxfer' suppresses the final transfer statistics, 'progress' shows periodic transfer statistics | + +## df +report file system space usage +Usage: `df [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ---------------------- | ---------------------------------------------------- | +| `-a, --all` | include pseudo, duplicate, inaccessible file systems | +| `-h, --human-readable` | print sizes in powers of 1024 (e.g., 1023M) | +| `-H, --si` | print sizes in powers of 1000 (e.g., 1.1G) | +| `-i, --inodes` | list inode information instead of block usage | + +## dirname +strip last component from file name +Usage: `dirname [OPTION] NAME...` + +## du +estimate file space usage +Usage: `du [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ---------------------- | -------------------------------------- | +| `-h, --human-readable` | print sizes in human readable format | +| `-s, --summarize` | display only a total for each argument | + +## echo +display a line of text +Usage: `echo [OPTION]... [STRING]...` + +### Options +| Option | Description | +| ------ | ----------------------------------------------------- | +| `-n` | do not output the trailing newline | +| `-e` | enable interpretation of backslash escapes | +| `-E` | disable interpretation of backslash escapes (default) | + +### Backslash Interpretations +| Sequence | Meaning | +| -------- | ----------------------------------------- | +| \\ | backslash | +| \a | alert (BEL) | +| \b | backspace | +| \c | produce no further output | +| \e | escape | +| \f | form feed | +| \n | new line | +| \r | carriage return | +| \t | horizontal tab | +| \v | vertical tab | +| \0NNN | byte with octal value NNN (1 to 3 digits) | +| \xHH | byte with hexadecimal value HH (1 to 2) | + +## env +run a program in a modified environment +Print [Environment Variables](../../linux/Environment%20Variables.md) with only `env` +Usage: `env [OPTION]... [-] [NAME=VALUE]... [COMMAND [ARG]...]` + +### Options +| Option | Description | +| -------------------------- | -------------------------------------------------- | +| `-i, --ignore-environment` | start with an empty environment | +| `-u, --unset=NAME` | remove variable from the environment | +| `-C, --chdir=DIR` | change working directory to DIR | +| `--block-signal[=SIG]` | block delivery of SIG signal(s) to COMMAND | +| `--ignore-signal[=SIG]` | set handling of SIG signal(s) to do nothing | +| `-v, --debug` | print verbose information for each processing step | + +## false +do nothing, unsuccessfully +Usage: `false` + +## head +output the first part of files +Usage: `head [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ----------------------- | ---------------------------------------------------------------------------------------------------------------------- | +| `-c, --bytes=[-]NUM` | print the first NUM bytes of each file; with the leading '-', print all but the last NUM bytes of each file | +| `-n, --lines=[-]NUM` | print the first NUM lines instead of the first 10; with the leading '-', print all but the last NUM lines of each file | +| `-q, --quiet, --silent` | never print headers giving file names | + +## id +print real and effective user and group IDs +Usage: `id [OPTION]... [USER]...` + +### Option +| Option | Description | +| -------------- | -------------------------------------------- | +| `-g, --group` | print only the effective group ID | +| `-G, --groups` | print all group IDs | +| `-n, --name` | print a name instead of a number, for `-ugG` | +| `-u, --user` | print only the effective user ID | + +## install +copy files and set attributes +Usage: `install [OPTION]... SOURCE... DIRECTORY` + +### Options +| Option | Description | +| ---------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------- | +| `-b` | make a backup of each existing destination file | +| `-S, --suffix=SUFFIX` | override the usual backup suffix | +| `-C, --compare` | compare  content of source and destination files, and if no change to content, ownership, and permissions, do not modify the destination at all | +| `-d, --directory` | treat all arguments as directory names; create all components of the specified directories | +| `-g, --group=GROUP` | set group ownership, instead of process' current group | +| `-m, --mode=MODE` | set permission mode (as in chmod), instead of rwxr-xr-x | +| `-o, --owner=OWNER` | set ownership (super-user only) | +| `-p, --preserve-timestamps` | apply access/modification times of SOURCE files to corresponding destination files | +| `-s, --strip` | strip symbol tables | +| `-t, --target-directory=DIRECTORY` | copy all SOURCE arguments into DIRECTORY | +| `-v, --verbose` | print the name of each created file or directory | + +## kill +terminate a process +Usage: `kill [-signal|-s signal|-p] [-q value] [-a] [--timeout milliseconds signal] [--] pid|name...` + +### Options +| Option | Description | +| --------------------- | -------------------------------------------------------------------------------- | +| `-s, --signal signal` | The signal to send. It may be given as a name or a number. | +| `-p, --pid` | Only print the process ID (PID) of the named processes, do not send any signals. | +| `--verbose` | Print PID(s) that will be signaled with kill along with the signal. | + +## ln +make links between files +Usage: `ln [OPTION]... TARGET LINK_NAME` + +### Options +| Option | Description | +| ---------------------------------- | -------------------------------------------------- | +| `-s, --symbolic` | make symbolic links instead of hard links | +| `-t, --target-directory=DIRECTORY` | specify the DIRECTORY in which to create the links | +| `-v, --verbose` | print name of each linked file | + +## ls +list directory contents +Usage: `ls [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ---------------------- | --------------------------------------------------- | +| `-a, --all` | do not ignore entries starting with . | +| `-h, --human-readable` | with `-l` print sizes like 1K 234M 2G etc | +| `-I, --ignore=PATTERN` | do not list implied entries matching shell PATTERN | +| `-l` | use a long listing format | +| `-r, --reverse` | reverse order while sorting | +| `-R, --recursive` | list subdirectories recursively | + +## mkdir +make directories +Usage: `mkdir [OPTION]... DIRECTORY...` + +### Options +| Option | Description | +| ----------------- | ----------------------------------------------------------------------------------------------------------- | +| `-m, --mode=MODE` | set file mode (as in chmod), not a=rwx - umask | +| `-p, --parents` | no error if existing, make parent directories as needed, with their file modes unaffected by any -m option. | +| `-v, --verbose` | print a message for each created directory | + +## mkfifo +make FIFOs (named pipes) +Usage: `mkfifo [OPTION]... NAME...` + +## mv +move (rename) files +Usage: `mv [OPTION]... SOURCE... DIRECTORY` + +### Options +| Option | Description | +| ---------------------------------- | ------------------------------------------------ | +| `-b` | make a backup of each existing destination file | +| `-S, --suffix=SUFFIX` | override the usual backup suffix | +| `-t, --target-directory=DIRECTORY` | copy all SOURCE arguments into DIRECTORY | +| `-v, --verbose` | print the name of each created file or directory | + +## nl +number lines of files +Usage: `nl [FILE]...` + +## nproc +print the number of processing units available +Usage: `nproc` + +## pwd +print name of current/working directory +Usage: `pwd` + +## readlink +print resolved symbolic links or canonical file names +Usage: `readlink [OPTION]... FILE...` + +### Options +| Option | Description | +| ----------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- | +| `-f, --canonicalize` | canonicalize by following every symlink in every component of the given name recursively; all but the last component must exist | +| `-e, --canonicalize-existing` | canonicalize by following every symlink in every component of the given name recursively, all components must exist | +| `-m, --canonicalize-missing` | canonicalize by following every symlink in every component of the given name recursively, without requirements on components existence | +| `-n, --no-newline` | do not output the trailing delimiter | + +## realpath +print the resolved path +Usage: `realpath [OPTION]... FILE...` + +### Options +| Option | Description | +| ----------------------------- | ----------------------------------------------- | +| `-e, --canonicalize-existing` | all components of the path must exist | +| `-m, --canonicalize-missing` | no path components need exist or be a directory | +| `-L, --logical` | resolve '..' components before symlinks | +| `--relative-to=DIR` | print the resolved path relative to DIR | +| `--relative-base=DIR` | print absolute paths unless paths below DIR | +| `-s, --strip, --no-symlinks` | don't expand symlinks | + +## rm +remove files or directories +Usage: `rm [OPTION]... [FILE]...` + +### Options +| Option | Description | +| --------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-f, --force` | ignore nonexistent files and arguments, never prompt | +| `-i` | prompt before every removal | +| `--one-file-system` | when removing a hierarchy recursively, skip any directory that is on a file system different from that of the corresponding command line argument | +| `-r, -R, --recursive` | remove directories and their contents recursively | +| `-d, --dir` | remove empty directories | +| `-v, --verbose` | explain what is being done | + +## rmdir +remove empty directories +Usage: `rmdir [OPTION]... DIRECTORY...` + +### Options +| Option | Description | +| --------------- | ------------------------------------------------------------------------------------ | +| `-p, --parents` | remove DIRECTORY and its ancestors; e.g., 'rmdir -p a/b' is similar to 'rmdir a/b a' | +| `-v, --verbose` | output a diagnostic for every directory processed | + +## seq +print a sequence of numbers +Usage: +- `seq [OPTION]... LAST` +- `seq [OPTION]... FIRST LAST` +- `seq [OPTION]... FIRST INCREMENT LAST` + +### Options +| Option | Description | +| ------------------------ | --------------------------------------------- | +| `-f, --format=FORMAT` | use printf style floating-point FORMAT | +| `-s, --separator=STRING` | use STRING to separate numbers (default: \n) | +| `-w, --equal-width` | equalize width by padding with leading zeroes | + +## shred +overwrite a file to hide its contents, and optionally delete it +Usage: `shred [OPTION]... FILE...` + +### Options +| Option | Description | +| ---------------------- | ------------------------------------------------ | +| `-f, --force` | change permissions to allow writing if necessary | +| `-n, --iterations=N` | overwrite N times instead of the default (3) | +| `--random-source=FILE` | get random bytes from FILE | + +## shuf +generate random permutations +Usage: `shuf [OPTION]... [FILE]` + +### Options +| Option | Description | +| ------------------------- | ------------------------------------------------ | +| `-i, --input-range=LO-HI` | treat each number LO through HI as an input line | +| `-n, --head-count=COUNT` | output at most COUNT lines | +| `-o, --output=FILE` | write result to FILE instead of standard output | +| `--random-source=FILE` | get random bytes from FILE | +| `-r, --repeat` | output lines can be repeated | + +## sleep +delay for a specified amount of time +Usage: `sleep NUMBER[SUFFIX]...` + +## sort +sort lines of text files +Usage: `sort [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ----------------------------- | ------------------------------------------------ | +| `-b, --ignore-leading-blanks` | ignore leading blanks | +| `-d, --dictionary-order` | consider only blanks and alphanumeric characters | +| `-f, --ignore-case` | fold lower case to upper case characters | +| `-g, --general-numeric-sort` | compare according to general numerical value | +| `-i, --ignore-nonprinting` | consider only printable characters | +| `-M, --month-sort` | compare (unknown) < 'JAN' < ... < 'DEC' | +| `-h, --human-numeric-sort` | compare human readable numbers (e.g., 2K 1G) | +| `-n, --numeric-sort` | compare according to string numerical value | +| `-r, --reverse` | reverse the result of comparisons | + +## split +split a file into pieces +Usage: `split [OPTION]... [FILE [PREFIX]]` + +### Options +| Option | Description | +| ---------------------------- | --------------------------------------------------------- | +| `-a, --suffix-length=N` | generate suffixes of length N (default 2) | +| `--additional-suffix=SUFFIX` | append an additional SUFFIX to file names | +| `-b, --bytes=SIZE` | put SIZE bytes per output file | +| `-C, --line-bytes=SIZE` | put at most SIZE bytes of records per output file | +| `-d` | use numeric suffixes starting at 0, not alphabetic | +| `--numeric-suffixes[=FROM]` | same as `-d`, but allow setting the start value | +| `-x` | use hex suffixes starting at 0, not alphabetic | +| `--hex-suffixes[=FROM]` | same as `-x`, but allow setting the start value | +| `-l, --lines=NUMBER` | put NUMBER lines/records per output file | +| `-n, --number=CHUNKS` | generate CHUNKS output files; see explanation below | +| `--verbose` | print a diagnostic just before each output file is opened | + +## stat +display file or file system status +Usage: `stat [OPTION]... FILE...` + +### Options +| Option | Description | +| --------------------- | ------------------------------------------------------------------------------------------ | +| `-L, --dereference` | follow links | +| `-f, --file-system` | display file system status instead of file status | +| `-c --format=FORMAT` | use the specified FORMAT instead of the default; output a newline after each use of FORMAT | + +### Format Modifiers +| Format | Description | +| ------ | ---------------------------------------------------------------------- | +| %a | permission bits in octal (note '#' and '0' printf flags) | +| %A | permission bits and file type in human readable form | +| %b | number of blocks allocated (see %B) | +| %B | the size in bytes of each block reported by %b | +| %C | SELinux security context string | +| %d | device number in decimal (st_dev) | +| %D | device number in hex (st_dev) | +| %Hd | major device number in decimal | +| %Ld | minor device number in decimal | +| %f | raw mode in hex | +| %F | file type | +| %g | group ID of owner | +| %G | group name of owner | +| %h | number of hard links | +| %i | inode number | +| %m | mount point | +| %n | file name | +| %N | quoted file name with dereference if symbolic link | +| %o | optimal I/O transfer size hint | +| %s | total size, in bytes | +| %r | device type in decimal (st_rdev) | +| %R | device type in hex (st_rdev) | +| %Hr | major device type in decimal, for character/block device special files | +| %Lr | minor device type in decimal, for character/block device special files | +| %t | major device type in hex, for character/block device special files | +| %T | minor device type in hex, for character/block device special files | +| %u | user ID of owner | +| %U | user name of owner | +| %w | time of file birth, human-readable; - if unknown | +| %W | time of file birth, seconds since Epoch; 0 if unknown | +| %x | time of last access, human-readable | +| %X | time of last access, seconds since Epoch | +| %y | time of last data modification, human-readable | +| %Y | time of last data modification, seconds since Epoch | +| %z | time of last status change, human-readable | +| %Z | time of last status change, seconds since Epoch | +| %a | free blocks available to non-superuser | +| %b | total data blocks in file system | +| %c | total file nodes in file system | +| %d | free file nodes in file system | +| %f | free blocks in file system | +| %i | file system ID in hex | +| %l | maximum length of filenames | +| %n | file name | +| %s | block size (for faster transfers) | +| %S | fundamental block size (for block counts) | +| %t | file system type in hex | +| %T | file system type in human readable form | + +## tac +concatenate and print files in reverse +Usage: `tac [FILE]...` + +## tail +output the last part of files +Usage: `tail [OPTION]... [FILE]...` + +### Options +| Option | Description | +| -------------------- | ---------------------------------------------------------------------------------------------------- | +| `-c, --bytes=[+]NUM` | output the last NUM bytes; or use `-c` +NUM to output starting with byte NUM of each file | +| `-f` | output appended data as the file grows; | +| `-n, --lines=[+]NUM` | output the last NUM lines, instead of the last 10; or use `-n` +NUM to skip NUM-1 lines at the start | +| `--pid=PID` | with `-f`, terminate after process ID, PID dies | + +## tee +read from standard input and write to standard output and files +Usage: `tee [OPTION]... [FILE]...` + +### Options +| Option | Description | +| -------------- | ------------------------------------------- | +| `-a, --append` | append to the given FILEs, do not overwrite | + +## touch +change file timestamps +Usage: `touch [OPTION]... FILE...` + +### Options +| Option | Description | +| ---------------------- | ----------------------------------------------- | +| `-a` | change only the access time | +| `-c, --no-create` | do not create any files | +| `-d, --date=STRING` | parse STRING and use it instead of current time | +| `-r, --reference=FILE` | use this file's times instead of current time | + +## tr +translate or delete characters +Usage: `tr [OPTION]... STRING1 [STRING2]` + +### Options +| Option | Description | +| -------------- | ---------------------------------------------- | +| `-d, --delete` | delete characters in STRING1, do not translate | + +## true +do nothing, successfully +Usage: `true` + +## truncate +shrink or extend the size of a file to the specified size +Usage: `truncate OPTION... FILE...` + +### Options +| Option | Description | +| ----------------------- | ----------------------------------------- | +| `-c, --no-create` | do not create any files | +| `-r, --reference=RFILE` | base size on RFILE | +| `-s, --size=SIZE` | set or adjust the file size by SIZE bytes | + +## uname +print system information +Usage: `uname [OPTION]...` + +### Options +| Option | Description | +| ---------------------- | ------------------------------- | +| `-a, --all` | print all information | +| `-s, --kernel-name` | print the kernel name | +| `-n, --nodename` | print the network node hostname | +| `-r, --kernel-release` | print the kernel release | +| `-v, --kernel-version` | print the kernel version | +| `-m, --machine` | print the machine hardware name | + +## uniq +report or omit repeated lines +Usage: `uniq [OPTION]... [INPUT [OUTPUT]]` + +### Options +| Option | Description | +| -------------------- | ---------------------------------------------- | +| `-c, --count` | prefix lines by the number of occurrences | +| `-d, --repeated` | only print duplicate lines, one for each group | +| `-i, --ignore-case` | ignore differences in case when comparing | +| `-s, --skip-chars=N` | avoid comparing the first N characters | +| `-u, --unique` | only print unique lines | + +## uptime +Tell how long the system has been running +Usage: `uptime [options]` + +### Options +| Option | Description | +| -------------- | ---------------------------------------------- | +| `-p, --pretty` | show uptime in pretty format | +| `-s, --since` | system up since, in yyyy-mm-dd HH:MM:SS format | + +## wc +print newline, word, and byte counts for each file +Usage: `wc [OPTION]... [FILE]...` + +### Options +| Option | Description | +| ------------- | -------------------------- | +| `-c, --bytes` | print the byte counts | +| `-m, --chars` | print the character counts | +| `-l, --lines` | print the newline counts | +| `-w, --words` | print the word counts | + +## whoami +print effective user name +Usage: `whoami` \ No newline at end of file diff --git a/technology/applications/cli/Loop.md b/technology/applications/cli/Loop.md new file mode 100644 index 0000000..b29cccd --- /dev/null +++ b/technology/applications/cli/Loop.md @@ -0,0 +1,27 @@ +--- +obj: application +os: linux +repo: https://github.com/Miserlou/Loop +--- +# Loop +[Repo](https://github.com/Miserlou/Loop) +Loops in bash are surprisingly complicated and fickle! I wanted a simple and intuitive way to write controllable loops that: + +- Run on controllable **timers**! + - `$ loop --every 10s -- ls` +- Have **custom counters**! + - `$ loop --count-by 5 -- 'touch $COUNT.txt'` +- Loop **until output matches** a condition! + - `$ loop --until-contains 200 -- ./get_response_code.sh --site mysite.biz` +- Loop **until a certain time**! + - `$ loop --for-duration 8h -- ./poke_server` +- Loop **until a program succeeds** (or fails!) + - `$ loop --until-success -- ./poke_server` +- Iterate over the **standard input**! + - `$ cat files_to_create.txt | loop -- 'touch $ITEM'` +- Get a **summary** of the runs! + - `$ loop --for-duration 10min --summary -- ls` +- Run until output **changes or stays the same** between invocations! + - `$ loop --until-changes -- date +%s` + - `$ loop --until-same -- date +%s` +- ..and **much more!** \ No newline at end of file diff --git a/technology/applications/cli/Shell.md b/technology/applications/cli/Shell.md new file mode 100644 index 0000000..4962bfb --- /dev/null +++ b/technology/applications/cli/Shell.md @@ -0,0 +1,339 @@ +--- +obj: concept +arch-wiki: https://wiki.archlinux.org/title/Command-line_shell +wiki: https://en.wikipedia.org/wiki/Unix_shell +--- +# Shell +The shell is a command-line interpreter that provides a user interface to an operating system's services. It allows users to interact with the system through text-based commands and scripts. Shell scripting refers to writing a series of commands in a script file to automate tasks and perform complex operations. + +The shell makes heavy use of [Environment Variables](../../linux/Environment%20Variables.md) for storing settings and configuration. + +## Usage +You can enter commands to be executed in the shell. +```shell +command +``` + +Commands can be either a script, a binary or anything that can be executed. If you don't provide a full path to the file you want to run the shell will search in the locations defined in the `$PATH` environment variable. + +### Arguments +Everything after the command will be provided to the command as arguments. Each argument is separated by a space character. To avoid that you could quote an argument or escape the space character. + +```shell +command argument1 argument2 argument3 + +# These two have identical arguments +command "argument 1" "argument 2" "argument 3" +command argument\ 1 argument\ 2 argument\ 3 +``` + +Arguments are typically structured into flags and options. +Flags (like `-v` or `--verbose`) toggle specific functionality while options (like `-o output.txt` or `--out output.txt`) allow you to specify a value for the command. + +### Running in the background +Append `&` to a command to run it in the background. +```shell +long-running-command & +``` + +### Running Commands Sequentially +The `;` symbol marks the end of a command. This allows you to execute multiple commands in one line. + +```shell +command1 ; command2 +``` + +### Globs +The shell supports globs like `*` for matching. +For example to delete all text files in the current directory: +```shell +rm -v *.txt +``` + +## Redirections +### 1. **Standard Input, Output, and Error** +In a shell environment, there are three standard streams: +- **Standard Input (stdin - fd 0):** Represents the input to a command. +- **Standard Output (stdout - fd 1):** Represents the output of a command. +- **Standard Error (stderr - fd 2):** Represents error messages generated by a command. + +### **Output Redirection (`>` and `>>`)** +- `>` is used to redirect standard output to a file, overwriting the file's contents if it already exists. +```shell +echo "Hello, World!" > output.txt +``` +- `>>` is used to redirect standard output to a file, appending to the file if it exists. +```shell +echo "More text" >> output.txt +``` + +### **Input Redirection (`<`)** +`<` is used to redirect standard input from a file. +```shell +while read line; do + echo "Line: $line" +done < input.txt + +cat < input.txt +``` + +### **Error Redirection (`2>` and `2>>`)** +- `2>` is used to redirect standard error to a file, overwriting the file if it exists. +```shell +command_that_might_fail 2> error.log +``` +- `2>>` is used to redirect standard error to a file, appending to the file if it exists. +```shell +command_that_might_fail 2>> error.log +``` + +### **Pipes (`|`)** +The pipe operator (`|`) allows the output of one command to be used as the input for another command. This enables the creation of powerful and concise command pipelines. +```shell +command1 | command2 +``` + +Example: Counting Lines in a File +```shell +cat textfile.txt | wc -l +``` + +### **Combining Redirection and Pipes** +You can combine redirection and pipes to create more complex command sequences. +```shell +# Redirect stderr to a file, and then pipe the output to another command +command1 2> error.log | command2 +``` + +### **Here Documents (`<<`)** +Here documents allow you to include multiple lines of input in a script or command. `EOF` stands for End Of File. +```shell +cat << EOF +This is a +multi-line +text block. +EOF +``` + +### **Command Substitution (`$()`)** +Command substitution allows the output of a command to replace the command itself. +```shell +result=$(ls -l) +echo "Listing: $result" +``` + +### **Named Pipes (FIFOs)** +Named pipes, or FIFOs (First In, First Out), are special files used for inter-process communication. +```shell +mkfifo mypipe +command1 > mypipe & # Background process writing to the pipe +command2 < mypipe # Reading from the pipe +``` + +### **tee Command** +The `tee` command reads from standard input and writes to standard output and files simultaneously. +```shell +echo "Hello, World!" | tee output.txt | wc -l +``` + +### **/dev/null** +`/dev/null` is a special file that discards all data written to it. + +```shell +command > /dev/null # Redirects output to null +``` + +## Shell Scripting +Shell scripting involves writing a series of commands for the shell to execute, allowing automation and the creation of more complex programs. It's a powerful way to streamline tasks and manage system configurations. + +### Shebang +The shebang is the first line of a script and it indicates which executable is used for the execution of the script. The syntax is `#!` followed by the absolute path to a executable. + +For simple shell scripts add this to the file: +```shell +#!/bin/bash +``` + +Although if you are scripting in another language you could change it for example to `python` + +```shell +#!/bin/python +``` + +### Comments +You can add comments to a script by using the `#` symbol. +```shell +# This is a comment +``` + +### Variables +You can store variables in a shell script by following a `key=value` syntax. + +```shell +name="Neo" # string +age=25 # number +fruits=("apple" "banana" "orange") # array + +# using arrays +echo "First elements ${fruits[0]}" + +# using all elements of an array +${fruits[*]} +${fruits[@]} +``` + +### Conditionals +You can use conditional statements. +```shell +if [ "$age" -eq 18 ]; then + echo "You're 18!" +elif [ "$age" -gt 18 ]; then + echo "You're an adult!" +else + echo "You're a minor." +fi + +# Case Statement (useful for checking a lot of conditions) +case $name in + "Neo") + echo "You are the one" + ;; + "Morpheus") + echo "See you again" + ;; + *) + # default if nothing matches + echo "Sorry, I don't understand" + ;; +esac +``` + +#### Operators +##### Arithmetic Operators +Assume variable **a** holds 10 and variable **b** holds 20 then − + +| Operator | Description | Example | +| ------------------ | --------------------------------------------------------------------- | --------------------------------------- | +| + (Addition) | Adds values on either side of the operator | `expr $a + $b` will give 30 | +| - (Subtraction) | Subtracts right hand operand from left hand operand | `expr $a - $b` will give -10 | +| * (Multiplication) | Multiplies values on either side of the operator | `expr $a \* $b` will give 200 | +| / (Division) | Divides left hand operand by right hand operand | `expr $b / $a` will give 2 | +| % (Modulus) | Divides left hand operand by right hand operand and returns remainder | `expr $b % $a` will give 0 | +| = (Assignment) | Assigns right operand in left operand | `a = $b` would assign value of b into a | +| == (Equality) | Compares two numbers, if both are same then returns true. | `[$a == $b ]` would return false. | +| != (Not Equality) | Compares two numbers, if both are different then returns true. | `[ $a != $b ]` would return true. | + +##### Relational Operators +For example, following operators will work to check a relation between 10 and 20 as well as in between "10" and "20" but not in between "ten" and "twenty". + +Assume variable **a** holds 10 and variable **b** holds 20 then − + +| Operator | Description | Example | +| -------- | ------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------- | +| **-eq** | Checks if the value of two operands are equal or not; if yes, then the condition becomes true. | `[ $a -eq $b ]` is not true. | +| **-ne** | Checks if the value of two operands are equal or not; if values are not equal, then the condition becomes true. | `[ $a -ne $b ]` is true. | +| **-gt** | Checks if the value of left operand is greater than the value of right operand; if yes, then the condition becomes true. | `[ $a -gt $b ]` is not true. | +| **-lt** | Checks if the value of left operand is less than the value of right operand; if yes, then the condition becomes true. | `[ $a -lt $b ]` is true. | +| **-ge** | Checks if the value of left operand is greater than or equal to the value of right operand; if yes, then the condition becomes true. | `[ $a -ge $b ]` is not true. | +| **-le** | Checks if the value of left operand is less than or equal to the value of right operand; if yes, then the condition becomes true. | `[ $a -le $b ]` is true. | + +##### Boolean Operators +Assume variable **a** holds 10 and variable **b** holds 20 then − + +| Operator | Description | Example | +| -------- | -------------------------------------------------------------------------------------------------------- | ------------------------------------- | +| **!** | This is logical negation. This inverts a true condition into false and vice versa. | `[ ! false ]` is true. | +| **-o** | This is logical **OR**. If one of the operands is true, then the condition becomes true. | `[ $a -lt 20 -o $b -gt 100 ]` is true. | +| **-a** | This is logical **AND**. If both the operands are true, then the condition becomes true otherwise false. | `[ $a -lt 20 -a $b -gt 100 ]` is false. | + +##### File Test Operators +We have a few operators that can be used to test various properties associated with a Unix file. + +Assume a variable **file** holds an existing file name "test" the size of which is 100 bytes and has **read**, **write** and **execute** permission. + +| Operator | Description | Example | +| ----------- | ---------------------------------------------------------------------------------------------------------------------- | --------------------------- | +| **-b file** | Checks if file is a block special file; if yes, then the condition becomes true. | `[ -b $file ]` is false. | +| **-c file** | Checks if file is a character special file; if yes, then the condition becomes true. | `[ -c $file ]` is false. | +| **-d file** | Checks if file is a directory; if yes, then the condition becomes true. | `[ -d $file ]` is not true. | +| **-f file** | Checks if file is an ordinary file as opposed to a directory or special file; if yes, then the condition becomes true. | `[ -f $file ]` is true. | +| **-g file** | Checks if file has its set group ID (SGID) bit set; if yes, then the condition becomes true. | `[ -g $file ]` is false. | +| **-k file** | Checks if file has its sticky bit set; if yes, then the condition becomes true. | `[ -k $file ]` is false. | +| **-p file** | Checks if file is a named pipe; if yes, then the condition becomes true. | `[ -p $file ]` is false. | +| **-t file** | Checks if file descriptor is open and associated with a terminal; if yes, then the condition becomes true. | `[ -t $file ]` is false. | +| **-u file** | Checks if file has its Set User ID (SUID) bit set; if yes, then the condition becomes true. | `[ -u $file ]` is false. | +| **-r file** | Checks if file is readable; if yes, then the condition becomes true. | `[ -r $file ]` is true. | +| **-w file** | Checks if file is writable; if yes, then the condition becomes true. | `[ -w $file ]` is true. | +| **-x file** | Checks if file is executable; if yes, then the condition becomes true. | `[ -x $file ]` is true. | +| **-s file** | Checks if file has size greater than 0; if yes, then condition becomes true. | `[ -s $file ]` is true. | +| **-e file** | Checks if file exists; is true even if file is a directory but exists. | `[ -e $file ]` is true. | + +### Loops + +You can also use loops. +```shell +# For Loop +for fruit in "${fruits[@]}"; do + echo "Fruit: $fruit" +done + +# Example: Loop over files +for file in *.txt; do + echo "File: $file"; +done + +# While Loop +count=0 +while [ $count -lt 5 ]; do + echo "Count: $count" + ((count++)) +done +``` + +You can use a few commands to control the loop. +- `break` breaks out of the loop, ending it prematurely +- `continue` skips to the next iteration of the loop, but skipping everything coming after it + +If you want to loop over every single line even if one line might contain spaces (from a command output for example) you can use this trick: +```shell +command | while IFS= read -r varName; do + echo "Working on $varName" +done +``` + +### Functions +You can define your own functions. The arguments you give to the functions can be accessed via `$1`, `$2`, `$n`, etc. The same way the arguments passed to a shell script can be accessed. + +```shell +greet() { + echo "Hello, $1!" +} + +# Function Call +greet "Alice" +``` + +Your functions can also have return values. +```shell +add() { + local result=$(( $1 + $2 )) + echo $result +} + +# Function Call +sum=$(add 5 3) +echo "Sum: $sum" +``` + +### Input Output +Read user input into a variable. +```shell +echo "Enter your name: " +read username +echo "Hello, $username!" +``` + +Output to Screen (`echo`, `printf`): +```shell +echo "Hello, World!" +``` diff --git a/technology/applications/cli/alacritty.md b/technology/applications/cli/alacritty.md new file mode 100644 index 0000000..54231a5 --- /dev/null +++ b/technology/applications/cli/alacritty.md @@ -0,0 +1,154 @@ +--- +obj: application +os: + - macos + - linux + - windows +repo: https://github.com/alacritty/alacritty +website: https://alacritty.org/ +--- +# Alacritty +Alacritty is a modern terminal emulator that comes with sensible defaults, but allows for extensive configuration. By integrating with other applications, rather than reimplementing their functionality, it manages to provide a flexible set of features with high performance. The supported platforms currently consist of BSD, [Linux](../../linux/Linux.md), [macOS](../../macos/macOS.md) and [Windows](../../windows/Windows.md). + +![Screenshot][Screenshot] + +## Configuration +Alacritty is highly customizable and can be configured using a [TOML](../../files/TOML.md) configuration file. Previous versions have used a [YAML](../../files/YAML.md) file. The configuration file is located in `~/.config/alacritty/alacritty.toml` on [Linux](../../linux/Linux.md) and [macOS](../../macos/macOS.md), and in `%APPDATA%\alacritty\alacritty.toml` on [Windows](../../windows/Windows.md). + +Here is an example configuration file: +```yml +# This is an example Alacritty configuration file +[font] +family: Fira Code +size: 14.0 + +[colors] +[colors.primary] +background: '#1d1f21' +foreground: '#c5c8c6' + +[colors.normal] +black: '#282a2e' +red: '#a54242' +green: '#8c9440' +yellow: '#de935f' +blue: '#5f819d' +magenta: '#85678f' +cyan: '#5e8d87' +white: '#707880' +``` + +## Configuration Options +### General +This is the root level of the config file. + +- `import = ["",]`: Import additional configuration files. + +### Font +The `font` section allows you to set the font family and size used by Alacritty. You can set the font size to a decimal value, which can be helpful if you want to fine-tune the size. +```toml +[font] +family = "Fira Code" +size = 14.0 +``` + +### Colors +The `colors` section allows you to set the color scheme used by Alacritty. There are three main categories of colors: + +- `primary`: The background and foreground colors of the terminal window itself. +- `normal`: The colors used for regular text in the terminal. +- `bright`: The colors used for bold text in the terminal. + +Each category can have different colors for each of the eight ANSI color codes (black, red, green, yellow, blue, magenta, cyan, and white). You can set colors using HEX color codes or RGB values. +```toml +[colors] +[colors.primary] +background = '#1d1f21' +foreground = '#c5c8c6' + +[colors.normal] +black = '#282a2e' +red = '#a54242' +green = '#8c9440' +yellow = '#de935f' +blue = '#5f819d' +magenta = '#85678f' +cyan = '#5e8d87' +white = '#707880' + +[colors.bright] +black = '#373b41' +red = '#cc6666' +green = '#b5bd68' +yellow = '#f0c674' +blue = '#81a2be' +magenta = '#b294bb' +cyan = '#8abeb7' +white = '#c5c8c6' +``` + +### Working Directory +You can set the initial directory that your [shell](Shell.md) will start in when you launch Alacritty +```toml +# working_directory = None +working_directory = "/home/your-username" +``` + +### Shell +You can control the [shell](Shell.md) that Alacritty uses when you launch it. By default, Alacritty will use the user's login [shell](Shell.md) on [Linux](../../linux/Linux.md) and BSD systems, `/bin/bash --login` on [macOS](../../macos/macOS.md), and PowerShell on [Windows](../../windows/Windows.md) +```toml +[shell] +program = /bin/zsh +args = ["- --rcfile", "/path/to/your/zshrc"] +``` + +### Environment +The Alacritty configuration file allows you to set [environment variables](../../linux/Environment%20Variables.md) that will be available to your [shell](Shell.md) sessions. Any entries in the `env` section will be added as [environment variables](../../linux/Environment%20Variables.md) when Alacritty launches your [shell](Shell.md) +```toml +[env] +TERM = "alacritty" +EDITOR = "nano" +``` + +### Window +The `window` section of the Alacritty configuration file contains options related to the appearance and behavior of the terminal window itself. + +- The `dimensions` option allows you to set the number of lines and columns that are displayed in the terminal. The default value of `0` will fall back to the window manager's recommended size. +- The `position` option lets you specify the position of the window on the screen in pixels. If this option is not set, the window manager will handle the placement. +- The `opacity` option sets the opacity of the terminal window as a floating point number from `0.0` to `1.0`, with `0.0` being completely transparent and `1.0` being opaque. +- The `startup_mode` option allows you to specify how the window should be displayed when Alacritty starts up. You can choose between `Windowed`, `Maximized`, and `Fullscreen`. On [macOS](../../macos/macOS.md), there is an additional option called `SimpleFullscreen`. +- The `title` option sets the title of the terminal window. +- The `dynamic_title` option allows terminal applications to change the title of the Alacritty window. When this option is set to `true`, the window title will be updated to match the title of the currently running program. +```toml +[window] +[window.dimensions] +columns = 100 +lines = 40 + +[window.position] +x = 100 +y = 100 + + +# Background opacity +# Window opacity as a floating point number from `0.0` to `1.0` +[window] +opacity: 0.9 # Set the window opacity to 90% + +# Startup Mode (changes require restart) +# +# Values for `startup_mode`: +# - Windowed +# - Maximized +# - Fullscreen +# +# Values for `startup_mode` (macOS only): +# - SimpleFullscreen +startup_mode: Maximized + +title: "Alacritty" + +dynamic_title: true +``` + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/cli/aria2.md b/technology/applications/cli/aria2.md new file mode 100644 index 0000000..6698243 --- /dev/null +++ b/technology/applications/cli/aria2.md @@ -0,0 +1,89 @@ +--- +obj: application +os: + - linux +website: https://aria2.github.io/ +repo: https://github.com/aria2/aria2 +--- +# aria2 +[Repo](https://github.com/aria2/aria2) +#refactor +[aria2](https://aria2.github.io/) is a utility for downloading files. The supported protocols are [HTTP](../../internet/HTTP.md)(S), FTP, SFTP, [BitTorrent](../../tools/BitTorrent.md), and Metalink. aria2 can download a file from multiple sources/protocols and tries to utilize your maximum download bandwidth. It supports downloading a file from [HTTP](../../internet/HTTP.md)(S)/FTP/SFTP and [BitTorrent](../../tools/BitTorrent.md) at the same time, while the data downloaded from [HTTP](../../internet/HTTP.md)(S)/FTP/SFTP is uploaded to the [BitTorrent](../../tools/BitTorrent.md) swarm. Using Metalink's chunk checksums, aria2 automatically validates chunks of data while downloading a file like [BitTorrent](../../tools/BitTorrent.md). Aria2 can be used as a downloader by [yt-dlp](../media/yt-dlp.md). + +## Usage + +```shell +aria2c [] [|||] +``` + +### Options +- The directory to store the downloaded file. +```shell +-d, --dir= +``` + +- Downloads the URIs listed in **FILE**. +```shell +-i, --input-file= +``` + +- Set the maximum number of parallel downloads for every queue item. +```shell +-j, --max-concurrent-downloads= +``` + +- Check file integrity by validating piece hashes or a hash of entire file. This option has effect only in [BitTorrent](../../tools/BitTorrent.md), Metalink downloads with checksums or [HTTP](../../internet/HTTP.md)(S)/FTP downloads with --checksum option. If piece hashes are provided, this option can detect damaged portions of a file and re-download them. If a hash of entire file is provided, hash check is only done when file has been already download. This is determined by file length. If hash check fails, file is re-downloaded from scratch. If both piece hashes and a hash of entire file are provided, only piece hashes are used. Default: false +```shell +-V, --check-integrity [true|false] +``` + +- Continue downloading a partially downloaded file. Use this option to resume a download started by a web browser or another program which downloads files sequentially from the beginning. Currently this option is only applicable to [HTTP](../../internet/HTTP.md)(S)/FTP downloads. +```shell +-c, --continue [true|false] +``` + +- Set checksum. TYPE is hash type. The supported hash type is listed in Hash Algorithms in aria2c -v. DIGEST is hex digest. For example, setting sha-1 digest looks like this: sha-1=0192ba11326fe2298c8cb4de616f4d4140213838 This option applies only to [HTTP](../../internet/HTTP.md)(S)/FTP downloads. +```shell +--checksum== +``` + +- The maximum number of connections to one server for each download.  Default: **1** +```shell +-x, --max-connection-per-server= +``` + +- aria2 does not split less than 2*SIZE byte range. For example, let's consider downloading 20MiB file. If SIZE is 10M, aria2 can split file into 2 range (0-10MiB) and (10MiB-20MiB) and download it using 2 sources(if --split >= 2, of course). If SIZE is 15M, since 2*15M > 20MiB, aria2 does not split file and download it using 1 source. You can append K or M (1K = 1024, 1M = 1024K). Possible Values: 1M -1024M Default: 20M +```shell +-k, --min-split-size= +``` + +- The file name of the downloaded file.  It is always relative to the directory given in --dir option. +```shell +-o, --out= +``` + +- Download a file using N connections. If more than N URIs are given, first N URIs are used and remaining URIs are used for backup. If less than N URIs are given, those URIs are used more than once so that N connections total are made simultaneously. The number of connections to the same host is restricted by the --max-connection-per-server option. See also the --min-split-size option. Default: 5 +```shell +-s, --split= +``` + +- Verify the peer using certificates specified in --ca-certificate option. Default: true +```shell +--check-certificate [true|false] +``` + +- [HTTP](../../internet/HTTP.md) Auth +```shell +--http-user= +--http-passwd= +``` + +- Load Cookies from FILE using the Firefox3 format (SQLite3), Chromium/Google Chrome (SQLite3) and the Mozilla/[Firefox](../network/browsers/Firefox.md)(1.x/2.x)/Netscape format. +```shell +--load-cookies= +``` + +- Save Cookies to FILE in Mozilla/[Firefox](../network/browsers/Firefox.md)(1.x/2.x)/ Netscape format. If FILE already exists, it is overwritten. Session Cookies are also saved and their expiry values are treated as 0. Possible Values: /path/to/file +```shell +--save-cookies= +``` \ No newline at end of file diff --git a/technology/applications/cli/bash.md b/technology/applications/cli/bash.md new file mode 100644 index 0000000..4b045cd --- /dev/null +++ b/technology/applications/cli/bash.md @@ -0,0 +1,10 @@ +--- +obj: application +website: https://www.gnu.org/software/bash/ +wiki: https://wikipedia.org/wiki/Bash_(Unix_shell) +arch-wiki: https://wiki.archlinux.org/title/Bash +repo: https://git.savannah.gnu.org/git/bash.git +--- + +# bash +Bash (Bourne-again Shell) is a command-line [shell](Shell.md)/programming language by the GNU Project. Bash can be run on most UNIX-like operating systems, including [Linux](../../linux/Linux.md). It can be used interactively or execute [shell](Shell.md) scripts. \ No newline at end of file diff --git a/technology/applications/cli/bat.md b/technology/applications/cli/bat.md new file mode 100644 index 0000000..359133b --- /dev/null +++ b/technology/applications/cli/bat.md @@ -0,0 +1,16 @@ +--- +obj: application +os: ["macos", "linux", "windows"] +repo: https://github.com/sharkdp/bat +--- +# bat +bat is a cat rewrite in [Rust](../../programming/languages/Rust.md) + +## Usage +Flags: +```shell +-r, --line-range ... Only print specific lines +-A, --show-all Show non-printable characters +-p, --plain Only show plain style, no decorations +-d, --diff Only show changed lines +``` diff --git a/technology/applications/cli/chattr.md b/technology/applications/cli/chattr.md new file mode 100644 index 0000000..ce1b776 --- /dev/null +++ b/technology/applications/cli/chattr.md @@ -0,0 +1,31 @@ +--- +obj: application +repo: https://git.kernel.org/pub/scm/fs/ext2/e2fsprogs.git +--- +# chattr +change file attributes on a Linux file system +Usage: +```shell +chattr + # Add Attribute +chattr - # Remove Attribute +chattr = # Set Attribute +``` + +## Options +| Option | Description | +| ------ | ---------------------------------------------------------------- | +| `-R` | Recursively change attributes of directories and their contents. | + +## Attributes +| Attribute | Description | +| --------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| `a` | A file with the 'a' attribute set can only be opened in append mode for writing. Only the superuser or a process possessing the CAP_LINUX_IMMUTABLE capability can set or clear this attribute. | +| `A` | When a file with the 'A' attribute set is accessed, its atime record is not modified. This avoids a certain amount of disk I/O for laptop systems. | +| `c` | A file with the 'c' attribute set is automatically compressed on the disk by the kernel. A read from this file returns uncompressed data. A write to this file compresses data before storing them on the disk. Note: please make sure to read the bugs and limitations section at the end of this document. (Note: For btrfs, If the 'c' flag is set, then the 'C' flag cannot be set. Also conflicts with btrfs mount option 'nodatasum') | +| `C` | A file with the 'C' attribute set will not be subject to copy-on-write updates. This flag is only supported on file systems which perform copy-on-write. (Note: For btrfs, the 'C' flag should be set on new or empty files. If it is set on a file which already has data blocks, it is undefined when the blocks assigned to the file will be fully stable. If the 'C' flag is set on a directory, it will have no effect on the directory, but new files created in that directory will have the No_COW attribute set. If the 'C' flag is set, then the 'c' flag cannot be set.) | +| `D` | When a directory with the 'D' attribute set is modified, the changes are written synchronously to the disk; this is equivalent to the 'dirsync' mount option applied to a subset of the files. | +| `i` | A file with the 'i' attribute cannot be modified: it cannot be deleted or renamed, no link can be created to this file, most of the file's metadata can not be modified, and the file can not be opened in write mode. Only the superuser or a process possessing the CAP_LINUX_IMMUTABLE capability can set or clear this attribute. | +| `m` | A file with the 'm' attribute is excluded from compression on file systems that support per-file compression. | +| `S` | When a file with the 'S' attribute set is modified, the changes are written synchronously to the disk; this is equivalent to the 'sync' mount option applied to a subset of the files. | + + diff --git a/technology/applications/cli/choose.md b/technology/applications/cli/choose.md new file mode 100644 index 0000000..7161120 --- /dev/null +++ b/technology/applications/cli/choose.md @@ -0,0 +1,24 @@ +--- +obj: application +os: + - macos + - linux + - windows +repo: https://github.com/theryangeary/choose +--- +# choose +`choose`, a human-friendly and fast alternative to `cut` and (sometimes) `awk` + +## Usage +```shell +choose [OPTIONS] ... +choose 1 # Choose the the second element +choose -f" " 0:3 # Choose element 0 to 3 seperated by " " +``` + +## Options +| Option | Description | +| ------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------- | +| `-f, --field-separator ` | Specify field separator other than whitespace, using [Rust](../../programming/languages/Rust.md) `regex` syntax | +| `-i, --input ` | Input file | +| `-o, --output-field-separator ` | Specify output field separator | diff --git a/technology/applications/cli/crunch.md b/technology/applications/cli/crunch.md new file mode 100644 index 0000000..9b6002c --- /dev/null +++ b/technology/applications/cli/crunch.md @@ -0,0 +1,23 @@ +--- +obj: application +source: https://www.kali.org/tools/crunch/ +repo: https://salsa.debian.org/debian/crunch +--- + +# crunch +wordlist generator + +Usage: `crunch [] [options]` + +## Options +| Option | Description | +| -------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-c number` | Specifies the number of lines to write to output file, only works if -o START is used | +| `-d numbersymbol` | Limits the number of duplicate characters. `-d 2@` limits the lower case alphabet to output like aab and aac. aaa would not be generated as that is 3 consecutive letters of a. | +| `-e string` | Specifies when crunch should stop early | +| `-f /path/to/charset.lst charset-name` | Specifies a character set from the charset.lst | +| `-i` | Inverts the output so instead of aaa,aab,aac,aad, etc you get aaa,baa,caa,daa,aba,bba | +| `-o wordlist.txt` | Specifies the file to write the output to, eg: wordlist.txt | +| `-s startblock` | Specifies a starting string, eg: 03god22fs | +| `-t @,%^` | Specifies a pattern, eg: @@god@@@@ where the only the @'s, ,'s, %'s, and ^'s  will change.
`@` will insert lower case characters
`,` will insert upper case characters
`%` will insert numbers
`^` will insert symbols | +| `-z gzip, bzip2, lzma, and 7z` | Compresses the output from the -o option. Valid parameters are gzip, bzip2, lzma, and [7z](p7zip.md). | diff --git a/technology/applications/cli/curl.md b/technology/applications/cli/curl.md new file mode 100644 index 0000000..ab79a1b --- /dev/null +++ b/technology/applications/cli/curl.md @@ -0,0 +1,32 @@ +--- +obj: application +os: linux +website: https://curl.se/ +repo: https://github.com/curl/curl +--- +# curl +cURL is a command-line tool and library for transferring data with URLs. It supports a wide range of protocols, making it a versatile tool for making [HTTP](../../internet/HTTP.md) requests, downloading files, and more. + +## Usage +To make a simple GET request: `curl https://example.com` + +## Options +| Option | Description | +| -------------------------------------- | ------------------------------------------------------------------------------------- | +| `-C, --continue-at ` | Continue/Resume a previous file transfer at the given offset. | +| `-c, --cookie-jar ` | Specify to which file you want curl to write all cookies after a completed operation. | +| `-b, --cookie ` | Pass the data to the [HTTP](../../internet/HTTP.md) server in the [Cookie](../../internet/Cookie.md) header. | +| `-d, --data ` | Sends the specified data in a POST request to the [HTTP](../../internet/HTTP.md) server | +| `-F, --form ` | Specify multipart MIME data | +| `-k, --insecure` | Allow insecure server connections when using SSL | +| `-L, --location` | Follow redirects | +| `-o, --output ` | Write to file instead of stdout | +| `-x, --proxy [protocol://]host[:port]` | Use this proxy | +| `-X, --request ` | Specify request command to use | +| `-r, --range ` | Retrieve only the bytes within RANGE | +| `--retry ` | Retry request if transient problems occur | +| `-s, --silent` | Silent mode | +| `--retry-delay ` | Wait time between retries | +| `-u, --user ` | Server user and password | +| `-A, --user-agent ` | Send User-Agent \ to server | + diff --git a/technology/applications/cli/diff.md b/technology/applications/cli/diff.md new file mode 100644 index 0000000..01a491a --- /dev/null +++ b/technology/applications/cli/diff.md @@ -0,0 +1,20 @@ +--- +obj: application +wiki: https://en.wikipedia.org/wiki/Diff +website: https://www.gnu.org/software/diffutils/ +repo: https://git.savannah.gnu.org/cgit/diffutils.git +--- +# diff +compare files line by line +Usage: `diff [OPTION]... FILES` + +## Options +| Option | Description | +| ------------------------------ | ----------------------------------------------- | +| `--normal` | output a normal diff (the default) | +| `-q, --brief` | report only when files differ | +| `-s, --report-identical-files` | report when two files are the same | +| `-c, -C NUM, --context[=NUM]` | output NUM (default 3) lines of copied context | +| `-u, -U NUM, --unified[=NUM]` | output NUM (default 3) lines of unified context | +| `-r, --recursive` | recursively compare any subdirectories found | +| `-a, --text` | treat all files as text | diff --git a/technology/applications/cli/diskonaut.md b/technology/applications/cli/diskonaut.md new file mode 100644 index 0000000..49406fa --- /dev/null +++ b/technology/applications/cli/diskonaut.md @@ -0,0 +1,9 @@ +--- +obj: application +os: + - linux +repo: https://github.com/imsnif/diskonaut +--- +# Diskonaut +[Repo](https://github.com/imsnif/diskonaut) +Diskonaut shows disk usage graphically to find big files. \ No newline at end of file diff --git a/technology/applications/cli/doas.md b/technology/applications/cli/doas.md new file mode 100644 index 0000000..5b3f57d --- /dev/null +++ b/technology/applications/cli/doas.md @@ -0,0 +1,71 @@ +--- +obj: application +repo: https://github.com/Duncaen/OpenDoas +wiki: https://en.wikipedia.org/wiki/Doas +arch-wiki: https://wiki.archlinux.org/title/Doas +--- + +# doas +doas is a program to execute commands as another user. The system administrator can configure it to give specified users privileges to execute specified commands. It is free and open-source under the ISC license and available in Unix and Unix-like operating systems ([FreeBSD](../../bsd/FreeBSD.md), [OpenBSD](../../bsd/OpenBSD.md), [Linux](../../linux/Linux.md)). + +## Usage +To use doas, simply prefix a command and its arguments with doas and a space: +```shell +$ doas cmd +``` + +To get to an interactive shell with root prompt: +```shell +$ doas -s +``` + +### Options +| Option | Description | +| --------- | ------------------------------------------------- | +| `-s` | Execute the shell from `SHELL` or /etc/passwd. | +| `-u user` | Execute the command as user. The default is root. | + +## Configuration +The configuration for doas is stored at `/etc/doas.conf`. + +The config file consist of rules with the following format: +`permit|deny [options] identity [as target] [cmd command [args ...]]` + +Rules consist of the following parts: +- `permit|deny`: The action to be taken if this rule matches. + +Options: + +| Option | Description | +| -------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `nopass` | The user is not required to enter a password. | +| `nolog` | Do not log successful command execution to syslogd | +| `persist` | After the user successfully authenticates, do not ask for a password again for some time. | +| `keepenv` | Environment variables other than those listed in doas are retained when creating the environment for the new process. | +| `setenv {var=value}` | Keep or set the space-separated specified variables. Variables may also be removed with a leading ‘-’ or set using the latter syntax. If the first character of value is a ‘`$`’ then the value to be set is taken from the existing environment variable of the indicated name. This option is processed after the default environment has been created. | + + +- `identity`: The username to match. Groups may be specified by prepending a colon (‘:’). Numeric IDs are also accepted. + +- `as`: The target user the running user is allowed to run the command as. The default is all users. + +- `cmd`: The command the user is allowed or denied to run. The default is all commands. Be advised that it is best to specify absolute paths. If a relative path is specified, only a restricted `PATH` will be searched. + +- `args`: Arguments to command. The command arguments provided by the user need to match those specified. The keyword `args` alone means that command must be run without any arguments. + +The last matching rule determines the action taken. If no rule matches, the action is denied. + +Comments can be put anywhere in the file using a hash mark (‘#’), and extend to the end of the current line. + +The following quoting rules apply: +- The text between a pair of double quotes (‘"’) is taken as is. +- The backslash character (‘\’) escapes the next character, including new line characters, outside comments; as a result, comments may not be extended over multiple lines. +- If quotes or backslashes are used in a word, it is not considered a keyword. + +### Examples +``` +permit persist setenv { PKG_CACHE PKG_PATH } aja cmd pkg_add +permit setenv { -ENV PS1=$DOAS_PS1 SSH_AUTH_SOCK } :wheel +permit nopass tedu as root cmd /usr/sbin/procmap +permit nopass keepenv setenv { PATH } root as root +``` \ No newline at end of file diff --git a/technology/applications/cli/duf.md b/technology/applications/cli/duf.md new file mode 100644 index 0000000..d438a62 --- /dev/null +++ b/technology/applications/cli/duf.md @@ -0,0 +1,54 @@ +--- +obj: application +os: + - linux +repo: https://github.com/muesli/duf +--- +# duf +Disk Usage/Free Utility + +## Usage +You can simply start duf without any command-line arguments: +``` +duf +``` + +If you supply arguments, duf will only list specific devices & mount points: +``` +duf /home /some/file +``` + +If you want to list everything (including pseudo, duplicate, inaccessible file systems): +``` +duf --all +``` + +### Filtering + +You can show and hide specific tables: +``` +duf --only local,network,fuse,special,loops,binds +duf --hide local,network,fuse,special,loops,binds +``` + +You can also show and hide specific [filesystems](../../linux/filesystems/Filesystems.md): +``` +duf --only-fs tmpfs,vfat +duf --hide-fs tmpfs,vfat +``` + +...or specific mount points: +``` +duf --only-mp /,/home,/dev +duf --hide-mp /,/home,/dev +``` + +Wildcards inside quotes work: +``` +duf --only-mp '/sys/*,/dev/*' +``` + +If you prefer your output as [JSON](../../files/JSON.md): +``` +duf --json +``` \ No newline at end of file diff --git a/technology/applications/cli/eza.md b/technology/applications/cli/eza.md new file mode 100644 index 0000000..389b757 --- /dev/null +++ b/technology/applications/cli/eza.md @@ -0,0 +1,20 @@ +--- +obj: application +os: linux +repo: https://github.com/eza-community/eza +--- +# exa +[**eza**](https://eza.rocks/) is a modern replacement for the venerable file-listing command-line program `ls` that ships with Unix and Linux operating systems, giving it more features and better defaults. It uses colours to distinguish file types and metadata. It knows about symlinks, extended attributes, and Git. And it’s **small**, **fast**, and just **one single binary**. + +## Usage +Flags: +```shell +-l, --long         display extended file metadata as a table +-R, --recurse      recurse into directories +-L, --level DEPTH limit the depth of recursion +-T, --tree         recurse into directories as a tree +-a, --all          show hidden and 'dot' files +-r, --reverse      reverse the sort order +-D, --only-dirs    list only directories +--git-ignore       ignore files mentioned in '.gitignore' +``` \ No newline at end of file diff --git a/technology/applications/cli/fd.md b/technology/applications/cli/fd.md new file mode 100644 index 0000000..3c13d6c --- /dev/null +++ b/technology/applications/cli/fd.md @@ -0,0 +1,22 @@ +--- +obj: application +os: linux +repo: https://github.com/sharkdp/fd +--- +# fd +`fd` is a program to find entries in your filesystem. It is a simple, fast and user-friendly alternative to [`find`](https://www.gnu.org/software/findutils/). While it does not aim to support all of `find`'s powerful functionality, it provides sensible (opinionated) defaults for a majority of use cases. + +## Usage +Flags: +```shell +-H, --hidden Include hidden files +-d, --max-depth Limit recursion +-e, --extension Search by extension +-x, --exec ... Execute command for every search result. +The following placeholders are substituted before the command is executed: +'{}':   path (of the current search result) +'{/}':  basename +'{//}': parent directory +'{.}':  path without file extension +'{/.}': basename without file extension +``` \ No newline at end of file diff --git a/technology/applications/cli/file.md b/technology/applications/cli/file.md new file mode 100644 index 0000000..b7111ed --- /dev/null +++ b/technology/applications/cli/file.md @@ -0,0 +1,15 @@ +--- +obj: application +repo: https://github.com/file/file +wiki: https://en.wikipedia.org/wiki/File_(command) +website: https://darwinsys.com/file +--- +# file +determine file / [MIME](../../files/MIME.md) type +Usage: `file [OPTION] [FILE]...` + +## Options +| Option | Description | +| ------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-b, --brief` | Do not prepend filenames to output lines (brief mode) | +| `-i, --mime` | Causes the file command to output mime type strings rather than the more traditional human readable ones. Thus it may say ‘text/plain; charset=us-ascii’ rather than "ASCII text" | \ No newline at end of file diff --git a/technology/applications/cli/glow.md b/technology/applications/cli/glow.md new file mode 100644 index 0000000..b37347a --- /dev/null +++ b/technology/applications/cli/glow.md @@ -0,0 +1,10 @@ +--- +obj: application +os: linux +repo: https://github.com/charmbracelet/glow +--- +# Glow +[Repo](https://github.com/charmbracelet/glow) +Glow is a terminal based markdown reader designed from the ground up to bring out the beauty—and power—of the CLI. + +Use it to discover markdown files, read documentation directly on the command line and stash markdown files to your own private collection so you can read them anywhere. Glow will find local markdown files in subdirectories or a local Git repository. \ No newline at end of file diff --git a/technology/applications/cli/handlr.md b/technology/applications/cli/handlr.md new file mode 100644 index 0000000..e2c7e02 --- /dev/null +++ b/technology/applications/cli/handlr.md @@ -0,0 +1,34 @@ +--- +obj: application +os: linux +repo: https://github.com/chmln/handlr +--- +# Handlr +Manage your default applications with ease using `handlr`! + +Open files in default application: +```shell +handlr open +``` + +List default apps: +```shell +handlr list +``` + +Get default app: +```sh +handlr get .png +``` + +Set default apps: +```sh +# Set default handler for png files +handlr set .png feh.desktop + +# Set wildcard handler for all text files +handlr set 'text/*' nvim.desktop + +# Set default handler based on mime +handlr set application/pdf evince.desktop +``` \ No newline at end of file diff --git a/technology/applications/cli/hashcat.md b/technology/applications/cli/hashcat.md new file mode 100644 index 0000000..707281e --- /dev/null +++ b/technology/applications/cli/hashcat.md @@ -0,0 +1,8 @@ +--- +obj: application +repo: https://github.com/hashcat/hashcat +website: https://hashcat.net/hashcat +--- + +# hashcat +#wip #🐇 \ No newline at end of file diff --git a/technology/applications/cli/hck.md b/technology/applications/cli/hck.md new file mode 100644 index 0000000..66980f3 --- /dev/null +++ b/technology/applications/cli/hck.md @@ -0,0 +1,28 @@ +--- +obj: application +os: linux +repo: https://github.com/sstadick/hck +--- +# hck +_`hck` is a shortening of `hack`, a rougher form of `cut`._ + +A close to drop in replacement for cut that can use a regex delimiter instead of a fixed string. Additionally this tool allows for specification of the order of the output columns using the same column selection syntax as cut (see below for examples). + +No single feature of `hck` on its own makes it stand out over `awk`, `cut`, `xsv` or other such tools. Where `hck` excels is making common things easy, such as reordering output fields, or splitting records on a weird delimiter. It is meant to be simple and easy to use while exploring datasets. Think of this as filling a gap between `cut` and `awk`. + +## Usage +Usage: `hck [options]` +Options: + +| Option | Description | +| ------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------- | +| `-o, --output ` | Output file to write to, defaults to `stdout` | +| `-d, --delimiter ` | Delimiter to use on input files, this is a substring literal by default. To treat it as a literal add the `-L` flag
\[default: `\s+`] | +| `-L, --delim-is-literal` | Treat the delimiter as a string literal. This can significantly improve performance, especially for single byte delimiters | +| `-I, --use-input-delim` | Use the input delimiter as the output delimiter if the input is literal and no other output delimiter has been set | +| `-D, --output-delimiter ` | Delimiter string to use on outputs
[default: "\t"] | +| `-f, --fields ` | Fields to keep in the output, ex: 1,2-,-5,2-5. Fields are 1-based and inclusive | +| `-e, --exclude ` | Fields to exclude from the output, ex: 3,9-11,15-. Exclude fields are 1 based and inclusive. Exclude fields take precedence over `fields` | +| `-E, --exclude-header ` | Headers to exclude from the output, ex: '^badfield.\*$'. This is a string literal by default. Add the `-r` flag to treat as a regex | +| `-F, --header-field ` | A string literal or regex to select headers, ex: '^is\_.\*$'. This is a string literal by default. add the `-r` flag to treat it as a regex | +| `-r, --header-is-regex` | Treat the header_fields as regexs instead of string literals | \ No newline at end of file diff --git a/technology/applications/cli/hexyl.md b/technology/applications/cli/hexyl.md new file mode 100644 index 0000000..e2ffb6f --- /dev/null +++ b/technology/applications/cli/hexyl.md @@ -0,0 +1,17 @@ +--- +obj: application +os: + - linux +repo: https://github.com/sharkdp/hexyl +--- +# Hexyl +[Repo](https://github.com/sharkdp/hexyl) +#refactor +`hexyl` is a simple hex viewer for the terminal. It uses a colored output to distinguish different categories of bytes (NULL bytes, printable [ASCII](../../files/ASCII.md) characters, [ASCII](../../files/ASCII.md) whitespace characters, other [ASCII](../../files/ASCII.md) characters and non-[ASCII](../../files/ASCII.md)). + +## Usage +Flags: +```shell +-n, --length Read n bytes fom input +-s, --skip Skip n bytes from input +``` \ No newline at end of file diff --git a/technology/applications/cli/huniq.md b/technology/applications/cli/huniq.md new file mode 100644 index 0000000..8b35348 --- /dev/null +++ b/technology/applications/cli/huniq.md @@ -0,0 +1,20 @@ +--- +obj: application +os: linux +repo: https://github.com/koraa/huniq +--- +# Huniq +[Repo](https://github.com/koraa/huniq) +Command line utility to remove duplicates from the given input. Note that huniq does not sort the input, it just removes duplicates. + +## Usage +Flags: +```shell +-c, --count      Output the amount of times a line was encountered + +-d, --delim         Which delimiter between elements to use. [default: "\n"] + +-s, --sort                     Sort output by the number of occurences, in ascending order + +-S, --sort-descending          Order output by the number of occurences, in descending order +``` \ No newline at end of file diff --git a/technology/applications/cli/hyperfine.md b/technology/applications/cli/hyperfine.md new file mode 100644 index 0000000..5c3d8d2 --- /dev/null +++ b/technology/applications/cli/hyperfine.md @@ -0,0 +1,81 @@ +--- +obj: application +repo: https://github.com/sharkdp/hyperfine +--- +# hyperfine +A command-line benchmarking tool. + +## Usage +To run a benchmark, you can simply call hyperfine .... The argument(s) can be any [shell](Shell.md) command. For example: +```shell +hyperfine 'sleep 0.3' +``` + +Hyperfine will automatically determine the number of runs to perform for each command. By default, it will perform at least 10 benchmarking runs and measure for at least 3 seconds. To change this, you can use the -r/--runs option: +```shell +hyperfine --runs 5 'sleep 0.3' +``` + +If you want to compare the runtimes of different programs, you can pass multiple commands: +```shell +hyperfine 'hexdump file' 'xxd file' +``` + +### Warmup runs and preparation commands +For programs that perform a lot of disk I/O, the benchmarking results can be heavily influenced by disk caches and whether they are cold or warm. + +If you want to run the benchmark on a warm cache, you can use the -w/--warmup option to perform a certain number of program executions before the actual benchmark: +```shell +hyperfine --warmup 3 'grep -R TODO *' +``` + +Conversely, if you want to run the benchmark for a cold cache, you can use the -p/--prepare option to run a special command before each timing run. For example, to clear harddisk caches on [Linux](../../linux/Linux.md), you can run +```shell +sync; echo 3 | sudo tee /proc/sys/vm/drop_caches +``` + +To use this specific command with hyperfine, call sudo -v to temporarily gain sudo permissions and then call: +```shell +hyperfine --prepare 'sync; echo 3 | sudo tee /proc/sys/vm/drop_caches' 'grep -R TODO *' +``` + +### Parameterized benchmarks +If you want to run a series of benchmarks where a single parameter is varied (say, the number of threads), you can use the -P/--parameter-scan option and call: +```shell +hyperfine --prepare 'make clean' --parameter-scan num_threads 1 12 'make -j {num_threads}' +``` + +This also works with decimal numbers. The -D/--parameter-step-size option can be used to control the step size: +```shell +hyperfine --parameter-scan delay 0.3 0.7 -D 0.2 'sleep {delay}' +``` + +This runs sleep 0.3, sleep 0.5 and sleep 0.7. + +For non-numeric parameters, you can also supply a list of values with the -L/--parameter-list option: +```shell +hyperfine -L compiler gcc,clang '{compiler} -O2 main.cpp' +``` + +## Options +| Option | Description | +| ---------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| `-w, --warmup ` | Perform NUM warmup runs before the actual benchmark. This can be used to fill (disk) caches for I/O-heavy programs. | +| `-m, --min-runs ` | Perform at least NUM runs for each command (default: 10). | +| `-M, --max-runs ` | Perform at most NUM runs for each command. By default, there is no limit. | +| `-r, --runs ` | Perform exactly NUM runs for each command. If this option is not specified, hyperfine automatically determines the number of runs. | +| `-s, --setup ` | Execute CMD before each set of timing runs. This is useful for compiling your software with the provided parameters, or to do any other work that should happen once before a series of benchmark runs, not every time as would happen with the --prepare option. | +| `-p, --prepare ` | Execute CMD before each timing run. This is useful for clearing disk caches, for example. The --prepare option can be specified once for all commands or multiple times, once for each command. In the latter case, each preparation command will be run prior to the corresponding benchmark command. | +| `-c, --cleanup ` | Execute CMD after the completion of all benchmarking runs for each individual command to be benchmarked. This is useful if the commands to be benchmarked produce artifacts that need to be cleaned up. | +| `-P, --parameter-scan ` | Perform benchmark runs for each value in the range MIN..MAX. Replaces the string '{VAR}' in each command by the current parameter value. | +| `-D, --parameter-step-size ` | This argument requires --parameter-scan to be specified as well. Traverse the range MIN..MAX in steps of DELTA. | +| `-L, --parameter-list ` | Perform benchmark runs for each value in the comma-separated list VALUES. Replaces the string '{VAR}' in each command by the current parameter value. | +| `-i, --ignore-failure` | Ignore non-zero exit codes of the benchmarked programs. | +| `--export-asciidoc ` | Export the timing summary statistics as an AsciiDoc table to the given FILE. | +| `--export-csv ` | Export the timing summary statistics as [CSV](../../files/CSV.md) to the given FILE. If you need the timing results for each individual run, use the [JSON](../../files/JSON.md) export format. The output time unit is always seconds. | +| `--export-json ` | Export the timing summary statistics and timings of individual runs as [JSON](../../files/JSON.md) to the given FILE. The output time unit is always seconds | +| `--export-markdown ` | Export the timing summary statistics as a [Markdown](../../files/Markdown.md) table to the given FILE. | +| `--show-output` | Print the stdout and stderr of the benchmark instead of suppressing it. This will increase the time it takes for benchmarks to run, so it should only be used for debugging purposes or when trying to benchmark output speed. | +| `-n, --command-name ` | Give a meaningful name to a command. This can be specified multiple times if several commands are benchmarked. | +| `--output ` | Control where the output of the benchmark is redirected. Note that some programs like 'grep' detect when standard output is /dev/null and apply certain optimizations. To avoid that, consider using '--output=pipe'.
\ can be:

- null: Redirect output to /dev/null (the default).
- pipe: Feed the output through a pipe before discarding it.
- inherit: Don't redirect the output at all (same as '--show-output').
- \: Write the output to the given file. | +| `--input ` | Control where the input of the benchmark comes from.

\ can be:
- null: Read from /dev/null (the default).
- \: Read the input from the given file. | diff --git a/technology/applications/cli/intermodal.md b/technology/applications/cli/intermodal.md new file mode 100644 index 0000000..42ba38b --- /dev/null +++ b/technology/applications/cli/intermodal.md @@ -0,0 +1,38 @@ +--- +obj: application +os: linux +repo: https://github.com/casey/intermodal +--- +# Intermodal +[Repo](https://github.com/casey/intermodal) +Intermodal is a user-friendly and featureful command-line [BitTorrent](../../tools/BitTorrent.md) metainfo utility. The binary is called `imdl` and runs on [Linux](../../linux/Linux.md), [Windows](../../windows/Windows.md), and [macOS](../../macos/macOS.md). + +## Usage +### Create torrent file: +```shell +imdl torrent create file +``` + +Flags: +```shell +-N, --name Set name of torrent +-i, --input Torrent Files +-c, --comment Torrent Comment +-a, --announce Torrent Tracker +``` + +### Show torrent information +```shell +imdl torrent show +``` + +### Verify torrent +```shell +imdl torrent verify +imdl torrent verify --input torr.torrent --content file +``` + +### Generate magnet link +```shell +imdl torrent link +``` \ No newline at end of file diff --git a/technology/applications/cli/jless.md b/technology/applications/cli/jless.md new file mode 100644 index 0000000..bfb591b --- /dev/null +++ b/technology/applications/cli/jless.md @@ -0,0 +1,6 @@ +--- +obj: application +os: linux +--- +# Jless +[`jless`](https://jless.io/) is a command-line [JSON](../../files/JSON.md) viewer. Use it as a replacement for whatever combination of `less`, `jq`, `cat` and your editor you currently use for viewing [JSON](../../files/JSON.md) files. It is written in [Rust](../../programming/languages/Rust.md) and can be installed as a single standalone binary. \ No newline at end of file diff --git a/technology/applications/cli/joshuto.md b/technology/applications/cli/joshuto.md new file mode 100644 index 0000000..e394f4d --- /dev/null +++ b/technology/applications/cli/joshuto.md @@ -0,0 +1,8 @@ +--- +obj: application +os: linux +repo: https://github.com/kamiyaa/joshuto +--- +# Joshuto +[Repo](https://github.com/kamiyaa/joshuto) +Joshuto is a [ranger](https://github.com/ranger/ranger)-like terminal file manager written in [Rust](../../programming/languages/Rust.md). \ No newline at end of file diff --git a/technology/applications/cli/jq.md b/technology/applications/cli/jq.md new file mode 100644 index 0000000..71fb320 --- /dev/null +++ b/technology/applications/cli/jq.md @@ -0,0 +1,157 @@ +--- +obj: application +website: https://jqlang.github.io/jq/ +repo: https://github.com/jqlang/jq +--- +# jq +jq is a lightweight and flexible command-line [JSON](../../files/JSON.md) processor akin to sed,awk,grep, and friends for [JSON](../../files/JSON.md) data. It's written in portable C and has zero runtime dependencies, allowing you to easily slice, filter, map, and transform structured data. + +## Usage +```shell +cat data.json | jq [FILTER] +``` + +## Filters +### Identity +The absolute simplest filter is `.` . This filter takes its input and produces the same value as output. That is, this is the identity operator. + +### Object Identifier +The simplest _useful_ filter has the form `.foo`. When given a [JSON](../../files/JSON.md) object (aka dictionary or hash) as input, `.foo` produces the value at the key "foo" if the key is present, or null otherwise. + +The `.foo` syntax only works for simple, identifier-like keys, that is, keys that are all made of alphanumeric characters and underscore, and which do not start with a digit. + +If the key contains special characters or starts with a digit, you need to surround it with double quotes like this: `."foo$"`, or else `.["foo$"]`. + +### Array Index +When the index value is an integer, `.[]` can index arrays. Arrays are zero-based, so `.[2]` returns the third element. + +Negative indices are allowed, with -1 referring to the last element, -2 referring to the next to last element, and so on. + +### Array/String Slice +The `.[:]` syntax can be used to return a subarray of an array or substring of a string. The array returned by `.[10:15]` will be of length 5, containing the elements from index 10 (inclusive) to index 15 (exclusive). Either index may be negative (in which case it counts backwards from the end of the array), or omitted (in which case it refers to the start or end of the array). Indices are zero-based. + +### Array/Object Value Iterator +If you use the `.[index]` syntax, but omit the index entirely, it will return _all_ of the elements of an array. Running `.[]` with the input `[1,2,3]` will produce the numbers as three separate results, rather than as a single array. A filter of the form `.foo[]` is equivalent to `.foo | .[]`. + +You can also use this on an object, and it will return all the values of the object. + +Note that the iterator operator is a generator of values. + +### Comma +If two filters are separated by a comma, then the same input will be fed into both and the two filters' output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter `.foo, .bar`, produces both the "foo" fields and "bar" fields as separate outputs. + +The `,` operator is one way to contruct generators. + +### Pipe +The `|` operator combines two filters by feeding the output(s) of the one on the left into the input of the one on the right. It's similar to the Unix [shell](Shell.md)'s pipe, if you're used to that. + +If the one on the left produces multiple results, the one on the right will be run for each of those results. So, the expression `.[] | .foo` retrieves the "foo" field of each element of the input array. This is a cartesian product, which can be surprising. + +Note that `.a.b.c` is the same as `.a | .b | .c`. + +Note too that `.` is the input value at the particular stage in a "pipeline", specifically: where the `.` expression appears. Thus `.a | . | .b` is the same as `.a.b`, as the `.` in the middle refers to whatever value `.a` produced. + +### Array Construction: `[]` +As in [JSON](../../files/JSON.md), `[]` is used to construct arrays, as in `[1,2,3]`. The elements of the arrays can be any jq expression, including a pipeline. All of the results produced by all of the expressions are collected into one big array. You can use it to construct an array out of a known quantity of values (as in `[.foo, .bar, .baz]`) or to "collect" all the results of a filter into an array (as in `[.items[].name]`) + +Once you understand the "," operator, you can look at jq's array syntax in a different light: the expression `[1,2,3]` is not using a built-in syntax for comma-separated arrays, but is instead applying the `[]` operator (collect results) to the expression 1,2,3 (which produces three different results). + +If you have a filter `X` that produces four results, then the expression `[X]` will produce a single result, an array of four elements. + +### Object Construction: `{}` +Like [JSON](../../files/JSON.md), `{}` is for constructing objects (aka dictionaries or hashes), as in: `{"a": 42, "b": 17}`. + +If the keys are "identifier-like", then the quotes can be left off, as in `{a:42, b:17}`. Variable references as key expressions use the value of the variable as the key. Key expressions other than constant literals, identifiers, or variable references, need to be parenthesized, e.g., `{("a"+"b"):59}`. + +The value can be any expression (although you may need to wrap it in parentheses if, for example, it contains colons), which gets applied to the {} expression's input (remember, all filters have an input and an output). +``` +{foo: .bar} +``` + +will produce the [JSON](../../files/JSON.md) object `{"foo": 42}` if given the [JSON](../../files/JSON.md) object `{"bar":42, "baz":43}` as its input. You can use this to select particular fields of an object: if the input is an object with "user", "title", "id", and "content" fields and you just want "user" and "title", you can write +``` +{user: .user, title: .title} +``` + +Because that is so common, there's a shortcut syntax for it: `{user, title}`. + +If one of the expressions produces multiple results, multiple dictionaries will be produced. If the input's +``` +{"user":"stedolan","titles":["JQ Primer", "More JQ"]} +``` + +then the expression +``` +{user, title: .titles[]} +``` + +will produce two outputs: +``` +{"user":"stedolan", "title": "JQ Primer"} +{"user":"stedolan", "title": "More JQ"} +``` + +Putting parentheses around the key means it will be evaluated as an expression. With the same input as above, +``` +{(.user): .titles} +``` + +produces +``` +{"stedolan": ["JQ Primer", "More JQ"]} +``` + +## Functions +### `has(key)` +The builtin function `has` returns whether the input object has the given key, or the input array has an element at the given index. + +### `map(f)`, `map_values(f)` +For any filter `f`, `map(f)` and `map_values(f)` apply `f` to each of the values in the input array or object, that is, to the values of `.[]`. + +In the absence of errors, `map(f)` always outputs an array whereas `map_values(f)` outputs an array if given an array, or an object if given an object. + +When the input to `map_values(f)` is an object, the output object has the same keys as the input object except for those keys whose values when piped to `f` produce no values at all. + +`map(f)` is equivalent to `[.[] | f]` and `map_values(f)` is equivalent to `.[] |= f`. + +### `del(path)` +The builtin function `del` removes a key and its corresponding value from an object. + +### `reverse` +This function reverses an array. + +### `contains(element)` +The filter `contains(b)` will produce true if b is completely contained within the input. A string B is contained in a string A if B is a substring of A. An array B is contained in an array A if all elements in B are contained in any element in A. An object B is contained in object A if all of the values in B are contained in the value in A with the same key. All other types are assumed to be contained in each other if they are equal. + +### `startswith(str)` +Outputs `true` if . starts with the given string argument. + +### `endswith(str)`  +Outputs `true` if . ends with the given string argument. + +### `split(str)` +Splits an input string on the separator argument. + +### `join(str)` +Joins the array of elements given as input, using the argument as separator. It is the inverse of `split`: that is, running `split("foo") | join("foo")` over any input string returns said input string. + +## Conditionals +### if-then-else-end +`if A then B else C end` will act the same as `B` if `A` produces a value other than false or null, but act the same as `C` otherwise. + +`if A then B end` is the same as `if A then B else . end`. That is, the `else` branch is optional, and if absent is the same as `.`. This also applies to `elif` with absent ending `else` branch. + +Checking for false or null is a simpler notion of "truthiness" than is found in JavaScript or [Python](../../programming/languages/Python.md), but it means that you'll sometimes have to be more explicit about the condition you want. You can't test whether, e.g. a string is empty using `if .name then A else B end`; you'll need something like `if .name == "" then A else B end` instead. + +If the condition `A` produces multiple results, then `B` is evaluated once for each result that is not false or null, and `C` is evaluated once for each false or null. + +More cases can be added to an if using `elif A then B` syntax. + +Example: `jq 'if . == 0 then "zero" elif . == 1 then "one" else "many" end'` + +### Alternative Operator `//` +The `//` operator produces all the values of its left-hand side that are neither `false` nor `null`, or, if the left-hand side produces no values other than `false` or `null`, then `//` produces all the values of its right-hand side. + +A filter of the form `a // b` produces all the results of `a` that are not `false` or `null`. If `a` produces no results, or no results other than `false` or `null`, then `a // b` produces the results of `b`. + +This is useful for providing defaults: `.foo // 1` will evaluate to `1` if there's no `.foo` element in the input. \ No newline at end of file diff --git a/technology/applications/cli/just.md b/technology/applications/cli/just.md new file mode 100644 index 0000000..158b095 --- /dev/null +++ b/technology/applications/cli/just.md @@ -0,0 +1,1141 @@ +--- +obj: application +website: https://just.systems/ +repo: https://github.com/casey/just +--- +# just +`just` is a handy way to save and run project-specific commands. +Commands, called recipes, are stored in a file called `justfile` with syntax inspired by `make`: + +![Screenshot][Screenshot] + +You can then run them with `just RECIPE`: +```shell +$ just test-all +cc *.c -o main +./test --all +Yay, all your tests passed! +``` + +## Usage +Initialize new justfile: +```shell +just --init +``` + +Print what just would do without doing it: +```shell +just --dry-run +``` + +List available recipes and their arguments: +```shell +just -l +just --list +``` + +List names of variables: +```shell +just --variables +``` + +### Options +| Option | Description | +| --------------------------------------------- | ---------------------------------------------------------------------------- | +| `--dotenv-filename ` | Search for environment file named \ instead of `.env` | +| `--dotenv-path ` | Load environment file at \ instead of searching for one | +| `-f, --justfile ` | Use \ as justfile | +| `--list-heading ` | Print \ before list | +| `--set ` | Override \ with \ | +| `-d, --working-directory ` | Use \ as working directory. `--justfile` must also be set | + +## Quick Start +Create a file named `justfile` in the root of your project with the following contents: +``` +recipe-name: + echo 'This is a recipe!' + +# this is a comment +another-recipe: + @echo 'This is another recipe.' +``` + +When you invoke `just` it looks for file `justfile` in the current directory and upwards, so you can invoke it from any subdirectory of your project. + +The search for a `justfile` is case insensitive, so any case, like `Justfile`, `JUSTFILE`, or `JuStFiLe`, will work. `just` will also look for files with the name `.justfile`, in case you’d like to hide a `justfile`. + +Running `just` with no arguments runs the first recipe in the `justfile`: +```shell +$ just +echo 'This is a recipe!' +This is a recipe! +``` + +One or more arguments specify the recipe(s) to run: +```shell +$ just another-recipe +This is another recipe. +``` + +`just` prints each command to standard error before running it, which is why `echo 'This is a recipe!'` was printed. This is suppressed for lines starting with `@`, which is why `echo 'This is another recipe.'` was not printed. + +Recipes stop running if a command fails. Here `cargo publish` will only run if `cargo test` succeeds: +``` +publish: + cargo test # tests passed, time to publish! + cargo publish +``` + +Recipes can depend on other recipes. Here the `test` recipe depends on the `build` recipe, so `build` will run before `test`: + +``` +build: + cc main.c foo.c bar.c -o main + +test: build + ./test + +sloc: + @echo "`wc -l *.c` lines of code" +``` + +```shell +$ just test +cc main.c foo.c bar.c -o main +./test +testing… all tests passed!` +``` + +Recipes without dependencies will run in the order they’re given on the command line: +```shell +$ just build sloc +cc main.c foo.c bar.c -o main +1337 lines of code +``` + +## Features +### Default Recipe +When `just` is invoked without a recipe, it runs the first recipe in the `justfile`. This recipe might be the most frequently run command in the project, like running the tests: +``` +test: + cargo test +``` + +You can also use dependencies to run multiple recipes by default: +``` +default: lint build test + +build: + echo Building + +test: + echo Testing + +lint: + echo Linting +``` + +If no recipe makes sense as the default recipe, you can add a recipe to the beginning of your `justfile` that lists the available recipes: +``` +default: + @just --list +``` + +### Listing Available Recipes +Recipes can be listed in alphabetical order with `just --list`: +```shell +$ just --list +Available recipes: + build + test + deploy + lint +``` + +`just --summary` is more concise: +```shell +$ just --summary +build test deploy lint +``` + +If you'd like `just` to default to listing the recipes in the `justfile`, you can use this as your default recipe: +```just +default: + @just --list +``` + +> Note that you may need to add `--justfile {{justfile()}}` to the line above above. Without it, if you executed `just -f /some/distant/justfile -d .` or `just -f ./non-standard-justfile`, the plain `just --list` inside the recipe would not necessarily use the file you provided. It would try to find a justfile in your current path, maybe even resulting in a `No justfile found` error. + +The heading text can be customized with `--list-heading`: +```shell +$ just --list --list-heading $'Cool stuff…\n' +Cool stuff… + test + build +``` + +### Aliases +Aliases allow recipes to be invoked with alternative names: +```just +alias b := build + +build: + echo 'Building!' +``` + +```shell +$ just b +build +echo 'Building!' +Building! +``` + +### Settings +Settings control interpretation and execution. Each setting may be specified at most once, anywhere in the `justfile`. + +For example: +```just +set shell := ["zsh", "-cu"] + +foo: + # this line will be run as `zsh -cu 'ls **/*.txt'` + ls **/*.txt +``` + +#### Table of Settings +| Name | Value | Default | Description | +| ------------------------- | ------------------ | ------- | --------------------------------------------------------------------------------------------- | +| `allow-duplicate-recipes` | boolean | `false` | Allow recipes appearing later in a `justfile` to override earlier recipes with the same name. | +| `dotenv-filename` | string | - | Load a `.env` file with a custom name, if present. | +| `dotenv-load` | boolean | `false` | Load a `.env` file, if present. | +| `dotenv-path` | string | - | Load a `.env` file from a custom path, if present. Overrides `dotenv-filename`. | +| `export` | boolean | `false` | Export all variables as [environment variables](../../linux/Environment%20Variables.md). | +| `fallback` | boolean | `false` | Search `justfile` in parent directory if the first recipe on the command line is not found. | +| `ignore-comments` | boolean | `false` | Ignore recipe lines beginning with `#`. | +| `positional-arguments` | boolean | `false` | Pass positional arguments. | +| `shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. | +| `tempdir` | string | - | Create temporary directories in `tempdir` instead of the system default temporary directory. | +| `windows-powershell` | boolean | `false` | Use PowerShell on [Windows](../../windows/Windows.md) as default [shell](Shell.md). (Deprecated. Use `windows-shell` instead. | +| `windows-shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. | + +#### Dotenv Settings +If `dotenv-load`, `dotenv-filename` or `dotenv-path` is set, `just` will load [environment variables](../../linux/Environment%20Variables.md) from a file. + +If `dotenv-path` is set, `just` will look for a file at the given path. + +Otherwise, `just` looks for a file named `.env` by default, unless `dotenv-filename` set, in which case the value of `dotenv-filename` is used. This file can be located in the same directory as your `justfile` or in a parent directory. + +The loaded variables are [environment variables](../../linux/Environment%20Variables.md), not `just` variables, and so must be accessed using `$VARIABLE_NAME` in recipes and backticks. + +For example, if your `.env` file contains: +```shell +# a comment, will be ignored +DATABASE_ADDRESS=localhost:6379 +SERVER_PORT=1337 +``` + +And your `justfile` contains: +```just +set dotenv-load + +serve: + @echo "Starting server with database $DATABASE_ADDRESS on port $SERVER_PORT…" + ./server --database $DATABASE_ADDRESS --port $SERVER_PORT +``` + +`just serve` will output: +```shell +$ just serve +Starting server with database localhost:6379 on port 1337… +./server --database $DATABASE_ADDRESS --port $SERVER_PORT +``` + +#### Positional Arguments +If `positional-arguments` is `true`, recipe arguments will be passed as positional arguments to commands. For linewise recipes, argument `$0` will be the name of the recipe. + +For example, running this recipe: +```just +set positional-arguments + +@foo bar: + echo $0 + echo $1 +``` + +Will produce the following output: +```shell +$ just foo hello +foo +hello +``` + +When using an `sh`-compatible [shell](Shell.md), such as [`bash`](bash.md) or [`zsh`](zsh.md), `$@` expands to the positional arguments given to the recipe, starting from one. When used within double quotes as `"$@"`, arguments including whitespace will be passed on as if they were double-quoted. That is, `"$@"` is equivalent to `"$1" "$2"`… When there are no positional parameters, `"$@"` and `$@` expand to nothing (i.e., they are removed). + +This example recipe will print arguments one by one on separate lines: +```just +set positional-arguments + +@test *args='': + bash -c 'while (( "$#" )); do echo - $1; shift; done' -- "$@" +``` + +Running it with _two_ arguments: +```shell +$ just test foo "bar baz" +- foo +- bar baz +``` + +#### Shell +The `shell` setting controls the command used to invoke recipe lines and backticks. Shebang recipes are unaffected. +```just +# use python3 to execute recipe lines and backticks +set shell := ["python3", "-c"] + +# use print to capture result of evaluation +foos := `print("foo" * 4)` + +foo: + print("Snake snake snake snake.") + print("{{foos}}") +``` + +`just` passes the command to be executed as an argument. Many shells will need an additional flag, often `-c`, to make them evaluate the first argument. + +### Documentation Comments +Comments immediately preceding a recipe will appear in `just --list`: +```just +# build stuff +build: + ./bin/build + +# test stuff +test: + ./bin/test +``` + +```shell +$ just --list +Available recipes: + build # build stuff + test # test stuff +``` + +### Variables and Substitution +Variables, strings, concatenation, path joining, and substitution using `{{…}}` are supported: +```just +tmpdir := `mktemp -d` +version := "0.2.7" +tardir := tmpdir / "awesomesauce-" + version +tarball := tardir + ".tar.gz" + +publish: + rm -f {{tarball}} + mkdir {{tardir}} + cp README.md *.c {{tardir}} + tar zcvf {{tarball}} {{tardir}} + scp {{tarball}} me@server.com:release/ + rm -rf {{tarball}} {{tardir}} +``` + +#### Joining Paths +The `/` operator can be used to join two strings with a slash: +```just +foo := "a" / "b" +``` + +``` +$ just --evaluate foo +a/b +``` + +Note that a `/` is added even if one is already present: +```just +foo := "a/" +bar := foo / "b" +``` + +``` +$ just --evaluate bar +a//b +``` + +Absolute paths can also be constructed: +```just +foo := / "b" +``` + +``` +$ just --evaluate foo +/b +``` + +#### Escaping `{{` +To write a recipe containing `{{`, use `{{{{`: +```just +braces: + echo 'I {{{{LOVE}} curly braces!' +``` + +(An unmatched `}}` is ignored, so it doesn't need to be escaped.) + +Another option is to put all the text you'd like to escape inside of an interpolation: +```just +braces: + echo '{{'I {{LOVE}} curly braces!'}}' +``` + +Yet another option is to use `{{ "{{" }}`: +```just +braces: + echo 'I {{ "{{" }}LOVE}} curly braces!' +``` + +### Ignoring Errors +Normally, if a command returns a non-zero exit status, execution will stop. To continue execution after a command, even if it fails, prefix the command with `-`: +```just +foo: + -cat foo + echo 'Done!' +``` + +```shell +$ just foo +cat foo +cat: foo: No such file or directory +echo 'Done!' +Done! +``` + +### Functions +`just` provides a few built-in functions that might be useful when writing recipes. + +#### System Information +- `arch()` — Instruction set architecture. Possible values are: `"aarch64"`, `"arm"`, `"asmjs"`, `"hexagon"`, `"mips"`, `"msp430"`, `"powerpc"`, `"powerpc64"`, `"s390x"`, `"sparc"`, `"wasm32"`, `"x86"`, `"x86_64"`, and `"xcore"`. +- `num_cpus()` - Number of logical CPUs. +- `os()` — Operating system. Possible values are: `"android"`, `"bitrig"`, `"dragonfly"`, `"emscripten"`, `"freebsd"`, `"haiku"`, `"ios"`, `"linux"`, `"macos"`, `"netbsd"`, `"openbsd"`, `"solaris"`, and `"windows"`. +- `os_family()` — Operating system family; possible values are: `"unix"` and `"windows"`. + +For example: +```just +system-info: + @echo "This is an {{arch()}} machine". +``` + +```shell +$ just system-info +This is an x86_64 machine +``` + +#### [Environment Variables](../../linux/Environment%20Variables.md) +- `env_var(key)` — Retrieves the environment variable with name `key`, aborting if it is not present. + +```just +home_dir := env_var('HOME') + +test: + echo "{{home_dir}}" +``` + +```shell +$ just +/home/user1 +``` + +- `env_var_or_default(key, default)` — Retrieves the environment variable with name `key`, returning `default` if it is not present. +- `env(key)` — Alias for `env_var(key)`. +- `env(key, default)` — Alias for `env_var_or_default(key, default)`. + +#### Invocation Directory +- `invocation_directory()` - Retrieves the absolute path to the current directory when `just` was invoked. + +For example, to call `rustfmt` on files just under the "current directory" (from the user/invoker's perspective), use the following rule: +```just +rustfmt: + find {{invocation_directory()}} -name \*.rs -exec rustfmt {} \; +``` + +Alternatively, if your command needs to be run from the current directory, you could use (e.g.): +```just +build: + cd {{invocation_directory()}}; ./some_script_that_needs_to_be_run_from_here +``` + +#### Justfile and Justfile Directory +- `justfile()` - Retrieves the path of the current `justfile`. +- `justfile_directory()` - Retrieves the path of the parent directory of the current `justfile`. + +For example, to run a command relative to the location of the current `justfile`: +```just +script: + ./{{justfile_directory()}}/scripts/some_script +``` + +#### Just Executable +- `just_executable()` - Absolute path to the `just` executable. + +For example: +```just +executable: + @echo The executable is at: {{just_executable()}} +``` + +```shell +$ just +The executable is at: /bin/just +``` + +#### String Manipulation +- `quote(s)` - Replace all single quotes with `'\''` and prepend and append single quotes to `s`. This is sufficient to escape special characters for many shells, including most Bourne [shell](Shell.md) descendants. +- `replace(s, from, to)` - Replace all occurrences of `from` in `s` to `to`. +- `replace_regex(s, regex, replacement)` - Replace all occurrences of `regex` in `s` to `replacement`. Regular expressions are provided by the [Rust `regex` crate](https://docs.rs/regex/latest/regex/). See the [syntax documentation](https://docs.rs/regex/latest/regex/#syntax) for usage examples. Capture groups are supported. The `replacement` string uses [Replacement string syntax](https://docs.rs/regex/latest/regex/struct.Regex.html#replacement-string-syntax). +- `trim(s)` - Remove leading and trailing whitespace from `s`. +- `trim_end(s)` - Remove trailing whitespace from `s`. +- `trim_end_match(s, pat)` - Remove suffix of `s` matching `pat`. +- `trim_end_matches(s, pat)` - Repeatedly remove suffixes of `s` matching `pat`. +- `trim_start(s)` - Remove leading whitespace from `s`. +- `trim_start_match(s, pat)` - Remove prefix of `s` matching `pat`. +- `trim_start_matches(s, pat)` - Repeatedly remove prefixes of `s` matching `pat`. + +#### Case Conversion +- `capitalize(s)` - Convert first character of `s` to uppercase and the rest to lowercase. +- `kebabcase(s)` - Convert `s` to `kebab-case`. +- `lowercamelcase(s)` - Convert `s` to `lowerCamelCase`. +- `lowercase(s)` - Convert `s` to lowercase. +- `shoutykebabcase(s)` - Convert `s` to `SHOUTY-KEBAB-CASE`. +- `shoutysnakecase(s)` - Convert `s` to `SHOUTY_SNAKE_CASE`. +- `snakecase(s)` - Convert `s` to `snake_case`. +- `titlecase(s)` - Convert `s` to `Title Case`. +- `uppercamelcase(s)` - Convert `s` to `UpperCamelCase`. +- `uppercase(s)` - Convert `s` to uppercase. + +#### Path Manipulation +##### Fallible +- `absolute_path(path)` - Absolute path to relative `path` in the working directory. `absolute_path("./bar.txt")` in directory `/foo` is `/foo/bar.txt`. +- `extension(path)` - Extension of `path`. `extension("/foo/bar.txt")` is `txt`. +- `file_name(path)` - File name of `path` with any leading directory components removed. `file_name("/foo/bar.txt")` is `bar.txt`. +- `file_stem(path)` - File name of `path` without extension. `file_stem("/foo/bar.txt")` is `bar`. +- `parent_directory(path)` - Parent directory of `path`. `parent_directory("/foo/bar.txt")` is `/foo`. +- `without_extension(path)` - `path` without extension. `without_extension("/foo/bar.txt")` is `/foo/bar`. + +These functions can fail, for example if a path does not have an extension, which will halt execution. + +##### Infallible +- `clean(path)` - Simplify `path` by removing extra path separators, intermediate `.` components, and `..` where possible. `clean("foo//bar")` is `foo/bar`, `clean("foo/..")` is `.`, `clean("foo/./bar")` is `foo/bar`. +- `join(a, b…)` - _This function uses `/` on Unix and `\` on [Windows](../../windows/Windows.md), which can be lead to unwanted behavior. The `/` operator, e.g., `a / b`, which always uses `/`, should be considered as a replacement unless `\`s are specifically desired on [Windows](../../windows/Windows.md)._ Join path `a` with path `b`. `join("foo/bar", "baz")` is `foo/bar/baz`. Accepts two or more arguments. + +#### Filesystem Access +- `path_exists(path)` - Returns `true` if the path points at an existing entity and `false` otherwise. Traverses symbolic links, and returns `false` if the path is inaccessible or points to a broken symlink. + +#### Error Reporting +- `error(message)` - Abort execution and report error `message` to user. + +#### UUID and Hash Generation +- `sha256(string)` - Return the [SHA](../../Cryptography/SHA.md)-256 hash of `string` as a hexadecimal string. +- `sha256_file(path)` - Return the [SHA](../../Cryptography/SHA.md)-256 hash of the file at `path` as a hexadecimal string. +- `uuid()` - Return a randomly generated UUID. + +### Recipe Attributes +Recipes may be annotated with attributes that change their behavior. + +| Name | Description | +| ------------------- | ----------------------------------------------- | +| `[no-cd]` | Don't change directory before executing recipe. | +| `[no-exit-message]` | Don't print an error message if recipe fails. | +| `[linux]` | Enable recipe on [Linux](../../linux/Linux.md). | +| `[macos]` | Enable recipe on [MacOS](../../macos/macOS.md). | +| `[unix]` | Enable recipe on Unixes. (Includes [MacOS](../../macos/macOS.md)). | +| `[windows]` | Enable recipe on [Windows](../../windows/Windows.md). | +| `[private]`1 | See Private Recipes. | + +A recipe can have multiple attributes, either on multiple lines: +```just +[no-cd] +[private] +foo: + echo "foo" +``` + +Or separated by commas on a single line: +```just +[no-cd, private] +foo: + echo "foo" +``` + +#### Enabling and Disabling Recipes +The `[linux]`, `[macos]`, `[unix]`, and `[windows]` attributes are configuration attributes. By default, recipes are always enabled. A recipe with one or more configuration attributes will only be enabled when one or more of those configurations is active. + +This can be used to write `justfile`s that behave differently depending on which operating system they run on. The `run` recipe in this `justfile` will compile and run `main.c`, using a different C compiler and using the correct output binary name for that compiler depending on the operating system: + +```just +[unix] +run: + cc main.c + ./a.out + +[windows] +run: + cl main.c + main.exe +``` + +#### Disabling Changing Directory +`just` normally executes recipes with the current directory set to the directory that contains the `justfile`. This can be disabled using the `[no-cd]` attribute. This can be used to create recipes which use paths relative to the invocation directory, or which operate on the current directory. + +For example, this `commit` recipe: +```just +[no-cd] +commit file: + git add {{file}} + git commit +``` + +Can be used with paths that are relative to the current directory, because `[no-cd]` prevents `just` from changing the current directory when executing `commit`. + +### Command Evaluation Using Backticks +Backticks can be used to store the result of commands: +```just +localhost := `dumpinterfaces | cut -d: -f2 | sed 's/\/.*//' | sed 's/ //g'` + +serve: + ./serve {{localhost}} 8080 +``` + +Indented backticks, delimited by three backticks, are de-indented in the same manner as indented strings: +
just
+# This backtick evaluates the command `echo foo\necho bar\n`, which produces the value `foo\nbar\n`.
+stuff := ```
+    echo foo
+    echo bar
+  ```
+
+ +### Conditional Expressions +`if`/`else` expressions evaluate different branches depending on if two expressions evaluate to the same value: +```just +foo := if "2" == "2" { "Good!" } else { "1984" } + +bar: + @echo "{{foo}}" +``` + +```shell +$ just bar +Good! +``` + +It is also possible to test for inequality: +```just +foo := if "hello" != "goodbye" { "xyz" } else { "abc" } + +bar: + @echo {{foo}} +``` + +```shell +$ just bar +xyz +``` + +And match against regular expressions: +```just +foo := if "hello" =~ 'hel+o' { "match" } else { "mismatch" } + +bar: + @echo {{foo}} +``` + +```shell +$ just bar +match +``` + +Regular expressions are provided by the [regex crate](https://github.com/rust-lang/regex), whose syntax is documented on [docs.rs](https://docs.rs/regex/1.5.4/regex/#syntax). Since regular expressions commonly use backslash escape sequences, consider using single-quoted string literals, which will pass slashes to the regex parser unmolested. + +Conditional expressions short-circuit, which means they only evaluate one of their branches. This can be used to make sure that backtick expressions don't run when they shouldn't. +```just +foo := if env_var("RELEASE") == "true" { `get-something-from-release-database` } else { "dummy-value" } +``` + +Conditionals can be used inside of recipes: +```just +bar foo: + echo {{ if foo == "bar" { "hello" } else { "goodbye" } }} +``` + +> Note the space after the final `}`! Without the space, the interpolation will be prematurely closed. + +Multiple conditionals can be chained: +```just +foo := if "hello" == "goodbye" { + "xyz" +} else if "a" == "a" { + "abc" +} else { + "123" +} + +bar: + @echo {{foo}} +``` + +```shell +$ just bar +abc +``` + +### Stopping execution with error +Execution can be halted with the `error` function. For example: +```just +foo := if "hello" == "goodbye" { + "xyz" +} else if "a" == "b" { + "abc" +} else { + error("123") +} +``` + +Which produce the following error when run: +``` +error: Call to function `error` failed: 123 + | +16 | error("123") +``` + +### Setting Variables from the Command Line +Variables can be overridden from the command line. +```just +os := "linux" + +test: build + ./test --test {{os}} + +build: + ./build {{os}} +``` + +```shell +$ just +./build linux +./test --test linux +``` + +Any number of arguments of the form `NAME=VALUE` can be passed before recipes: +```shell +$ just os=plan9 +./build plan9 +./test --test plan9 +``` + +Or you can use the `--set` flag: +```shell +$ just --set os bsd +./build bsd +./test --test bsd +``` + +### Getting and Setting [Environment Variables](../../linux/Environment%20Variables.md) +#### Exporting `just` Variables +Assignments prefixed with the `export` keyword will be exported to recipes as [environment variables](../../linux/Environment%20Variables.md): +```just +export RUST_BACKTRACE := "1" + +test: + # will print a stack trace if it crashes + cargo test +``` + +Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md): +```just +test $RUST_BACKTRACE="1": + # will print a stack trace if it crashes + cargo test +``` + +Exported variables and parameters are not exported to backticks in the same scope. +```just +export WORLD := "world" +# This backtick will fail with "WORLD: unbound variable" +BAR := `echo hello $WORLD` +``` + +```just +# Running `just a foo` will fail with "A: unbound variable" +a $A $B=`echo $A`: + echo $A $B +``` + +When `export` is set, all `just` variables are exported as [environment variables](../../linux/Environment%20Variables.md). + +#### Getting [Environment Variables](../../linux/Environment%20Variables.md) from the environment +[Environment variables](../../linux/Environment%20Variables.md) from the environment are passed automatically to the recipes. + +```just +print_home_folder: + echo "HOME is: '${HOME}'" +``` + +```shell +$ just +HOME is '/home/myuser' +``` + +#### Setting `just` Variables from [Environment Variables](../../linux/Environment%20Variables.md) +[Environment variables](../../linux/Environment%20Variables.md) can be propagated to `just` variables using the functions `env_var()` and `env_var_or_default()`. + +### Recipe Parameters +Recipes may have parameters. Here recipe `build` has a parameter called `target`: +```just +build target: + @echo 'Building {{target}}…' + cd {{target}} && make +``` + +To pass arguments on the command line, put them after the recipe name: +```shell +$ just build my-awesome-project +Building my-awesome-project… +cd my-awesome-project && make +``` + +To pass arguments to a dependency, put the dependency in parentheses along with the arguments: +```just +default: (build "main") + +build target: + @echo 'Building {{target}}…' + cd {{target}} && make +``` + +Variables can also be passed as arguments to dependencies: +```just +target := "main" + +_build version: + @echo 'Building {{version}}…' + cd {{version}} && make + +build: (_build target) +``` + +A command's arguments can be passed to dependency by putting the dependency in parentheses along with the arguments: +```just +build target: + @echo "Building {{target}}…" + +push target: (build target) + @echo 'Pushing {{target}}…' +``` + +Parameters may have default values: +```just +default := 'all' + +test target tests=default: + @echo 'Testing {{target}}:{{tests}}…' + ./test --tests {{tests}} {{target}} +``` + +Parameters with default values may be omitted: +```shell +$ just test server +Testing server:all… +./test --tests all server +``` + +Or supplied: +```shell +$ just test server unit +Testing server:unit… +./test --tests unit server +``` + +Default values may be arbitrary expressions, but concatenations or path joins must be parenthesized: +```just +arch := "wasm" + +test triple=(arch + "-unknown-unknown") input=(arch / "input.dat"): + ./test {{triple}} +``` + +The last parameter of a recipe may be variadic, indicated with either a `+` or a `*` before the argument name: +```just +backup +FILES: + scp {{FILES}} me@server.com: +``` + +Variadic parameters prefixed with `+` accept _one or more_ arguments and expand to a string containing those arguments separated by spaces: +```shell +$ just backup FAQ.md GRAMMAR.md +scp FAQ.md GRAMMAR.md me@server.com: +FAQ.md 100% 1831 1.8KB/s 00:00 +GRAMMAR.md 100% 1666 1.6KB/s 00:00 +``` + +Variadic parameters prefixed with `*` accept _zero or more_ arguments and expand to a string containing those arguments separated by spaces, or an empty string if no arguments are present: +```just +commit MESSAGE *FLAGS: + git commit {{FLAGS}} -m "{{MESSAGE}}" +``` + +Variadic parameters can be assigned default values. These are overridden by arguments passed on the command line: +```just +test +FLAGS='-q': + cargo test {{FLAGS}} +``` + +`{{…}}` substitutions may need to be quoted if they contain spaces. For example, if you have the following recipe: +```just +search QUERY: + lynx https://www.google.com/?q={{QUERY}} +``` + +And you type: +```shell +$ just search "cat toupee" +``` + +`just` will run the command `lynx https://www.google.com/?q=cat toupee`, which will get parsed by `sh` as `lynx`, `https://www.google.com/?q=cat`, and `toupee`, and not the intended `lynx` and `https://www.google.com/?q=cat toupee`. + +You can fix this by adding quotes: +```just +search QUERY: + lynx 'https://www.google.com/?q={{QUERY}}' +``` + +Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md): +```just +foo $bar: + echo $bar +``` + +### Running Recipes at the End of a Recipe +Normal dependencies of a recipes always run before a recipe starts. That is to say, the dependee always runs before the depender. These dependencies are called "prior dependencies". + +A recipe can also have subsequent dependencies, which run after the recipe and are introduced with an `&&`: +```just +a: + echo 'A!' + +b: a && c d + echo 'B!' + +c: + echo 'C!' + +d: + echo 'D!' +``` + +…running _b_ prints: +```shell +$ just b +echo 'A!' +A! +echo 'B!' +B! +echo 'C!' +C! +echo 'D!' +D! +``` + +### Running Recipes in the Middle of a Recipe +`just` doesn't support running recipes in the middle of another recipe, but you can call `just` recursively in the middle of a recipe. Given the following `justfile`: +```just +a: + echo 'A!' + +b: a + echo 'B start!' + just c + echo 'B end!' + +c: + echo 'C!' +``` + +…running _b_ prints: +```shell +$ just b +echo 'A!' +A! +echo 'B start!' +B start! +echo 'C!' +C! +echo 'B end!' +B end! +``` + +This has limitations, since recipe `c` is run with an entirely new invocation of `just`: Assignments will be recalculated, dependencies might run twice, and command line arguments will not be propagated to the child `just` process. + +### Writing Recipes in Other Languages +Recipes that start with `#!` are called shebang recipes, and are executed by saving the recipe body to a file and running it. This lets you write recipes in different languages: +```just +polyglot: python js perl sh ruby nu + +python: + #!/usr/bin/env python3 + print('Hello from python!') + +js: + #!/usr/bin/env node + console.log('Greetings from JavaScript!') + +perl: + #!/usr/bin/env perl + print "Larry Wall says Hi!\n"; + +sh: + #!/usr/bin/env sh + hello='Yo' + echo "$hello from a shell script!" + +nu: + #!/usr/bin/env nu + let hello = 'Hola' + echo $"($hello) from a nushell script!" + +ruby: + #!/usr/bin/env ruby + puts "Hello from ruby!" +``` + +```shell +$ just polyglot +Hello from python! +Greetings from JavaScript! +Larry Wall says Hi! +Yo from a shell script! +Hola from a nushell script! +Hello from ruby! +``` + +On Unix-like operating systems, including [Linux](../../linux/Linux.md) and [MacOS](../../macos/macOS.md), shebang recipes are executed by saving the recipe body to a file in a temporary directory, marking the file as executable, and executing it. The OS then parses the shebang line into a command line and invokes it, including the path to the file. For example, if a recipe starts with `#!/usr/bin/env bash`, the final command that the OS runs will be something like `/usr/bin/env bash /tmp/PATH_TO_SAVED_RECIPE_BODY`. Keep in mind that different operating systems split shebang lines differently. + +[Windows](../../windows/Windows.md) does not support shebang lines. On [Windows](../../windows/Windows.md), `just` splits the shebang line into a command and arguments, saves the recipe body to a file, and invokes the split command and arguments, adding the path to the saved recipe body as the final argument. + +### Multi-Line Constructs +Recipes without an initial shebang are evaluated and run line-by-line, which means that multi-line constructs probably won't do what you want. + +For example, with the following `justfile`: +```makefile +conditional: + if true; then + echo 'True!' + fi +``` + +The extra leading whitespace before the second line of the `conditional` recipe will produce a parse error: +```shell +$ just conditional +error: Recipe line has extra leading whitespace + | +3 | echo 'True!' + | ^^^^^^^^^^^^^^^^ +``` + +To work around this, you can write conditionals on one line, escape newlines with slashes, or add a shebang to your recipe. Some examples of multi-line constructs are provided for reference. + +#### `if` statements +```just +conditional: + if true; then echo 'True!'; fi +``` + +```just +conditional: + if true; then \ + echo 'True!'; \ + fi +``` + +```just +conditional: + #!/usr/bin/env sh + if true; then + echo 'True!' + fi +``` + +#### `for` loops +```just +for: + for file in `ls .`; do echo $file; done +``` + +```just +for: + for file in `ls .`; do \ + echo $file; \ + done +``` + +```just +for: + #!/usr/bin/env sh + for file in `ls .`; do + echo $file + done +``` + +#### `while` loops +```just +while: + while `server-is-dead`; do ping -c 1 server; done +``` + +```just +while: + while `server-is-dead`; do \ + ping -c 1 server; \ + done +``` + +```just +while: + #!/usr/bin/env sh + while `server-is-dead`; do + ping -c 1 server + done +``` + +### Private Recipes +Recipes and aliases whose name starts with a `_` are omitted from `just --list`: +```just +test: _test-helper + ./bin/test + +_test-helper: + ./bin/super-secret-test-helper-stuff +``` + +```shell +$ just --list +Available recipes: + test +``` + +The `[private]` attribute may also be used to hide recipes or aliases without needing to change the name: +```just +[private] +foo: + +[private] +alias b := bar + +bar: +``` + +```shell +$ just --list +Available recipes: + bar +``` + +This is useful for helper recipes which are only meant to be used as dependencies of other recipes. + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/cli/losetup.md b/technology/applications/cli/losetup.md new file mode 100644 index 0000000..040bacf --- /dev/null +++ b/technology/applications/cli/losetup.md @@ -0,0 +1,63 @@ +--- +obj: application +repo: git://git.kernel.org/pub/scm/utils/util-linux/util-linux.git +--- + +# losetup +set up and control [loop devices](../../linux/Loop%20Device.md) + +## Usage +Get info: +```shell +losetup [loopdev] +losetup -l [-a] +losetup -j file +``` + +Attach a loop device: +```shell +losetup -fP file +``` + +Detach a loop device: +```shell +losetup -d loopdev ... +``` + +Detach all associated loop devices: +```shell +losetup -D +``` + +## Options +| Option | Description | +| --------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-a, --all` | Show the status of all loop devices | +| `-d, --detach loopdev...` | Detach the file or device associated with the specified loop device(s) | +| `-D, --detach-all` | Detach all associated loop devices | +| `-f, --find [file]` | Find the first unused loop device. If a file argument is present, use the found device as loop device. Otherwise, just print its name | +| `--show` | Display the name of the assigned loop device if the `-f` option and a file argument are present | +| `-L, --nooverlap` | Check for conflicts between loop devices to avoid situation when the same backing file is shared between more loop devices. If the file is already used by another device then re-use the device rather than a new one. The option makes sense only with `--find` | +| `-j, --associated file` | Show the status of all loop devices associated with the given file | +| `-P, --partscan` | Force the kernel to scan the partition table on a newly created loop device. Note that the partition table parsing depends on sector sizes | +| `-r, --read-only` | Set up a read-only loop device | +| `-v, --verbose` | Verbose mode | +| `-l, --list` | If a loop device or the -a option is specified, print the default columns for either the specified loop device or all loop devices | +| `-O, --output column[,column]...` | Specify the columns that are to be printed for the `--list` output | +| `-J, --json` | Use JSON format for `--list` output | + +## Output Columns +| Output | Description | +| ------------ | -------------------------------------- | +| NAME | loop device name | +| AUTOCLEAR | autoclear flag set | +| BACK-FILE | device backing file | +| BACK-INO | backing file inode number | +| BACK-MAJ:MIN | backing file major:minor device number | +| MAJ:MIN | loop device major:minor number | +| OFFSET | offset from the beginning | +| PARTSCAN | partscan flag set | +| RO | read-only device | +| SIZELIMIT | size limit of the file in bytes | +| DIO | access backing file with direct-io | +| LOG-SEC | logical sector size in bytes | \ No newline at end of file diff --git a/technology/applications/cli/lsblk.md b/technology/applications/cli/lsblk.md new file mode 100644 index 0000000..ca0c878 --- /dev/null +++ b/technology/applications/cli/lsblk.md @@ -0,0 +1,92 @@ +--- +obj: application +repo: git://git.kernel.org/pub/scm/utils/util-linux/util-linux.git +--- +# lsblk +List block devices +Usage: `lsblk [options] [device...]` + +## Options +| Option | Description | +| ------------------- | ------------------------------------------------------------------------------------------------------------------------ | +| `-A, --noempty` | Don’t print empty devices | +| `-a, --all` | Disable all built-in filters and list all empty devices and RAM disk devices too | +| `-f, --fs` | Output info about filesystems. This option is equivalent to `-o NAME,FSTYPE,FSVER,LABEL,UUID,FSAVAIL,FSUSE%,MOUNTPOINTS` | +| `-J, --json` | Use JSON output format | +| `-l, --list` | Produce output in the form of a list | +| `-N, --nvme` | Output info about NVMe devices only | +| `-o, --output list` | Specify which output columns to print | +| `-p, --paths` | Print full device paths | + +## Output Columns +| Output | Description | +| ------------ | ------------------------------------------------- | +| ALIGNMENT | alignment offset | +| ID-LINK | the shortest udev /dev/disk/by-id link name | +| ID | udev ID (based on ID-LINK) | +| DISC-ALN | discard alignment offset | +| DAX | dax-capable device | +| DISC-GRAN | discard granularity | +| DISK-SEQ | disk sequence number | +| DISC-MAX | discard max bytes | +| DISC-ZERO | discard zeroes data | +| FSAVAIL | filesystem size available | +| FSROOTS | mounted filesystem roots | +| FSSIZE | filesystem size | +| FSTYPE | filesystem type | +| FSUSED | filesystem size used | +| FSUSE% | filesystem use percentage | +| FSVER | filesystem version | +| GROUP | group name | +| HCTL | Host:Channel:Target:Lun for SCSI | +| HOTPLUG | removable or hotplug device (usb, pcmcia, ...) | +| KNAME | internal kernel device name | +| LABEL | filesystem LABEL | +| LOG-SEC | logical sector size | +| MAJ:MIN | major:minor device number | +| MIN-IO | minimum I/O size | +| MODE | device node permissions | +| MODEL | device identifier | +| MQ | device queues | +| NAME | device name | +| OPT-IO | optimal I/O size | +| OWNER | user name | +| PARTFLAGS | partition flags | +| PARTLABEL | partition LABEL | +| PARTN | partition number as read from the partition table | +| PARTTYPE | partition type code or UUID | +| PARTTYPENAME | partition type name | +| PARTUUID | partition UUID | +| PATH | path to the device node | +| PHY-SEC | physical sector size | +| PKNAME | internal parent kernel device name | +| PTTYPE | partition table type | +| PTUUID | partition table identifier (usually UUID) | +| RA | read-ahead of the device | +| RAND | adds randomness | +| REV | device revision | +| RM | removable device | +| RO | read-only device | +| ROTA | rotational device | +| RQ-SIZE | request queue size | +| SCHED | I/O scheduler name | +| SERIAL | disk serial number | +| SIZE | size of the device | +| START | partition start offset | +| STATE | state of the device | +| SUBSYSTEMS | de-duplicated chain of subsystems | +| MOUNTPOINT | where the device is mounted | +| MOUNTPOINTS | all locations where device is mounted | +| TRAN | device transport type | +| TYPE | device type | +| UUID | filesystem UUID | +| VENDOR | device vendor | +| WSAME | write same max bytes | +| WWN | unique storage identifier | +| ZONED | zone model | +| ZONE-SZ | zone size | +| ZONE-WGRAN | zone write granularity | +| ZONE-APP | zone append max bytes | +| ZONE-NR | number of zones | +| ZONE-OMAX | maximum number of open zones | +| ZONE-AMAX | maximum number of active zones | \ No newline at end of file diff --git a/technology/applications/cli/man.md b/technology/applications/cli/man.md new file mode 100644 index 0000000..4da2336 --- /dev/null +++ b/technology/applications/cli/man.md @@ -0,0 +1,17 @@ +--- +obj: application +arch-wiki: https://wiki.archlinux.org/title/man_page +wiki: https://en.wikipedia.org/wiki/Man_page +--- +# man +A man page (short for manual page) is a form of software documentation usually found on a Unix or Unix-like operating system. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts. A user may invoke a man page by issuing the man command. + +To read a man page, simply enter: +```shell +man page_name +``` + +## Online Man Pages +- [Arch Linux Man Pages](https://man.archlinux.org) +- [FreeBSD Man Pages](https://man.freebsd.org/cgi/man.cgi) +- [OpenBSD Man Pages](https://man.openbsd.org/) \ No newline at end of file diff --git a/technology/applications/cli/micro.md b/technology/applications/cli/micro.md new file mode 100644 index 0000000..22b9291 --- /dev/null +++ b/technology/applications/cli/micro.md @@ -0,0 +1,799 @@ +--- +obj: application +os: linux +repo: https://github.com/zyedidia/micro +website: https://micro-editor.github.io/ +--- +# micro +**micro** is a terminal-based text editor that aims to be easy to use and intuitive, while also taking advantage of the capabilities of modern terminals. It comes as a single, batteries-included, static binary with no dependencies; you can download and use it right now! + +As its name indicates, micro aims to be somewhat of a successor to the nano editor by being easy to install and use. It strives to be enjoyable as a full-time editor for people who prefer to work in a terminal, or those who regularly edit files over [SSH](../SSH.md). + +![Screenshot][Screenshot] + +## Keybindings +Micro has a plethora of hotkeys that make it easy and powerful to use and all hotkeys are fully customizable to your liking. + +Custom keybindings are stored internally in micro if changed with the > bind command or can also be added in the file `~/.config/micro/bindings.json` + +### Rebinding keys +The bindings may be rebound using the `~/.config/micro/bindings.json` file. Each key is bound to an action. + +For example, to bind Ctrl-y to undo and Ctrl-z to redo, you could put the following in the bindings.json file. +```json +{ + "Ctrl-y": "Undo", + "Ctrl-z": "Redo" +} +``` + +### Binding commands +You can also bind a key to execute a command in command mode (see help commands). Simply prepend the binding with command:. For example: +```json +{ + "Alt-p": "command:pwd" +} +``` + +### Bindables +Actions: +``` +CursorUp +CursorDown +CursorPageUp +CursorPageDown +CursorLeft +CursorRight +CursorStart +CursorEnd +SelectToStart +SelectToEnd +SelectUp +SelectDown +SelectLeft +SelectRight +SelectToStartOfText +SelectToStartOfTextToggle +WordRight +WordLeft +SelectWordRight +SelectWordLeft +MoveLinesUp +MoveLinesDown +DeleteWordRight +DeleteWordLeft +SelectLine +SelectToStartOfLine +SelectToEndOfLine +InsertNewline +InsertSpace +Backspace +Delete +Center +InsertTab +Save +SaveAll +SaveAs +Find +FindLiteral +FindNext +FindPrevious +DiffPrevious +DiffNext +Undo +Redo +Copy +CopyLine +Cut +CutLine +DuplicateLine +DeleteLine +IndentSelection +OutdentSelection +OutdentLine +IndentLine +Paste +SelectAll +OpenFile +Start +End +PageUp +PageDown +SelectPageUp +SelectPageDown +HalfPageUp +HalfPageDown +StartOfLine +EndOfLine +StartOfText +StartOfTextToggle +ParagraphPrevious +ParagraphNext +ToggleHelp +ToggleDiffGutter +ToggleRuler +JumpLine +ClearStatus +ShellMode +CommandMode +Quit +QuitAll +AddTab +PreviousTab +NextTab +NextSplit +Unsplit +VSplit +HSplit +PreviousSplit +ToggleMacro +PlayMacro +Suspend (Unix only) +ScrollUp +ScrollDown +SpawnMultiCursor +SpawnMultiCursorUp +SpawnMultiCursorDown +SpawnMultiCursorSelect +RemoveMultiCursor +RemoveAllMultiCursors +SkipMultiCursor +None +JumpToMatchingBrace +Autocomplete +``` + +Keys: +``` +Up +Down +Right +Left +UpLeft +UpRight +DownLeft +DownRight +Center +PageUp +PageDown +Home +End +Insert +Delete +Help +Exit +Clear +Cancel +Print +Pause +Backtab +F1 +F2 +F3 +F4 +F5 +F6 +F7 +F8 +F9 +F10 +F11 +F12 +F13 +F14 +F15 +F16 +F17 +F18 +F19 +F20 +F21 +F22 +F23 +F24 +F25 +F26 +F27 +F28 +F29 +F30 +F31 +F32 +F33 +F34 +F35 +F36 +F37 +F38 +F39 +F40 +F41 +F42 +F43 +F44 +F45 +F46 +F47 +F48 +F49 +F50 +F51 +F52 +F53 +F54 +F55 +F56 +F57 +F58 +F59 +F60 +F61 +F62 +F63 +F64 +CtrlSpace +Ctrl-a +Ctrl-b +Ctrl-c +Ctrl-d +Ctrl-e +Ctrl-f +Ctrl-g +Ctrl-h +Ctrl-i +Ctrl-j +Ctrl-k +Ctrl-l +Ctrl-m +Ctrl-n +Ctrl-o +Ctrl-p +Ctrl-q +Ctrl-r +Ctrl-s +Ctrl-t +Ctrl-u +Ctrl-v +Ctrl-w +Ctrl-x +Ctrl-y +Ctrl-z +CtrlLeftSq +CtrlBackslash +CtrlRightSq +CtrlCarat +CtrlUnderscore +Backspace +OldBackspace +Tab +Esc +Escape +Enter +``` + +Mouse +``` +MouseLeft +MouseMiddle +MouseRight +MouseWheelUp +MouseWheelDown +MouseWheelLeft +MouseWheelRight +``` + +# Commands +Micro provides the following commands that can be executed at the command-bar by pressing `Ctrl-e` and entering the command. Arguments are placed in single quotes here but these are not necessary when entering the command in micro. + +- `bind 'key' 'action'`: creates a keybinding from key to action. See the `keybindings` documentation for more information about binding keys. This command will modify `bindings.json` and overwrite any bindings to `key` that already exist. +- `help 'topic'?`: opens the corresponding help topic. If no topic is provided opens the default help screen. Help topics are stored as `.md` files in the `runtime/help` directory of the source tree, which is embedded in the final binary. +- `save 'filename'?`: saves the current buffer. If the file is provided it will 'save as' the filename. +- `quit`: quits micro. +- `goto 'line'`: jumps to the given line number. A negative number can be passed to jump inward from the end of the file; for example, -5 jumps to the 5th-last line in the file. +- `replace 'search' 'value' 'flags'?`: This will replace `search` with `value`. The `flags` are optional. Possible flags are: + - `-a`: Replace all occurrences at once + - `-l`: Do a literal search instead of a [regex](../../tools/Regex.md) search + + Note that `search` must be a valid [regex](../../tools/Regex.md) (unless `-l` is passed). If one of the arguments does not have any spaces in it, you may omit the quotes. +- `replaceall 'search' 'value'`: this will replace all occurrences of `search` with `value` without user confirmation. + See `replace` command for more information. +- `set 'option' 'value'`: sets the option to value. See the `options` help topic for a list of options you can set. This will modify your `settings.json` with the new value. +- `setlocal 'option' 'value'`: sets the option to value locally (only in the current buffer). This will _not_ modify `settings.json`. +- `show 'option'`: shows the current value of the given option. +- `run 'sh-command'`: runs the given [shell](Shell.md) command in the background. The command's output will be displayed in one line when it finishes running. +- `vsplit 'filename'`: opens a vertical split with `filename`. If no filename is provided, a vertical split is opened with an empty buffer. +- `hsplit 'filename'`: same as `vsplit` but opens a horizontal split instead of a vertical split. +- `tab 'filename'`: opens the given file in a new tab. +- `tabmove '[-+]?n'`: Moves the active tab to another slot. `n` is an integer. If `n` is prefixed with `-` or `+`, then it represents a relative position (e.g. `tabmove +2` moves the tab to the right by `2`). If `n` has no prefix, it represents an absolute position (e.g. `tabmove 2` moves the tab to slot `2`). +- `tabswitch 'tab'`: This command will switch to the specified tab. The `tab` can either be a tab number, or a name of a tab. +- `textfilter 'sh-command'`: filters the current selection through a [shell](Shell.md) command as standard input and replaces the selection with the stdout of the [shell](Shell.md) command. For example, to sort a list of numbers, first select them, and then execute `> textfilter sort -n`. +- `log`: opens a log of all messages and debug statements. +- `plugin list`: lists all installed plugins. +- `plugin install 'pl'`: install a plugin. +- `plugin remove 'pl'`: remove a plugin. +- `plugin update 'pl'`: update a plugin (if no arguments are provided updates all plugins). +- `plugin search 'pl'`: search available plugins for a keyword. +- `plugin available`: show available plugins that can be installed. +- `reload`: reloads all runtime files. +- `cd 'path'`: Change the working directory to the given `path`. +- `pwd`: Print the current working directory. +- `open 'filename'`: Open a file in the current buffer. +- `reset 'option'`: resets the given option to its default value +- `retab`: Replaces all leading tabs with spaces or leading spaces with tabs depending on the value of `tabstospaces`. +- `raw`: micro will open a new tab and show the escape sequence for every event it receives from the terminal. This shows you what micro actually sees from the terminal and helps you see which bindings aren't possible and why. This is most useful for debugging keybindings. +- `showkey`: Show the action(s) bound to a given key. For example running `> showkey Ctrl-c` will display `Copy`. +- `term exec?`: Open a terminal emulator running the given executable. If no executable is given, this will open the default [shell](Shell.md) in the terminal emulator. + +## Settings +Micro stores all of the user configuration in its configuration directory. + +Micro uses `$MICRO_CONFIG_HOME` as the configuration directory. If this +environment variable is not set, it uses `$XDG_CONFIG_HOME/micro` instead. If +that environment variable is not set, it uses `~/.config/micro` as the +configuration directory. In the documentation, we use `~/.config/micro` to +refer to the configuration directory (even if it may in fact be somewhere else +if you have set either of the above environment variables). Settings are stored in `settings.json` + +Here are the available options: + +* `autoindent`: when creating a new line, use the same indentation as the + previous line. + + default value: `true` + +* `autosave`: automatically save the buffer every n seconds, where n is the + value of the autosave option. Also when quitting on a modified buffer, micro + will automatically save and quit. Be warned, this option saves the buffer + without prompting the user, so data may be overwritten. If this option is + set to `0`, no autosaving is performed. + + default value: `0` + +* `autosu`: When a file is saved that the user doesn't have permission to + modify, micro will ask if the user would like to use super user + privileges to save the file. If this option is enabled, micro will + automatically attempt to use super user privileges to save without + asking the user. + + default value: `false` + +* `backup`: micro will automatically keep backups of all open buffers. Backups + are stored in `~/.config/micro/backups` and are removed when the buffer is + closed cleanly. In the case of a system crash or a micro crash, the contents + of the buffer can be recovered automatically by opening the file that was + being edited before the crash, or manually by searching for the backup in + the backup directory. Backups are made in the background for newly modified + buffers every 8 seconds, or when micro detects a crash. + + default value: `true` + +* `backupdir`: the directory micro should place backups in. For the default + value of `""` (empty string), the backup directory will be + `ConfigDir/backups`, which is `~/.config/micro/backups` by default. The + directory specified for backups will be created if it does not exist. + + default value: `""` (empty string) + +* `basename`: in the infobar and tabbar, show only the basename of the file + being edited rather than the full path. + + default value: `false` + +* `clipboard`: specifies how micro should access the system clipboard. + Possible values are: + * `external`: accesses clipboard via an external tool, such as xclip/xsel + or wl-clipboard on [Linux](../../linux/Linux.md), pbcopy/pbpaste on [MacOS](../../macos/macOS.md), and system calls on + [Windows](../../windows/Windows.md). On Linux, if you do not have one of the tools installed, or if + they are not working, micro will throw an error and use an internal + clipboard. + * `terminal`: accesses the clipboard via your terminal emulator. Note that + there is limited support among terminal emulators for this feature + (called OSC 52). Terminals that are known to work are Kitty (enable + reading with `clipboard_control` setting), iTerm2 (only copying), + st, rxvt-unicode and xterm if enabled (see `> help copypaste` for + details). Note that Gnome-terminal does not support this feature. With + this setting, copy-paste **will** work over [ssh](../SSH.md). See `> help copypaste` + for details. + * `internal`: micro will use an internal clipboard. + + default value: `external` + +* `colorcolumn`: if this is not set to 0, it will display a column at the + specified column. This is useful if you want column 80 to be highlighted + special for example. + + default value: `0` + +* `colorscheme`: loads the colorscheme stored in + $(configDir)/colorschemes/`option`.micro, This setting is `global only`. + + default value: `default` + + Note that the default colorschemes (default, solarized, and solarized-tc) + are not located in configDir, because they are embedded in the micro + binary. + + The colorscheme can be selected from all the files in the + ~/.config/micro/colorschemes/ directory. Micro comes by default with + three colorschemes: + + You can read more about micro's colorschemes in the `colors` help topic + (`help colors`). + +* `cursorline`: highlight the line that the cursor is on in a different color + (the color is defined by the colorscheme you are using). + + default value: `true` + +* `diffgutter`: display [diff](diff.md) indicators before lines. + + default value: `false` + +* `divchars`: specifies the "divider" characters used for the dividing line + between vertical/horizontal splits. The first character is for vertical + dividers, and the second is for horizontal dividers. By default, for + horizontal splits the statusline serves as a divider, but if the statusline + is disabled the horizontal divider character will be used. + + default value: `|-` + +* `divreverse`: colorschemes provide the color (foreground and background) for + the characters displayed in split dividers. With this option enabled, the + colors specified by the colorscheme will be reversed (foreground and + background colors swapped). + + default value: `true` + +* `encoding`: the encoding to open and save files with. Supported encodings + are listed at https://www.w3.org/TR/encoding/. + + default value: `utf-8` + +* `eofnewline`: micro will automatically add a newline to the end of the + file if one does not exist. + + default value: `true` + +* `fakecursor`: forces micro to render the cursor using terminal colors rather + than the actual terminal cursor. This is useful when the terminal's cursor is + slow or otherwise unavailable/undesirable to use. + + default value: `false` + +* `fastdirty`: this determines what kind of algorithm micro uses to determine + if a buffer is modified or not. When `fastdirty` is on, micro just uses a + boolean `modified` that is set to `true` as soon as the user makes an edit. + This is fast, but can be inaccurate. If `fastdirty` is off, then micro will + hash the current buffer against a hash of the original file (created when + the buffer was loaded). This is more accurate but obviously more resource + intensive. This option will be automatically disabled if the file size + exceeds 50KB. + + default value: `false` + +* `fileformat`: this determines what kind of line endings micro will use for + the file. Unix line endings are just `\n` (linefeed) whereas dos line + endings are `\r\n` (carriage return + linefeed). The two possible values for + this option are `unix` and `dos`. The fileformat will be automatically + detected (when you open an existing file) and displayed on the statusline, + but this option is useful if you would like to change the line endings or if + you are starting a new file. Changing this option while editing a file will + change its line endings. Opening a file with this option set will only have + an effect if the file is empty/newly created, because otherwise the fileformat + will be automatically detected from the existing line endings. + + default value: `unix` + +* `filetype`: sets the filetype for the current buffer. Set this option to + `off` to completely disable filetype detection. + + default value: `unknown`. This will be automatically overridden depending + on the file you open. + +* `hlsearch`: highlight all instances of the searched text after a successful + search. This highlighting can be temporarily turned off via the + `UnhighlightSearch` action (triggered by the Esc key by default) or toggled + on/off via the `ToggleHighlightSearch` action. Note that these actions don't + change the `hlsearch` setting. As long as `hlsearch` is set to true, the next + search will have the highlighting turned on again. + + default value: `false` + +* `incsearch`: enable incremental search in "Find" prompt (matching as you type). + + default value: `true` + +* `ignorecase`: perform case-insensitive searches. + + default value: `true` + +* `indentchar`: sets the indentation character. This will not be inserted into + files; it is only a visual indicator that whitespace is present. If set to a + printing character, it functions as a subset of the "show invisibles" + setting available in many other text editors. The color of this character is + determined by the `indent-char` field in the current theme rather than the + default text color. + + default value: ` ` (space) + +* `infobar`: enables the line at the bottom of the editor where messages are + printed. This option is `global only`. + + default value: `true` + +* `keepautoindent`: when using autoindent, whitespace is added for you. This + option determines if when you move to the next line without any insertions + the whitespace that was added should be deleted to remove trailing + whitespace. By default, the autoindent whitespace is deleted if the line + was left empty. + + default value: `false` + +* `keymenu`: display the nano-style key menu at the bottom of the screen. Note + that ToggleKeyMenu is bound to `Alt-g` by default and this is displayed in + the statusline. To disable the key binding, bind `Alt-g` to `None`. + + default value: `false` + +* `matchbrace`: underline matching braces for '()', '{}', '[]' when the cursor + is on a brace character. + + default value: `true` + +* `mkparents`: if a file is opened on a path that does not exist, the file + cannot be saved because the parent directories don't exist. This option lets + micro automatically create the parent directories in such a situation. + + default value: `false` + +* `mouse`: mouse support. When mouse support is disabled, + usually the terminal will be able to access mouse events which can be useful + if you want to copy from the terminal instead of from micro (if over [ssh](../SSH.md) for + example, because the terminal has access to the local clipboard and micro + does not). + + default value: `true` + +* `multiopen`: specifies how to layout multiple files opened at startup. + Most useful as a command-line option, like `-multiopen vsplit`. Possible + values correspond to commands (see `> help commands`) that open files: + * `tab`: open each file in a separate tab. + * `vsplit`: open files side-by-side. + * `hsplit`: open files stacked top to bottom. + + default value: `tab` + +* `paste`: treat characters sent from the terminal in a single chunk as a paste + event rather than a series of manual key presses. If you are pasting using + the terminal keybinding (not Ctrl-v, which is micro's default paste + keybinding) then it is a good idea to enable this option during the paste + and disable once the paste is over. See `> help copypaste` for details about + copying and pasting in a terminal environment. + + default value: `false` + +* `parsecursor`: if enabled, this will cause micro to parse filenames such as + file.txt:10:5 as requesting to open `file.txt` with the cursor at line 10 + and column 5. The column number can also be dropped to open the file at a + given line and column 0. Note that with this option enabled it is not possible + to open a file such as `file.txt:10:5`, where `:10:5` is part of the filename. + It is also possible to open a file with a certain cursor location by using the + `+LINE:COL` flag syntax. See `micro -help` for the command line options. + + default value: `false` + +* `permbackup`: this option causes backups (see `backup` option) to be + permanently saved. With permanent backups, micro will not remove backups when + files are closed and will never apply them to existing files. Use this option + if you are interested in manually managing your backup files. + + default value: `false` + +* `pluginchannels`: list of URLs pointing to plugin channels for downloading and + installing plugins. A plugin channel consists of a [json](../../files/JSON.md) file with links to + plugin repos, which store information about plugin versions and download URLs. + By default, this option points to the official plugin channel hosted on GitHub + at https://github.com/micro-editor/plugin-channel. + + default value: `https://raw.githubusercontent.com/micro-editor/plugin-channel/master/channel.json` + +* `pluginrepos`: a list of links to plugin repositories. + + default value: `` + +* `readonly`: when enabled, disallows edits to the buffer. It is recommended + to only ever set this option locally using `setlocal`. + + default value: `false` + +* `reload`: controls the reload behavior of the current buffer in case the file + has changed. The available options are `prompt`, `auto` & `disabled`. + + default value: `prompt` + +* `rmtrailingws`: micro will automatically trim trailing whitespaces at ends of + lines. Note: This setting overrides `keepautoindent` + + default value: `false` + +* `ruler`: display line numbers. + + default value: `true` + +* `relativeruler`: make line numbers display relatively. If set to true, all + lines except for the line that the cursor is located will display the distance + from the cursor's line. + + default value: `false` + +* `savecursor`: remember where the cursor was last time the file was opened and + put it there when you open the file again. Information is saved to + `~/.config/micro/buffers/` + + default value: `false` + +* `savehistory`: remember command history between closing and re-opening + micro. Information is saved to `~/.config/micro/buffers/history`. + + default value: `true` + +* `saveundo`: when this option is on, undo is saved even after you close a file + so if you close and reopen a file, you can keep undoing. Information is + saved to `~/.config/micro/buffers/`. + + default value: `false` + +* `scrollbar`: display a scroll bar + + default value: `false` + +* `scrollbarchar`: specifies the character used for displaying the scrollbar + + default value: `|` + +* `scrollmargin`: margin at which the view starts scrolling when the cursor + approaches the edge of the view. + + default value: `3` + +* `scrollspeed`: amount of lines to scroll for one scroll event. + + default value: `2` + +* `smartpaste`: add leading whitespace when pasting multiple lines. + This will attempt to preserve the current indentation level when pasting an + unindented block. + + default value: `true` + +* `softwrap`: wrap lines that are too long to fit on the screen. + + default value: `false` + +* `splitbottom`: when a horizontal split is created, create it below the + current split. + + default value: `true` + +* `splitright`: when a vertical split is created, create it to the right of the + current split. + + default value: `true` + +* `statusformatl`: format string definition for the left-justified part of the + statusline. Special directives should be placed inside `$()`. Special + directives include: `filename`, `modified`, `line`, `col`, `lines`, + `percentage`, `opt`, `bind`. + The `opt` and `bind` directives take either an option or an action afterward + and fill in the value of the option or the key bound to the action. + + default value: `$(filename) $(modified)($(line),$(col)) $(status.paste)| + ft:$(opt:filetype) | $(opt:fileformat) | $(opt:encoding)` + +* `statusformatr`: format string definition for the right-justified part of the + statusline. + + default value: `$(bind:ToggleKeyMenu): bindings, $(bind:ToggleHelp): help` + +* `statusline`: display the status line at the bottom of the screen. + + default value: `true` + +* `sucmd`: specifies the super user command. On most systems this is "sudo" but + on BSD it can be "[doas](doas.md)." This option can be customized and is only used when + saving with su. + + default value: `sudo` + +* `syntax`: enables syntax highlighting. + + default value: `true` + +* `tabmovement`: navigate spaces at the beginning of lines as if they are tabs + (e.g. move over 4 spaces at once). This option only does anything if + `tabstospaces` is on. + + default value: `false` + +* `tabhighlight`: inverts the tab characters' (filename, save indicator, etc) + colors with respect to the tab bar. + + default value: false + +* `tabreverse`: reverses the tab bar colors when active. + + default value: true + +* `tabsize`: the size in spaces that a tab character should be displayed with. + + default value: `4` + +* `tabstospaces`: use spaces instead of tabs. Note: This option will be + overridden by [the `ftoptions` plugin](https://github.com/zyedidia/micro/blob/master/runtime/plugins/ftoptions/ftoptions.lua) + for certain filetypes. To disable this behavior, add `"ftoptions": false` to + your config. See [issue #2213](https://github.com/zyedidia/micro/issues/2213) + for more details. + + default value: `false` + +* `useprimary` (only useful on unix): defines whether or not micro will use the + primary clipboard to copy selections in the background. This does not affect + the normal clipboard using Ctrl-c and Ctrl-v. + + default value: `true` + +* `wordwrap`: wrap long lines by words, i.e. break at spaces. This option + only does anything if `softwrap` is on. + + default value: `false` + +* `xterm`: micro will assume that the terminal it is running in conforms to + `xterm-256color` regardless of what the `$TERM` variable actually contains. + Enabling this option may cause unwanted effects if your terminal in fact + does not conform to the `xterm-256color` standard. + + Default value: `false` + +### Global and local settings +You can set these settings either globally or locally. Locally means that the +setting won't be saved to `~/.config/micro/settings.json` and that it will only +be set in the current buffer. Setting an option globally is the default, and +will set the option in all buffers. Use the `setlocal` command to set an option +locally rather than globally. + +The `colorscheme` option is global only, and the `filetype` option is local +only. To set an option locally, use `setlocal` instead of `set`. + +In the `settings.json` file you can also put set options locally by specifying +either a glob or a filetype. Here is an example which has `tabstospaces` on for +all files except Go files, and `tabsize` 4 for all files except Ruby files: +```json +{ + "ft:go": { + "tabstospaces": false + }, + "ft:ruby": { + "tabsize": 2 + }, + "tabstospaces": true, + "tabsize": 4 +} +``` + +Or similarly you can match with globs: +```json +{ + "*.go": { + "tabstospaces": false + }, + "*.rb": { + "tabsize": 2 + }, + "tabstospaces": true, + "tabsize": 4 +} +``` + + + +[Screenshot]:  \ No newline at end of file diff --git a/technology/applications/cli/netcat.md b/technology/applications/cli/netcat.md new file mode 100644 index 0000000..5ebd200 --- /dev/null +++ b/technology/applications/cli/netcat.md @@ -0,0 +1,56 @@ +--- +obj: application +wiki: https://en.wikipedia.org/wiki/Netcat +--- + +# netcat +The `nc` (or `netcat`) utility is used for just about anything under the sun involving [TCP](../../internet/TCP.md), [UDP](../../internet/UDP.md), or UNIX-domain sockets. It can open [TCP](../../internet/TCP.md) connections, send [UDP](../../internet/UDP.md) packets, listen on arbitrary [TCP](../../internet/TCP.md) and [UDP](../../internet/UDP.md) ports, do port scanning, and deal with both IPv4 and IPv6. + +Common uses include: +- simple [TCP](../../internet/TCP.md) proxies +- shell-script based [HTTP](../../internet/HTTP.md) clients and servers +- network daemon testing +- a SOCKS or [HTTP](../../internet/HTTP.md) ProxyCommand for [ssh](../SSH.md) + +## Options +| Option | Description | +| ------------------ | --------------------------------------------------------------------------------------------------- | +| `-4` | Use IPv4 addresses only | +| `-6` | Use IPv6 addresses only | +| `-b` | Allow broadcast | +| `-l` | Listen for an incoming connection rather than initiating a connection to a remote host | +| `-N` | shutdown the network socket after EOF on the input. Some servers require this to finish their work | +| `-p ` | Specify the source port `nc` should use, subject to privilege restrictions and availability | + +## Examples +### Client/Server Model +On one console, start `nc` listening on a specific port for a connection. For example: +```shell +nc -l 1234 +``` + +`nc` is now listening on port 1234 for a connection. On a second console (or a second machine), connect to the machine and port being listened on: +```shell +nc -N 127.0.0.1 1234 +``` + +There should now be a connection between the ports. Anything typed at the second console will be concatenated to the first, and vice-versa. After the connection has been set up, `nc` does not really care which side is being used as a ‘server’ and which side is being used as a ‘client’. The connection may be terminated using an `EOF` (`^D`), as the `-N` flag was given. + +### Data Transfer +The example in the previous section can be expanded to build a basic data transfer model. Any information input into one end of the connection will be output to the other end, and input and output can be easily captured in order to emulate file transfer. + +Start by using `nc` to listen on a specific port, with output captured into a file: +```shell +nc -l 1234 > filename.out +``` + +Using a second machine, connect to the listening `nc` process, feeding it the file which is to be transferred: +```shell +nc -N host.example.com 1234 < filename.in +``` + +### Talking to Servers +It is sometimes useful to talk to servers “by hand” rather than through a user interface. It can aid in troubleshooting, when it might be necessary to verify what data a server is sending in response to commands issued by the client. For example, to retrieve the home page of a web site: +```shell +printf "GET / HTTP/1.0\r\n\r\n" | nc host.example.com 80 +``` \ No newline at end of file diff --git a/technology/applications/cli/netdiscover.md b/technology/applications/cli/netdiscover.md new file mode 100644 index 0000000..fbaa31c --- /dev/null +++ b/technology/applications/cli/netdiscover.md @@ -0,0 +1,33 @@ +--- +obj: application +source: https://www.kali.org/tools/netdiscover +repo: https://github.com/netdiscover-scanner/netdiscover +--- + +# netdiscover +Netdiscover is an active/passive address reconnaissance tool, mainly developed for those wireless networks without [dhcp](../../internet/DHCP.md) server, when you are wardriving. It can be also used on hub/switched networks. + +Built on top of libnet and libpcap, it can passively detect online hosts, or search for them, by actively sending ARP requests. + +Netdiscover can also be used to inspect your network ARP traffic, or find network addresses using auto scan mode, which will scan for common local networks. + +Netdiscover uses the OUI table to show the vendor of the each MAC address discovered and is very useful for security checks or in pentests. + +## Options +| Option | Description | +| ------------ | -------------------------------------------------------------------------------------------- | +| ` -i device` | network device used | +| ` -r range` | scan a given range instead of auto scan. 192.168.6.0/24,/16,/8 | +| ` -l file` | scan the list of ranges contained into the given file | +| ` -p` | passive mode, do not send anything, only sniff | +| ` -m file` | scan a list of known MACs and host names | +| ` -F filter` | customize pcap filter expression (default: "arp") | +| ` -s time` | time to sleep between each ARP request (milliseconds) | +| ` -c count` | number of times to send each ARP request (for nets with packet loss) | +| ` -n node` | last source IP octet used for scanning (from 2 to 253) | +| ` -d` | ignore home config files for autoscan and fast mode | +| ` -f` | enable fastmode scan, saves a lot of time, recommended for auto | +| ` -P` | print results in a format suitable for parsing by another program and stop after active scan | +| ` -L` | similar to `-P` but continue listening after the active scan is completed | +| ` -N` | Do not print header. Only valid when `-P` or `-L` is enabled. | +| ` -S` | enable sleep time suppression between each request (hardcore mode) | diff --git a/technology/applications/cli/nmap.md b/technology/applications/cli/nmap.md new file mode 100644 index 0000000..2d6fdef --- /dev/null +++ b/technology/applications/cli/nmap.md @@ -0,0 +1,122 @@ +--- +obj: application +website: https://nmap.org +repo: https://github.com/nmap/nmap +--- + +# nmap +Network exploration tool and security / port scanner + +## Usage +Usage: `nmap [Scan Type(s)] [Options] {target specification}` + +### Options +#### TARGET SPECIFICATION +Can pass hostnames, IP addresses, networks, etc. +Ex: scanme.nmap.org, 192.168.0.1; 10.0.0-255.1-254 + +| Option | Description | +| --------------------------------------- | --------------------------------- | +| `-iL ` | Input from list of hosts/networks | +| `--exclude ` | Exclude hosts/networks | +| `--excludefile ` | Exclude list from file | + +#### HOST DISCOVERY +| Option | Description | +| ----------------------------------- | --------------------------------------------------------------------------------------------------- | +| `-sL` | List Scan - simply list targets to scan | +| `-sn` | Ping Scan - disable port scan | +| `-PS/PA/PU/PY[portlist]` | [TCP](../../internet/TCP.md) SYN/ACK, [UDP](../../internet/UDP.md) or SCTP discovery to given ports | +| `-PE/PP/PM` | ICMP echo, timestamp, and netmask request discovery probes | +| `-n/-R` | Never do [DNS](../../internet/DNS.md) resolution/Always resolve \[default: sometimes] | +| `--dns-servers ` | Specify custom [DNS](../../internet/DNS.md) servers | +| `--traceroute` | Trace hop path to each host | + +#### SCAN TECHNIQUES +| Option | Description | +| --------------------- | ------------------------------------------------------------------ | +| `-sS/sT/sA/sW/sM` | [TCP](../../internet/TCP.md) SYN/Connect()/ACK/Window/Maimon scans | +| `-sU` | [UDP](../../internet/UDP.md) Scan | +| `-sN/sF/sX` | [TCP](../../internet/TCP.md) Null, FIN, and Xmas scans | +| `--scanflags ` | Customize [TCP](../../internet/TCP.md) scan flags | +| `-sO` | IP protocol scan | + +#### PORT SPECIFICATION AND SCAN ORDER +| Option | Description | +| ------------------------------- | --------------------------------------------------------------------------------------------- | +| `-p ` | Only scan specified ports. Ex: `-p22`; `-p1-65535`; `-p U:53,111,137,T:21-25,80,139,8080,S:9` | +| `--exclude-ports ` | Exclude the specified ports from scanning | +| `-F` | Fast mode - Scan fewer ports than the default scan | +| `-r` | Scan ports sequentially - don't randomize | +| `-top-ports ` | Scan \ most common ports | + +#### SERVICE/VERSION DETECTION +| Option | Description | +| ----------------------------- | -------------------------------------------------- | +| `-sV` | Probe open ports to determine service/version info | +| `--version-intensity ` | Set from 0 (light) to 9 (try all probes) | +| `--version-light` | Limit to most likely probes (intensity 2) | +| `--version-all` | Try every single probe (intensity 9) | + +#### SCRIPT SCAN +| Option | Description | +| ------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-sC` | equivalent to `--script=default` | +| `--script=` | \ is a comma separated list of directories, script-files or script-categories. The scripts are commonly found at `/usr/share/nmap/scripts` | +| `--script-updatedb` | Update the script database. | + +#### OS DETECTION +| Option | Description | +| ---------------- | --------------------------------------- | +| `-O` | Enable OS detection | +| `--osscan-limit` | Limit OS detection to promising targets | +| `--osscan-guess` | Guess OS more aggressively | + +#### TIMING AND PERFORMANCE + Options which take \