Compare commits
47 Commits
9258398be4
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
| 549b420df2 | |||
|
edf76874fc
|
|||
|
95ad6b0c6a
|
|||
|
ff36975eb7
|
|||
|
5ae19346d6
|
|||
|
53ee621747
|
|||
|
dd339f2939
|
|||
|
e0fbdf852e
|
|||
|
b5983ed308
|
|||
|
f39af6d446
|
|||
|
8fe3d112ba
|
|||
|
4c81bcea73
|
|||
|
5623d08d85
|
|||
|
0a369efe1b
|
|||
|
1640ebfb45
|
|||
|
d2c561fc28
|
|||
|
a920e48422
|
|||
|
0ed07de2d2
|
|||
|
abad965e9a
|
|||
|
b5b0140e34
|
|||
|
5d75b6f79e
|
|||
|
87fd722509
|
|||
|
eaacecd87a
|
|||
|
4c57a180ac
|
|||
|
96bd945ef2
|
|||
|
49fd27d3be
|
|||
|
3c9f1d71cb
|
|||
|
3a226ed5bb
|
|||
|
fe83b3eb25
|
|||
|
a34dda20c7
|
|||
|
021db1064e
|
|||
|
b70b89433b
|
|||
|
8531543982
|
|||
|
e05b47ae52
|
|||
|
e9a6f4ddda
|
|||
|
cbb493b5c4
|
|||
|
31ddf3a6d2
|
|||
|
47827282a9
|
|||
|
16075cdd61
|
|||
|
29e5c960de
|
|||
|
526dade1f8
|
|||
|
66126167c8
|
|||
|
3696cc06af
|
|||
|
8da2059d1e
|
|||
|
9da84a69f2
|
|||
|
50bd28abe4
|
|||
|
bbbc0de694
|
47
Makefile
47
Makefile
@@ -1,4 +1,4 @@
|
|||||||
# Autogenerated at 09.01.2025 15:37 using ./gen-makefile
|
# Autogenerated at 10.07.2025 23:45 using ./gen-makefile
|
||||||
.DEFAULT_GOAL := help
|
.DEFAULT_GOAL := help
|
||||||
|
|
||||||
#===============================================
|
#===============================================
|
||||||
@@ -21,6 +21,10 @@ canon-mg2500:
|
|||||||
chrome:
|
chrome:
|
||||||
@./install/chrome
|
@./install/chrome
|
||||||
|
|
||||||
|
##clamav: ClamAV (WIP)
|
||||||
|
clamav:
|
||||||
|
@./install/clamav
|
||||||
|
|
||||||
##composer: Install composer (latest)
|
##composer: Install composer (latest)
|
||||||
composer:
|
composer:
|
||||||
@./install/composer
|
@./install/composer
|
||||||
@@ -45,9 +49,9 @@ droidcam-obs:
|
|||||||
flameshot:
|
flameshot:
|
||||||
@./install/flameshot
|
@./install/flameshot
|
||||||
|
|
||||||
##frkn: Install Wireguard + FRKN
|
##frkn.deprecated: Install Wireguard + FRKN
|
||||||
frkn:
|
frkn.deprecated:
|
||||||
@./install/frkn
|
@./install/frkn.deprecated
|
||||||
|
|
||||||
##git: Install git (latest)
|
##git: Install git (latest)
|
||||||
git:
|
git:
|
||||||
@@ -81,15 +85,11 @@ kde-file-templates:
|
|||||||
kde-portal:
|
kde-portal:
|
||||||
@./install/kde-portal
|
@./install/kde-portal
|
||||||
|
|
||||||
##lazynvim: <no description>
|
|
||||||
lazynvim:
|
|
||||||
@./install/lazynvim
|
|
||||||
|
|
||||||
##libreoffice: Install libreoffice
|
##libreoffice: Install libreoffice
|
||||||
libreoffice:
|
libreoffice:
|
||||||
@./install/libreoffice
|
@./install/libreoffice
|
||||||
|
|
||||||
##lite-xl: Install lite-xl
|
##lite-xl: Install lite-xl v2.1.7
|
||||||
lite-xl:
|
lite-xl:
|
||||||
@./install/lite-xl
|
@./install/lite-xl
|
||||||
|
|
||||||
@@ -105,6 +105,10 @@ nodejs:
|
|||||||
ntfy:
|
ntfy:
|
||||||
@./install/ntfy
|
@./install/ntfy
|
||||||
|
|
||||||
|
##nvim: Install nvim + lazyvim
|
||||||
|
nvim:
|
||||||
|
@./install/nvim
|
||||||
|
|
||||||
##obs-studio: Install obs-studio (latest snap)
|
##obs-studio: Install obs-studio (latest snap)
|
||||||
obs-studio:
|
obs-studio:
|
||||||
@./install/obs-studio
|
@./install/obs-studio
|
||||||
@@ -129,7 +133,7 @@ papirus:
|
|||||||
pgsql:
|
pgsql:
|
||||||
@./install/pgsql
|
@./install/pgsql
|
||||||
|
|
||||||
##php: Install php v8.3 + ppa
|
##php: Install php v8.4
|
||||||
php:
|
php:
|
||||||
@./install/php
|
@./install/php
|
||||||
|
|
||||||
@@ -165,10 +169,14 @@ postman:
|
|||||||
qt5:
|
qt5:
|
||||||
@./install/qt5
|
@./install/qt5
|
||||||
|
|
||||||
##rustdesk: Install rustdesk client v1.1.9 (deb)
|
##rustdesk: Install rustdesk client (flatpak)
|
||||||
rustdesk:
|
rustdesk:
|
||||||
@./install/rustdesk
|
@./install/rustdesk
|
||||||
|
|
||||||
|
##rustdesk-deb: Install rustdesk client v1.4.0 (deb)
|
||||||
|
rustdesk-deb:
|
||||||
|
@./install/rustdesk-deb
|
||||||
|
|
||||||
##snap: Install bunch of software from snap
|
##snap: Install bunch of software from snap
|
||||||
snap:
|
snap:
|
||||||
@./install/snap
|
@./install/snap
|
||||||
@@ -181,6 +189,10 @@ sublimemerge:
|
|||||||
sublimetext:
|
sublimetext:
|
||||||
@./install/sublimetext
|
@./install/sublimetext
|
||||||
|
|
||||||
|
##suld: Samsung Unified Linux Driver repo
|
||||||
|
suld:
|
||||||
|
@./install/suld
|
||||||
|
|
||||||
##syncthing: Install syncthing (latest) + ppa
|
##syncthing: Install syncthing (latest) + ppa
|
||||||
syncthing:
|
syncthing:
|
||||||
@./install/syncthing
|
@./install/syncthing
|
||||||
@@ -205,7 +217,7 @@ vivaldi:
|
|||||||
vscode:
|
vscode:
|
||||||
@./install/vscode
|
@./install/vscode
|
||||||
|
|
||||||
##wine: Install wine (latest) + ppa (focal)
|
##wine: Install wine (latest) + ppa
|
||||||
wine:
|
wine:
|
||||||
@./install/wine
|
@./install/wine
|
||||||
|
|
||||||
@@ -230,9 +242,6 @@ zsh:
|
|||||||
# Scripts listed in ./packs
|
# Scripts listed in ./packs
|
||||||
#===============================================
|
#===============================================
|
||||||
|
|
||||||
##flameshot: [TODO] [PACK] qt5 + flameshot from source
|
|
||||||
flameshot: qt5 flameshot-build
|
|
||||||
|
|
||||||
##lamp: [PACK] Apache + php + mariadb
|
##lamp: [PACK] Apache + php + mariadb
|
||||||
lamp: apache phpstack mariadb
|
lamp: apache phpstack mariadb
|
||||||
|
|
||||||
@@ -244,8 +253,8 @@ omz: zsh omz-clean omz-fancy
|
|||||||
chsh -s /usr/bin/zsh
|
chsh -s /usr/bin/zsh
|
||||||
@exec zsh
|
@exec zsh
|
||||||
|
|
||||||
##phptools: [PACK] Install only php tooling (composer, phpunit, psalm, phpcs, php-cs-fixer, php-spx, phpmd)
|
##phptools: [PACK] Install only php tooling (composer, phpunit, psalm, phpcs, php-cs-fixer, phpmd)
|
||||||
phptools: composer php-psalm php-spx phpcs phpmd phpstan phpunit
|
phptools: composer php-psalm phpcs phpmd phpstan phpunit
|
||||||
|
|
||||||
##phpstack: [PACK] Install full php stack with tooling
|
##phpstack: [PACK] Install full php stack with tooling
|
||||||
phpstack: php phptools
|
phpstack: php phptools
|
||||||
@@ -310,6 +319,10 @@ phpstack: php phptools
|
|||||||
/vivaldi:
|
/vivaldi:
|
||||||
@./uninstall/vivaldi
|
@./uninstall/vivaldi
|
||||||
|
|
||||||
|
##/wine: Uninstall wine
|
||||||
|
/wine:
|
||||||
|
@./uninstall/wine
|
||||||
|
|
||||||
#===============================================
|
#===============================================
|
||||||
# Service goals
|
# Service goals
|
||||||
#===============================================
|
#===============================================
|
||||||
|
|||||||
@@ -16,13 +16,13 @@ If some dependecies are missed for some of these scripts it is enougth to run `.
|
|||||||
|
|
||||||
```shell
|
```shell
|
||||||
# with git
|
# with git
|
||||||
git clone git@git.axenov.dev:anthony/my-env.git --depth=1 --single-branch
|
git clone git@git.axenov.dev:anthony/shell.git --depth=1 --single-branch
|
||||||
|
|
||||||
# without git
|
# without git
|
||||||
wget -qO - https://git.axenov.dev/anthony/my-env/archive/master.tar.gz | tar -zxf -
|
wget -qO - https://git.axenov.dev/anthony/shell/archive/master.tar.gz | tar -zxf -
|
||||||
|
|
||||||
# get full list of `make` goals
|
# get full list of `make` goals
|
||||||
cd my-env && make
|
cd shell && make
|
||||||
```
|
```
|
||||||
|
|
||||||
## How to add my script?
|
## How to add my script?
|
||||||
@@ -85,6 +85,9 @@ where:
|
|||||||
* https://lug.fh-swf.de/vim/vim-bash/StyleGuideShell.en.pdf
|
* https://lug.fh-swf.de/vim/vim-bash/StyleGuideShell.en.pdf
|
||||||
* https://www.thegeekstuff.com/2010/06/bash-array-tutorial/
|
* https://www.thegeekstuff.com/2010/06/bash-array-tutorial/
|
||||||
* https://www.distributednetworks.com/linux-network-admin/module4/ephemeral-reserved-portNumbers.php
|
* https://www.distributednetworks.com/linux-network-admin/module4/ephemeral-reserved-portNumbers.php
|
||||||
|
* https://github.com/community-scripts/ProxmoxVE/tree/main/install
|
||||||
|
* https://github.com/community-scripts/ProxmoxVE/tree/main/misc
|
||||||
|
* https://faculty.cs.niu.edu/~hutchins/csci480/signals.htm
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
[alias]
|
||||||
a = "add"
|
a = "add"
|
||||||
aa = "add --all" # add all unstaged into index
|
aa = "add --all" # add all unstaged into index
|
||||||
aliases = "config --get-regexp '^alias.*'" # show all aliases
|
aliases = "config --get-regexp '^alias.*'" # show all aliases
|
||||||
@@ -119,6 +120,7 @@ undo = "uncommit"
|
|||||||
unstage = "reset HEAD" # staged file => unstaged
|
unstage = "reset HEAD" # staged file => unstaged
|
||||||
upstream-branch = "!git for-each-ref --format='%(upstream:short)' $(git symbolic-ref -q HEAD)"
|
upstream-branch = "!git for-each-ref --format='%(upstream:short)' $(git symbolic-ref -q HEAD)"
|
||||||
user = "config --local --get-regexp '^user'" # show local user settings (in current repo)
|
user = "config --local --get-regexp '^user'" # show local user settings (in current repo)
|
||||||
|
vacuum="!git reflog expire --expire-unreachable=now --all; git gc --prune=now"
|
||||||
whoami = "user"
|
whoami = "user"
|
||||||
wip = "!git add . && git commit -am 'WIP'"
|
wip = "!git add . && git commit -am 'WIP'"
|
||||||
wipa = "!git add . && git commit --amend -am 'WIP'"
|
wipa = "!git add . && git commit --amend -am 'WIP'"
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ set -oe pipefail
|
|||||||
|
|
||||||
__root__=$( dirname $(readlink -e -- "${BASH_SOURCE}"))
|
__root__=$( dirname $(readlink -e -- "${BASH_SOURCE}"))
|
||||||
source $__root__/helpers/io.sh || exit 255
|
source $__root__/helpers/io.sh || exit 255
|
||||||
|
source $__root__/helpers/git.sh || exit 255
|
||||||
source $__root__/helpers/basic.sh || exit 255
|
source $__root__/helpers/basic.sh || exit 255
|
||||||
source $__root__/helpers/debug.sh || exit 255
|
source $__root__/helpers/debug.sh || exit 255
|
||||||
source $__root__/helpers/packages.sh || exit 255
|
source $__root__/helpers/packages.sh || exit 255
|
||||||
|
|||||||
@@ -42,8 +42,8 @@ arg() {
|
|||||||
|
|
||||||
# clear $arg_search from special and duplicate characters, e.g. 'fas-)dfs' will become 'fasd'
|
# clear $arg_search from special and duplicate characters, e.g. 'fas-)dfs' will become 'fasd'
|
||||||
local arg_chars="$(printf "%s" "$arg_search" \
|
local arg_chars="$(printf "%s" "$arg_search" \
|
||||||
| tr -s "[$arg_search]" 2>&1 >/dev/null \
|
| tr -s "[$arg_search]" 2>/dev/null \
|
||||||
| tr -d "[:punct:][:blank:]" 2>&1 >/dev/null)"
|
| tr -d "[:punct:][:blank:]" 2>/dev/null)"
|
||||||
|
|
||||||
# if $arg_name is not one of $arg_chars the skip it
|
# if $arg_name is not one of $arg_chars the skip it
|
||||||
grep_match "-$arg_name" "^-[$arg_chars]$" || continue
|
grep_match "-$arg_name" "^-[$arg_chars]$" || continue
|
||||||
|
|||||||
@@ -5,6 +5,34 @@ source $( dirname $(readlink -e -- "${BASH_SOURCE}"))/io.sh || exit 255
|
|||||||
# Little handy helpers for scripting
|
# Little handy helpers for scripting
|
||||||
########################################################
|
########################################################
|
||||||
|
|
||||||
|
is_bash() {
|
||||||
|
[[ "$(basename "$SHELL")" != "bash" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
is_sourced() {
|
||||||
|
[[ "${BASH_SOURCE[0]}" != "$0" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
is_root() {
|
||||||
|
[[ "$(id -u)" -ne 0 || $(ps -o comm= -p $PPID) == "sudo" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
get_os() {
|
||||||
|
case "$(uname -s)" in
|
||||||
|
Linux*) echo Linux ;;
|
||||||
|
Darwin*) echo Macos ;;
|
||||||
|
CYGWIN*) echo Cygwin ;;
|
||||||
|
MINGW*) echo MinGw ;;
|
||||||
|
MSYS_NT*) echo Git ;;
|
||||||
|
*) return 1 ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
get_os_id() {
|
||||||
|
[ -f /etc/os-release ] && source /etc/os-release
|
||||||
|
echo "$ID"
|
||||||
|
}
|
||||||
|
|
||||||
# convert relative path $1 to full one
|
# convert relative path $1 to full one
|
||||||
abspath() {
|
abspath() {
|
||||||
echo $(realpath -q "${1/#\~/$HOME}")
|
echo $(realpath -q "${1/#\~/$HOME}")
|
||||||
@@ -66,7 +94,7 @@ open_url() {
|
|||||||
# unpack .tar.gz file $1 into path $2
|
# unpack .tar.gz file $1 into path $2
|
||||||
unpack_targz() {
|
unpack_targz() {
|
||||||
require tar
|
require tar
|
||||||
tar -xzf "$1" -C "$2"
|
tar -xzvf "$1" -C "$2"
|
||||||
}
|
}
|
||||||
|
|
||||||
# make soft symbolic link of path $1 to path $2
|
# make soft symbolic link of path $1 to path $2
|
||||||
@@ -93,3 +121,7 @@ is_int() {
|
|||||||
is_number() {
|
is_number() {
|
||||||
[[ "$1" =~ ^[0-9]+([.,][0-9]+)?$ ]]
|
[[ "$1" =~ ^[0-9]+([.,][0-9]+)?$ ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trim() {
|
||||||
|
echo "$1" | xargs
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,26 +1,3 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
source $( dirname $(readlink -e -- "${BASH_SOURCE}"))/io.sh || exit 255
|
source $( dirname $(readlink -e -- "${BASH_SOURCE}"))/io.sh || exit 255
|
||||||
|
|
||||||
########################################################
|
|
||||||
# Functions to debug scripts
|
|
||||||
########################################################
|
|
||||||
|
|
||||||
var_dump() {
|
|
||||||
debug "$1 = ${!1}"
|
|
||||||
}
|
|
||||||
|
|
||||||
print_stacktrace() {
|
|
||||||
STACK=""
|
|
||||||
local i
|
|
||||||
local stack_size=${#FUNCNAME[@]}
|
|
||||||
debug "Callstack:"
|
|
||||||
# for (( i=$stack_size-1; i>=1; i-- )); do
|
|
||||||
for (( i=1; i<$stack_size; i++ )); do
|
|
||||||
local func="${FUNCNAME[$i]}"
|
|
||||||
[ x$func = x ] && func=MAIN
|
|
||||||
local linen="${BASH_LINENO[$(( i - 1 ))]}"
|
|
||||||
local src="${BASH_SOURCE[$i]}"
|
|
||||||
[ x"$src" = x ] && src=non_file_source
|
|
||||||
debug " at $func $src:$linen"
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -46,3 +46,34 @@ docker.exec() {
|
|||||||
debug "Команда: $cmd"
|
debug "Команда: $cmd"
|
||||||
$cmd
|
$cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Выводит информацию о контейнере
|
||||||
|
docker.inspect() {
|
||||||
|
cmd="docker inspect $*"
|
||||||
|
debug "Команда: $cmd"
|
||||||
|
$cmd 2>/dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
docker.ip() { # not finished
|
||||||
|
if [ "$1" ]; then
|
||||||
|
if [ "$1" = "-a" ]; then
|
||||||
|
docker ps -aq \
|
||||||
|
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
||||||
|
| sed -e 's#^/##' \
|
||||||
|
| column -t
|
||||||
|
elif [ "$1" = "-c" ]; then
|
||||||
|
docker-compose ps -q \
|
||||||
|
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
||||||
|
| sed -e 's#^/##' \
|
||||||
|
| column -t
|
||||||
|
else
|
||||||
|
docker inspect --format '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' "$1"
|
||||||
|
docker port "$1"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
docker ps -q \
|
||||||
|
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
||||||
|
| sed -e 's#^/##' \
|
||||||
|
| column -t
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
_dir=$( dirname $(readlink -e -- "${BASH_SOURCE}"))
|
_dir=$( dirname $(readlink -e -- "${BASH_SOURCE}"))
|
||||||
source $_dir/io.sh || exit 255
|
source "$_dir/io.sh" || exit 255
|
||||||
source $_dir/basic.sh || exit 255
|
source "$_dir/basic.sh" || exit 255
|
||||||
source $_dir/pkg.sh || exit 255
|
source "$_dir/packages.sh" || exit 255
|
||||||
|
|
||||||
########################################################
|
########################################################
|
||||||
# Shorthands for git
|
# Shorthands for git
|
||||||
@@ -10,7 +10,7 @@ source $_dir/pkg.sh || exit 255
|
|||||||
|
|
||||||
git.clone_quick() {
|
git.clone_quick() {
|
||||||
require git
|
require git
|
||||||
git clone --depth=1 --single-branch $*
|
git clone --depth=1 --single-branch "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
git.is_repo() {
|
git.is_repo() {
|
||||||
@@ -64,12 +64,12 @@ git.reset() {
|
|||||||
|
|
||||||
git.clone() {
|
git.clone() {
|
||||||
require git
|
require git
|
||||||
git clone $* 2>&1
|
git clone "$*" 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
git.co() {
|
git.co() {
|
||||||
require git
|
require git
|
||||||
git checkout $* 2>&1
|
git checkout "$*" 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
git.is_it_current_branch() {
|
git.is_it_current_branch() {
|
||||||
|
|||||||
28
helpers/help.sh
Normal file
28
helpers/help.sh
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
#TODO source basic.sh
|
||||||
|
#TODO source args-parser/args.sh
|
||||||
|
|
||||||
|
########################################################
|
||||||
|
# Help functions
|
||||||
|
########################################################
|
||||||
|
|
||||||
|
process_help_arg() {
|
||||||
|
command="${FUNCNAME[1]}"
|
||||||
|
need_help=$(arg help 1)
|
||||||
|
[[ "$need_help" -eq 0 ]] && need_help=$(argl help 1)
|
||||||
|
[[ "$need_help" -eq 1 ]] && help "$command"
|
||||||
|
}
|
||||||
|
|
||||||
|
help() {
|
||||||
|
is_function "help.$1" && help."$1" && exit
|
||||||
|
echo "Main help message"
|
||||||
|
}
|
||||||
|
|
||||||
|
help.example() {
|
||||||
|
echo "Example help message"
|
||||||
|
}
|
||||||
|
|
||||||
|
example() {
|
||||||
|
process_help_arg
|
||||||
|
echo "Example command"
|
||||||
|
}
|
||||||
224
helpers/io.sh
224
helpers/io.sh
@@ -7,93 +7,137 @@
|
|||||||
which tput > /dev/null 2>&1 && [[ $(tput -T$TERM colors) -gt 8 ]] && CAN_USE_COLORS=1 || CAN_USE_COLORS=0
|
which tput > /dev/null 2>&1 && [[ $(tput -T$TERM colors) -gt 8 ]] && CAN_USE_COLORS=1 || CAN_USE_COLORS=0
|
||||||
USE_COLORS=${USE_COLORS:-$CAN_USE_COLORS}
|
USE_COLORS=${USE_COLORS:-$CAN_USE_COLORS}
|
||||||
|
|
||||||
[ $USE_COLORS = 1 ] && IINFO="( i )" || IINFO=''
|
# Icons (message prefixes)
|
||||||
[ $USE_COLORS = 1 ] && INOTE="( * )" || INOTE=''
|
[[ "$USE_COLORS" == 1 ]] && IINFO="( i )" || IINFO=''
|
||||||
[ $USE_COLORS = 1 ] && IWARN="( # )" || IWARN=''
|
[[ "$USE_COLORS" == 1 ]] && INOTE="( * )" || INOTE=''
|
||||||
[ $USE_COLORS = 1 ] && IERROR="( ! )" || IERROR=''
|
[[ "$USE_COLORS" == 1 ]] && IWARN="( # )" || IWARN=''
|
||||||
[ $USE_COLORS = 1 ] && IFATAL="( @ )" || IFATAL=''
|
[[ "$USE_COLORS" == 1 ]] && IERROR="( ! )" || IERROR=''
|
||||||
[ $USE_COLORS = 1 ] && ISUCCESS="( ! )" || ISUCCESS=''
|
[[ "$USE_COLORS" == 1 ]] && IFATAL="( @ )" || IFATAL=''
|
||||||
[ $USE_COLORS = 1 ] && IASK="( ? )" || IASK=''
|
[[ "$USE_COLORS" == 1 ]] && ISUCCESS="( ! )" || ISUCCESS=''
|
||||||
[ $USE_COLORS = 1 ] && IDEBUG="(DBG)" || IDEBUG=''
|
[[ "$USE_COLORS" == 1 ]] && IASK="( ? )" || IASK=''
|
||||||
[ $USE_COLORS = 1 ] && IVRB="( + )" || IVRB=''
|
[[ "$USE_COLORS" == 1 ]] && IDEBUG="(DBG)" || IDEBUG=''
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && IVRB="( + )" || IVRB=''
|
||||||
|
|
||||||
[ $USE_COLORS = 1 ] && BOLD="\e[1m" || BOLD=''
|
# Text attributes
|
||||||
[ $USE_COLORS = 1 ] && DIM="\e[2m" || DIM=''
|
[[ "$USE_COLORS" == 1 ]] && FRESET="$(tput sgr0)" || FRESET='' # Normal
|
||||||
[ $USE_COLORS = 1 ] && NOTBOLD="\e[22m" || NOTBOLD='' # sometimes \e[21m
|
[[ "$USE_COLORS" == 1 ]] && FBOLD="$(tput bold)" || FBOLD='' # Bold
|
||||||
[ $USE_COLORS = 1 ] && NOTDIM="\e[22m" || NOTDIM=''
|
[[ "$USE_COLORS" == 1 ]] && FDIM="$(tput dim)" || FDIM='' # Dimmed
|
||||||
[ $USE_COLORS = 1 ] && NORMAL="\e[20m" || NORMAL=''
|
[[ "$USE_COLORS" == 1 ]] && FLINE="$(tput smul)" || FLINE='' # Underlined
|
||||||
[ $USE_COLORS = 1 ] && RESET="\e[0m" || RESET=''
|
[[ "$USE_COLORS" == 1 ]] && FENDLINE="$(tput rmul)" || FENDLINE='' # End of underlined
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLINK="$(tput blink)" || FBLINK='' # Blink
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FREV="$(tput rev)" || FREV='' # Reversed
|
||||||
|
|
||||||
[ $USE_COLORS = 1 ] && FRESET="\e[39m" || FRESET=''
|
# Text colors - normal
|
||||||
[ $USE_COLORS = 1 ] && FBLACK="\e[30m" || FBLACK=''
|
[[ "$USE_COLORS" == 1 ]] && FBLACK="$(tput setaf 0)" || FBLACK='' # Black
|
||||||
[ $USE_COLORS = 1 ] && FWHITE="\e[97m" || FWHITE=''
|
[[ "$USE_COLORS" == 1 ]] && FRED="$(tput setaf 1)" || FRED='' # Red
|
||||||
[ $USE_COLORS = 1 ] && FRED="\e[31m" || FRED=''
|
[[ "$USE_COLORS" == 1 ]] && FGREEN="$(tput setaf 2)" || FGREEN='' # Green
|
||||||
[ $USE_COLORS = 1 ] && FGREEN="\e[32m" || FGREEN=''
|
[[ "$USE_COLORS" == 1 ]] && FYELLOW="$(tput setaf 3)" || FYELLOW='' # Yellow
|
||||||
[ $USE_COLORS = 1 ] && FYELLOW="\e[33m" || FYELLOW=''
|
[[ "$USE_COLORS" == 1 ]] && FBLUE="$(tput setaf 4)" || FBLUE='' # Blue
|
||||||
[ $USE_COLORS = 1 ] && FBLUE="\e[34m" || FBLUE=''
|
[[ "$USE_COLORS" == 1 ]] && FPURPLE="$(tput setaf 5)" || FPURPLE='' # Purple
|
||||||
[ $USE_COLORS = 1 ] && FLRED="\e[91m" || FLRED=''
|
[[ "$USE_COLORS" == 1 ]] && FCYAN="$(tput setaf 6)" || FCYAN='' # Cyan
|
||||||
[ $USE_COLORS = 1 ] && FLGREEN="\e[92m" || FLGREEN=''
|
[[ "$USE_COLORS" == 1 ]] && FWHITE="$(tput setaf 7)" || FWHITE='' # White
|
||||||
[ $USE_COLORS = 1 ] && FLYELLOW="\e[93m" || FLYELLOW=''
|
|
||||||
[ $USE_COLORS = 1 ] && FLBLUE="\e[94m" || FLBLUE=''
|
|
||||||
|
|
||||||
[ $USE_COLORS = 1 ] && BRESET="\e[49m" || BRESET=''
|
# Text colors - bright
|
||||||
[ $USE_COLORS = 1 ] && BBLACK="\e[40m" || BBLACK=''
|
[[ "$USE_COLORS" == 1 ]] && FLBLACK="$(tput setaf 8)" || FLBLACK='' # Black
|
||||||
[ $USE_COLORS = 1 ] && BWHITE="\e[107m" || BWHITE=''
|
[[ "$USE_COLORS" == 1 ]] && FLRED="$(tput setaf 9)" || FLRED='' # Red
|
||||||
[ $USE_COLORS = 1 ] && BRED="\e[41m" || BRED=''
|
[[ "$USE_COLORS" == 1 ]] && FLGREEN="$(tput setaf 10)" || FLGREEN='' # Green
|
||||||
[ $USE_COLORS = 1 ] && BGREEN="\e[42m" || BGREEN=''
|
[[ "$USE_COLORS" == 1 ]] && FLYELLOW="$(tput setaf 11)" || FLYELLOW='' # Yellow
|
||||||
[ $USE_COLORS = 1 ] && BYELLOW="\e[43m" || BYELLOW=''
|
[[ "$USE_COLORS" == 1 ]] && FLBLUE="$(tput setaf 12)" || FLBLUE='' # Blue
|
||||||
[ $USE_COLORS = 1 ] && BBLUE="\e[44m" || BBLUE=''
|
[[ "$USE_COLORS" == 1 ]] && FLPURPLE="$(tput setaf 13)" || FLPURPLE='' # Purple
|
||||||
[ $USE_COLORS = 1 ] && BLRED="\e[101m" || BLRED=''
|
[[ "$USE_COLORS" == 1 ]] && FLCYAN="$(tput setaf 14)" || FLCYAN='' # Cyan
|
||||||
[ $USE_COLORS = 1 ] && BLGREEN="\e[102m" || BLGREEN=''
|
[[ "$USE_COLORS" == 1 ]] && FLWHITE="$(tput setaf 15)" || FLWHITE='' # White
|
||||||
[ $USE_COLORS = 1 ] && BLYELLOW="\e[103m" || BLYELLOW=''
|
|
||||||
[ $USE_COLORS = 1 ] && BLBLUE="\e[104m" || BLBLUE=''
|
|
||||||
|
|
||||||
dt() {
|
# Background colors - normal
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBBLACK="$(tput setab 0)" || FBBLACK='' # Black
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBRED="$(tput setab 1)" || FBRED='' # Red
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBGREEN="$(tput setab 2)" || FBGREEN='' # Green
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBYELLOW="$(tput setab 3)" || FBYELLOW='' # Yellow
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBBLUE="$(tput setab 4)" || FBBLUE='' # Blue
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBPURPLE="$(tput setab 5)" || FBPURPLE='' # Purple
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBCYAN="$(tput setab 6)" || FBCYAN='' # Cyan
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBWHITE="$(tput setab 7)" || FBWHITE='' # White
|
||||||
|
|
||||||
|
# Background colors - bright
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLBLACK="$(tput setab 8)" || FBLBLACK='' # Black
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLRED="$(tput setab 9)" || FBLRED='' # Red
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLGREEN="$(tput setab 10)" || FBLGREEN='' # Green
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLYELLOW="$(tput setab 11)" || FBLYELLOW='' # Yellow
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLBLUE="$(tput setab 12)" || FBLBLUE='' # Blue
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLPURPLE="$(tput setab 13)" || FBLPURPLE='' # Purple
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLCYAN="$(tput setab 14)" || FBLCYAN='' # Cyan
|
||||||
|
[[ "$USE_COLORS" == 1 ]] && FBLWHITE="$(tput setab 15)" || FBLWHITE='' # White
|
||||||
|
|
||||||
|
now() {
|
||||||
echo "[$(date +'%H:%M:%S')] "
|
echo "[$(date +'%H:%M:%S')] "
|
||||||
}
|
}
|
||||||
|
|
||||||
ask() {
|
ask() {
|
||||||
IFS= read -rp "$(print ${BOLD}${BBLUE}${FWHITE}${IASK}${BRESET}\ ${BOLD}$1 ): " $2
|
IFS= read -rp "$(print ${FBOLD}${FBBLUE}${FWHITE}${IASK}${FRESET}\ ${FBOLD}$1 ): " $2
|
||||||
}
|
}
|
||||||
|
|
||||||
print() {
|
print() {
|
||||||
echo -e "$*${RESET}"
|
# if [ -n "$SPINNER_PID" ] && ps -p $SPINNER_PID > /dev/null; then kill $SPINNER_PID > /dev/null; fi
|
||||||
|
echo -e "$*${FRESET}"
|
||||||
|
}
|
||||||
|
|
||||||
|
link() {
|
||||||
|
echo -e "\e]8;;$2\a$1\e]8;;\a"
|
||||||
}
|
}
|
||||||
|
|
||||||
debug() {
|
debug() {
|
||||||
if [ "$2" ]; then
|
if [ "$2" ]; then
|
||||||
print "${DIM}${BOLD}${RESET}${DIM}$(dt)${IDEBUG} ${FUNCNAME[1]:-?}():${BASH_LINENO:-?}\t$1 " >&2
|
print "${FDIM}${FBOLD}${FRESET}${FDIM}$(now)${IDEBUG} ${FUNCNAME[1]:-?}():${BASH_LINENO:-?}\t$1 " >&2
|
||||||
else
|
else
|
||||||
print "${DIM}${BOLD}${RESET}${DIM}$(dt)${IDEBUG} $1 " >&2
|
print "${FDIM}${FBOLD}${FRESET}${FDIM}$(now)${IDEBUG} $1 " >&2
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var_dump() {
|
||||||
|
debug "$1 = ${!1}"
|
||||||
|
}
|
||||||
|
|
||||||
|
print_stacktrace() {
|
||||||
|
STACK=""
|
||||||
|
local i
|
||||||
|
local stack_size=${#FUNCNAME[@]}
|
||||||
|
debug "Callstack:"
|
||||||
|
# for (( i=$stack_size-1; i>=1; i-- )); do
|
||||||
|
for (( i=1; i<$stack_size; i++ )); do
|
||||||
|
local func="${FUNCNAME[$i]}"
|
||||||
|
[ x$func = x ] && func=MAIN
|
||||||
|
local linen="${BASH_LINENO[$(( i - 1 ))]}"
|
||||||
|
local src="${BASH_SOURCE[$i]}"
|
||||||
|
[ x"$src" = x ] && src=non_file_source
|
||||||
|
debug " at $func $src:$linen"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
verbose() {
|
verbose() {
|
||||||
print "${BOLD}$(dt)${IVRB}${RESET}${FYELLOW} $1 "
|
print "${FBOLD}$(now)${IVRB}${FRESET}${FYELLOW} $1 "
|
||||||
}
|
}
|
||||||
|
|
||||||
info() {
|
info() {
|
||||||
print "${BOLD}$(dt)${FWHITE}${BLBLUE}${IINFO}${RESET}${FWHITE} $1 "
|
print "${FBOLD}$(now)${FWHITE}${FBLBLUE}${IINFO}${FRESET}${FWHITE} $1 "
|
||||||
}
|
}
|
||||||
|
|
||||||
note() {
|
note() {
|
||||||
print "${BOLD}$(dt)${DIM}${FWHITE}${INOTE}${RESET} $1 "
|
print "${FBOLD}$(now)${FDIM}${FWHITE}${INOTE}${FRESET} $1 "
|
||||||
}
|
}
|
||||||
|
|
||||||
success() {
|
success() {
|
||||||
print "${BOLD}$(dt)${BGREEN}${FWHITE}${ISUCCESS}${BRESET}$FGREEN $1 "
|
print "${FBOLD}$(now)${FBGREEN}${FWHITE}${ISUCCESS}${FRESET}$FGREEN $1 "
|
||||||
}
|
}
|
||||||
|
|
||||||
warn() {
|
warn() {
|
||||||
print "${BOLD}$(dt)${BYELLOW}${FBLACK}${IWARN}${BRESET}${FYELLOW} Warning:${RESET} $1 "
|
print "${FBOLD}$(now)${FBYELLOW}${FBLACK}${IWARN}${FRESET}${FYELLOW} Warning:${FRESET} $1 "
|
||||||
}
|
}
|
||||||
|
|
||||||
error() {
|
error() {
|
||||||
print "${BOLD}$(dt)${BLRED}${FWHITE}${IERROR} Error: ${BRESET}${FLRED} $1 " >&2
|
print "${FBOLD}$(now)${FBLRED}${FWHITE}${IERROR} Error: ${FRESET}${FLRED} $1 " >&2
|
||||||
}
|
}
|
||||||
|
|
||||||
fatal() {
|
fatal() {
|
||||||
print "${BOLD}$(dt)${BRED}${FWHITE}${IFATAL} FATAL: $1 " >&2
|
print "${FBOLD}$(now)${FBRED}${FWHITE}${IFATAL} FATAL: $1 " >&2
|
||||||
print_stacktrace
|
print_stacktrace
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -116,10 +160,43 @@ die() {
|
|||||||
|
|
||||||
# experiments ==============================================================================
|
# experiments ==============================================================================
|
||||||
|
|
||||||
|
# spinner() {
|
||||||
|
# local frames=('⠋' '⠙' '⠹' '⠸' '⠼' '⠴' '⠦' '⠧' '⠇' '⠏')
|
||||||
|
# local spin_i=0
|
||||||
|
# local interval=0.1
|
||||||
|
# printf "\e[?25l"
|
||||||
|
|
||||||
|
# local color="${FGREEN}"
|
||||||
|
|
||||||
|
# while true; do
|
||||||
|
# printf "\r ${color}%s${CL}" "${frames[spin_i]}"
|
||||||
|
# spin_i=$(( (spin_i + 1) % ${#frames[@]} ))
|
||||||
|
# sleep "$interval"
|
||||||
|
# done
|
||||||
|
# }
|
||||||
|
|
||||||
|
# echo "lorem ipsum dolor sit amet"
|
||||||
|
# spinner &
|
||||||
|
# SPINNER_PID=$!
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# ===========
|
||||||
|
|
||||||
|
|
||||||
# https://unix.stackexchange.com/a/269085
|
# https://unix.stackexchange.com/a/269085
|
||||||
# https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit
|
# https://en.wikipedia.org/wiki/ANSI_escape_code#8-bit
|
||||||
# https://linuxcommand.org/lc3_adv_tput.php
|
# https://linuxcommand.org/lc3_adv_tput.php
|
||||||
# https://gist.github.com/dtmilano/4055d6df5b6e4ea87c5a72dc2d604193
|
# https://gist.github.com/nowmilano/4055d6df5b6e4ea87c5a72dc2d604193
|
||||||
# https://gist.github.com/nick3499/402a6d7dccd474f2bdb679f4311b1238
|
# https://gist.github.com/nick3499/402a6d7dccd474f2bdb679f4311b1238
|
||||||
# https://gist.github.com/connorjan/2b02126868157c2b69f9aa0a052cdc86
|
# https://gist.github.com/connorjan/2b02126868157c2b69f9aa0a052cdc86
|
||||||
|
|
||||||
@@ -143,53 +220,6 @@ die() {
|
|||||||
|
|
||||||
# ===========
|
# ===========
|
||||||
|
|
||||||
# Text color - normal
|
|
||||||
# fgblack="$(tput setaf 0)" # Black
|
|
||||||
# fgred="$(tput setaf 1)" # Red
|
|
||||||
# fggreen="$(tput setaf 2)" # Green
|
|
||||||
# fgyellow="$(tput setaf 3)" # Yellow
|
|
||||||
# fgblue="$(tput setaf 4)" # Blue
|
|
||||||
# fgpurple="$(tput setaf 5)" # Purple
|
|
||||||
# fgcyan="$(tput setaf 6)" # Cyan
|
|
||||||
# fgwhite="$(tput setaf 7)" # White
|
|
||||||
|
|
||||||
# # Text color - bright
|
|
||||||
# bfgblack="$(tput setaf 8)" # Black
|
|
||||||
# bfgred="$(tput setaf 9)" # Red
|
|
||||||
# bfggreen="$(tput setaf 10)" # Green
|
|
||||||
# bfgyellow="$(tput setaf 11)" # Yellow
|
|
||||||
# bfgblue="$(tput setaf 12)" # Blue
|
|
||||||
# bfgpurple="$(tput setaf 13)" # Purple
|
|
||||||
# bfgcyan="$(tput setaf 14)" # Cyan
|
|
||||||
# bfgwhite="$(tput setaf 15)" # White
|
|
||||||
|
|
||||||
# # Background color - normal
|
|
||||||
# bgblack="$(tput setab 0)" # Black - Background
|
|
||||||
# bgred="$(tput setab 1)" # Red
|
|
||||||
# bggreen="$(tput setab 2)" # Green
|
|
||||||
# bgyellow="$(tput setab 3)" # Yellow
|
|
||||||
# bgblue="$(tput setab 4)" # Blue
|
|
||||||
# bgpurple="$(tput setab 5)" # Purple
|
|
||||||
# bgcyan="$(tput setab 6)" # Cyan
|
|
||||||
# bgwhite="$(tput setab 7)" # White
|
|
||||||
|
|
||||||
# # Background color - bright
|
|
||||||
# bbgblack="$(tput setab 8)" # Black - Background - Bright
|
|
||||||
# bbgred="$(tput setab 9)" # Red
|
|
||||||
# bbggreen="$(tput setab 10)" # Green
|
|
||||||
# bbgyellow="$(tput setab 11)" # Yellow
|
|
||||||
# bbgblue="$(tput setab 12)" # Blue
|
|
||||||
# bbgpurple="$(tput setab 13)" # Purple
|
|
||||||
# bbgcyan="$(tput setab 14)" # Cyan
|
|
||||||
# bbgwhite="$(tput setab 15)" # White
|
|
||||||
|
|
||||||
# # Other attributes
|
|
||||||
# normal="$(tput sgr0)" # text reset
|
|
||||||
# bold="$(tput bold)" # make bold
|
|
||||||
# underline="$(tput smul)" # underline
|
|
||||||
# nounderlin="$(tput rmul)" # remove underline
|
|
||||||
# mkblink="$(tput blink)" # make blink
|
|
||||||
# reverse="$(tput rev)" # reverse
|
|
||||||
|
|
||||||
# ===========
|
# ===========
|
||||||
|
|
||||||
|
|||||||
@@ -6,10 +6,10 @@
|
|||||||
|
|
||||||
# https://askubuntu.com/a/30414
|
# https://askubuntu.com/a/30414
|
||||||
is_full_screen() {
|
is_full_screen() {
|
||||||
local WINDOW=$(echo $(xwininfo -id $(xdotool getactivewindow) -stats | \
|
local WINDOW=$(xwininfo -id "$(xdotool getactivewindow)" -stats \
|
||||||
egrep '(Width|Height):' | \
|
| grep -E '(Width|Height):' \
|
||||||
awk '{print $NF}') | \
|
| awk '{print $NF}' \
|
||||||
sed -e 's/ /x/')
|
| sed -e 's/ /x/')
|
||||||
local SCREEN=$(xdpyinfo | grep -m1 dimensions | awk '{print $2}')
|
local SCREEN=$(xdpyinfo | grep -m1 dimensions | awk '{print $2}')
|
||||||
if [ "$WINDOW" = "$SCREEN" ]; then
|
if [ "$WINDOW" = "$SCREEN" ]; then
|
||||||
return 0
|
return 0
|
||||||
@@ -17,19 +17,6 @@ is_full_screen() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
curltime() {
|
|
||||||
curl -w @- -o /dev/null -s "$@" <<'EOF'
|
|
||||||
time_namelookup: %{time_namelookup} sec\n
|
|
||||||
time_connect: %{time_connect} sec\n
|
|
||||||
time_appconnect: %{time_appconnect} sec\n
|
|
||||||
time_pretransfer: %{time_pretransfer} sec\n
|
|
||||||
time_redirect: %{time_redirect} sec\n
|
|
||||||
time_starttransfer: %{time_starttransfer} sec\n
|
|
||||||
---------------\n
|
|
||||||
time_total: %{time_total} sec\n
|
|
||||||
EOF
|
|
||||||
}
|
|
||||||
|
|
||||||
ytm() {
|
ytm() {
|
||||||
youtube-dl \
|
youtube-dl \
|
||||||
--extract-audio \
|
--extract-audio \
|
||||||
@@ -38,29 +25,5 @@ ytm() {
|
|||||||
--format bestaudio \
|
--format bestaudio \
|
||||||
--write-info-json \
|
--write-info-json \
|
||||||
--output "$HOME/Downloads/ytm/%(playlist_title)s/%(channel)s - %(title)s.%(ext)s" \
|
--output "$HOME/Downloads/ytm/%(playlist_title)s/%(channel)s - %(title)s.%(ext)s" \
|
||||||
$*
|
"$@"
|
||||||
}
|
|
||||||
|
|
||||||
docker.ip() { # not finished
|
|
||||||
if [ "$1" ]; then
|
|
||||||
if [ "$1" = "-a" ]; then
|
|
||||||
docker ps -aq \
|
|
||||||
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
|
||||||
| sed -e 's#^/##' \
|
|
||||||
| column -t
|
|
||||||
elif [ "$1" = "-c" ]; then
|
|
||||||
docker-compose ps -q \
|
|
||||||
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
|
||||||
| sed -e 's#^/##' \
|
|
||||||
| column -t
|
|
||||||
else
|
|
||||||
docker inspect --format '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' "$1"
|
|
||||||
docker port "$1"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
docker ps -q \
|
|
||||||
| xargs -n 1 docker inspect --format '{{.Name}}{{range .NetworkSettings.Networks}} {{.IPAddress}}{{end}}' \
|
|
||||||
| sed -e 's#^/##' \
|
|
||||||
| column -t
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|||||||
51
helpers/net.sh
Normal file
51
helpers/net.sh
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
########################################################
|
||||||
|
# Networking functions
|
||||||
|
########################################################
|
||||||
|
|
||||||
|
get_current_ip() {
|
||||||
|
local CURRENT_IP
|
||||||
|
[ -f /etc/os-release ] && source /etc/os-release
|
||||||
|
case "$ID" in
|
||||||
|
debian|ubuntu) CURRENT_IP=$(hostname -I | awk '{print $1}') ;;
|
||||||
|
alpine) CURRENT_IP=$(ip -4 addr show eth0 | awk '/inet / {print $2}' | cut -d/ -f1 | head -n 1) ;;
|
||||||
|
*) CURRENT_IP="Unknown" ;;
|
||||||
|
esac
|
||||||
|
echo "$CURRENT_IP"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_external_ip() {
|
||||||
|
local ip="$(curl -s https://api.myip.com | jq .ip)"
|
||||||
|
echo "$ip" | tr -d '"'
|
||||||
|
}
|
||||||
|
|
||||||
|
is_valid_ipv4() {
|
||||||
|
local ip="$1"
|
||||||
|
local regex="^([0-9]{1,3}\.){3}[0-9]{1,3}$"
|
||||||
|
|
||||||
|
if [[ $ip =~ $regex ]]; then
|
||||||
|
IFS='.' read -r -a parts <<< "$ip"
|
||||||
|
for part in "${parts[@]}"; do
|
||||||
|
if ! [[ $part =~ ^[0-9]+$ ]] || ((part < 0 || part > 255)); then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
curltime() {
|
||||||
|
curl -w @- -o /dev/null -s "$@" <<'EOF'
|
||||||
|
time_namelookup: %{time_namelookup} sec\n
|
||||||
|
time_connect: %{time_connect} sec\n
|
||||||
|
time_appconnect: %{time_appconnect} sec\n
|
||||||
|
time_pretransfer: %{time_pretransfer} sec\n
|
||||||
|
time_redirect: %{time_redirect} sec\n
|
||||||
|
time_starttransfer: %{time_starttransfer} sec\n
|
||||||
|
---------------\n
|
||||||
|
time_total: %{time_total} sec\n
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
63
helpers/notif.sh
Normal file
63
helpers/notif.sh
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
########################################################
|
||||||
|
# Notifications
|
||||||
|
########################################################
|
||||||
|
|
||||||
|
TITLE="$0"
|
||||||
|
NTFY_CHANNEL="example"
|
||||||
|
|
||||||
|
# отправляет простую нотификацию
|
||||||
|
ntfy_info() {
|
||||||
|
require ntfy
|
||||||
|
ntfy send \
|
||||||
|
--title "$TITLE" \
|
||||||
|
--message "$1" \
|
||||||
|
--priority 1 \
|
||||||
|
"$NTFY_CHANNEL"
|
||||||
|
}
|
||||||
|
|
||||||
|
# отправляет нотификацию с предупреждением
|
||||||
|
ntfy_warn() {
|
||||||
|
require ntfy
|
||||||
|
ntfy send \
|
||||||
|
--title "$TITLE" \
|
||||||
|
--tags "warning" \
|
||||||
|
--message "$1" \
|
||||||
|
--priority 5 \
|
||||||
|
"$NTFY_CHANNEL"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
notify () {
|
||||||
|
if ! installed "notify-send"; then
|
||||||
|
warning "Notifications toggled on, but 'notify-send' is not installed!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
[ -n "$1" ] && local title="$1"
|
||||||
|
local text="$2"
|
||||||
|
local level="$3"
|
||||||
|
local icon="$4"
|
||||||
|
case "$level" in
|
||||||
|
critical) local timeout=0 ;;
|
||||||
|
low) local timeout=5000 ;;
|
||||||
|
*) local timeout=10000 ;;
|
||||||
|
esac
|
||||||
|
debug "$title / $text / $level / $icon / $timeout"
|
||||||
|
notify-send "$title" "$text" -a "$0" -u "$level" -i "$icon" -t $timeout
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO: docblock
|
||||||
|
notify_error() {
|
||||||
|
notify "Error" "$1" "critical" "dialog-error"
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO: docblock
|
||||||
|
notify_warning() {
|
||||||
|
notify "Warning" "$1" "normal" "dialog-warning"
|
||||||
|
}
|
||||||
|
|
||||||
|
# TODO: docblock
|
||||||
|
notify_info() {
|
||||||
|
notify "" "$1" "low" "dialog-information"
|
||||||
|
}
|
||||||
21
helpers/traps.sh
Normal file
21
helpers/traps.sh
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
#TODO source basic.sh
|
||||||
|
#TODO source args-parser/args.sh
|
||||||
|
|
||||||
|
########################################################
|
||||||
|
# Trap usage examples
|
||||||
|
########################################################
|
||||||
|
|
||||||
|
# for sig in SIGHUP SIGINT SIGQUIT SIGABRT SIGKILL SIGTERM SIGTSTP; do
|
||||||
|
# # shellcheck disable=SC2064
|
||||||
|
# trap "set +x && echo && echo && echo '*** Прервано сигналом $sig, остановка ***' && exit" $sig
|
||||||
|
# done
|
||||||
|
|
||||||
|
for sig in SIGHUP SIGINT SIGQUIT SIGABRT SIGKILL SIGTERM SIGTSTP; do
|
||||||
|
trap "myfunc" $sig
|
||||||
|
done
|
||||||
|
|
||||||
|
myfunc() {
|
||||||
|
echo "trapped!"
|
||||||
|
exit
|
||||||
|
}
|
||||||
6
install/clamav
Executable file
6
install/clamav
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
##makedesc: ClamAV (WIP)
|
||||||
|
|
||||||
|
sudo apt install clamav -y && \
|
||||||
|
echo "DatabaseMirror packages.microsoft.com/clamav" | sudo tee -a /etc/clamav/freshclam.conf && \
|
||||||
|
sudo freshclam
|
||||||
@@ -25,10 +25,10 @@ php "$HOME/install/other/composer-setup.php" \
|
|||||||
--filename="composer"
|
--filename="composer"
|
||||||
|
|
||||||
COMPOSER_GLOBAL_HOME="$($HOME/.local/bin/composer config -g home)"
|
COMPOSER_GLOBAL_HOME="$($HOME/.local/bin/composer config -g home)"
|
||||||
NEWPATH="export PATH=\"$COMPOSER_GLOBAL_HOME/vendor/bin:\${PATH}\""
|
NEWPATH="PATH=\"$COMPOSER_GLOBAL_HOME/vendor/bin:\${PATH}\""
|
||||||
cat "$HOME/.profile" | grep -qoh "$NEWPATH" || {
|
cat "$HOME/.profile" | grep -qoh "$NEWPATH" || {
|
||||||
$NEWPATH
|
export "$NEWPATH"
|
||||||
echo "$NEWPATH" >> "$HOME/.profile"
|
echo "export $NEWPATH" >> "$HOME/.profile"
|
||||||
}
|
}
|
||||||
|
|
||||||
source "$HOME/.profile"
|
source "$HOME/.profile"
|
||||||
|
|||||||
@@ -4,12 +4,51 @@ source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 25
|
|||||||
|
|
||||||
title
|
title
|
||||||
|
|
||||||
sudo apt install -y --autoremove flameshot && \
|
# https://github.com/flameshot-org/flameshot?tab=readme-ov-file#compilation
|
||||||
sudo systemctl restart flameshot
|
# sudo apt install -y --autoremove flameshot && \
|
||||||
|
# sudo systemctl restart flameshot
|
||||||
|
|
||||||
|
dir="$HOME/install"
|
||||||
|
clone_dir="$dir/flameshot"
|
||||||
|
mkdir -p "$dir"
|
||||||
|
|
||||||
|
sudo apt install -y \
|
||||||
|
g++ \
|
||||||
|
cmake \
|
||||||
|
build-essential \
|
||||||
|
qtbase5-dev \
|
||||||
|
qttools5-dev-tools \
|
||||||
|
libqt5svg5-dev \
|
||||||
|
qttools5-dev \
|
||||||
|
libqt5dbus5 \
|
||||||
|
libqt5network5 \
|
||||||
|
libqt5core5a \
|
||||||
|
libqt5widgets5 \
|
||||||
|
libqt5gui5 \
|
||||||
|
libqt5svg5
|
||||||
|
|
||||||
|
if [ ! -d "$clone_dir" ]; then
|
||||||
|
git clone --depth=1 --single-branch https://github.com/flameshot-org/flameshot.git "$clone_dir"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Directory where build files will be placed, may be relative
|
||||||
|
export BUILD_DIR=build
|
||||||
|
|
||||||
|
# Directory prefix where flameshot will be installed. If you are just building and don't want to
|
||||||
|
# install, comment this environment variable.
|
||||||
|
# This excludes the bin/flameshot part of the install,
|
||||||
|
# e.g. in /opt/flameshot/bin/flameshot, the CMAKE_INSTALL_PREFIX is /opt/flameshot
|
||||||
|
# This must be an absolute path. Requires CMAKE 3.29.
|
||||||
|
export CMAKE_INSTALL_PREFIX=/opt/flameshot
|
||||||
|
|
||||||
|
cd "$clone_dir" && \
|
||||||
|
git pull && \
|
||||||
|
cmake -S . -B "$BUILD_DIR" && \
|
||||||
|
cmake --build "$BUILD_DIR"
|
||||||
|
|
||||||
[ $? = 0 ] && {
|
[ $? = 0 ] && {
|
||||||
echo
|
echo
|
||||||
success "flameshot installed!"
|
success "flameshot installed!"
|
||||||
flameshot -v
|
# /opt/flameshot/flameshot -v
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
##makedesc: Install Wireguard + FRKN
|
##makedesc: Install Wireguard + FRKN (deprecated)
|
||||||
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
||||||
|
|
||||||
# https://frkn.org/ru/installation
|
# https://frkn.org/ru/installation
|
||||||
@@ -11,7 +11,7 @@ cd "$HOME/install/frkn"
|
|||||||
|
|
||||||
apt_install wireguard jq
|
apt_install wireguard jq
|
||||||
|
|
||||||
countries=(uk ru nl nl2 ch)
|
countries=(jp nl tr at ru se)
|
||||||
for idx in ${!countries[@]}; do
|
for idx in ${!countries[@]}; do
|
||||||
country=${countries[idx]}
|
country=${countries[idx]}
|
||||||
info "Downloading config for $country ($(expr $idx + 1)/${#countries[@]})"
|
info "Downloading config for $country ($(expr $idx + 1)/${#countries[@]})"
|
||||||
|
|||||||
@@ -1,64 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
# https://www.devas.life/effective-neovim-setup-for-web-development-towards-2024/
|
|
||||||
|
|
||||||
set -eo pipefail
|
|
||||||
trap ontrap SIGINT SIGTERM SIGSTOP
|
|
||||||
|
|
||||||
ontrap() {
|
|
||||||
echo
|
|
||||||
echo "[!] Interrupted"
|
|
||||||
exit
|
|
||||||
}
|
|
||||||
|
|
||||||
[ -z "$1" ] && version=0.10.1 || version="$1"
|
|
||||||
|
|
||||||
filedir="$HOME/install/neovim-$version"
|
|
||||||
filename="nvim-linux64.tar.gz"
|
|
||||||
filepath="$filedir/$filename"
|
|
||||||
configdir="$HOME/.config/nvim"
|
|
||||||
localdir="$HOME/.local"
|
|
||||||
|
|
||||||
echo "[*] Installing neovim v$version"
|
|
||||||
|
|
||||||
if [ -d $configdir ]; then
|
|
||||||
mv $configdir "$configdir.bak-$(date +'%Y%m%d_%H%M%S')"
|
|
||||||
fi
|
|
||||||
|
|
||||||
mkdir -p $filedir $configdir $localdir/{bin,lib,share}
|
|
||||||
|
|
||||||
if [ ! -f $filepath ]; then
|
|
||||||
echo "[*] Downloading to $filepath..."
|
|
||||||
wget -q https://github.com/neovim/neovim/releases/download/v$version/nvim-linux64.tar.gz \
|
|
||||||
-O $filepath \
|
|
||||||
--show-progress
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "[*] Unpacking: $filepath..."
|
|
||||||
tar -zxf $filepath -C $filedir
|
|
||||||
cp -rf $filedir/nvim-linux64/bin/nvim $localdir/bin/
|
|
||||||
cp -rf $filedir/nvim-linux64/lib/nvim $localdir/lib/
|
|
||||||
cp -rf $filedir/nvim-linux64/share $localdir/share
|
|
||||||
rm -rf $filedir/nvim-linux64
|
|
||||||
|
|
||||||
echo "[*] Reinit git repo..."
|
|
||||||
git clone https://github.com/LazyVim/starter \
|
|
||||||
$configdir \
|
|
||||||
--depth=1 \
|
|
||||||
--single-branch
|
|
||||||
cd $configdir
|
|
||||||
rm -rf .git
|
|
||||||
git init -q
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,43 +1,45 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
##makedesc: Install lite-xl
|
##makedesc: Install lite-xl v2.1.7
|
||||||
|
|
||||||
# https://github.com/lite-xl/lite-xl/releases
|
# https://github.com/lite-xl/lite-xl/releases
|
||||||
# https://lite-xl.com/en/documentation/build
|
# https://lite-xl.com/setup/getting-started/
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo "Installing lite-xl v2.1.0..."
|
echo "Installing lite-xl v2.1.7..."
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
tar_url="https://github.com/lite-xl/lite-xl/releases/download/v2.1.0/lite-xl-v2.1.0-addons-linux-x86_64-portable.tar.gz"
|
tar_url="https://github.com/lite-xl/lite-xl/releases/download/v2.1.7/lite-xl-v2.1.7-addons-linux-x86_64-portable.tar.gz"
|
||||||
tar_filepath="/tmp/lite-xl.tar.gz"
|
lpm_url="https://github.com/lite-xl/lite-xl-plugin-manager/releases/download/latest/lpm.x86_64-linux"
|
||||||
|
tar_filepath="$HOME/install/lite-xl-v2.1.7.tar.gz"
|
||||||
untar_dir="$HOME/install"
|
untar_dir="$HOME/install"
|
||||||
untar_subdir="$untar_dir/lite-xl"
|
|
||||||
dest_bin_dir="$HOME/.local/bin"
|
|
||||||
dest_config_dir="$HOME/.config/lite-xl"
|
|
||||||
dest_share_dir="$HOME/.local/share"
|
|
||||||
dest_share_subdir="$dest_share_dir/lite-xl"
|
|
||||||
|
|
||||||
wget "$tar_url" -O "$tar_filepath"
|
rm -rf \
|
||||||
|
"$HOME/.local/bin/lpm" \
|
||||||
|
"$HOME/install/lite-xl" \
|
||||||
|
"$HOME/.local/bin/lite-xl" \
|
||||||
|
"$HOME/.local/share/lite-xl"
|
||||||
|
|
||||||
mkdir -vp \
|
mkdir -vp \
|
||||||
"$untar_dir" \
|
"$untar_dir" \
|
||||||
#"$dest_config" \
|
"$HOME/.local/bin" \
|
||||||
"$dest_bin_dir" \
|
"$HOME/.local/share/lite-xl"
|
||||||
"$dest_share_dir"
|
|
||||||
|
|
||||||
tar -xzf "$tar_filepath" -C "$untar_dir"
|
wget "$tar_url" -O "$tar_filepath" && \
|
||||||
mv -fv "$untar_subdir/lite-xl" "$dest_bin_dir/lite-xl"
|
wget "$lpm_url" -O "$HOME/.local/bin/lpm" && \
|
||||||
mv -fvT "$untar_subdir/data" "$dest_share_subdir"
|
chmod +x "$HOME/.local/bin/lpm" && \
|
||||||
rm -fr "$tar_file" "$untar_subdir"
|
tar -xzf "$tar_filepath" -C "$untar_dir" && \
|
||||||
|
cp -vf "$untar_dir/lite-xl/lite-xl" "$HOME/.local/bin/" && \
|
||||||
|
cp -vfr "$untar_dir"/lite-xl/data/* "$HOME/.local/share/lite-xl/"
|
||||||
|
|
||||||
# echo -e "\nexport LITE_SCALE=1 # https://github.com/lite-xl/lite-xl/issues/1173\n" >> $HOME/.profile
|
# echo -e "\nexport LITE_SCALE=1 # https://github.com/lite-xl/lite-xl/issues/1173\n" >> $HOME/.profile
|
||||||
cat << EOF > "$dest_share_dir/applications/org.lite_xl.lite_xl.desktop"
|
cat << EOF > "$HOME/.local/share/applications/org.lite_xl.lite_xl.desktop"
|
||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
Type=Application
|
Type=Application
|
||||||
Name=Lite XL
|
Name=Lite XL
|
||||||
Comment=A lightweight text editor written in Lua
|
Comment=A lightweight text editor written in Lua
|
||||||
Exec=env LITE_SCALE=1 ${dest_bin_dir}/lite-xl %F
|
Exec=$HOME/.local/bin/lite-xl %F
|
||||||
Icon=lite-xl
|
Icon=lite-xl
|
||||||
Terminal=false
|
Terminal=false
|
||||||
StartupWMClass=lite-xl
|
StartupWMClass=lite-xl
|
||||||
@@ -48,53 +50,6 @@ EOF
|
|||||||
sudo update-desktop-database && \
|
sudo update-desktop-database && \
|
||||||
xdg-desktop-menu forceupdate
|
xdg-desktop-menu forceupdate
|
||||||
|
|
||||||
echo
|
|
||||||
echo "==============================================="
|
|
||||||
echo "Installing lite-xl plugins..."
|
|
||||||
echo "https://github.com/lite-xl/lite-xl-plugins"
|
|
||||||
echo "==============================================="
|
|
||||||
echo
|
|
||||||
|
|
||||||
download_plugin() {
|
|
||||||
echo "- $1"
|
|
||||||
curl -s "https://raw.githubusercontent.com/lite-xl/lite-xl-plugins/master/plugins/$1.lua" \
|
|
||||||
> "$dest_share_subdir/plugins/$1.lua"
|
|
||||||
}
|
|
||||||
|
|
||||||
download_plugin "align_carets"
|
|
||||||
download_plugin "autosaveonfocuslost"
|
|
||||||
download_plugin "bracketmatch"
|
|
||||||
download_plugin "copyfilelocation"
|
|
||||||
download_plugin "dragdropselected"
|
|
||||||
download_plugin "fontconfig"
|
|
||||||
download_plugin "force_syntax"
|
|
||||||
download_plugin "lfautoinsert"
|
|
||||||
download_plugin "markers"
|
|
||||||
download_plugin "memoryusage"
|
|
||||||
download_plugin "minimap"
|
|
||||||
download_plugin "navigate"
|
|
||||||
download_plugin "openselected"
|
|
||||||
download_plugin "restoretabs"
|
|
||||||
download_plugin "smoothcaret"
|
|
||||||
|
|
||||||
# echo "- eofnewline-xl"
|
|
||||||
# curl -s "https://raw.githubusercontent.com/bokunodev/lite_modules/master/plugins/eofnewline-xl.lua" \
|
|
||||||
# > "$dest_share_subdir/plugins/eofnewline-xl.lua"
|
|
||||||
|
|
||||||
echo "- language_env"
|
|
||||||
curl -s "https://raw.githubusercontent.com/anthonyaxenov/lite-xl-env-syntax/master/language_env.lua" \
|
|
||||||
> "$dest_share_subdir/plugins/language_env.lua"
|
|
||||||
|
|
||||||
echo "- language_ignore"
|
|
||||||
curl -s "https://raw.githubusercontent.com/anthonyaxenov/lite-xl-ignore-syntax/master/language_ignore.lua" \
|
|
||||||
> "$dest_share_subdir/plugins/language_ignore.lua"
|
|
||||||
|
|
||||||
# echo "- language-containerfile"
|
|
||||||
# git clone -q "https://github.com/FilBot3/lite-xl-language-containerfile.git" \
|
|
||||||
# "$dest_share_subdir/plugins/language_containerfile"
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "Finish!"
|
echo "Finish!"
|
||||||
echo "- $dest_bin_dir/lite-xl"
|
|
||||||
echo "- $dest_share_subdir"
|
|
||||||
echo
|
echo
|
||||||
|
|||||||
33
install/nvim
Executable file
33
install/nvim
Executable file
@@ -0,0 +1,33 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
##makedesc: Install nvim + lazyvim
|
||||||
|
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
||||||
|
|
||||||
|
# https://www.lazyvim.org/installation
|
||||||
|
# https://www.devas.life/effective-neovim-setup-for-web-development-towards-2024/
|
||||||
|
|
||||||
|
title
|
||||||
|
|
||||||
|
require git
|
||||||
|
|
||||||
|
nvimUrl="https://github.com/neovim/neovim/releases/latest/download/nvim-linux-x86_64.tar.gz"
|
||||||
|
installPath="$HOME/install"
|
||||||
|
installTar="$installPath/nvim.tar.gz"
|
||||||
|
|
||||||
|
[ -d "$HOME/.config/nvim" ] && mv "$HOME"/.config/nvim{,.bak}
|
||||||
|
[ -d "$HOME/.local/share/nvim" ] && mv "$HOME"/.local/share/nvim{,.bak}
|
||||||
|
[ -d "$HOME/.local/state/nvim" ] && mv "$HOME"/.local/state/nvim{,.bak}
|
||||||
|
[ -d "$HOME/.cache/nvim" ] && mv "$HOME"/.cache/nvim{,.bak}
|
||||||
|
|
||||||
|
download "$nvimUrl" "$installTar"
|
||||||
|
unpack_targz "$installTar" "$installPath"
|
||||||
|
|
||||||
|
sudo rm -vrf /opt/nvim
|
||||||
|
sudo mv -v "$installPath/nvim-linux-x86_64" /opt/nvim
|
||||||
|
|
||||||
|
git.clone_quick https://github.com/LazyVim/starter "$HOME/.config/nvim"
|
||||||
|
rm -rf "$HOME/.config/nvim/.git"
|
||||||
|
|
||||||
|
sudo update-desktop-database && \
|
||||||
|
xdg-desktop-menu forceupdate
|
||||||
|
|
||||||
|
# export PATH="$PATH:/opt/nvim-linux-x86_64/bin"
|
||||||
@@ -1,16 +1,16 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
##makedesc: Install php v8.3 + ppa
|
##makedesc: Install php v8.4
|
||||||
|
|
||||||
[ $1 ] && PHPVER="$1" || PHPVER="8.3"
|
[ "$1" ] && PHPVER="$1" || PHPVER="8.4"
|
||||||
echo
|
echo
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo "Installing php${PHPVER}..."
|
echo "Installing php${PHPVER}..."
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
sudo LC_ALL=C.UTF-8 add-apt-repository -y ppa:ondrej/php
|
|
||||||
sudo apt install -y --autoremove \
|
sudo apt install -y --autoremove \
|
||||||
php${PHPVER} \
|
php${PHPVER}-fpm \
|
||||||
|
php${PHPVER}-dev \
|
||||||
php${PHPVER}-apcu \
|
php${PHPVER}-apcu \
|
||||||
php${PHPVER}-bcmath \
|
php${PHPVER}-bcmath \
|
||||||
php${PHPVER}-cli \
|
php${PHPVER}-cli \
|
||||||
@@ -24,6 +24,7 @@ sudo apt install -y --autoremove \
|
|||||||
php${PHPVER}-mysql \
|
php${PHPVER}-mysql \
|
||||||
php${PHPVER}-opcache \
|
php${PHPVER}-opcache \
|
||||||
php${PHPVER}-pgsql \
|
php${PHPVER}-pgsql \
|
||||||
|
php${PHPVER}-simplexml \
|
||||||
php${PHPVER}-soap \
|
php${PHPVER}-soap \
|
||||||
php${PHPVER}-sqlite3 \
|
php${PHPVER}-sqlite3 \
|
||||||
php${PHPVER}-xdebug \
|
php${PHPVER}-xdebug \
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
##makedesc: Install rustdesk client v1.1.9 (deb)
|
##makedesc: Install rustdesk client v1.4.2 (deb)
|
||||||
|
|
||||||
[ $1 ] && RDVER="$1" || RDVER="1.1.9"
|
[ "$1" ] && RDVER="$1" || RDVER="1.4.2"
|
||||||
echo
|
echo
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo "Installing rustdesk v$RDVER..."
|
echo "Installing rustdesk v$RDVER..."
|
||||||
@@ -12,9 +12,13 @@ echo
|
|||||||
|
|
||||||
deb_path="$HOME/install"
|
deb_path="$HOME/install"
|
||||||
deb_name="rustdesk-$RDVER.deb"
|
deb_name="rustdesk-$RDVER.deb"
|
||||||
mkdir -p $deb_path
|
mkdir -p "$deb_path"
|
||||||
deb="$deb_path/$deb_name"
|
deb="$deb_path/$deb_name"
|
||||||
|
|
||||||
sudo apt install -y libxdo3 python3-pip && \
|
sudo apt install -y libxdo3 python3-pip
|
||||||
wget "https://github.com/rustdesk/rustdesk/releases/download/$RDVER/$deb_name" -O $deb && \
|
wget "https://github.com/rustdesk/rustdesk/releases/download/$RDVER/$deb_name" -O "$deb"
|
||||||
sudo dpkg -i $deb
|
sudo dpkg -i "$deb"
|
||||||
|
|
||||||
|
# flatpak install -y com.rustdesk.RustDesk
|
||||||
|
# https://develop.kde.org/docs/administration/portal-permissions/
|
||||||
|
# flatpak permission-set kde-authorized remote-desktop com.rustdesk.RustDesk yes
|
||||||
|
|||||||
@@ -3,29 +3,32 @@
|
|||||||
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
||||||
|
|
||||||
# https://www.sublimetext.com/download
|
# https://www.sublimetext.com/download
|
||||||
# https://gist.github.com/skoqaq/3f3e8f28e23c881143cef9cf49d821ff
|
# https://gist.axenov.dev/anthony/sublime
|
||||||
|
# https://gist.axenov.dev/anthony/sublime2
|
||||||
# https://gist.github.com/lugrus2000/1fc55158b87f94d799392a6dd1ac0ce2
|
# https://gist.github.com/lugrus2000/1fc55158b87f94d799392a6dd1ac0ce2
|
||||||
# https://gist.github.com/maboloshi/feaa63c35f4c2baab24c9aaf9b3f4e47
|
# https://gist.github.com/maboloshi/feaa63c35f4c2baab24c9aaf9b3f4e47
|
||||||
|
|
||||||
[ "$1" ] && STVER="$1" || STVER='4189'
|
[ "$1" ] && STVER="$1" || STVER='4200'
|
||||||
|
|
||||||
title
|
title
|
||||||
|
|
||||||
mkdir -p "$HOME/install"
|
mkdir -p "$HOME/install"
|
||||||
DEB_PATH="$HOME/install/sublime-text_build-${SMVER}_amd64.deb"
|
DEB_PATH="$HOME/install/sublime-text_build-${STVER}_amd64.deb"
|
||||||
BIN_PATH="/opt/sublime_text/sublime_text"
|
BIN_PATH="/opt/sublime_text/sublime_text"
|
||||||
|
|
||||||
if [[ ! -f "$DEB_PATH" ]]; then
|
if [[ ! -f "$DEB_PATH" ]]; then
|
||||||
download https://download.sublimetext.com/sublime-text_build-${STVER}_amd64.deb "$DEB_PATH"
|
download "https://download.sublimetext.com/sublime-text_build-${STVER}_amd64.deb" "$DEB_PATH"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sudo dpkg -i "$DEB_PATH"
|
sudo dpkg -i "$DEB_PATH"
|
||||||
sudo cp -f $BIN_PATH $BIN_PATH.old
|
sudo cp -f "$BIN_PATH" "$BIN_PATH.old"
|
||||||
|
|
||||||
if [[ $STVER = 4169 ]]; then
|
if [[ $STVER = 4169 ]]; then
|
||||||
echo "00489f39: c640 0501 4885 c9" | sudo xxd -r - $BIN_PATH
|
echo "00489f39: c640 0501 4885 c9" | sudo xxd -r - "$BIN_PATH"
|
||||||
|
elif [[ $STVER = 4200 ]]; then
|
||||||
|
sudo sed -i 's#\x0F\xB6\x51\x05\x83\xF2\x01#\xC6\x41\x05\x01\xB2\x00\x90#' "$BIN_PATH"
|
||||||
else
|
else
|
||||||
sudo sed -i 's#\x80\x79\x05\x00\x0F\x94\xC2#\xC6\x41\x05\x01\xB2\x00\x90#' $BIN_PATH
|
sudo sed -i 's#\x80\x79\x05\x00\x0F\x94\xC2#\xC6\x41\x05\x01\xB2\x00\x90#' "$BIN_PATH"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
|
|||||||
20
install/suld
Executable file
20
install/suld
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
##makedesc: Samsung Unified Linux Driver repo
|
||||||
|
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
||||||
|
|
||||||
|
# https://www.bchemnet.com/suldr/
|
||||||
|
# https://www.bchemnet.com/suldr/supported.html
|
||||||
|
|
||||||
|
title
|
||||||
|
|
||||||
|
mkdir -vp "$HOME/install"
|
||||||
|
sudo bash -c 'echo "deb https://www.bchemnet.com/suldr/ debian extra" >> /etc/apt/sources.list.d/samsung.list'
|
||||||
|
download \
|
||||||
|
https://www.bchemnet.com/suldr/pool/debian/extra/su/suldr-keyring_3_all.deb \
|
||||||
|
"$HOME/install/suldr-keyring_3_all.deb"
|
||||||
|
sudo dpkg -i "$HOME/install/suldr-keyring_3_all.deb"
|
||||||
|
apt_install suld-driver2-1.00.39
|
||||||
|
|
||||||
|
success "Samsung Unified Linux Driver installed!"
|
||||||
|
info "Don't forget to connect your Samsung printer"
|
||||||
|
info "See more info here: https://www.bchemnet.com/suldr/"
|
||||||
@@ -7,5 +7,7 @@ echo "Installing ulauncher (latest) + ppa..."
|
|||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
sudo add-apt-repository -y ppa:agornostal/ulauncher
|
sudo add-apt-repository universe -y
|
||||||
sudo apt install -y --autoremove ulauncher
|
sudo add-apt-repository ppa:agornostal/ulauncher -y
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install ulauncher
|
||||||
|
|||||||
@@ -11,11 +11,9 @@ echo "Installing Vivaldi + ppa..."
|
|||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
wget -qO- https://repo.vivaldi.com/archive/linux_signing_key.pub \
|
wget -qO- https://repo.vivaldi.com/archive/linux_signing_key.pub | gpg --dearmor > packages.vivaldi.gpg
|
||||||
| gpg --dearmor \
|
sudo install -o root -g root -m 644 packages.vivaldi.gpg /etc/apt/trusted.gpg.d
|
||||||
| sudo dd of=/usr/share/keyrings/vivaldi-browser.gpg
|
sudo sh -c 'echo "deb [arch=amd64,armhf signed-by=/etc/apt/trusted.gpg.d/packages.vivaldi.gpg] https://repo.vivaldi.com/archive/deb stable main" > /etc/apt/sources.list.d/vivaldi.list'
|
||||||
|
rm -f packages.vivaldi.gpg
|
||||||
echo "deb [signed-by=/usr/share/keyrings/vivaldi-browser.gpg arch=$(dpkg --print-architecture)] https://repo.vivaldi.com/archive/deb/ stable main" \
|
|
||||||
| sudo dd of=/etc/apt/sources.list.d/vivaldi-archive.list
|
|
||||||
|
|
||||||
sudo apt update && sudo apt install vivaldi-stable
|
sudo apt update && sudo apt install vivaldi-stable
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
##makedesc: Install wine (latest) + ppa (focal)
|
##makedesc: Install wine (latest) + ppa
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
@@ -9,6 +9,6 @@ echo
|
|||||||
|
|
||||||
sudo dpkg --add-architecture i386
|
sudo dpkg --add-architecture i386
|
||||||
wget -qO- https://dl.winehq.org/wine-builds/winehq.key | sudo apt-key add -
|
wget -qO- https://dl.winehq.org/wine-builds/winehq.key | sudo apt-key add -
|
||||||
sudo add-apt-repository -y 'deb https://dl.winehq.org/wine-builds/ubuntu/ focal main'
|
sudo add-apt-repository -y "deb https://dl.winehq.org/wine-builds/ubuntu/ $(lsb_release -cs 2>/dev/null) main"
|
||||||
sudo apt install -y --autoremove winehq-stable
|
sudo apt install -y --autoremove winehq-stable
|
||||||
wine --version
|
wine --version
|
||||||
|
|||||||
@@ -1,2 +0,0 @@
|
|||||||
##flameshot: [TODO] [PACK] qt5 + flameshot from source
|
|
||||||
flameshot: qt5 flameshot-build
|
|
||||||
@@ -1,2 +1,2 @@
|
|||||||
##phptools: [PACK] Install only php tooling (composer, phpunit, psalm, phpcs, php-cs-fixer, php-spx, phpmd)
|
##phptools: [PACK] Install only php tooling (composer, phpunit, psalm, phpcs, php-cs-fixer, phpmd)
|
||||||
phptools: composer php-psalm php-spx phpcs phpmd phpstan phpunit
|
phptools: composer php-psalm phpcs phpmd phpstan phpunit
|
||||||
|
|||||||
@@ -1,19 +1,6 @@
|
|||||||
# Shell scripts
|
# Shell-скрипты
|
||||||
|
|
||||||
## Russian
|
|
||||||
|
|
||||||
Эти скрипты я писал в разное время для решения разных задач.
|
Эти скрипты я писал в разное время для решения разных задач.
|
||||||
Чтобы они не растерялись по репозиториям и носителям, я решил собрать их здесь в одну кучу.
|
Чтобы они не растерялись по репозиториям и носителям, я решил собрать их здесь в одну кучу.
|
||||||
|
|
||||||
Я всегда использую Ubuntu в качестве своих настольных и серверных ОС, поэтому все эти скрипты писались и использовались в этих средах с версий 18.*.
|
Я всегда использую Ubuntu в качестве своих настольных и серверных ОС, поэтому все эти скрипты писались и использовались в этих средах с версий 18.*.
|
||||||
|
|
||||||
Многие скрипты зависимы от [io.sh](/io.sh).
|
|
||||||
|
|
||||||
## English
|
|
||||||
|
|
||||||
These scripts were written at different times to solve different my own problems.
|
|
||||||
I decided to collect them here in a heap so that they are not lost in repositories and media.
|
|
||||||
|
|
||||||
I always use Ubuntu as my desktop and server OS, so all these scripts has been written and used in these environments since version 18.*.
|
|
||||||
|
|
||||||
Many scripts depending on [io.sh](/io.sh).
|
|
||||||
|
|||||||
5
tools/disable-ipv6.sh
Executable file
5
tools/disable-ipv6.sh
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
sudo sysctl -w net.ipv6.conf.all.disable_ipv6="$1"
|
||||||
|
sudo sysctl -w net.ipv6.conf.default.disable_ipv6="$1"
|
||||||
|
sudo sysctl -w net.ipv6.conf.lo.disable_ipv6="$1"
|
||||||
11
tools/display-rotate.sh
Executable file
11
tools/display-rotate.sh
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# X11:
|
||||||
|
# xrandr --listactivemonitors
|
||||||
|
# xrandr --output $OUTPUT --rotate (left|right|normal|...)
|
||||||
|
|
||||||
|
# Wayland KDE: https://www.reddit.com/r/kde/comments/11vrbwc/how_do_i_rotate_the_screen_on_kde_with_wayland/
|
||||||
|
# kscreen-doctor --outputs
|
||||||
|
OUTPUT='HDMI-0'
|
||||||
|
DIRECTION="$1" # (left|right|normal|inverted)
|
||||||
|
kscreen-doctor "output.$OUTPUT.rotation.$DIRECTION"
|
||||||
47
tools/docker-volume-snapshot.sh
Normal file
47
tools/docker-volume-snapshot.sh
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Original filename: docker-volume-snapshot
|
||||||
|
# Author: Juned Khatri
|
||||||
|
# License: MIT
|
||||||
|
# Repo: https://github.com/junedkhatri31/docker-volume-snapshot
|
||||||
|
|
||||||
|
set -e -o pipefail
|
||||||
|
|
||||||
|
programname=`basename "$0"`
|
||||||
|
|
||||||
|
display_usage() {
|
||||||
|
echo "usage: $programname (create|restore) source destination"
|
||||||
|
echo " create create snapshot file from docker volume"
|
||||||
|
echo " restore restore snapshot file to docker volume"
|
||||||
|
echo " source source path"
|
||||||
|
echo " destination destination path"
|
||||||
|
echo
|
||||||
|
echo "Tip: Supports tar's compression algorithms automatically"
|
||||||
|
echo " based on the file extention, for example .tar.gz"
|
||||||
|
echo
|
||||||
|
echo "Examples:"
|
||||||
|
echo "docker-volume-snapshot create xyz_volume xyz_volume.tar"
|
||||||
|
echo "docker-volume-snapshot create xyz_volume xyz_volume.tar.gz"
|
||||||
|
echo "docker-volume-snapshot restore xyz_volume.tar xyz_volume"
|
||||||
|
echo "docker-volume-snapshot restore xyz_volume.tar.gz xyz_volume"
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
"create")
|
||||||
|
if [[ -z "$2" || -z "$3" ]]; then display_usage; exit 1; fi
|
||||||
|
directory=`dirname "$3"`
|
||||||
|
if [ "$directory" == "." ]; then directory=$(pwd); fi
|
||||||
|
filename=`basename "$3"`
|
||||||
|
docker run --rm -v "$2:/source" -v "$directory:/dest" busybox tar cvaf "/dest/$filename" -C /source .
|
||||||
|
;;
|
||||||
|
"restore")
|
||||||
|
if [[ -z "$2" || -z "$3" ]]; then display_usage; exit 1; fi
|
||||||
|
directory=`dirname "$2"`
|
||||||
|
if [ "$directory" == "." ]; then directory=$(pwd); fi
|
||||||
|
filename=`basename "$2"`
|
||||||
|
docker run --rm -v "$3:/dest" -v "$directory:/source" busybox tar xvf "/source/$filename" -C /dest
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
display_usage
|
||||||
|
exit 1 # Command to come out of the program with status 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
3
tools/duckdns/.env.example
Normal file
3
tools/duckdns/.env.example
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
DUCK_TOKEN=
|
||||||
|
DUCK_DOMAINS=
|
||||||
|
DUCK_IP=
|
||||||
2
tools/duckdns/.gitignore
vendored
Normal file
2
tools/duckdns/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
.env
|
||||||
|
*.log
|
||||||
9
tools/duckdns/install.sh
Executable file
9
tools/duckdns/install.sh
Executable file
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
thisdir="$( dirname "$(readlink -e -- "${BASH_SOURCE[0]}")")"
|
||||||
|
|
||||||
|
# https://www.duckdns.org/install.jsp
|
||||||
|
|
||||||
|
croncmd="$thisdir/update.sh"
|
||||||
|
cronjob="*/30 * * * * $croncmd" # every 30 min
|
||||||
|
( crontab -l | grep -v -F "$croncmd" ; echo "$cronjob" ) | crontab -
|
||||||
|
cp -f "$thisdir/.env.example" "$thisdir/.env"
|
||||||
3
tools/duckdns/uninstall.sh
Executable file
3
tools/duckdns/uninstall.sh
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
( crontab -l | grep -v -F "duckdns" ) | crontab -
|
||||||
30
tools/duckdns/update.sh
Executable file
30
tools/duckdns/update.sh
Executable file
@@ -0,0 +1,30 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# shellcheck disable=SC1091
|
||||||
|
thisdir="$( dirname "$(readlink -e -- "${BASH_SOURCE[0]}")")"
|
||||||
|
|
||||||
|
log() {
|
||||||
|
timestamp="$(date +'%Y-%m-%d %H:%M:%S')"
|
||||||
|
datestamp="$(date +'%Y-%m-%d')"
|
||||||
|
[ ! -d "$thisdir/log" ] && mkdir "$thisdir/log"
|
||||||
|
echo "[$timestamp] $*" >> "$thisdir/log/$datestamp.log"
|
||||||
|
}
|
||||||
|
|
||||||
|
[ ! -f "$thisdir/.env" ] && {
|
||||||
|
log "ERROR: .env not exists"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
source "$thisdir/.env"
|
||||||
|
|
||||||
|
[ -z "$DUCK_TOKEN" ] && {
|
||||||
|
log "ERROR: env var DUCK_TOKEN not specified"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$DUCK_DOMAINS" ] && {
|
||||||
|
log "ERROR: env var DUCK_DOMAINS not specified"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
result=$(curl -s "https://www.duckdns.org/update?domains=${DUCK_DOMAINS}&token=${DUCK_TOKEN}&ip=${DUCK_IP}")
|
||||||
|
log "$result"
|
||||||
11
tools/fix-repo-vivaldi.sh
Executable file
11
tools/fix-repo-vivaldi.sh
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# https://gist.github.com/pkorpine/16fcdbe070222cf1d99e67cf542e60c2
|
||||||
|
|
||||||
|
sudo rm -rf /etc/apt/sources.list.d/vivaldi*
|
||||||
|
cd /tmp
|
||||||
|
wget -qO- https://repo.vivaldi.com/archive/linux_signing_key.pub | gpg --dearmor > packages.vivaldi.gpg
|
||||||
|
sudo install -o root -g root -m 644 packages.vivaldi.gpg /etc/apt/trusted.gpg.d
|
||||||
|
sudo sh -c 'echo "deb [arch=amd64,armhf signed-by=/etc/apt/trusted.gpg.d/packages.vivaldi.gpg] https://repo.vivaldi.com/archive/deb stable main" > /etc/apt/sources.list.d/vivaldi.list'
|
||||||
|
rm -f packages.vivaldi.gpg
|
||||||
|
sudo apt update
|
||||||
12
tools/fix-repo-vscode.sh
Executable file
12
tools/fix-repo-vscode.sh
Executable file
@@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# https://code.visualstudio.com/docs/setup/linux
|
||||||
|
|
||||||
|
sudo rm -rf /etc/apt/sources.list.d/vscode*
|
||||||
|
cd /tmp
|
||||||
|
sudo apt install wget gpg apt-transport-https
|
||||||
|
wget -qO- https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > packages.microsoft.gpg
|
||||||
|
sudo install -D -o root -g root -m 644 packages.microsoft.gpg /etc/apt/keyrings/packages.microsoft.gpg
|
||||||
|
echo "deb [arch=amd64,arm64,armhf signed-by=/etc/apt/keyrings/packages.microsoft.gpg] https://packages.microsoft.com/repos/code stable main" |sudo tee /etc/apt/sources.list.d/vscode.list > /dev/null
|
||||||
|
rm -f packages.microsoft.gpg
|
||||||
|
sudo apt update
|
||||||
@@ -3,46 +3,60 @@
|
|||||||
# https://gist.github.com/anthonyaxenov/02c00c965be4eb5bb163a153abdf4c2b
|
# https://gist.github.com/anthonyaxenov/02c00c965be4eb5bb163a153abdf4c2b
|
||||||
# https://itsfoss.com/free-up-space-ubuntu-linux/
|
# https://itsfoss.com/free-up-space-ubuntu-linux/
|
||||||
|
|
||||||
df -h
|
|
||||||
echo ""
|
echo
|
||||||
|
echo
|
||||||
|
df -hx tmpfs
|
||||||
|
echo
|
||||||
|
|
||||||
|
echo
|
||||||
echo "[1/5] Removing apt caches and unused packages"
|
echo "[1/5] Removing apt caches and unused packages"
|
||||||
echo ""
|
echo
|
||||||
|
|
||||||
sudo apt autoremove --purge
|
sudo apt autoremove --purge
|
||||||
sudo apt autoclean
|
sudo apt autoclean
|
||||||
sudo apt clean
|
sudo apt clean
|
||||||
|
|
||||||
echo ""
|
echo
|
||||||
echo "[2/5] Removing old journalctl logs"
|
echo "[2/5] Removing old system logs"
|
||||||
echo ""
|
echo
|
||||||
|
|
||||||
sudo journalctl --vacuum-time=1d
|
sudo journalctl --vacuum-time=1d
|
||||||
sudo rm -rf /var/log/journal/user-*@*
|
sudo rm -rf /var/log/journal/user-*@*
|
||||||
sudo rm -rf /var/log/journal/system*@*
|
sudo rm -rf /var/log/journal/system*@*
|
||||||
|
sudo rm /var/log/{syslog,dmesg,btmp}.*
|
||||||
|
sudo rm /var/log/{auth,dpkg,kern,alternatives,dmesg}.log.*
|
||||||
|
|
||||||
echo ""
|
echo
|
||||||
echo "[3/5] Cleaning user trash and thumbnails"
|
echo "[3/5] Cleaning user trash and thumbnails"
|
||||||
echo ""
|
echo
|
||||||
|
|
||||||
rm -rf ~/.local/share/Trash/files/*
|
rm -rf ~/.local/share/Trash/files/*
|
||||||
rm -rf ~/.cache/thumbnails/*
|
rm -rf ~/.cache/thumbnails/*
|
||||||
|
|
||||||
echo ""
|
echo
|
||||||
echo "[4/5] Cleaning out dangling docker objects"
|
echo "[4/5] Cleaning out dangling docker objects"
|
||||||
echo ""
|
echo
|
||||||
|
|
||||||
docker system prune -f
|
docker system prune -f
|
||||||
# docker system prune -af
|
# docker system prune -af
|
||||||
|
|
||||||
echo ""
|
echo
|
||||||
echo "[5/5] Removing disabled unused snaps"
|
echo "[5/5] Removing disabled unused snaps"
|
||||||
echo ""
|
echo
|
||||||
|
|
||||||
sudo snap list --all | awk '/disabled/{print $1, $3}' |
|
sudo snap list --all \
|
||||||
while read snapname revision; do
|
| awk '/disabled/{print $1, $3}' \
|
||||||
sudo snap remove "$snapname" --revision="$revision"
|
| while read snapname revision; do
|
||||||
done
|
sudo snap remove "$snapname" --revision="$revision"
|
||||||
|
done
|
||||||
|
|
||||||
echo ""
|
|
||||||
echo ""
|
|
||||||
df -h
|
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo
|
||||||
|
df -hx tmpfs
|
||||||
|
echo
|
||||||
|
echo
|
||||||
|
|||||||
31
tools/make-swapfile.sh
Executable file
31
tools/make-swapfile.sh
Executable file
@@ -0,0 +1,31 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -exo pipefail
|
||||||
|
|
||||||
|
# https://www.linode.com/docs/guides/how-to-increase-swap-space-in-ubuntu/
|
||||||
|
# https://help.ubuntu.com/community/SwapFaq
|
||||||
|
|
||||||
|
sudo swapon --show
|
||||||
|
free -h
|
||||||
|
df -h
|
||||||
|
|
||||||
|
if [ -f /swapfile ]; then
|
||||||
|
set +x
|
||||||
|
echo "Already exists"
|
||||||
|
exit 1
|
||||||
|
fi;
|
||||||
|
|
||||||
|
sudo fallocate -l 1G /swapfile
|
||||||
|
sudo chmod 600 /swapfile
|
||||||
|
sudo mkswap /swapfile
|
||||||
|
sudo swapon /swapfile
|
||||||
|
|
||||||
|
sudo swapon --show
|
||||||
|
free -h
|
||||||
|
df -h
|
||||||
|
|
||||||
|
sudo cp /etc/fstab /etc/fstab.bak
|
||||||
|
echo "/swapfile swap swap defaults 0 0" | sudo tee -a /etc/fstab
|
||||||
|
sudo sysctl vm.swappiness=50
|
||||||
|
echo "vm.swappiness=50" | sudo tee -a /etc/fstab
|
||||||
|
|
||||||
|
sudo swapon --show
|
||||||
@@ -2,23 +2,11 @@
|
|||||||
# https://dev.to/chefgs/upgrading-an-end-of-life-eol-ubuntu-os-to-lts-version-3a36
|
# https://dev.to/chefgs/upgrading-an-end-of-life-eol-ubuntu-os-to-lts-version-3a36
|
||||||
# https://changelogs.ubuntu.com/meta-release
|
# https://changelogs.ubuntu.com/meta-release
|
||||||
|
|
||||||
installed() {
|
# shellcheck disable=SC1091
|
||||||
command -v "$1" >/dev/null 2>&1
|
|
||||||
}
|
|
||||||
|
|
||||||
# sudo software-properties-qt (переключиться с LTS на нормальные релизы)
|
|
||||||
# sudo aptitude install update-manager-core update-manager
|
|
||||||
# sudo apt upgrade --autoremove -y
|
|
||||||
# installed pkcon && sudo pkcon update --autoremove -y
|
|
||||||
# sudo apt dist-upgrade
|
|
||||||
# sudo apt install update-manager-core
|
|
||||||
# sudo do-release-upgrade -p
|
|
||||||
|
|
||||||
source /etc/os-release
|
source /etc/os-release
|
||||||
|
|
||||||
echo "Loading..."
|
echo "Loading..."
|
||||||
|
mapfile -t codenames < <(curl -s https://changelogs.ubuntu.com/meta-release | grep -oP '(?<=Dist:\s).*')
|
||||||
IFS=$'\n' codenames=($(curl -s https://changelogs.ubuntu.com/meta-release | grep -xP "^Dist:\s[\w]+$" | sed "s/Dist: //" ))
|
|
||||||
thisCodename="$VERSION_CODENAME"
|
thisCodename="$VERSION_CODENAME"
|
||||||
for idx in "${!codenames[@]}"; do
|
for idx in "${!codenames[@]}"; do
|
||||||
if [ "${codenames[idx]}" = "$thisCodename" ]; then
|
if [ "${codenames[idx]}" = "$thisCodename" ]; then
|
||||||
@@ -26,7 +14,7 @@ for idx in "${!codenames[@]}"; do
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
targetDownloadPath="`pwd`/upgrade-$nextCodename"
|
targetDownloadPath="$(pwd)/upgrade-$nextCodename"
|
||||||
targetToolPath="$targetDownloadPath/unpacked"
|
targetToolPath="$targetDownloadPath/unpacked"
|
||||||
targetToolFile="$targetDownloadPath/$nextCodename.tar.gz"
|
targetToolFile="$targetDownloadPath/$nextCodename.tar.gz"
|
||||||
|
|
||||||
@@ -38,12 +26,14 @@ rm -rf "$targetToolPath"
|
|||||||
mkdir -p "$targetToolPath"
|
mkdir -p "$targetToolPath"
|
||||||
|
|
||||||
echo "Downloading..."
|
echo "Downloading..."
|
||||||
cd "$targetDownloadPath"
|
cd "$targetDownloadPath" || exit 1
|
||||||
wget "http://archive.ubuntu.com/ubuntu/dists/${nextCodename}-updates/main/dist-upgrader-all/current/${nextCodename}.tar.gz"
|
wget "http://archive.ubuntu.com/ubuntu/dists/${nextCodename}-updates/main/dist-upgrader-all/current/${nextCodename}.tar.gz"
|
||||||
|
|
||||||
echo "Unpacking..."
|
echo "Unpacking..."
|
||||||
tar -xaf "$targetToolFile" -C "$targetToolPath"
|
tar -xaf "$targetToolFile" -C "$targetToolPath"
|
||||||
|
|
||||||
echo "Starting..."
|
echo "Starting..."
|
||||||
cd unpacked
|
cd ./unpacked || exit 1
|
||||||
|
|
||||||
|
# shellcheck disable=SC2086
|
||||||
sudo ./$nextCodename
|
sudo ./$nextCodename
|
||||||
@@ -29,4 +29,5 @@ apt install -y \
|
|||||||
mariadb-server \
|
mariadb-server \
|
||||||
mariadb-client \
|
mariadb-client \
|
||||||
nginx \
|
nginx \
|
||||||
certbot
|
certbot \
|
||||||
|
python3-certbot-nginx
|
||||||
@@ -41,13 +41,6 @@ sudo apt install -y \
|
|||||||
notify-osd \
|
notify-osd \
|
||||||
fonts-open-sans \
|
fonts-open-sans \
|
||||||
libnotify-bin \
|
libnotify-bin \
|
||||||
gnome-software \
|
|
||||||
gnome-software-plugin-flatpak \
|
|
||||||
gnome-software-plugin-snap \
|
|
||||||
terminator \
|
|
||||||
geoclue-2.0 \
|
|
||||||
redshift \
|
|
||||||
redshift-gtk \
|
|
||||||
samba \
|
samba \
|
||||||
dkms
|
dkms
|
||||||
|
|
||||||
51
tools/ubuntu/server.sh
Normal file
51
tools/ubuntu/server.sh
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
sudo apt install -y ca-certificates curl && \
|
||||||
|
sudo install -m 0755 -d /etc/apt/keyrings && \
|
||||||
|
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc && \
|
||||||
|
sudo chmod a+r /etc/apt/keyrings/docker.asc && \
|
||||||
|
source /etc/os-release && \
|
||||||
|
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
|
||||||
|
$(. /etc/os-release && echo "${UBUNTU_CODENAME:-$VERSION_CODENAME}") stable" | \
|
||||||
|
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null && \
|
||||||
|
sudo apt update && \
|
||||||
|
sudo apt upgrade -y --autoremove && \
|
||||||
|
sudo apt install -y \
|
||||||
|
apt-transport-https \
|
||||||
|
build-essential \
|
||||||
|
ca-certificates \
|
||||||
|
git \
|
||||||
|
cmake \
|
||||||
|
curl \
|
||||||
|
dialog \
|
||||||
|
gettext \
|
||||||
|
gnupg \
|
||||||
|
htop \
|
||||||
|
libcurl4-gnutls-dev \
|
||||||
|
libexpat1-dev \
|
||||||
|
libghc-zlib-dev \
|
||||||
|
libssl-dev \
|
||||||
|
lsb-release \
|
||||||
|
make \
|
||||||
|
mc \
|
||||||
|
meld \
|
||||||
|
nano \
|
||||||
|
neofetch \
|
||||||
|
net-tools \
|
||||||
|
nmap \
|
||||||
|
p7zip-full \
|
||||||
|
unzip \
|
||||||
|
ffmpeg \
|
||||||
|
inotify-tools \
|
||||||
|
notify-osd \
|
||||||
|
fonts-open-sans \
|
||||||
|
libnotify-bin \
|
||||||
|
tree \
|
||||||
|
nginx \
|
||||||
|
certbot \
|
||||||
|
python3-certbot-nginx \
|
||||||
|
docker-ce \
|
||||||
|
docker-ce-cli \
|
||||||
|
containerd.io \
|
||||||
|
docker-buildx-plugin \
|
||||||
|
docker-compose-plugin
|
||||||
@@ -7,5 +7,5 @@ echo "Uninstalling omz..."
|
|||||||
echo "==============================================="
|
echo "==============================================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
bash $ZSH/tools/uninstall.sh
|
bash "$ZSH/tools/uninstall.sh"
|
||||||
exec bash
|
exec bash
|
||||||
|
|||||||
11
uninstall/rustdesk
Executable file
11
uninstall/rustdesk
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
##makedesc: Uninstall rustdesk client
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo "==============================================="
|
||||||
|
echo "Uninstalling rustdesk..."
|
||||||
|
echo "==============================================="
|
||||||
|
echo
|
||||||
|
|
||||||
|
sudo dpkg -r rustdesk
|
||||||
|
# flatpak remove -y com.rustdesk.RustDesk
|
||||||
19
uninstall/wine
Executable file
19
uninstall/wine
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
##makedesc: Uninstall wine
|
||||||
|
source "$( dirname $(readlink -e -- "${BASH_SOURCE}"))/../helpers.sh" || exit 255
|
||||||
|
|
||||||
|
title
|
||||||
|
|
||||||
|
sudo apt remove --purge "wine*"
|
||||||
|
rm -rf "$HOME/.wine"
|
||||||
|
rm -f "$HOME/.config/menus/applications-merged/*wine*"
|
||||||
|
rm -rf "$HOME/.local/share/applications/wine"
|
||||||
|
rm -f "$HOME/.local/share/desktop-directories/*wine*"
|
||||||
|
rm -f "$HOME/.local/share/icons/*wine*"
|
||||||
|
|
||||||
|
# !!! dangerous!!!
|
||||||
|
#sudo apt remove --purge wine* *:i386
|
||||||
|
#dpkg --remove-architecture i386
|
||||||
|
|
||||||
|
success "wine removed!"
|
||||||
|
|
||||||
Reference in New Issue
Block a user