Installation
Dual-licenseThe 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.
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.
- Import all schemas
- Import schemas and assign them to services and domains
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).
// ...
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
},
],
];
In this example we document services, assign schemas to them, and organize everything within a domain.
We create an orders domain and an Orders Service that sends and receives messages.
// ...
[
'@eventcatalog/generator-apicurio',
{
// The URL of your Apicurio Registry
registryUrl: 'http://localhost:8080',
// The services to assign schemas to (optional)
services: [
{
id: 'Orders Service',
version: '1.0.0',
// the messages this service sends
// We use the prefix matching against the artifact name
sends: [
{ events: { prefix: 'order-' } }
],
// the messages this service receives
// We use the exact matching against the artifact name
receives: [
{ commands: ['place-order', 'cancel-order'] }
],
},
],
domain: {
id: 'orders',
name: 'Orders',
version: '1.0.0',
}
},
],
Configure API keys
The EventCatalog Apicurio Registry plugin requires API keys in your environment variables.
- A license key for the Apicurio Registry plugin (14 days trial, at EventCatalog Cloud)
- 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.
# 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.