Prevents some unintended usage of UUID for filenames
This commit is contained in:
parent
396c0a9d41
commit
8b47aeb8f2
@ -59,7 +59,7 @@ public class CommandDecrypt implements TabExecutor {
|
|||||||
//Get the "encryption key" from the filename
|
//Get the "encryption key" from the filename
|
||||||
String key = "";
|
String key = "";
|
||||||
for (String encryptedFile : encryptedFiles) {
|
for (String encryptedFile : encryptedFiles) {
|
||||||
if (encryptedFile.contains(BookHelper.getBookFile(bookMetadata, player))) {
|
if (encryptedFile.contains(BookHelper.getBookFile(bookMetadata, player, true))) {
|
||||||
key = encryptedFile.substring(encryptedFile.indexOf("[") + 1, encryptedFile.indexOf("]"));
|
key = encryptedFile.substring(encryptedFile.indexOf("[") + 1, encryptedFile.indexOf("]"));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ public class CommandSave implements TabExecutor {
|
|||||||
saveToPublicFolder ? BookDirectory.PUBLIC : BookDirectory.PLAYER, player);
|
saveToPublicFolder ? BookDirectory.PUBLIC : BookDirectory.PLAYER, player);
|
||||||
|
|
||||||
//Generate book filename
|
//Generate book filename
|
||||||
String fileName = BookHelper.getBookFile(book, player);
|
String fileName = BookHelper.getBookFile(book, player, saveToPublicFolder);
|
||||||
|
|
||||||
//Make sure the used folders exist
|
//Make sure the used folders exist
|
||||||
File file = new File(savePath);
|
File file = new File(savePath);
|
||||||
|
@ -116,7 +116,7 @@ public final class BookHelper {
|
|||||||
* @param player <p>The player trying to do something with the book</p>
|
* @param player <p>The player trying to do something with the book</p>
|
||||||
* @return <p>The book file</p>
|
* @return <p>The book file</p>
|
||||||
*/
|
*/
|
||||||
public static String getBookFile(BookMeta book, Player player) {
|
public static String getBookFile(BookMeta book, Player player, boolean isPublic) {
|
||||||
String titleAuthorSeparator = BooksWithoutBordersConfig.getTitleAuthorSeparator();
|
String titleAuthorSeparator = BooksWithoutBordersConfig.getTitleAuthorSeparator();
|
||||||
String bookName;
|
String bookName;
|
||||||
if (book.hasTitle()) {
|
if (book.hasTitle()) {
|
||||||
@ -126,9 +126,11 @@ public final class BookHelper {
|
|||||||
}
|
}
|
||||||
|
|
||||||
String authorName;
|
String authorName;
|
||||||
if (!book.hasAuthor() || isAuthor(player.getName(), book.getAuthor())) {
|
if ((!book.hasAuthor() || isAuthor(player.getName(), book.getAuthor())) && !isPublic) {
|
||||||
//Store as unique id to account for name changes
|
//Store as unique id to account for name changes
|
||||||
authorName = player.getUniqueId().toString();
|
authorName = player.getUniqueId().toString();
|
||||||
|
} else if (!book.hasAuthor()) {
|
||||||
|
authorName = player.getName();
|
||||||
} else {
|
} else {
|
||||||
authorName = book.getAuthor();
|
authorName = book.getAuthor();
|
||||||
}
|
}
|
||||||
|
@ -198,7 +198,7 @@ public final class EncryptionHelper {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String fileName = "[" + key + "]" + BookHelper.getBookFile(bookMetadata, player);
|
String fileName = "[" + key + "]" + BookHelper.getBookFile(bookMetadata, player, true);
|
||||||
fileName = fixName(cleanString(fileName), false);
|
fileName = fixName(cleanString(fileName), false);
|
||||||
|
|
||||||
File file = new File(path + fileName + ".yml");
|
File file = new File(path + fileName + ".yml");
|
||||||
@ -261,7 +261,7 @@ public final class EncryptionHelper {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Generate file name
|
//Generate file name
|
||||||
String fileName = BookHelper.getBookFile(bookMetadata, player);
|
String fileName = BookHelper.getBookFile(bookMetadata, player, true);
|
||||||
|
|
||||||
List<String> newLore = new ArrayList<>();
|
List<String> newLore = new ArrayList<>();
|
||||||
newLore.add(ChatColor.GRAY + "[" + groupName + " encrypted]");
|
newLore.add(ChatColor.GRAY + "[" + groupName + " encrypted]");
|
||||||
@ -300,7 +300,7 @@ public final class EncryptionHelper {
|
|||||||
private static Boolean saveEncryptedBook(Player player, BookMeta bookMetaData, String key) {
|
private static Boolean saveEncryptedBook(Player player, BookMeta bookMetaData, String key) {
|
||||||
String path = getBookFolder() + "Encrypted" + getSlash();
|
String path = getBookFolder() + "Encrypted" + getSlash();
|
||||||
|
|
||||||
String fileName = "[" + key + "]" + BookHelper.getBookFile(bookMetaData, player);
|
String fileName = "[" + key + "]" + BookHelper.getBookFile(bookMetaData, player, true);
|
||||||
fileName = fixName(cleanString(fileName), false);
|
fileName = fixName(cleanString(fileName), false);
|
||||||
|
|
||||||
//cancels saving if file is already encrypted
|
//cancels saving if file is already encrypted
|
||||||
|
Loading…
Reference in New Issue
Block a user