Backstage
    Preparing search index...

    Module @backstage/plugin-search-backend-module-catalog

    A module for the search backend that exports Catalog modules.

    search-backend-module-catalog

    This package exports a module that extends the search backend to also indexing the entities of your catalog.

    Add the module package as a dependency:

    # From your Backstage root directory
    yarn --cwd packages/backend add @backstage/plugin-search-backend-module-catalog

    Add the collator to your backend instance, along with the search plugin itself:

    // packages/backend/src/index.ts
    import { createBackend } from '@backstage/backend-defaults';

    const backend = createBackend();
    backend.add(import('@backstage/plugin-search-backend'));
    backend.add(import('@backstage/plugin-search-backend-module-catalog'));
    backend.start();

    You may also want to add configuration parameters to your app-config, for example for controlling the scheduled indexing interval. These parameters should be placed under the search.collators.catalog key. See the config definition file for more details.

    This module also has an extension point, which lets you inject advanced customizations. Here's an example of how to leverage that extension point to tweak the transformer used for building the search indexer documents:

    // packages/backend/src/index.ts
    import { createBackend } from '@backstage/backend-defaults';
    import { createBackendModule } from '@backstage/backend-plugin-api';
    import { CatalogCollatorEntityTransformer } from '@backstage/plugin-search-backend-module-catalog';
    import { catalogCollatorExtensionPoint } from '@backstage/plugin-search-backend-module-catalog/alpha';

    const customTransformer: CatalogCollatorEntityTransformer = entity => ({
    title: entity.metadata.title || entity.metadata.name,
    text: entity.metadata.description || '',
    componentType: entity.spec?.type?.toString() || 'other',
    type: entity.spec?.type?.toString() || 'other',
    namespace: entity.metadata.namespace || 'default',
    kind: entity.kind,
    lifecycle: (entity.spec?.lifecycle as string) || '',
    owner: (entity.spec?.owner as string) || '',
    });

    const backend = createBackend();
    backend.add(import('@backstage/plugin-search-backend'));
    backend.add(import('@backstage/plugin-search-backend-module-catalog'));
    backend.add(
    createBackendModule({
    pluginId: 'search',
    moduleId: 'my-catalog-collator-options',
    register(reg) {
    reg.registerInit({
    deps: { collator: catalogCollatorExtensionPoint },
    async init({ collator }) {
    collator.setEntityTransformer(customTransformer);
    },
    });
    },
    })(),
    );
    backend.start();

    Type Aliases

    CatalogCollatorEntityTransformer
    CatalogCollatorExtensionPoint

    Variables

    catalogCollatorExtensionPoint
    default
    defaultCatalogCollatorEntityTransformer