diff options
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/.gitignore | 1 | ||||
-rw-r--r-- | scripts/chat.tmux.conf | 64 | ||||
-rw-r--r-- | scripts/chroot-man.sh | 2 | ||||
-rw-r--r-- | scripts/chroot-prompt.sh | 6 | ||||
-rw-r--r-- | scripts/reconnect.sh | 10 | ||||
-rw-r--r-- | scripts/sandman.1 | 36 | ||||
-rw-r--r-- | scripts/sandman.m | 87 | ||||
-rw-r--r-- | scripts/sshd_config | 9 |
8 files changed, 74 insertions, 141 deletions
diff --git a/scripts/.gitignore b/scripts/.gitignore deleted file mode 100644 index f6dc107..0000000 --- a/scripts/.gitignore +++ /dev/null @@ -1 +0,0 @@ -sandman diff --git a/scripts/chat.tmux.conf b/scripts/chat.tmux.conf new file mode 100644 index 0000000..3489a19 --- /dev/null +++ b/scripts/chat.tmux.conf @@ -0,0 +1,64 @@ +# use `tmux -L chat -f ./chat.tmux.conf attach-session' (without any other +# options or parameters) to access this session group in its own tmux server, +# not interfering with existing servers/sessions/configurations + +new-session -t chat + +# catgirl(1) puts windows at the top +set-option -g -- status-position top + +# intuitive navigation +set-option -g -- mode-keys vi +set-option -g -- mouse on + +# indicate new messages +set-option -g -- monitor-activity on +set-option -g -- monitor-bell on + +# hardcode names during window creation +set-option -g -- automatic-rename off +set-option -g -- allow-rename off +set-option -g -- set-titles off +set-option -g -- renumber-windows on +# for the F1 binding, make hotkeys match window numbers +set-option -g -- base-index 1 + + +# clients exit on network errors, restart them automatically +# (use `kill-pane'/`C-b x' to destroy windows) +set-option -g -- remain-on-exit on +set-hook -g -- pane-died respawn-pane + + +# disarm ^C to avoid accidentially losing logs +bind-key -n -N 'confirm INTR key' -- C-c \ + confirm-before -p 'Send ^C? (y/N)' -- 'send-keys -- C-c' + +# one-click version of default `C-b w' (shows preview windows) +bind-key -n -N 'pick chat network' -- F1 choose-tree -Z + +# catgirl(1) might run in `-R'/`restrict'ed mode, i.e. `/help' is disabled +bind-key -n -N 'read catgirl help' -- F2 \ + new-window -S -n help -- man -s 1 -- catgirl + +# intuitive refresh, just don't spam it ;-) +bind-key -n -N 'reconnect network' -- F5 \ + confirm-before -p 'reconnect network? (y/N)' -- 'respawn-pane -k' + +# immersive mode ;-) +bind-key -n -N 'toggle fullscreen' -- F11 set status + + +# this configuration is idempotent, i.e. reloading it only changes settings +# and never duplicates already existing windows +bind-key -N 'reload configuration' -- R { + source-file -F -- '#{source_files}' + display-message -- 'configuration reloaded' +} + + +## do not double-quote commands to avoid running through "sh -c" + +# IRC +new-window -d -S -n hackint -- catgirl -- defaults hackint +new-window -d -S -n efnet -- catgirl -- defaults efnet diff --git a/scripts/chroot-man.sh b/scripts/chroot-man.sh deleted file mode 100644 index 9d686f9..0000000 --- a/scripts/chroot-man.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -exec mandoc /usr/share/man/man1/catgirl.1 | LESSSECURE=1 less diff --git a/scripts/chroot-prompt.sh b/scripts/chroot-prompt.sh deleted file mode 100644 index 3b43841..0000000 --- a/scripts/chroot-prompt.sh +++ /dev/null @@ -1,6 +0,0 @@ -#!/bin/sh -set -eu - -printf 'Name: ' -read -r nick rest -exec catgirl -n "$nick" -s "$nick" "$@" diff --git a/scripts/reconnect.sh b/scripts/reconnect.sh new file mode 100644 index 0000000..92d9668 --- /dev/null +++ b/scripts/reconnect.sh @@ -0,0 +1,10 @@ +#!/bin/sh +set -u + +while :; do + catgirl "$@" + status=$? + if [ $status -ne 69 ]; then + exit $status + fi +done diff --git a/scripts/sandman.1 b/scripts/sandman.1 deleted file mode 100644 index 35765ec..0000000 --- a/scripts/sandman.1 +++ /dev/null @@ -1,36 +0,0 @@ -.Dd February 12, 2020 -.Dt SANDMAN 1 -.Os -. -.Sh NAME -.Nm sandman -.Nd sleep wrapper -. -.Sh SYNOPSIS -.Nm -.Op Fl t Ar secs -.Ar command ... -. -.Sh DESCRIPTION -The -.Nm -utility wraps a -.Ar command , -sending it -.Dv SIGHUP -when the system goes to sleep, -and restarting it -when the system wakes. -. -.Pp -The arguments are as follows: -.Bl -tag -width Ds -.It Fl t Ar secs -Wait for -.Ar secs -before restarting the process. -The default is 8 seconds. -.El -. -.Sh AUTHORS -.An June Bug Aq Mt june@causal.agency diff --git a/scripts/sandman.m b/scripts/sandman.m deleted file mode 100644 index 99899ab..0000000 --- a/scripts/sandman.m +++ /dev/null @@ -1,87 +0,0 @@ -/* Copyright (C) 2019, 2020 C. McEnroe <june@causal.agency> - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see <https://www.gnu.org/licenses/>. - */ - -#import <Cocoa/Cocoa.h> -#import <err.h> -#import <signal.h> -#import <stdio.h> -#import <stdlib.h> -#import <sysexits.h> -#import <unistd.h> - -typedef unsigned uint; - -static pid_t pid; -static void spawn(char *argv[]) { - pid = fork(); - if (pid < 0) err(EX_OSERR, "fork"); - if (pid) return; - execvp(argv[0], argv); - err(EX_CONFIG, "%s", argv[0]); -} - -static void handler(int signal) { - (void)signal; - int status; - pid_t pid = wait(&status); - if (pid < 0) _exit(EX_OSERR); - _exit(status); -} - -int main(int argc, char *argv[]) { - uint delay = 8; - - for (int opt; 0 < (opt = getopt(argc, argv, "t:"));) { - switch (opt) { - break; case 't': delay = strtoul(optarg, NULL, 10); - break; default: return EX_USAGE; - } - } - argc -= optind; - argv += optind; - if (!argc) errx(EX_USAGE, "command required"); - - NSWorkspace *workspace = [NSWorkspace sharedWorkspace]; - NSNotificationCenter *notifCenter = [workspace notificationCenter]; - - [notifCenter addObserverForName:NSWorkspaceWillSleepNotification - object:nil - queue:nil - usingBlock:^(NSNotification *notif) { - (void)notif; - signal(SIGCHLD, SIG_IGN); - int error = kill(pid, SIGHUP); - if (error) err(EX_UNAVAILABLE, "kill"); - int status; - wait(&status); - }]; - - [notifCenter addObserverForName:NSWorkspaceDidWakeNotification - object:nil - queue:nil - usingBlock:^(NSNotification *notif) { - (void)notif; - warnx("waiting %u seconds...", delay); - sleep(delay); - signal(SIGCHLD, handler); - spawn(argv); - }]; - - signal(SIGCHLD, handler); - spawn(argv); - - [[NSApplication sharedApplication] run]; -} diff --git a/scripts/sshd_config b/scripts/sshd_config deleted file mode 100644 index c7e99ec..0000000 --- a/scripts/sshd_config +++ /dev/null @@ -1,9 +0,0 @@ -UsePAM no - -Match User chat - PasswordAuthentication yes - PermitEmptyPasswords yes - ChrootDirectory /home/chat - ForceCommand catgirl-prompt - DisableForwarding yes - MaxSessions 1 |