Grasscutter/src/main/java/emu/grasscutter/game/Account.java

171 lines
3.9 KiB
Java
Raw Normal View History

2022-04-17 20:43:07 +08:00
package emu.grasscutter.game;
import dev.morphia.annotations.*;
2022-05-07 12:00:55 +08:00
import emu.grasscutter.Grasscutter;
2022-04-17 20:43:07 +08:00
import emu.grasscutter.database.DatabaseHelper;
import emu.grasscutter.utils.Crypto;
import emu.grasscutter.utils.Utils;
2022-04-19 12:38:19 +08:00
import java.util.ArrayList;
2022-04-19 11:46:04 +08:00
import java.util.List;
import org.bson.Document;
import com.mongodb.DBObject;
2022-04-21 09:11:57 +08:00
@Entity(value = "accounts", useDiscriminator = false)
2022-04-17 20:43:07 +08:00
public class Account {
@Id private String id;
@Indexed(options = @IndexOptions(unique = true))
@Collation(locale = "simple", caseLevel = true)
private String username;
private String password; // Unused for now
@AlsoLoad("playerUid") private int playerId;
2022-04-17 20:43:07 +08:00
private String email;
private String token;
private String sessionKey; // Session token for dispatch server
2022-04-19 11:46:04 +08:00
private List<String> permissions;
2022-04-17 20:43:07 +08:00
@Deprecated
2022-04-19 12:38:19 +08:00
public Account() {
this.permissions = new ArrayList<>();
}
2022-04-17 20:43:07 +08:00
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getToken() {
return token;
}
public void setToken(String token) {
this.token = token;
}
public int getPlayerUid() {
2022-04-17 20:43:07 +08:00
return this.playerId;
}
public void setPlayerId(int playerId) {
this.playerId = playerId;
}
public String getEmail() {
if(email != null && !email.isEmpty()) {
return email;
} else {
return "";
}
2022-04-17 20:43:07 +08:00
}
public void setEmail(String email) {
this.email = email;
}
public String getSessionKey() {
return this.sessionKey;
}
public String generateSessionKey() {
this.sessionKey = Utils.bytesToHex(Crypto.createSessionKey(32));
this.save();
return this.sessionKey;
}
2022-04-19 11:46:04 +08:00
/**
* The collection of a player's permissions.
*/
public List<String> getPermissions() {
return this.permissions;
}
public boolean addPermission(String permission) {
if(this.permissions.contains(permission)) return false;
this.permissions.add(permission); return true;
}
2022-05-07 12:00:55 +08:00
public static boolean permissionMatchesWildcard(String wildcard, String[] permissionParts) {
String[] wildcardParts = wildcard.split("\\.");
if (permissionParts.length < wildcardParts.length) { // A longer wildcard can never match a shorter permission
return false;
}
for (int i=0; i<wildcardParts.length; i++) {
switch (wildcardParts[i]) {
case "**": // Recursing match
return true;
case "*": // Match only one layer
if (i >= (permissionParts.length-1)) {
return true;
}
break;
default: // This layer isn't a wildcard, it needs to match exactly
if (!wildcardParts[i].equals(permissionParts[i])) {
return false;
}
}
}
// At this point the wildcard will have matched every layer, but if it is shorter then the permission then this is not a match at this point (no **).
return (wildcardParts.length == permissionParts.length);
}
public boolean hasPermission(String permission) {
2022-05-07 12:00:55 +08:00
if (this.permissions.contains(permission) || this.permissions.contains("*")) {
return true;
}
String[] permissionParts = permission.split("\\.");
for (String p : this.permissions) {
if (permissionMatchesWildcard(p, permissionParts)) {
return true;
}
}
return false;
}
2022-04-19 11:46:04 +08:00
public boolean removePermission(String permission) {
return this.permissions.remove(permission);
}
2022-04-17 20:43:07 +08:00
// TODO make unique
public String generateLoginToken() {
this.token = Utils.bytesToHex(Crypto.createSessionKey(32));
this.save();
return this.token;
}
public void save() {
DatabaseHelper.saveAccount(this);
}
@PreLoad
public void onLoad(Document document) {
// Grant the superuser permissions to accounts created before the permissions update
if (!document.containsKey("permissions")) {
this.addPermission("*");
}
}
2022-04-17 20:43:07 +08:00
}