CrafterCMS Plugin Descriptor¶
The craftercms-plugin.yaml file contains information for use in CrafterCMS.  This descriptor file contains
information about your extension, such as the license, the versions of CrafterCMS supported, and other
configurations and metadata.  In this section, we’ll take a look at a plugin descriptor file.
 1# This file describes a plugin for use in CrafterCMS
 2
 3# The version of the format for this file
 4descriptorVersion: 2
 5
 6# Describe the plugin
 7plugin:
 8  type: site
 9  id: org.craftercms.plugin.test
10  name: Project Plugin Example
11  tags:
12    - test
13  version:
14    major: 3
15    minor: 0
16    patch: 1
17  description: A simple example for project plugins
18  documentation: "https://raw.githubusercontent.com/craftercms/site-plugin-example/master/readme.md"
19  website:
20    name: Plugin Example
21    url: https://github.com/craftercms/site-plugins-example
22  media:
23    screenshots:
24      - title: CrafterCMS
25        description: CrafterCMS Example Plugin
26        url: "https://raw.githubusercontent.com/craftercms/site-plugin-example/master/.crafter/screenshots/default.png"
27  developer:
28    company:
29      name: CrafterCMS
30      email: info@craftercms.com
31      url: https://craftercms.com
32  license:
33    name: MIT
34    url: https://opensource.org/licenses/MIT
35  crafterCmsVersions:
36    - major: 4
37      minor: 0
38  crafterCmsEditions:
39    - community
40    - enterprise
41  # Option auto-wiring section
42  # installation:
Here are some things to note in the descriptor file:
| Field | Required | Description | 
|---|---|---|
| descriptorVersion | ✓ | The version of the format for this file which is currently 2 | 
| plugin.type | ✓ | Set the value to  | 
| plugin.id | ✓ | A unique Id that is meaningful/recognizable to people who will be using the plugin | 
| plugin.name | ✓ | The name displayed in the Crafter Marketplace.  | 
| plugin.version | ✓ | The version number for the plugin | 
| plugin.description | Contains a short description of the plugin and is displayed underneath the plugin name in  | |
| plugin.documentation | Serves as the help block for the plugin. It contains a URL to the plugin’s documentation file  | |
| plugin.website.url | Can be a page for more information on your plugin or for announcing updates, reporting bugs, etc.  | |
| plugin.media.url | The path to look for a representative image of the plugin.  | |
| plugin.license | The license supported by the plugin | |
| plugin.crafterCmsVersions | ✓ | Contains the CrafterCMS version/s (major and minor numbers) that the plugin is compatible with  Here’s an example: crafterCmsVersions:
  - major: 3
    minor: 1
  - major: 4
    minor: 0
Note that use of the full CrafterCMS version with the major, minor, and patch numbers is still supported for  | 
Note
For the images to be used for the screenshots in the craftercms-plugin.yaml file, we recommend
using images with approximately a 4:3 aspect ratio (width to height), such as an image sized at 1200x800
Auto-wiring¶
CrafterCMS supports automatically wiring your plugin to the corresponding configuration file in Studio during your plugin installation.
To setup a plugin to be automatically wired in the corresponding configuration file in
Studio (for example, a form control, will be wired to the Content Type Editor Configuration file)
during the installation, add the following to your craftercms-plugin.yaml descriptor file
 1installation:
 2 - type: preview-app
 3   parentXpath: //widget[@id='craftercms.components.ToolsPanel']
 4   elementXpath: //plugin[@id='org.craftercms.sampleComponentLibraryPlugin.components.reactComponent']
 5   element:
 6     name: configuration
 7     children:
 8     - name: widgets
 9       children:
10       - name: widget
11         attributes:
12         - name: id
13           value: org.craftercms.sampleComponentLibraryPlugin.components.reactComponent
14         children:
15         - name: plugin
16           attributes:
17           - name: id
18             value: org.craftercms.plugin.sidebar
19           - name: type
20             value: sidebar
21           - name: name
22             value: react-sample
23           - name: file
24             value: index.modern.js
where:
- installation.typeis the type of plugin for auto-wiring in Studio. Available values are form-control, form-datasource, preview-app, site-filter and site-context
- installation.parentXpathis an XPath selector for the element where the plugin will be added, required when installation-type is preview-app
- installation.elementXpathis an XPath selector to check if the plugin is already present in the configuration and used to remove the config when the plugin is uninstalled
- installation.element.nameis the element name to be wired in your project configuration file so the plugin will show up in Studio Available values are control (for form-control installation type), datasource (for form-datasource installation type) and for preview-app installation type, the start of the section the plugin needs to be inserted in, e.g. configuration, etc.
- installation.element.childrencontains any number of name and children describing your plugin, such as the icon to be used by your plugin if applicable, or the plugin location, where:- nameis the name of what’s being described, e.g. plugin or icon
- childrencontains any number of name and value and can contain the class (icon), plugin id, plugin type, plugin name and plugin files/folders (plugin location) and its corresponding values
 
Below are examples on how to setup auto-wiring in Studio for various plugin types:
Below is a sample auto-wiring setup for a form control.
 1installation:
 2  - type: form-control
 3    elementXpath: //control/plugin[pluginId='org.craftercms.plugin.control']
 4    element:
 5      name: control
 6      children:
 7        - name: plugin
 8          children:
 9            - name: pluginId
10              value: org.craftercms.plugin.control
11            - name: type
12              value: control
13            - name: name
14              value: text-input
15            - name: filename
16              value: main.js
17        - name: icon
18          children:
19            - name: class
20              value: fa-pencil-square-o
Below is a sample auto-wiring setup for a data source.
 1installation:
 2  - type: form-datasource
 3    elementXpath: //datasource/plugin[pluginId='org.craftercms.plugin.datasource']
 4    element:
 5      name: datasource
 6      children:
 7        - name: plugin
 8          children:
 9            - name: pluginId
10              value: org.craftercms.plugin.datasource
11            - name: type
12              value: datasource
13            - name: name
14              value: text-input
15            - name: filename
16              value: main.js
17            - name: icon
18              children:
19            - name: class
20              value: fa-pencil-square-o
Below is a sample auto-wiring setup for a preview-app.
 1installation:
 2  - type: preview-app
 3    parentXpath: //widget[@id='craftercms.components.ToolsPanel']
 4    elementXpath: //plugin[@id='org.craftercms.sampleComponentLibraryPlugin.components.reactComponent']
 5    element:
 6      name: configuration
 7      children:
 8      - name: widgets
 9        children:
10        - name: widget
11          attributes:
12          - name: id
13            value: org.craftercms.sampleComponentLibraryPlugin.components.reactComponent
14          children:
15          - name: plugin
16            attributes:
17            - name: id
18              value: org.craftercms.plugin
19            - name: type
20              value: sidebar
21            - name: name
22              value: react-sample
23            - name: file
24              value: index.modern.js
Below is a sample auto-wiring setup for a site filter.
 1installation:
 2  - type: site-filter
 3    elementXpath: //filter/script[text()='/scripts/filters/plugins/org/craftercms/plugin/filter/myFilter.groovy']
 4    element:
 5      name: filter
 6      children:
 7        - name: script
 8          value: '/scripts/filters/plugins/org/craftercms/plugin/filter/myFilter.groovy'
 9        - name: mapping
10          children:
11            - name: include
12              value: '/**'
Below is a sample auto-wiring setup for the site context.
 1installation:
 2  - type: site-context
 3    elementXpath: //bean[@id='myBean']
 4    element:
 5      name: bean
 6      attributes:
 7        - name: id
 8          value: myBean
 9        - name: class
10          value: plugins.org.craftercms.plugin/context/MyClass
11      children:
12        - name: property
13          attributes:
14            - name: name
15              value: siteItemService
16            - name: ref
17              value: crafter.siteItemService
See here for examples of plugins auto-wired in Studio.