Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
@red-hat-developer-hub/backstage-plugin-bulk-import-backend
Advanced tools
This is bulk-import-backend
plugin which provides Rest API to bulk import catalog entities into the catalog
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 @red-hat-developer-hub/backstage-plugin-bulk-import-backend
Add the following code to the packages/backend/src/index.ts
file:
const backend = createBackend();
/* highlight-add-next-line */
backend.add(
import('@red-hat-developer-hub/backstage-plugin-bulk-import-backend'),
);
backend.start();
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.
packages/backend/src/plugins/permissions.ts
file: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 '@red-hat-developer-hub/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());
},
});
},
});
@backstage/plugin-permission-backend/alpha
and add your permission module to the packages/backend/src/index.ts
file:import { BulkImportPermissionBackendModule } from './plugins/permissions';
backend.add(BulkImportPermissionBackendModule);
backend.add(import('@backstage/plugin-permission-backend/alpha'));
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 GET
requests to the /ping
endpoint, which allows to make sure the bulk import backend is up and running.
BulkImportFindAllOrganizations: tracks GET
requests to the /organizations
endpoint, which returns the list of organizations accessible from all configured GitHub Integrations.
BulkImportFindRepositoriesByOrganization: tracks GET
requests to the /organizations/:orgName/repositories
endpoint, which returns the list of repositories for the specified organization (accessible from any of the configured GitHub Integrations).
BulkImportFindAllRepositories: tracks GET
requests to the /repositories
endpoint, which returns the list of repositories accessible from all configured GitHub Integrations.
BulkImportFindAllImports: tracks GET
requests to the /imports
endpoint, which returns the list of existing import jobs along with their statuses.
BulkImportCreateImportJobs: tracks POST
requests to the /imports
endpoint, 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 GET
requests to the /import/by-repo
endpoint, which fetches details about the import job for the specified repository.
BulkImportDeleteImportByRepo: tracks DELETE
requests to the /import/by-repo
endpoint, 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"
}
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.
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.
FAQs
Unknown package
The npm package @red-hat-developer-hub/backstage-plugin-bulk-import-backend receives a total of 549 weekly downloads. As such, @red-hat-developer-hub/backstage-plugin-bulk-import-backend popularity was classified as not popular.
We found that @red-hat-developer-hub/backstage-plugin-bulk-import-backend demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.