Allow to set folder by id or name

This commit is contained in:
eikek 2021-07-17 15:10:19 +02:00
parent 1c0d87527b
commit d95a78f495
3 changed files with 26 additions and 2 deletions

View File

@ -5073,7 +5073,8 @@ components:
A direction can be given, `Incoming` is used if not specified. A direction can be given, `Incoming` is used if not specified.
A folderId can be given, the item is placed into this folder 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 The `fileFilter` is an optional glob for filtering files to
import. Only applicable if archive files are uploaded. It import. Only applicable if archive files are uploaded. It

View File

@ -74,6 +74,25 @@ object RFolder {
sql.query[RFolder].option 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( def findAll(
coll: Ident, coll: Ident,
nameQ: Option[String], nameQ: Option[String],

View File

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