我正在构建一个 Scala Play 应用程序,其中事件和数据以 Json 格式保存,并且我正在尝试对用户及其分配的角色进行建模。我的想法是将角色建模为案例对象,因为每个标准角色只需要为应用程序中的所有用户定义一次,并且我想对分配给特定用户的角色类型进行模式匹配。到目前为止,我有这个;
package models
abstract class User {
def displayName: String
def role: Role
}
case class GuestUser(displayName: String, role: Role) extends User {
}
case class RegisteredUser(displayName: String, role: Role) extends User {
}
trait Role { // have tried abstract class too - but like idea of developing stackable traits for role permissions
}
object Role {
implicit val RoleTypeFormat: Format[Role] = Json.format[Role]
def apply(className: String): Role = Class.forName(className: String).asInstanceOf[Role]
def unapply(role: Role): Option[String] = Option(this.getClass.getName) // have also tried .getSimpleName
}
case object GuestUserRole extends Role {
}
case object RegisteredUserRole extends Role {
}
如果我没有在 中定义 apply 和 unapply 方法object Role
,并且仅依赖于使用的隐式值Json.format[Role]
,我会收到“未找到应用函数”或“未找到未应用函数”错误 - 所以我添加了它们,以尝试获取摆脱这个错误。
.asInstanceOf[Role]
如果不添加到Role
apply 方法,我无法编译它。它现在可以编译,但是当我尝试使用设置role: Role
新RegisteredUser
实例的参数时,
val role: Role = RegisteredUserRole
创建了一个新RegisteredUser
实例,其中角色属性被序列化为 Json;
"role":{"className":"models.Role$”}
但是当我尝试反序列化它时,我得到Exception in thread "pool-4868-thread-1" java.lang.ClassCastException: java.lang.Class cannot be cast to models.Role
我的目标是最终得到相同的RegisteredUser
实例(或GuestUser
实例),所以我可以在视图控制器中进行模式匹配,如下所示;
def isAuthorized: Boolean = {
role match {
case RegisteredUserRole => true
case GuestUserRole => false
// etc
}
}
对此的任何帮助和建议将不胜感激。我在 Scala 和 Play 方面还不够熟练和知识渊博,无法知道我在建模用户和角色方面是否走在正确的轨道上。