mirror of
https://github.com/TheAnachronism/docspell.git
synced 2025-04-05 10:59:33 +00:00
Allow to set folder by id or name
This commit is contained in:
parent
1c0d87527b
commit
d95a78f495
@ -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
|
||||
|
@ -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],
|
||||
|
@ -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
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user