{
fetchFromGitHub,
lib,
stdenvNoCC,
}:
stdenvNoCC.mkDerivation rec {
pname = "ssh-agents";
version = "1.0.1";
src = fetchFromGitHub {
owner = "kalbasit";
repo = "ssh-agents";
rev = "v${version}";
sha256 = "1l09zy87033v7hd17lhkxikwikqz5nj9x6c2w80rqpad4lp9ihwz";
};
installFlags = [ "PREFIX=$(out)" ];
meta = with lib; {
description = "ssh-agents capable of spawning and maintaining multiple ssh-agents across terminals";
longDescription = ''
The SSH agent is usually spawned by running eval $(ssh-agent), however this
spawns a new SSH agent at every invocation. This project provides an
ssh-agent wrapper called ssh-agents that is capable of spawning an SSH
agent and caching the environment variables for later invocation.
Features
- One SSH agent across all terminals
- Add all un-encrypted SSH keys to the agent upon spawning. Please note
that encrypted SSH keys can only be added via ssh-add after having
started the agent.
- Ability to have different keys in different agents for security purposes.
- Multiple SSH agents
- To use multi-SSH agents, start ssh agent with the --name flag. The
given name is expected to be a folder under ~/.ssh/name containing the
keys to include in the agent.
'';
homepage = "https://github.com/kalbasit/ssh-agents";
license = licenses.mit;
maintainers = with maintainers; [ kalbasit ];
platforms = platforms.unix;
mainProgram = "ssh-agents";
}