@janus-idp/backstage-plugin-bulk-import-backend-dynamic v3.1.4
Bulk Import Backend Plugin
This is bulk-import-backend plugin which provides Rest API to bulk import catalog entities into the catalog
For administrators
Installation and Configuration
To set up the bulk import backend package for the backend:
- Install the bulk import backend plugin using the following command: - yarn workspace backend add @janus-idp/backstage-plugin-bulk-import-backend
- Add the following code to the - packages/backend/src/index.tsfile:- const backend = createBackend(); /* highlight-add-next-line */ backend.add(import('@janus-idp/backstage-plugin-bulk-import-backend')); backend.start();
Permission Framework Support
The Bulk Import Backend plugin has support for the permission framework. A basic example permission policy is shown below to disallow access to the bulk import API for all users except those in the backstage-admins group.
- Create a backend module for the permission policy, under a packages/backend/src/plugins/permissions.tsfile:
import { createBackendModule } from '@backstage/backend-plugin-api';
import { BackstageIdentityResponse } from '@backstage/plugin-auth-node';
import {
  AuthorizeResult,
  isPermission,
  PolicyDecision,
} from '@backstage/plugin-permission-common';
import {
  PermissionPolicy,
  PolicyQuery,
} from '@backstage/plugin-permission-node';
import { policyExtensionPoint } from '@backstage/plugin-permission-node/alpha';
import { bulkImportPermission } from '@janus-idp/backstage-plugin-bulk-import-common';
class BulkImportPermissionPolicy implements PermissionPolicy {
  async handle(
    request: PolicyQuery,
    user?: BackstageIdentityResponse,
  ): Promise<PolicyDecision> {
    if (isPermission(request.permission, bulkImportPermission)) {
      if (
        user?.identity.ownershipEntityRefs.includes(
          'group:default/backstage-admins',
        )
      ) {
        return { result: AuthorizeResult.ALLOW };
      }
    }
    return { result: AuthorizeResult.DENY };
  }
}
export const BulkImportPermissionBackendModule = createBackendModule({
  pluginId: 'permission',
  moduleId: 'custom-policy',
  register(reg) {
    reg.registerInit({
      deps: { policy: policyExtensionPoint },
      async init({ policy }) {
        policy.setPolicy(new BulkImportPermissionPolicy());
      },
    });
  },
});- Import @backstage/plugin-permission-backend/alphaand add your permission module to thepackages/backend/src/index.tsfile:
import { BulkImportPermissionBackendModule } from './plugins/permissions';
backend.add(BulkImportPermissionBackendModule);
backend.add(import('@backstage/plugin-permission-backend/alpha'));Audit Logging
Audit logging is backed by the backstage-plugin-audit-log-node package. The Bulk Import Backend plugin adds the following events to the backend audit logs:
- BulkImportUnknownEndpoint: tracks requests to unknown endpoints. 
- BulkImportPing: tracks - GETrequests to the- /pingendpoint, which allows to make sure the bulk import backend is up and running.
- BulkImportFindAllOrganizations: tracks - GETrequests to the- /organizationsendpoint, which returns the list of organizations accessible from all configured GitHub Integrations.
- BulkImportFindRepositoriesByOrganization: tracks - GETrequests to the- /organizations/:orgName/repositoriesendpoint, which returns the list of repositories for the specified organization (accessible from any of the configured GitHub Integrations).
- BulkImportFindAllRepositories: tracks - GETrequests to the- /repositoriesendpoint, which returns the list of repositories accessible from all configured GitHub Integrations.
- BulkImportFindAllImports: tracks - GETrequests to the- /importsendpoint, which returns the list of existing import jobs along with their statuses.
- BulkImportCreateImportJobs: tracks - POSTrequests to the- /importsendpoint, which allows to submit requests to bulk-import one or many repositories into the Backstage Catalog, by eventually creating import Pull Requests in the target repositories.
- BulkImportFindImportStatusByRepo: tracks - GETrequests to the- /import/by-repoendpoint, which fetches details about the import job for the specified repository.
- BulkImportDeleteImportByRepo: tracks - DELETErequests to the- /import/by-repoendpoint, which deletes any existing import job for the specified repository, by closing any open import Pull Request that could have been created.
Example:
{
  "actor": {
    "actorId": "user:default/myuser",
    "hostname": "localhost",
    "ip": "::1",
    "userAgent": "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/128.0.0.0 Safari/537.36"
  },
  "eventName": "BulkImportFindAllOrganizations",
  "isAuditLog": true,
  "level": "info",
  "message": "'get /organizations' endpoint hit by user:default/myuser",
  "meta": {},
  "plugin": "bulk-import",
  "request": {
    "body": {},
    "method": "GET",
    "params": {},
    "query": {
      "pagePerIntegration": "1",
      "sizePerIntegration": "5"
    },
    "url": "/api/bulk-import/organizations?pagePerIntegration=1&sizePerIntegration=5"
  },
  "response": {
    "status": 200
  },
  "service": "backstage",
  "stage": "completion",
  "status": "succeeded",
  "timestamp": "2024-08-26 16:41:02"
}For Users
Usage
The bulk import backend plugin provides a REST API to bulk import catalog entities into the catalog. The API is available at the /api/bulk-import endpoint.
As a prerequisite, you need to add at least one GitHub Integration (using either a GitHub token or a GitHub App or both) in your app-config YAML file (or a local app-config.local.yaml file).
See https://backstage.io/docs/integrations/github/locations/#configuration and https://backstage.io/docs/integrations/github/github-apps/#including-in-integrations-config for more details.
REST API
Please refer to src/schema/openapi.yaml for the API definition (along with some examples) and the generated documentation for more details about the request and response parameters and formats.
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago