Skip to content

Commit

Permalink
Follow Include to extract more SSH hosts (#993)
Browse files Browse the repository at this point in the history
Sometimes, we have so many SSH servers that divide to extra config files
and include in *~/.ssh/config*

This PR follow the `Include` directive to retrieve more hosts.

Example of such config:

```ssh_config
Include extra/agriconnect
Include "extra/Old servers"
```

This PR also fix an issue that orginal code grabs this:

```ssh_config
Host *
```
  • Loading branch information
hongquan authored Dec 14, 2024
1 parent cc62dd7 commit 8c21f6e
Showing 1 changed file with 11 additions and 4 deletions.
15 changes: 11 additions & 4 deletions custom-completions/ssh/ssh-completions.nu
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,21 @@ def "nu-complete ssh-host" [] {
let files = [
'/etc/ssh/ssh_config',
'~/.ssh/config'
] | filter { |file| $file | path exists }
] | filter {|file| $file | path exists }

$files | each { |file|
let included_files = $files | each {|file|
let folder = $file | path expand | path dirname
let rel_subfiles = $file | open | lines | str trim | where { |s| $s | str starts-with 'Include' } | each { |s| $s | parse --regex '^Include\s+(?<subfile>.+)' | get subfile | str replace -a '"' '' } | flatten
$rel_subfiles | each { |f| $folder | path join $f }
} | flatten | filter { |p| $p | path exists }


[ ...$files, ...$included_files ] | each {|file|
let lines = $file | open | lines | str trim

mut result = []
for $line in $lines {
let data = $line | parse --regex '^Host\s+(?<host>.+)'
let data = $line | parse --regex '^Host\s+(?<host>[-\.\w]+)'
if ($data | is-not-empty) {
$result = ($result | append { 'value': ($data.host | first), 'description': "" })
continue;
Expand All @@ -54,4 +61,4 @@ def "nu-complete ssh-host" [] {
}
$result
} | flatten
}
}

0 comments on commit 8c21f6e

Please sign in to comment.