Resources References
"Resource References" allow you use external files in Blueprints
Blueprints steps such as installPlugin
or installTheme
require a location of the plugin or theme to be installed.
That location can be defined as a URL
resource of the .zip
file containing the theme or plugin. It can also be defined as a wordpress.org/plugins
or wordpress.org/themes
resource for those plugins/themes published in the official WordPress directories.
The following resource references are available:
URLReference
The URLReference
resource is used to reference files that are stored on a remote server. The URLReference
resource is defined as follows:
type URLReference = {
resource: 'url';
url: string;
};
To use the URLReference
resource, you need to provide the URL of the file. For example, to reference a file named "index.html" that is stored on a remote server, you can create a URLReference
as follows:
{
"resource": "url",
"url": "https://example.com/index.html"
}
The resource url
type works really in combination with blueprint steps such as installPlugin
or installTheme
. These steps require a ResourceType
to define the location of the plugin or the theme to install.
With a "resource": "url"
we can define the location of a .zip
containing the plugin/theme via a URL that can point directly to a GitHub repo.
The Playground project provides a GitHub Proxy that allows you to generate a .zip
from a repository (or even a folder inside a repo) containing your plugin or theme. This tool is very useful for avoiding CORS issues, among others.
GitDirectoryReference
The GitDirectoryReference
resource is used to reference a directory inside a Git repository. This is useful when a plugin or theme lives in a subfolder of a repo, or when you want to install from a specific branch, tag, or commit.
type GitDirectoryReference = {
resource: 'git:directory';
url: string; // Repository URL (https://, ssh git@..., etc.)
path?: string; // Optional subdirectory inside the repository
ref?: string; // Optional branch, tag, or commit SHA
'.git'?: boolean; // Experimental: include a .git directory with fetched metadata
};
Example:
{
"step": "installPlugin",
"pluginData": {
"resource": "git:directory",
"url": "https://github.com/WordPress/block-development-examples",
"ref": "HEAD",
"path": "plugins/data-basics-59c8f8"
},
"options": {
"activate": true
}
}
Notes:
- Playground automatically detects providers like GitHub and GitLab.
- It handles CORS-proxied fetches and sparse checkouts, so you can use URLs that point to specific subdirectories or branches.
- This resource can be used with steps like
installPlugin
andinstallTheme
. - Set
".git": true
to include a.git
folder containing packfiles and refs so Git-aware tooling can detect the checkout. This currently mirrors a shallow clone of the selected ref.
CoreThemeReference
The CoreThemeReference resource is used to reference WordPress core themes. The CoreThemeReference resource is defined as follows:
type CoreThemeReference = {
resource: 'wordpress.org/themes';
slug: string;
version?: string;
};
To use the CoreThemeReference resource, you need to provide the slug of the theme. For example, to reference the "Twenty Twenty-One" theme, you can create a CoreThemeReference as follows:
{
"resource": "wordpress.org/themes",
"slug": "twentytwentyone"
}
CorePluginReference
The CorePluginReference resource is used to reference WordPress core plugins. The CorePluginReference resource is defined as follows:
type CorePluginReference = {
resource: 'wordpress.org/plugins';
slug: string;
version?: string;
};
To use the CorePluginReference resource, you need to provide the slug of the plugin. For example, to reference the "Akismet" plugin, you can create a CorePluginReference as follows:
{
"resource": "wordpress.org/plugins",
"slug": "akismet"
}
VFSReference
The VFSReference resource is used to reference files that are stored in a virtual file system (VFS). The VFS is a file system that is stored in memory and can be used to store files that are not part of the file system of the operating system. The VFSReference resource is defined as follows:
type VFSReference = {
resource: 'vfs';
path: string;
};
To use the VFSReference resource, you need to provide the path to the file in the VFS. For example, to reference a file named "index.html" that is stored in the root of the VFS, you can create a VFSReference as follows:
{
"resource": "vfs",
"path": "/index.html"
}
LiteralReference
The LiteralReference resource is used to reference files that are stored as literals in the code. The LiteralReference resource is defined as follows:
type LiteralReference = {
resource: 'literal';
name: string;
contents: string | Uint8Array;
};
To use the LiteralReference resource, you need to provide the name of the file and its contents. For example, to reference a file named "index.html" that contains the text "Hello, World!", you can create a LiteralReference as follows:
{
"resource": "literal",
"name": "index.html",
"contents": "Hello, World!"
}
BundledReference
The BundledReference
resource is used to reference files that are bundled with the Blueprint itself. This is particularly useful for creating self-contained Blueprint bundles that include all necessary resources. The BundledReference
resource is defined as follows:
type BundledReference = {
resource: 'bundled';
path: string;
};
To use the BundledReference
resource, you need to provide the relative path to the file within the bundle. For example, to reference a file named "plugin.php" that is bundled with the Blueprint, you can create a BundledReference
as follows:
{
"resource": "bundled",
"path": "plugin.php"
}
Blueprint bundles can be distributed in various formats, including:
- ZIP files with a top-level
blueprint.json
file - Directories containing a
blueprint.json
file and related resources - Remote URLs where the Blueprint and its resources are hosted together
For more information on Blueprint bundles, see the Blueprint Bundles documentation.