mirror of
				https://github.com/TheAnachronism/docspell.git
				synced 2025-10-25 22:50:12 +00:00 
			
		
		
		
	Merge pull request #1566 from eikek/fix-addon-newitem
Fixes related to addons
This commit is contained in:
		| @@ -25,7 +25,7 @@ object AddonOutput { | ||||
|   val empty: AddonOutput = AddonOutput() | ||||
|  | ||||
|   def combine(a: AddonOutput, b: AddonOutput): AddonOutput = | ||||
|     AddonOutput(a.commands ++ b.commands, a.files ++ b.files) | ||||
|     AddonOutput(a.commands ++ b.commands, a.files ++ b.files, a.newItems ++ b.newItems) | ||||
|  | ||||
|   implicit val addonResultMonoid: Monoid[AddonOutput] = | ||||
|     Monoid.instance(empty, combine) | ||||
|   | ||||
| @@ -50,10 +50,11 @@ final private[joex] class AddonPostProcess[F[_]: Sync: Files]( | ||||
|       outputDir: Path | ||||
|   ): F[Unit] = | ||||
|     for { | ||||
|       _ <- logger.info("Applying addon output") | ||||
|       _ <- logger.info(s"Applying addon output commands (${output.commands.size})") | ||||
|       _ <- cmdRunner.runAll(collective, output.commands) | ||||
|       _ <- logger.debug("Applying changes from files") | ||||
|       _ <- logger.debug(s"Applying changes from files (${output.files.size})") | ||||
|       _ <- output.files.traverse_(updateOne(logger, collective, outputDir)) | ||||
|       _ <- logger.debug(s"Applying new items (${output.newItems.size})") | ||||
|       _ <- output.newItems.traverse_(submitNewItem(logger, collective, outputDir)) | ||||
|     } yield () | ||||
|  | ||||
| @@ -63,7 +64,7 @@ final private[joex] class AddonPostProcess[F[_]: Sync: Files]( | ||||
|       outputDir: Path | ||||
|   )(newItem: NewItem): F[Unit] = | ||||
|     for { | ||||
|       _ <- logger.info(s"Submit new item with ${newItem.files.size} files") | ||||
|       _ <- logger.debug(s"Submit new item with ${newItem.files.size} files") | ||||
|       files <- newItem.resolveFiles[F](logger, outputDir) | ||||
|       collLang <- store.transact(RCollective.findLanguage(collective)) | ||||
|       uploaded <- files.traverse(file => | ||||
|   | ||||
| @@ -223,7 +223,8 @@ object OAddons { | ||||
|             upsert.flatTap { runConfigId => | ||||
|               runConfig.schedule match { | ||||
|                 case Some(timer) => | ||||
|                   userTasks.updateTask( | ||||
|                   userTasks | ||||
|                     .updateTask( | ||||
|                       UserTaskScope.collective(collective), | ||||
|                       s"Addon task ${runConfig.name}".some, | ||||
|                       UserTask( | ||||
| @@ -235,8 +236,10 @@ object OAddons { | ||||
|                         ScheduledAddonTaskArgs(collective, runConfigId) | ||||
|                       ) | ||||
|                     ) | ||||
|                     .flatTap(_ => joex.notifyPeriodicTasks) | ||||
|                 case None => | ||||
|                   userTasks.deleteTask(UserTaskScope.collective(collective), runConfigId) | ||||
|                   userTasks | ||||
|                     .deleteTask(UserTaskScope.collective(collective), runConfigId) | ||||
|               } | ||||
|             } | ||||
|           ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user