Merge pull request #218 from eikek/upload-check

Fail early when source id is wrong
This commit is contained in:
mergify[bot] 2020-08-08 16:50:34 +00:00 committed by GitHub
commit 795b8edb51
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 5 deletions

View File

@ -8,7 +8,7 @@ import docspell.backend.PasswordCrypt
import docspell.backend.ops.OCollective._
import docspell.common._
import docspell.store.queries.QCollective
import docspell.store.records.{RCollective, RContact, RUser}
import docspell.store.records._
import docspell.store.{AddResult, Store}
trait OCollective[F[_]] {
@ -41,6 +41,8 @@ trait OCollective[F[_]] {
kind: Option[ContactKind]
): Stream[F, RContact]
def findSource(sourceId: Ident): F[Option[RSource]]
}
object OCollective {
@ -156,5 +158,7 @@ object OCollective {
): Stream[F, RContact] =
store.transact(QCollective.getContacts(collective, query, kind))
def findSource(sourceId: Ident): F[Option[RSource]] =
store.transact(RSource.find(sourceId))
})
}

View File

@ -1,5 +1,6 @@
package docspell.restserver.routes
import cats.data.OptionT
import cats.effect._
import cats.implicits._
@ -43,11 +44,21 @@ object UploadRoutes {
import dsl._
HttpRoutes.of {
case req @ POST -> Root / "item" / Ident(id) =>
submitFiles(backend, cfg, Left(id))(req, None, Priority.Low, dsl)
case req @ POST -> Root / "item" / Ident(srcId) =>
(for {
_ <- OptionT(backend.collective.findSource(srcId))
res <- OptionT.liftF(
submitFiles(backend, cfg, Left(srcId))(req, None, Priority.Low, dsl)
)
} yield res).getOrElseF(NotFound())
case req @ POST -> Root / "item" / Ident(itemId) / Ident(id) =>
submitFiles(backend, cfg, Left(id))(req, Some(itemId), Priority.Low, dsl)
case req @ POST -> Root / "item" / Ident(itemId) / Ident(srcId) =>
(for {
_ <- OptionT(backend.collective.findSource(srcId))
res <- OptionT.liftF(
submitFiles(backend, cfg, Left(srcId))(req, Some(itemId), Priority.Low, dsl)
)
} yield res).getOrElseF(NotFound())
}
}