about summary refs log tree commit diff
path: root/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'scripts')
-rw-r--r--scripts/.gitignore1
-rw-r--r--scripts/chat.tmux.conf64
-rw-r--r--scripts/chroot-man.sh2
-rw-r--r--scripts/chroot-prompt.sh6
-rw-r--r--scripts/reconnect.sh10
-rw-r--r--scripts/sandman.136
-rw-r--r--scripts/sandman.m87
-rw-r--r--scripts/sshd_config9
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