aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala
diff options
context:
space:
mode:
authorVyatcheslav Suharnikov <arz.freezy@gmail.com>2017-07-04 15:21:48 +0300
committerVyatcheslav Suharnikov <arz.freezy@gmail.com>2017-07-07 12:15:19 +0300
commit6bb9a40ea51449f9239f459bfd98b94b685a99df (patch)
tree77f8a6370f380a23681465a34faefab2036209ad /src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala
parentcbd561e51118be6e3ecc0157f74089c560d891cb (diff)
downloadrest-query-6bb9a40ea51449f9239f459bfd98b94b685a99df.tar.gz
rest-query-6bb9a40ea51449f9239f459bfd98b94b685a99df.tar.bz2
rest-query-6bb9a40ea51449f9239f459bfd98b94b685a99df.zip
PDSUI-2026 Create Trial Curation's own user history table for trials
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala b/src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala
new file mode 100644
index 0000000..17111a9
--- /dev/null
+++ b/src/main/scala/xyz/driver/pdsuidomain/services/TrialHistoryService.scala
@@ -0,0 +1,49 @@
+package xyz.driver.pdsuidomain.services
+
+import java.time.LocalDateTime
+
+import xyz.driver.pdsuicommon.auth.AuthenticatedRequestContext
+import xyz.driver.pdsuicommon.db.{Pagination, SearchFilterExpr, Sorting}
+import xyz.driver.pdsuicommon.domain.StringId
+import xyz.driver.pdsuicommon.error.DomainError
+import xyz.driver.pdsuidomain.entities.{Trial, TrialHistory}
+
+import scala.concurrent.Future
+
+object TrialHistoryService {
+
+ trait DefaultNotFoundError {
+ def userMessage: String = "Trial not found"
+ }
+
+ trait DefaultAccessDeniedError {
+ def userMessage: String = "Access denied"
+ }
+
+ sealed trait GetListReply
+ object GetListReply {
+ case class EntityList(xs: Seq[TrialHistory],
+ totalFound: Int,
+ lastUpdate: Option[LocalDateTime])
+ extends GetListReply
+
+ case object AuthorizationError
+ extends GetListReply
+ with DomainError.AuthorizationError
+ with DefaultAccessDeniedError
+ }
+
+}
+
+trait TrialHistoryService {
+
+ import TrialHistoryService._
+
+ def getListByTrialId(id: StringId[Trial],
+ filter: SearchFilterExpr = SearchFilterExpr.Empty,
+ sorting: Option[Sorting] = None,
+ pagination: Option[Pagination] = None)(
+ implicit requestContext: AuthenticatedRequestContext)
+ : Future[GetListReply]
+
+}