mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-24 19:42:04 +01:00
46 lines
1.7 KiB
Go
46 lines
1.7 KiB
Go
|
/*
|
||
|
Package ssh wraps the crypto/ssh package with a higher-level API for building
|
||
|
SSH servers. The goal of the API was to make it as simple as using net/http, so
|
||
|
the API is very similar.
|
||
|
|
||
|
You should be able to build any SSH server using only this package, which wraps
|
||
|
relevant types and some functions from crypto/ssh. However, you still need to
|
||
|
use crypto/ssh for building SSH clients.
|
||
|
|
||
|
ListenAndServe starts an SSH server with a given address, handler, and options. The
|
||
|
handler is usually nil, which means to use DefaultHandler. Handle sets DefaultHandler:
|
||
|
|
||
|
ssh.Handle(func(s ssh.Session) {
|
||
|
io.WriteString(s, "Hello world\n")
|
||
|
})
|
||
|
|
||
|
log.Fatal(ssh.ListenAndServe(":2222", nil))
|
||
|
|
||
|
If you don't specify a host key, it will generate one every time. This is convenient
|
||
|
except you'll have to deal with clients being confused that the host key is different.
|
||
|
It's a better idea to generate or point to an existing key on your system:
|
||
|
|
||
|
log.Fatal(ssh.ListenAndServe(":2222", nil, ssh.HostKeyFile("/Users/progrium/.ssh/id_rsa")))
|
||
|
|
||
|
Although all options have functional option helpers, another way to control the
|
||
|
server's behavior is by creating a custom Server:
|
||
|
|
||
|
s := &ssh.Server{
|
||
|
Addr: ":2222",
|
||
|
Handler: sessionHandler,
|
||
|
PublicKeyHandler: authHandler,
|
||
|
}
|
||
|
s.AddHostKey(hostKeySigner)
|
||
|
|
||
|
log.Fatal(s.ListenAndServe())
|
||
|
|
||
|
This package automatically handles basic SSH requests like setting environment
|
||
|
variables, requesting PTY, and changing window size. These requests are
|
||
|
processed, responded to, and any relevant state is updated. This state is then
|
||
|
exposed to you via the Session interface.
|
||
|
|
||
|
The one big feature missing from the Session abstraction is signals. This was
|
||
|
started, but not completed. Pull Requests welcome!
|
||
|
*/
|
||
|
package ssh
|