Skip to main content

Installation

License: Dual-license

The Apicurio Registry plugin is used to generate a catalog from an Apicurio Registry and import your schemas and specifications into EventCatalog.

You can map your schemas from your Apicurio Registry to events, commands, or queries in your catalog, and assign these to services and domains.

Installation

Run the command below to install the EventCatalog Apicurio Registry plugin.

"Don't have an EventCatalog project yet?"

If you don't have an EventCatalog project yet, you can follow the instructions in the Getting Started guide.

npm i @eventcatalog/generator-apicurio

Configuration

To use the plugin you need to configure it in your eventcatalog.config.js file.

Add the plugin to the generators array.

In this example we import all schemas from an Apicurio Registry into EventCatalog.

You can also create services and assign schemas to them, along with domains. (see examples).

eventcatalog.config.js
// ...
generators: [
// 1. Import all schemas from an Apicurio Registry
[
'@eventcatalog/generator-apicurio',
{
// The URL of your Apicurio Registry
registryUrl: 'http://localhost:8080',
// Do you want to include all versions of a schema? (default: false)
includeAllVersions: true
},
],
];

Configure API keys

The EventCatalog Apicurio Registry plugin requires API keys in your environment variables.

  1. A license key for the Apicurio Registry plugin (14 days trial, at EventCatalog Cloud)
  2. Apicurio Registry access token (optional - only if your registry requires authentication)

Create a .env file in the root, and add your keys to the project.

.env
# EventCatalog license key
EVENTCATALOG_LICENSE_KEY_APICURIO_SCHEMA_REGISTRY=your-license-key

# Apicurio Registry Bearer Token (optional - only if your registry requires authentication)
APICURIO_ACCESS_TOKEN=your-access-token-here

White listing EventCatalog domains

If you are behind a firewall you will need to white list the domain https://api.eventcatalog.cloud in your firewall. This is because the plugin needs to verify your license key.

Run the plugin

Run the plugin to import your schemas into EventCatalog.

This command will run the generators in your eventcatalog.config.js file.

npm run generate

View your catalog

Run your catalog locally to see the changes

npm run dev

Build your catalog for production

npm run build

Any questions or need help?

If you get stuck, find an issue or need help, please raise an issue on GitHub or join our Discord community.

You can also find some examples of the plugin in action in our examples repository: eventcatalog/examples.