diff --git a/x-pack/plugins/rule_registry/server/event_log/elasticsearch/index_writer.ts b/x-pack/plugins/rule_registry/server/event_log/elasticsearch/index_writer.ts index 7f83421ec80d8..04b7129d4c7c7 100644 --- a/x-pack/plugins/rule_registry/server/event_log/elasticsearch/index_writer.ts +++ b/x-pack/plugins/rule_registry/server/event_log/elasticsearch/index_writer.ts @@ -6,6 +6,7 @@ */ import type { PublicMethodsOf } from '@kbn/utility-types'; +import { estypes } from '@elastic/elasticsearch'; import util from 'util'; import { Logger, ElasticsearchClient } from 'src/core/server'; import { BufferedStream } from './utils/buffered_stream'; @@ -40,7 +41,9 @@ export class IndexWriter { this.logger = params.logger.get('IndexWriter'); this.buffer = new BufferedStream({ - flush: (items) => this.bulkIndex(items), + flush: async (items) => { + this.bulkIndex(items); + }, }); } @@ -60,11 +63,16 @@ export class IndexWriter { } } + public async indexManyNow(docs: Document[]): Promise { + const bufferItems = docs.map((doc) => ({ index: this.indexName, doc })); + return this.bulkIndex(bufferItems); + } + public async close(): Promise { await this.buffer.closeAndWaitUntilFlushed(); } - private async bulkIndex(items: BufferItem[]): Promise { + private async bulkIndex(items: BufferItem[]): Promise { this.logger.debug(`Indexing ${items.length} documents`); const bulkBody: Array> = []; @@ -85,10 +93,12 @@ export class IndexWriter { error.stack += '\n' + util.inspect(response.body.items, { depth: null }); this.logger.error(error); } + return response.body; } catch (e) { this.logger.error( `error writing bulk events: "${e.message}"; docs: ${JSON.stringify(bulkBody)}` ); + return undefined; } } }