1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
package xyz.driver.core
import xyz.driver.core.domain.{Email, PhoneNumber}
import scalaz.Equal
object auth {
trait Permission
final case class Role(id: Id[Role], name: Name[Role])
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 AuthUser(id: Id[AuthUser],
userId: Id[User],
email: Email,
emailVerified: Boolean,
phoneNumber: Option[PhoneNumber],
phoneVerified: Boolean,
isBlocked: Boolean,
roles: Set[Role])
final case class AuthTokenUserInfo(id: Id[User],
authUserId: Id[AuthUser],
email: Email,
emailVerified: Boolean,
audience: String,
roles: Set[Role])
extends User
final case class RefreshToken(value: String)
final case class PermissionsToken(value: String)
final case class PasswordHash(value: String)
final case class AuthCredentials(email: Email, password: String)
}
|