Merge pull request #940 from eikek/fix/set-folder-on-process

Set folder on process
This commit is contained in:
mergify[bot] 2021-07-17 13:19:58 +00:00 committed by GitHub
commit bf75662e82
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 33 additions and 3 deletions

View File

@ -12,6 +12,7 @@ import cats.implicits._
import docspell.backend.ops.OItem
import docspell.common._
import docspell.joex.scheduler.Task
import docspell.store.UpdateResult
object SetGivenData {
type Args = ProcessItemArgs
@ -46,7 +47,12 @@ object SetGivenData {
e <- ops.setFolder(itemId, folderId, collective).attempt
_ <- e.fold(
ex => ctx.logger.warn(s"Error setting folder: ${ex.getMessage}"),
_ => ().pure[F]
res =>
res match {
case UpdateResult.Failure(ex) =>
ctx.logger.warn(s"Error setting folder: ${ex.getMessage}")
case _ => ().pure[F]
}
)
} yield data
}

View File

@ -5073,7 +5073,8 @@ components:
A direction can be given, `Incoming` is used if not specified.
A folderId can be given, the item is placed into this folder
after creation.
after creation. It may be the exact id of the folder or its
name.
The `fileFilter` is an optional glob for filtering files to
import. Only applicable if archive files are uploaded. It

View File

@ -74,6 +74,25 @@ object RFolder {
sql.query[RFolder].option
}
def requireIdByIdOrName(
folderId: Ident,
name: String,
collective: Ident
): ConnectionIO[Ident] = {
val sql = run(
select(T.id),
from(T),
T.id === folderId || (T.name === name && T.collective === collective)
)
sql.query[Ident].option.flatMap {
case Some(id) => id.pure[ConnectionIO]
case None =>
Sync[ConnectionIO].raiseError(
new Exception(s"No folder found for: id=${folderId.id} or name=${name}")
)
}
}
def findAll(
coll: Ident,
nameQ: Option[String],

View File

@ -274,10 +274,14 @@ object RItem {
): ConnectionIO[Int] =
for {
t <- currentTime
fid <- folderId match {
case Some(f) => RFolder.requireIdByIdOrName(f, f.id, coll).map(_.some)
case None => None.pure[ConnectionIO]
}
n <- DML.update(
T,
T.cid === coll && T.id === itemId,
DML.set(T.folder.setTo(folderId), T.updated.setTo(t))
DML.set(T.folder.setTo(fid), T.updated.setTo(t))
)
} yield n