aboutsummaryrefslogtreecommitdiff
path: root/shared/src/main/scala/xyz/driver/core/auth.scala
diff options
context:
space:
mode:
authorJakob Odersky <jakob@driver.xyz>2018-06-29 17:56:06 -0700
committerJakob Odersky <jakob@driver.xyz>2018-07-01 16:16:52 -0700
commitb6859c8560af601d716729d29094a156c9c01503 (patch)
tree031929da54c659ff5cd58835962c53459b498629 /shared/src/main/scala/xyz/driver/core/auth.scala
parent901b02274fdfc08030443aac2f1760fc479b3816 (diff)
downloaddriver-core-b6859c8560af601d716729d29094a156c9c01503.tar.gz
driver-core-b6859c8560af601d716729d29094a156c9c01503.tar.bz2
driver-core-b6859c8560af601d716729d29094a156c9c01503.zip
Move shared classes (IDs, Formats, etc) to shared source folder
* The JSON format object was split into traits and akka-specific unmarshallers are moved into a separate 'Directives' trait. * The singleton object xyz.driver.core.json is now deprecated. These changes should be source compatible, although they are not binary compatible.
Diffstat (limited to 'shared/src/main/scala/xyz/driver/core/auth.scala')
-rw-r--r--shared/src/main/scala/xyz/driver/core/auth.scala43
1 files changed, 43 insertions, 0 deletions
diff --git a/shared/src/main/scala/xyz/driver/core/auth.scala b/shared/src/main/scala/xyz/driver/core/auth.scala
new file mode 100644
index 0000000..896bd89
--- /dev/null
+++ b/shared/src/main/scala/xyz/driver/core/auth.scala
@@ -0,0 +1,43 @@
+package xyz.driver.core
+
+import xyz.driver.core.domain.Email
+import xyz.driver.core.time.Time
+import scalaz.Equal
+
+object auth {
+
+ trait Permission
+
+ final case class Role(id: Id[Role], name: Name[Role]) {
+
+ def oneOf(roles: Role*): Boolean = roles.contains(this)
+
+ def oneOf(roles: Set[Role]): Boolean = roles.contains(this)
+ }
+
+ object Role {
+ implicit def idEqual: Equal[Role] = Equal.equal[Role](_ == _)
+ }
+
+ trait User {
+ def id: Id[User]
+ }
+
+ final case class AuthToken(value: String)
+
+ final case class AuthTokenUserInfo(
+ id: Id[User],
+ email: Email,
+ emailVerified: Boolean,
+ audience: String,
+ roles: Set[Role],
+ expirationTime: Time)
+ extends User
+
+ final case class RefreshToken(value: String)
+ final case class PermissionsToken(value: String)
+
+ final case class PasswordHash(value: String)
+
+ final case class AuthCredentials(identifier: String, password: String)
+}