Skip to content

Latest commit

 

History

History
114 lines (84 loc) · 4.63 KB

README.md

File metadata and controls

114 lines (84 loc) · 4.63 KB

vim-puppet-nav

This plugin, like vim-rspec-puppet, assumes your puppet code is organized similar to the below and is rooted at the value of g:puppet_nav_proj_path (must be set):

.
├── manifests
├── modules
│   ├── some-forge-module
│   ├── your-custom-mod
...

Given that code organization, the plugin will assist in navigating that puppet code. Given a simple puppet code snippet below:

include some::class

the plugin will extract all of the puppet resources in the file (except the built in resources like file, package, etc) and let the user define various actions on them, namely:

  1. Going directly to the manifest file of a resource. This can be done by either selecting the target resource from an fzf driven selection list or extracting the resource from the current line.
  2. Going directly to the spec file of a resource.
  3. Grepping the code base for a resource
  4. Going from the spec file to the manifest of the resource.

In addition, the original Rg command from the fzf.vim plugin was used as the inspiration for a variant called Rgp to grep only the puppet manifests.

Install

Install using vim-plug or another vim plugin system. If you don't have a plugin system, put the file in a location that is sourced by Vim such as ~/.vim/plugin.

Use

Variables

The following variables control the behavior of the plugin.

Variable Purpose
g:puppet_nav_proj_path Path to the puppet code base. MUST BE SET.
g:puppetdb_host Host and port of the PuppetDB service. See PuppetDB Integration.
g:puppet_nav_debug Enable debug output.

Functions

The following functions are exposed for the bindings of your choice:

Function Purpose
GoToPuppetManifest() Go to the puppet manifest of the resource on the line
SelectResourcesFzf() Go to the puppet manifest of the resource selected via an FZF dialog
PuppetDbTypeTitleLookup() See PuppetDB Integration.
PuppetDbTypeLookup() See PuppetDB Integration.
SearchPuppetCode() Search the puppet manifests for the resource on the current line and present the results in an FZF dialog. The result will exclude the current file. The idea is to search for the use of the resource in other manifests.

The following commands are defined:

Command Purpose
Rgp Grep the puppet manifests presenting the results using an FZF dialog

PuppetDB Integration

If the PuppetDB component of the plugin is configured, it becomes possible to see which puppet managed hosts utilize this or that puppet resource. In order for puppetdb lookups to work, you need to set the g:puppetdb_host variable to your server in this format: http(s)://<DBHOST>:<DBPORT>.

Once the host is set, you can position the cursor on a line with a puppet resource and execute :call PuppetDbTypeTitleLookup() or :call PuppetDbTypeLookup(). The output in a new tab will be a list of hosts using that resource.

The difference between those two functions is that given the code below:

some::defined::type { 'instance':; }

PuppetDbTypeTitleLookup will query PuppetDB using both the type (some::defined::type) and the title instance, while PuppetDbTypeLookup will use only the type.

However given this code:

some::class { 'class-name':; }

both functions will work identically by using both the type (class) and the title (class-name). The reason why title is forcefully used in these cases is because querying just by the type could potentially produce hundreds of results and create unnecessary load on PuppetDB.

Example key binding for the functions are below:

:nnoremap <Leader>L :call PuppetDbTypeTitleLookup()<cr>
:nnoremap <Leader>l :call PuppetDbTypeLookup()<cr>

NOTE: Internally, the plugin uses curl andjq to present the results of the query. So they should be present on the system.

Dependencies

  • fzf
  • fzf.vim
  • Ripgrep
  • Vim >= 8.1 (because of the "terminal" capability in vim >= 8.1)
  • The following Linux utils to query puppetdb and process the responses: curl, jq, column.

Acknowledgements

  • Tim Byrne for the initial idea and all the suggestions.
  • Junegunn Choi for the fzf suite of tools. Amazing stuff.