snips

Usage

snips.sh is an SSH-driven snippet manager. All interactions happen through your terminal — upload, download, edit, delete, and share files using standard SSH commands. No account creation needed; your SSH key is your identity.

Quick reference

Action Command
Upload echo "content" | ssh snips.sh
Upload (private) echo "content" | ssh snips.sh -private
Upload (with type hint) echo "content" | ssh snips.sh -ext py
Upload (private + signed URL) echo "content" | ssh snips.sh -private -ttl 24h
Download ssh f:<id>@snips.sh
Update echo "new" | ssh f:<id>:content@snips.sh
Delete ssh f:<id>@snips.sh rm
Force delete ssh f:<id>@snips.sh rm -f
Sign ssh f:<id>@snips.sh sign -ttl 1h
Interactive TUI ssh snips.sh

Authentication

snips.sh uses SSH public key authentication exclusively. The first time you connect with a key, a user account is automatically created and linked to your key fingerprint. All files you create are tied to that key.

If your server has an authorized keys file configured, only listed keys will be allowed to connect.

Uploading

Pipe any content to the SSH server to create a new snippet:

echo "Hello, world!" | ssh snips.sh
cat main.go | ssh snips.sh
curl -s https://example.com | ssh snips.sh

The server auto-detects the file type from the content. To override detection, pass an extension hint:

cat config | ssh snips.sh -ext yaml

Private uploads

By default, files are public. To upload a private file:

echo "secret" | ssh snips.sh -private

Private files are only accessible by the owner (via their SSH key) or through signed URLs.

You can combine -private with -ttl to get a signed URL back immediately:

echo "secret" | ssh snips.sh -private -ttl 24h

Limits

  • Max file size: 1 MB (default)
  • Max files per user: 100 (default)
  • Empty files are rejected.

Downloading

Retrieve a file by connecting as f:<id>:

ssh f:abc123@snips.sh

Output goes to stdout, so you can pipe it:

ssh f:abc123@snips.sh > local_copy.txt
ssh f:abc123@snips.sh | less

Private files can only be downloaded by their owner.

Updating content

Pipe new content to f:<id>:content to replace a file’s contents:

echo "updated content" | ssh f:abc123:content@snips.sh

You can also change the file type during an update:

cat renamed.py | ssh f:abc123:content@snips.sh -ext py

Only the file owner can update content. Each update creates a revision with a unified diff of the changes (for text files). Old revisions are pruned once the limit (default 64, but configurable) is reached.

Deleting

Delete a file with the rm command:

ssh f:abc123@snips.sh rm

This prompts for confirmation. To skip the prompt:

ssh f:abc123@snips.sh rm -f

Only the file owner can delete their files.

Signed URLs

Private files can be shared via time-limited signed URLs. Use the sign command with a -ttl duration:

ssh f:abc123@snips.sh sign -ttl 1h
ssh f:abc123@snips.sh sign -ttl 7d

The returned URL can be opened by anyone until it expires. Signing only works on private files.

Duration format

Durations support these units, and can be combined:

Unit Meaning
s seconds
m minutes
h hours
d days
w weeks

Examples: 30s, 2h30m, 1w2d, 7d

Interactive TUI

Connect without piping to open an interactive terminal UI:

ssh snips.sh

The TUI lets you browse your files, view contents, see revision history, delete files, and generate signed URLs. Sessions have a default timeout of 15 minutes.

Web access

Public files are also available over HTTP:

https://snips.sh/f/<id>

The web view includes syntax highlighting, metadata, and revision history. Private files require a valid signed URL to access over HTTP.