2018-09-25 14:29:18 +00:00
---
2019-04-26 18:24:29 +00:00
title: About Chef InSpec and Train Plugins
2018-09-25 14:29:18 +00:00
---
2019-04-26 18:24:29 +00:00
# Chef InSpec and Train Plugins
2018-09-25 14:29:18 +00:00
2019-04-26 18:24:29 +00:00
## What are Chef InSpec Plugins?
2018-09-25 14:29:18 +00:00
2019-04-26 18:24:29 +00:00
Chef InSpec Plugins are optional software components that extend the capabilities of InSpec. For example, [`inspec-iggy` ](https://github.com/inspec/inspec-iggy ) is a Plugin project that aims to generate Chef InSpec controls from infrastructure-as-code files. Plugins are distributed as RubyGems, and Chef InSpec manages their installation. Chef InSpec Plugins always begin with the prefix 'inspec-'.
2018-09-27 22:46:35 +00:00
## What are Train Plugins?
2019-04-26 18:24:29 +00:00
Train Plugins allow Chef InSpec to speak to new kinds of targets (typically new remote targets or APIs, but you could treat the local system in a new way if you wished to). For example, if you wanted to audit a Kubernetes cluster, you might want a transport that can talk to the supervisor API. You would develop a Train Plugin for that, and install it using the Chef InSpec command line. Train Plugins always begin with the prefix 'train-'.
2018-09-25 14:29:18 +00:00
## What can plugins do?
Currently, each plugin can offer one or more of these capabilities:
2020-05-02 04:23:41 +00:00
* define new output formats ("reporters")
* input sources
2018-10-18 19:56:04 +00:00
* define a new command-line-interface (CLI) command suite (`inspec` plugins)
2018-09-27 22:46:35 +00:00
* connectivity to new types of hosts or cloud providers (`train` plugins)
Plugin Type: DSLs (#3557)
This PR adds 5 closely related plugin types, which allow a plugin to implement new DSL methods / keywords. The mechanism to activate the plugins are all very similar - basically, in a particular location in the code, `method_missing` is implemented, and is used to activate the particular type of DSL being requested.
4 of the DSL plugin types relate to code that could appear in a profile control file.
* outer_profile_dsl plugins allow you to extend the code in profile Ruby files that appear outside `control` or `describe` blocks.
* control_dsl plugins allow you to extend the code within `control` blocks.
* describe_dsl plugins allow you to extend the code within `describe` blocks.
* test_dsl plugins allow you to extend the code within `it`/`its` blocks.
Finally, the `resource_dsl` plugin allows you to extend the code used within custom resources.
Basic unit tests are provided to prove that the plugin types are properly defined.
A simple plugin fixture defining DSL hooks (based on favorite foods) is included, and is exercised through a set of functional tests.
The plugin developer docs are updated to describe the 5 DSLs.
*Note*: Implementing a plugin using any of the DSL plugin types is experimental. The contexts that are exposed to the DSL methods are private and poorly documented. The InSpec project does not claim the APIs used by these plugin types are covered by SemVer. Plugin authors are encouraged to pin tightly to the `inspec` gem in their gemspecs.
Motivation for this plugin comes from the desire to allow passionate community members to implement things like "2 out of 3" tests, example groups, improved serverspec compatibility, "they/their" and other "fluency" changes, as well as make it possible for future work by the InSpec team to be implemented as a core plugin, rather than a direct change to the main codebase.
2018-11-29 19:14:06 +00:00
* DSL extensions at the file, control, describe block, or test level
2020-05-02 04:23:41 +00:00
* DSL extensions for custom resources
2018-09-25 14:29:18 +00:00
## How do I find out which plugins are available?
2019-04-26 18:24:29 +00:00
The Chef InSpec CLI can tell you which plugins are available:
2018-09-25 14:29:18 +00:00
```bash
2018-10-18 19:56:04 +00:00
$ inspec plugin search inspec-
2018-09-25 14:29:18 +00:00
```
## How do I install and manage plugins?
2019-04-26 18:24:29 +00:00
The Chef InSpec command line now offers a new subcommand just for managing plugins.
2018-09-25 14:29:18 +00:00
You can install a plugin by running:
```bash
$ inspec plugin install inspec-some-plugin
2018-09-27 22:46:35 +00:00
$ inspec plugin install train-some-plugin
2018-09-25 14:29:18 +00:00
```
For more details on what the `plugin` command can do, see the [online help ](https://www.inspec.io/docs/reference/cli/#plugin ), or run `inspec plugin help` .
2020-03-19 10:39:35 +00:00
## How do I use a different Gem server?
You can specify an alternate source by passing the base of your Gem repository to the `--source` parameter:
```bash
$ inspec plugin search --source https://my.private.server inspec-private
$ inspec plugin install --source https://my.private.server inspec-private-plugin
```
2018-09-25 14:29:18 +00:00
## How do I write a plugin?
2019-04-26 18:24:29 +00:00
### Chef InSpec Plugins
2018-09-27 22:46:35 +00:00
2019-11-01 21:12:33 +00:00
For details on how to author a Chef InSpec Plugin, see the [developer documentation ](https://github.com/inspec/inspec/blob/master/docs/dev/plugins.md )
2018-09-27 22:46:35 +00:00
### Train Plugins
2018-11-07 20:40:07 +00:00
For details on how to author a Train Plugin, see the [developer documentation ](https://github.com/inspec/train/blob/master/docs/plugins.md )