tailscale-localsend
4
总安装量
4
周安装量
#52252
全站排名
安装命令
npx skills add https://github.com/plurigrid/asi --skill tailscale-localsend
Agent 安装分布
codex
4
claude-code
4
mcpjam
3
kilo
3
windsurf
3
zencoder
3
Skill 文档
Tailscale + LocalSend Peer Discovery
Discover peers via Tailscale mesh and exchange files via LocalSend protocol.
Architecture
âââââââââââââââââââ ââââââââââââââââââââ âââââââââââââââââââ
â Tailscale API ââââââ¶â Peer Discovery ââââââ¶â LocalSend API â
â (mesh network) â â (propagator) â â (file xfer) â
âââââââââââââââââââ ââââââââââââââââââââ âââââââââââââââââââ
Discovery Flow
- Tailscale Status:
tailscale status --jsonâ get mesh peers - LocalSend Probe: UDP multicast 224.0.0.167:53317 â find localsend-enabled peers
- Intersection: Peers on both networks get deterministic Gay.jl colors
Usage
# Discover peers on tailscale with localsend
just ts-localsend-discover
# Send file to peer
just ts-localsend-send <peer> <file>
# Receive mode
just ts-localsend-receive
Python API
from tailscale_localsend import TailscaleLocalSend
tls = TailscaleLocalSend(seed=0x6761795f636f6c6f)
# Discover peers
peers = tls.discover()
# [{'name': 'macbook', 'tailscale_ip': '100.x.x.x', 'localsend_port': 53317, 'color': '#A855F7'}]
# Send file
tls.send(peer='macbook', file='data.json')
# Receive (blocking)
tls.receive(callback=lambda f: print(f"Got {f}"))
Protocol Details
Tailscale Discovery
- Uses
tailscale status --jsonfor mesh peers - Extracts TailscaleIPs for each peer
- Falls back to Tailscale API if CLI unavailable
LocalSend Protocol
- Multicast: 224.0.0.167:53317 (UDP)
- Announce: JSON with alias, fingerprint, port
- Transfer: REST API over HTTPS
POST /api/localsend/v2/prepare-uploadPOST /api/localsend/v2/upload?sessionId=...
Color Assignment
Each peer gets deterministic color from Gay.jl:
peer_color = gay_color_at(hash(peer_fingerprint) % 1000, seed=GAY_SEED)
Integration with epistemic-arbitrage
from epistemic_arbitrage import ArbitrageNetwork
network = ArbitrageNetwork(seed=1069)
for peer in tls.discover():
network.add_cell(peer['name'], knowledge=peer.get('files', 0))
# Propagate knowledge between peers
network.add_propagator(:peer_sync, sources, targets)
network.run_parallel(n_workers=len(peers))
Commands
just ts-peers # List tailscale peers
just ls-peers # List localsend peers
just ts-ls-bridge # Bridge both networks
Base directory: ~/.codex/skills/tailscale-localsend