mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Implement the webhook
This commit is contained in:
		| @@ -37,6 +37,7 @@ pub fn snapshot_index_scheduler(scheduler: &IndexScheduler) -> String { | ||||
|         snapshots_path: _, | ||||
|         auth_path: _, | ||||
|         version_file_path: _, | ||||
|         webhook_url: _, | ||||
|         test_breakpoint_sdr: _, | ||||
|         planned_failures: _, | ||||
|         run_loop_iteration: _, | ||||
|   | ||||
| @@ -170,8 +170,8 @@ impl ProcessingTasks { | ||||
|     } | ||||
|  | ||||
|     /// Set the processing tasks to an empty list | ||||
|     fn stop_processing(&mut self) { | ||||
|         self.processing = RoaringBitmap::new(); | ||||
|     fn stop_processing(&mut self) -> RoaringBitmap { | ||||
|         std::mem::take(&mut self.processing) | ||||
|     } | ||||
|  | ||||
|     /// Returns `true` if there, at least, is one task that is currently processing that we must stop. | ||||
| @@ -241,6 +241,7 @@ pub struct IndexSchedulerOptions { | ||||
|     pub snapshots_path: PathBuf, | ||||
|     /// The path to the folder containing the dumps. | ||||
|     pub dumps_path: PathBuf, | ||||
|     pub webhook_url: Option<String>, | ||||
|     /// The maximum size, in bytes, of the task index. | ||||
|     pub task_db_size: usize, | ||||
|     /// The size, in bytes, with which a meilisearch index is opened the first time of each meilisearch index. | ||||
| @@ -323,6 +324,9 @@ pub struct IndexScheduler { | ||||
|     /// The maximum number of tasks that will be batched together. | ||||
|     pub(crate) max_number_of_batched_tasks: usize, | ||||
|  | ||||
|     /// The webhook url we should send tasks to after processing every batches. | ||||
|     pub(crate) webhook_url: Option<String>, | ||||
|  | ||||
|     /// A frame to output the indexation profiling files to disk. | ||||
|     pub(crate) puffin_frame: Arc<puffin::GlobalFrameView>, | ||||
|  | ||||
| @@ -388,6 +392,7 @@ impl IndexScheduler { | ||||
|             dumps_path: self.dumps_path.clone(), | ||||
|             auth_path: self.auth_path.clone(), | ||||
|             version_file_path: self.version_file_path.clone(), | ||||
|             webhook_url: self.webhook_url.clone(), | ||||
|             currently_updating_index: self.currently_updating_index.clone(), | ||||
|             embedders: self.embedders.clone(), | ||||
|             #[cfg(test)] | ||||
| @@ -487,6 +492,7 @@ impl IndexScheduler { | ||||
|             snapshots_path: options.snapshots_path, | ||||
|             auth_path: options.auth_path, | ||||
|             version_file_path: options.version_file_path, | ||||
|             webhook_url: options.webhook_url, | ||||
|             currently_updating_index: Arc::new(RwLock::new(None)), | ||||
|             embedders: Default::default(), | ||||
|  | ||||
| @@ -1251,19 +1257,41 @@ impl IndexScheduler { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         self.processing_tasks.write().unwrap().stop_processing(); | ||||
|         let processed = self.processing_tasks.write().unwrap().stop_processing(); | ||||
|  | ||||
|         #[cfg(test)] | ||||
|         self.maybe_fail(tests::FailureLocation::CommittingWtxn)?; | ||||
|  | ||||
|         wtxn.commit().map_err(Error::HeedTransaction)?; | ||||
|  | ||||
|         // We shouldn't crash the tick function if we can't send data to the webhook. | ||||
|         let _ = self.notify_webhook(&processed); | ||||
|  | ||||
|         #[cfg(test)] | ||||
|         self.breakpoint(Breakpoint::AfterProcessing); | ||||
|  | ||||
|         Ok(TickOutcome::TickAgain(processed_tasks)) | ||||
|     } | ||||
|  | ||||
|     /// Once the tasks changes have been commited we must send all the tasks that were updated to our webhook if there is one. | ||||
|     fn notify_webhook(&self, updated: &RoaringBitmap) -> Result<()> { | ||||
|         if let Some(ref url) = self.webhook_url { | ||||
|             let rtxn = self.env.read_txn()?; | ||||
|  | ||||
|             // on average a task takes ~50 bytes | ||||
|             let mut buffer = Vec::with_capacity(updated.len() as usize * 50); | ||||
|  | ||||
|             for id in updated { | ||||
|                 let task = self.get_task(&rtxn, id)?.ok_or(Error::CorruptedTaskQueue)?; | ||||
|                 let _ = serde_json::to_writer(&mut buffer, &task); | ||||
|             } | ||||
|  | ||||
|             let _ = ureq::post(url).send_bytes(&buffer); | ||||
|         } | ||||
|  | ||||
|         Ok(()) | ||||
|     } | ||||
|  | ||||
|     /// Register a task to cleanup the task queue if needed | ||||
|     fn cleanup_task_queue(&self) -> Result<()> { | ||||
|         let rtxn = self.env.read_txn().map_err(Error::HeedTransaction)?; | ||||
| @@ -1677,6 +1705,7 @@ mod tests { | ||||
|                 indexes_path: tempdir.path().join("indexes"), | ||||
|                 snapshots_path: tempdir.path().join("snapshots"), | ||||
|                 dumps_path: tempdir.path().join("dumps"), | ||||
|                 webhook_url: None, | ||||
|                 task_db_size: 1000 * 1000, // 1 MB, we don't use MiB on purpose. | ||||
|                 index_base_map_size: 1000 * 1000, // 1 MB, we don't use MiB on purpose. | ||||
|                 enable_mdb_writemap: false, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user