diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/bulk_upload_asset_criticality.schema.yaml b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/bulk_upload_asset_criticality.schema.yaml index 25053de391d87..1e7a9b6ca3372 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/bulk_upload_asset_criticality.schema.yaml +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/bulk_upload_asset_criticality.schema.yaml @@ -1,3 +1,4 @@ +# ⚠️ Updating this file? Also update the public API docs at https://github.com/elastic/security-docs/tree/main/docs/advanced-entity-analytics/api openapi: 3.0.0 info: version: '2023-10-31' @@ -8,7 +9,8 @@ paths: x-labels: [ess, serverless] x-codegen-enabled: true operationId: BulkUpsertAssetCriticalityRecords - summary: Bulk upsert asset criticality data, creating or updating records as needed + summary: Bulk Upsert Asset Criticality Records + description: Bulk upsert up to 1000 asset criticality records, creating or updating them as needed. requestBody: content: application/json: diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/create_asset_criticality.schema.yaml b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/create_asset_criticality.schema.yaml index ea05996e1f958..13a9e831a2cd5 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/create_asset_criticality.schema.yaml +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/create_asset_criticality.schema.yaml @@ -1,3 +1,4 @@ +# ⚠️ Updating this file? Also update the public API docs at https://github.com/elastic/security-docs/tree/main/docs/advanced-entity-analytics/api openapi: 3.0.0 info: version: '2023-10-31' @@ -8,7 +9,8 @@ paths: x-labels: [ess, serverless] x-codegen-enabled: true operationId: CreateAssetCriticalityRecord - summary: Create Criticality Record + summary: Upsert Criticality Record + description: Create or update a criticality record for a specific asset. requestBody: required: true content: diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.gen.ts b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.gen.ts index 4b747b6a48674..de493f0cc0972 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.gen.ts +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.gen.ts @@ -44,8 +44,11 @@ export type DeleteAssetCriticalityRecordResponse = z.infer< >; export const DeleteAssetCriticalityRecordResponse = z.object({ /** - * If the record was deleted. If false the record did not exist. + * True if the record was deleted or false if the record did not exist. */ deleted: z.boolean(), + /** + * The deleted record if it existed. + */ record: AssetCriticalityRecord.optional(), }); diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.schema.yaml b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.schema.yaml index 521cacd51406b..f74cf5791aa21 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.schema.yaml +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/delete_asset_criticality.schema.yaml @@ -1,3 +1,4 @@ +# ⚠️ Updating this file? Also update the public API docs at https://github.com/elastic/security-docs/tree/main/docs/advanced-entity-analytics/api openapi: 3.0.0 info: version: '2023-10-31' @@ -9,6 +10,7 @@ paths: x-codegen-enabled: true operationId: DeleteAssetCriticalityRecord summary: Delete Criticality Record + description: Delete the asset criticality record for a specific asset if it exists. parameters: - name: id_value in: query @@ -40,8 +42,9 @@ paths: properties: deleted: type: boolean - description: If the record was deleted. If false the record did not exist. + description: True if the record was deleted or false if the record did not exist. record: + description: The deleted record if it existed. $ref: './common.schema.yaml#/components/schemas/AssetCriticalityRecord' required: - deleted diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/get_asset_criticality.schema.yaml b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/get_asset_criticality.schema.yaml index ce9e8ee03330c..a162cf3944c69 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/get_asset_criticality.schema.yaml +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/get_asset_criticality.schema.yaml @@ -1,3 +1,4 @@ +# ⚠️ Updating this file? Also update the public API docs at https://github.com/elastic/security-docs/tree/main/docs/advanced-entity-analytics/api openapi: 3.0.0 info: version: '2023-10-31' @@ -9,6 +10,7 @@ paths: x-codegen-enabled: true operationId: GetAssetCriticalityRecord summary: Get Criticality Record + description: Get the criticality record for a specific asset. parameters: - name: id_value in: query diff --git a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/list_asset_criticality.schema.yaml b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/list_asset_criticality.schema.yaml index db338bf5404f9..020727c4638d7 100644 --- a/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/list_asset_criticality.schema.yaml +++ b/x-pack/plugins/security_solution/common/api/entity_analytics/asset_criticality/list_asset_criticality.schema.yaml @@ -1,14 +1,16 @@ +# ⚠️ Updating this file? Also update the public API docs at https://github.com/elastic/security-docs/tree/main/docs/advanced-entity-analytics/api openapi: 3.0.0 info: version: '2023-10-31' title: Asset Criticality List Schema paths: /api/asset_criticality/list: - post: + get: x-labels: [ess, serverless] x-codegen-enabled: true operationId: FindAssetCriticalityRecords - summary: List asset criticality data, filtering and sorting as needed + summary: List Asset Criticality Records + description: List asset criticality records, paging, sorting and filtering as needed. parameters: - name: sort_field in: query diff --git a/x-pack/plugins/security_solution/docs/openapi/ess/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml b/x-pack/plugins/security_solution/docs/openapi/ess/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml index 35346afa0f120..fa4998f85b335 100644 --- a/x-pack/plugins/security_solution/docs/openapi/ess/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml +++ b/x-pack/plugins/security_solution/docs/openapi/ess/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml @@ -13,6 +13,7 @@ servers: paths: /api/asset_criticality: delete: + description: Delete the asset criticality record for a specific asset if it exists. operationId: DeleteAssetCriticalityRecord parameters: - description: The ID value of the asset. @@ -45,11 +46,12 @@ paths: properties: deleted: description: >- - If the record was deleted. If false the record did not - exist. + True if the record was deleted or false if the record did + not exist. type: boolean record: $ref: '#/components/schemas/AssetCriticalityRecord' + description: The deleted record if it existed. required: - deleted description: Successful response @@ -59,6 +61,7 @@ paths: tags: - Security Solution Entity Analytics API get: + description: Get the criticality record for a specific asset. operationId: GetAssetCriticalityRecord parameters: - description: The ID value of the asset. @@ -89,6 +92,7 @@ paths: tags: - Security Solution Entity Analytics API post: + description: Create or update a criticality record for a specific asset. operationId: CreateAssetCriticalityRecord requestBody: content: @@ -115,11 +119,14 @@ paths: description: Successful response '400': description: Invalid request - summary: Create Criticality Record + summary: Upsert Criticality Record tags: - Security Solution Entity Analytics API /api/asset_criticality/bulk: post: + description: >- + Bulk upsert up to 1000 asset criticality records, creating or updating + them as needed. operationId: BulkUpsertAssetCriticalityRecords requestBody: content: @@ -170,13 +177,12 @@ paths: description: Bulk upload successful '413': description: File too large - summary: >- - Bulk upsert asset criticality data, creating or updating records as - needed + summary: Bulk Upsert Asset Criticality Records tags: - Security Solution Entity Analytics API /api/asset_criticality/list: - post: + get: + description: 'List asset criticality records, paging, sorting and filtering as needed.' operationId: FindAssetCriticalityRecords parameters: - description: The field to sort by. @@ -247,7 +253,7 @@ paths: - per_page - total description: Bulk upload successful - summary: 'List asset criticality data, filtering and sorting as needed' + summary: List Asset Criticality Records tags: - Security Solution Entity Analytics API components: diff --git a/x-pack/plugins/security_solution/docs/openapi/serverless/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml b/x-pack/plugins/security_solution/docs/openapi/serverless/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml index 79df809b600c2..d1345790f6b62 100644 --- a/x-pack/plugins/security_solution/docs/openapi/serverless/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml +++ b/x-pack/plugins/security_solution/docs/openapi/serverless/security_solution_entity_analytics_api_2023_10_31.bundled.schema.yaml @@ -13,6 +13,7 @@ servers: paths: /api/asset_criticality: delete: + description: Delete the asset criticality record for a specific asset if it exists. operationId: DeleteAssetCriticalityRecord parameters: - description: The ID value of the asset. @@ -45,11 +46,12 @@ paths: properties: deleted: description: >- - If the record was deleted. If false the record did not - exist. + True if the record was deleted or false if the record did + not exist. type: boolean record: $ref: '#/components/schemas/AssetCriticalityRecord' + description: The deleted record if it existed. required: - deleted description: Successful response @@ -59,6 +61,7 @@ paths: tags: - Security Solution Entity Analytics API get: + description: Get the criticality record for a specific asset. operationId: GetAssetCriticalityRecord parameters: - description: The ID value of the asset. @@ -89,6 +92,7 @@ paths: tags: - Security Solution Entity Analytics API post: + description: Create or update a criticality record for a specific asset. operationId: CreateAssetCriticalityRecord requestBody: content: @@ -115,11 +119,14 @@ paths: description: Successful response '400': description: Invalid request - summary: Create Criticality Record + summary: Upsert Criticality Record tags: - Security Solution Entity Analytics API /api/asset_criticality/bulk: post: + description: >- + Bulk upsert up to 1000 asset criticality records, creating or updating + them as needed. operationId: BulkUpsertAssetCriticalityRecords requestBody: content: @@ -170,13 +177,12 @@ paths: description: Bulk upload successful '413': description: File too large - summary: >- - Bulk upsert asset criticality data, creating or updating records as - needed + summary: Bulk Upsert Asset Criticality Records tags: - Security Solution Entity Analytics API /api/asset_criticality/list: - post: + get: + description: 'List asset criticality records, paging, sorting and filtering as needed.' operationId: FindAssetCriticalityRecords parameters: - description: The field to sort by. @@ -247,7 +253,7 @@ paths: - per_page - total description: Bulk upload successful - summary: 'List asset criticality data, filtering and sorting as needed' + summary: List Asset Criticality Records tags: - Security Solution Entity Analytics API components: diff --git a/x-pack/test/api_integration/services/security_solution_api.gen.ts b/x-pack/test/api_integration/services/security_solution_api.gen.ts index dd2b9eaab6a0b..b1df28bdf908c 100644 --- a/x-pack/test/api_integration/services/security_solution_api.gen.ts +++ b/x-pack/test/api_integration/services/security_solution_api.gen.ts @@ -212,6 +212,9 @@ after 30 days. It also deletes other artifacts specific to the migration impleme .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana') .send(props.body as object); }, + /** + * Bulk upsert up to 1000 asset criticality records, creating or updating them as needed. + */ bulkUpsertAssetCriticalityRecords(props: BulkUpsertAssetCriticalityRecordsProps) { return supertest .post('/api/asset_criticality/bulk') @@ -252,6 +255,9 @@ Migrations are initiated per index. While the process is neither destructive nor .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana') .send(props.body as object); }, + /** + * Create or update a criticality record for a specific asset. + */ createAssetCriticalityRecord(props: CreateAssetCriticalityRecordProps) { return supertest .post('/api/asset_criticality') @@ -296,6 +302,9 @@ Migrations are initiated per index. While the process is neither destructive nor .set(ELASTIC_HTTP_VERSION_HEADER, '2023-10-31') .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana'); }, + /** + * Delete the asset criticality record for a specific asset if it exists. + */ deleteAssetCriticalityRecord(props: DeleteAssetCriticalityRecordProps) { return supertest .delete('/api/asset_criticality') @@ -575,9 +584,12 @@ finalize it. .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana') .send(props.body as object); }, + /** + * List asset criticality records, paging, sorting and filtering as needed. + */ findAssetCriticalityRecords(props: FindAssetCriticalityRecordsProps) { return supertest - .post('/api/asset_criticality/list') + .get('/api/asset_criticality/list') .set('kbn-xsrf', 'true') .set(ELASTIC_HTTP_VERSION_HEADER, '2023-10-31') .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana') @@ -602,6 +614,9 @@ finalize it. .set(X_ELASTIC_INTERNAL_ORIGIN_REQUEST, 'kibana') .query(props.query); }, + /** + * Get the criticality record for a specific asset. + */ getAssetCriticalityRecord(props: GetAssetCriticalityRecordProps) { return supertest .get('/api/asset_criticality')