Skip to content

amiantos/lurker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

420 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

  Lurker

CI Docker image codecov OpenSSF Scorecard License: MPL 2.0 IRC: #lurker

Lurker is a self-hosted modern IRC client with a retro flair, most easily described as "your personal IRCCloud, with Weechat looks".

Lurker runs as an always-on server that stays connected to IRC on your behalf, keeps full message history, and lets you reattach from any browser — desktop or mobile — picking up exactly where you left off. Open it on as many devices and tabs as you like; read state, settings, and history stay in sync everywhere; when all clients are disconnected, auto-away sets your status, and web push notifications inform you of highlights. Oh, and the icon rules.

Features

  • Always-on and multi-user. Each invited user connects to their own set of IRC networks, and Lurker stays connected when they're away.
  • Full history and search. Every message is stored and searchable. Auto-away triggers after your last client disconnects, and smart push notifications fire on highlights.
  • IRC with Modern Convienences. Peer presence, automatic nick regain, join/part summarization, tab nickname completion, message drafts, saved messages, user notes, and a searchable channel browser w/ cache.
  • Image uploads. Paste, drag, or pick an image; Lurker optimizes it, uploads it to x0.at or catbox.moe, inserts the link into your message, and keeps a history of all your uploads.
  • Customizable UI. The beautiful retro terminal-style interface has 40+ settings to customize it how you want, and you can freely pin and rearrange channels and DMs.
  • Installable. Lurker is a PWA — install it as a native-feeling app on your phone, Mac, or PC straight from the browser.

Screenshot (as macOS PWA)

Lurker IRC client screenshot

Rave Reviews

  • <cfuser> amiantos: holy shit, you made something better than irccloud
  • <amigojapan> great, now that amiantos's chat client is catching up to IRC cloud, I think I can switch to it as my daily driver
  • <skdoo> amiantos makes cool shit
  • <jadeia> lurker is really nice. this is streets ahead of irccloud in terms of design and ease of use.

Stack

  • Server — TypeScript on Node (run via tsx), Express, irc-framework, ws, better-sqlite3, sharp, web-push
  • Client — TypeScript, Vue 3, Vite, Pinia, vue-router
  • Tooling — Vitest, oxlint, oxfmt

Installation

Install (Docker — Recommended)

curl -O https://raw.githubusercontent.com/amiantos/lurker/main/docker-compose.yml
docker compose up -d

Then open http://localhost:8015 and create your admin account. Username + password is the default; passkeys are optional. See SELF_HOSTING.md for the full guide — reverse proxy + HTTPS, enabling passkeys, push notifications, updating, and backups.

Deploy on DigitalOcean

Stand up a public, HTTPS-enabled Lurker on a fresh droplet from a single pasted script — no SSH required, with passkeys, web push, and TLS all configured for you. Step-by-step instructions are in docs/digitalocean.md.

Manual Install (without Docker)

npm run install:all
npm run client:build
npm start

The server listens on port 8010 by default and stores everything in ./data/. Override with the envvars documented in .env.example.

Development

npm run install:all
cp .env.example .env   # defaults assume the local hostname documented in the file
npm run dev

Documentation

Community

License

Mozilla Public License 2.0 — see LICENSE.

About

Lurker is a beautiful self-hosted modern IRC client with a retro flair, most easily described as "your personal IRCCloud, with Weechat looks".

Topics

Resources

License

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Contributors