我正在尝试将一些spring-webflux
示例代码迁移到kotlin。
目前我想将我的Spring Data Mongo样本转换为kotlin。有一个User
,原始的Data Mongo版本看起来是:
@Data
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
@Document
class User implements UserDetails {
@Id
private String id;
private String username;
private String password;
@Builder.Default()
private boolean active = true;
@Builder.Default()
private List<String> roles = new ArrayList<>();
@Override
public Collection<? extends GrantedAuthority> getAuthorities() {
return AuthorityUtils.createAuthorityList(roles.toArray(new String[roles.size()]));
}
@Override
public boolean isAccountNonExpired() {
return active;
}
@Override
public boolean isAccountNonLocked() {
return active;
}
@Override
public boolean isCredentialsNonExpired() {
return active;
}
@Override
public boolean isEnabled() {
return active;
}
}
UserDetails
界面包含一些getXXX和isXXX方法,如何将override
添加到kotlin中的username
和password
个问题?
BTW:目前我删除了kotlin版本check here中的UserDetails
:
@Document
data class User(
@Id var id: String? = null,
var username: String? = null,
var password: String? = null,
var active: Boolean = true,
var roles: List<String> = ArrayList()
)
更新:如何向其添加,this question is helpful。UserDetails
界面?
新问题是当使用破坏时,它不起作用。
(id, username, password, active, roles) = <a user>
User
位于https://github.com/hantsy/spring-reactive-sample/blob/master/kotlin-gradle/src/main/kotlin/com/example/demo/User.kt。目前我注释了实施的UserDetails
版本。如果我使用注释代码(用户:UserDetails),desstruction
中的Beans.kt
代码将报告IDE中的错误。错误发生在username
和password
:销毁用户类型的声明初始化程序!必须具有component2功能。
答案 0 :(得分:-1)
data class User(
// inherits from UserDetails
private val username: String,
private val password: String,
private val isEnabled: Boolean, //Disabled account can not log in
private val isCredentialsNonExpired: Boolean, //credential can be expired,eg. Change the password every three months
private val isAccountNonExpired: Boolean, //eg. Demo account(guest) can only be online 24 hours
private val isAccountNonLocked: Boolean, //eg. Users who malicious attack system,lock their account for one year
private val authorities: Set<GrantedAuthority>,
// inherits from Tree.If the user is not a tree structure, can be ignored
val id: Long,
val parentId: Long? = null,
val lft: Int? = null, // preorder tree traversal algorithm
val rgt: Int? = null, // preorder tree traversal algorithm
val depth: Int? = null, // or levels
val isLeaf: Boolean? = null,
val teamTotal: Int? = null, // The number of all subordinates
val childrenTotal: Int? = null, //The number of all directly under the subordinate
//Custom attributes
val tenantId: Long, //We are the platform + tenant model
val role: Set<Role>, // TENANT, SUBACCOUNT, DEFAULT_GROUP, MEMBER, GUEST
val platform: Platform, // PC, IOS, ANDROID, WAP, INTERNAL
val deviceToken: String? = null, //or machine code
val ip: InetAddress //Inet4Address or Inet6Address
) : UserDetails, Tree(id, parentId) {
override fun getUsername(): String = username
override fun getPassword(): String = password
override fun isEnabled(): Boolean = isEnabled
override fun isCredentialsNonExpired(): Boolean = isCredentialsNonExpired
override fun isAccountNonExpired(): Boolean = isAccountNonExpired
override fun isAccountNonLocked(): Boolean = isAccountNonLocked
override fun getAuthorities(): Set<out GrantedAuthority> = authorities
}