Skip to content

Commit

Permalink
Add canonically-cased config options
Browse files Browse the repository at this point in the history
  • Loading branch information
StephenBrown2 committed Feb 10, 2022
1 parent c7f8dec commit 5e1d41b
Show file tree
Hide file tree
Showing 2 changed files with 149 additions and 1 deletion.
7 changes: 6 additions & 1 deletion config.go
Original file line number Diff line number Diff line change
Expand Up @@ -571,6 +571,11 @@ type KV struct {
position Position
}

// CanonicalKey returns k's Key, using the canonical casing from https://man.openbsd.org/ssh_config.
func (k *KV) CanonicalKey() string {
return getCanonicalCase(k.Key)
}

// Pos returns k's Position.
func (k *KV) Pos() Position {
return k.position
Expand All @@ -586,7 +591,7 @@ func (k *KV) String() string {
if k.hasEquals {
equals = " = "
}
line := fmt.Sprintf("%s%s%s%s", strings.Repeat(" ", int(k.leadingSpace)), k.Key, equals, k.Value)
line := fmt.Sprintf("%s%s%s%s", strings.Repeat(" ", k.leadingSpace), k.CanonicalKey(), equals, k.Value)
if k.Comment != "" {
line += " #" + k.Comment
}
Expand Down
143 changes: 143 additions & 0 deletions config_options.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
package ssh_config

import (
"strings"
)

// Current as of OpenSSH 8.2
// Source: https://man.openbsd.org/ssh_config
var configOptions = []string{
"Host",
"Match",
"AddKeysToAgent",
"AddressFamily",
"BatchMode",
"BindAddress",
"BindInterface",
"CanonicalDomains",
"CanonicalizeFallbackLocal",
"CanonicalizeHostname",
"CanonicalizeMaxDots",
"CanonicalizePermittedCNAMEs",
"CASignatureAlgorithms",
"CertificateFile",
"CheckHostIP",
"Ciphers",
"ClearAllForwardings",
"Compression",
"ConnectionAttempts",
"ConnectTimeout",
"ControlMaster",
"ControlPath",
"ControlPersist",
"DynamicForward",
"EnableSSHKeysign",
"EscapeChar",
"ExitOnForwardFailure",
"FingerprintHash",
"ForkAfterAuthentication",
"ForwardAgent",
"ForwardX11",
"ForwardX11Timeout",
"ForwardX11Trusted",
"GatewayPorts",
"GlobalKnownHostsFile",
"GSSAPIAuthentication",
"GSSAPIDelegateCredentials",
"HashKnownHosts",
"HostbasedAcceptedAlgorithms",
"HostbasedAuthentication",
"HostKeyAlgorithms",
"HostKeyAlias",
"Hostname",
"IdentitiesOnly",
"IdentityAgent",
"IdentityFile",
"IgnoreUnknown",
"Include",
"IPQoS",
"KbdInteractiveAuthentication",
"KbdInteractiveDevices",
"KexAlgorithms",
"KnownHostsCommand",
"LocalCommand",
"LocalForward",
"LogLevel",
"LogVerbose",
"MACs",
"NoHostAuthenticationForLocalhost",
"NumberOfPasswordPrompts",
"PasswordAuthentication",
"PermitLocalCommand",
"PermitRemoteOpen",
"PKCS11Provider",
"Port",
"PreferredAuthentications",
"ProxyCommand",
"ProxyJump",
"ProxyUseFdpass",
"PubkeyAcceptedAlgorithms",
"PubkeyAuthentication",
"RekeyLimit",
"RemoteCommand",
"RemoteForward",
"RequestTTY",
"RevokedHostKeys",
"SecurityKeyProvider",
"SendEnv",
"ServerAliveCountMax",
"ServerAliveInterval",
"SessionType",
"SetEnv",
"StdinNull",
"StreamLocalBindMask",
"StreamLocalBindUnlink",
"StrictHostKeyChecking",
"SyslogFacility",
"TCPKeepAlive",
"Tunnel",
"TunnelDevice",
"UpdateHostKeys",
"User",
"UserKnownHostsFile",
"VerifyHostKeyDNS",
"VisualHostKey",
"XAuthLocation",
}

// // getConfigOptions retrieves a sorted list of all the current config options
// // from the official source: https://man.openbsd.org/ssh_config and filtered
// // with "github.com/PuerkitoBio/goquery".
// // The result is sorted and therefore may be searched with sort.SearchStrings()
// func getConfigOptions() (opts []string, err error) {
// SSHConfigURL := "https://man.openbsd.org/ssh_config"

// resp, err := http.Get(SSHConfigURL)
// if err != nil {
// return opts, fmt.Errorf("getting %s: %w", SSHConfigURL, err)
// }
// defer resp.Body.Close()

// doc, err := goquery.NewDocumentFromReader(resp.Body)
// if err != nil {
// return opts, fmt.Errorf("parsing %s: %w", SSHConfigURL, err)
// }

// doc.Find("dt > a > code.Cm").Each(func(i int, c *goquery.Selection) {
// opts = append(opts, c.Text())
// })

// sort.Strings(opts)
// return opts, nil
// }

// getCanonicalCase checks for the given key in the known ssh config keys
// and returns with proper casing if found, otherwise returns what was given.
func getCanonicalCase(key string) string {
for _, value := range configOptions {
if strings.EqualFold(key, value) {
return value
}
}
return key
}

0 comments on commit 5e1d41b

Please sign in to comment.