mirror of
https://gitlab.bixilon.de/bixilon/minosoft.git
synced 2025-09-15 02:15:34 -04:00
brigadier: parse command before sending, tests
This fixes communication commands on 1.19
This commit is contained in:
parent
42f450506a
commit
64f55b52db
@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Minosoft
|
||||||
|
* Copyright (C) 2020-2023 Moritz Zwerger
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package de.bixilon.minosoft.data.chat.signature.command
|
||||||
|
|
||||||
|
import de.bixilon.minosoft.commands.nodes.ArgumentNode
|
||||||
|
import de.bixilon.minosoft.commands.nodes.LiteralNode
|
||||||
|
import de.bixilon.minosoft.commands.parser.minecraft.message.MessageParser
|
||||||
|
import de.bixilon.minosoft.commands.stack.CommandStack
|
||||||
|
import de.bixilon.minosoft.data.chat.signature.SignatureTestUtil
|
||||||
|
import de.bixilon.minosoft.data.chat.signature.signer.DummyMessageSigner
|
||||||
|
import de.bixilon.minosoft.protocol.ProtocolUtil.encodeNetwork
|
||||||
|
import de.bixilon.minosoft.protocol.network.connection.play.ConnectionTestUtil
|
||||||
|
import org.testng.Assert.assertEquals
|
||||||
|
import org.testng.annotations.Test
|
||||||
|
import java.time.Instant
|
||||||
|
|
||||||
|
@Test(groups = ["command", "signature"], dependsOnGroups = ["private_key"])
|
||||||
|
class SignCommandTest {
|
||||||
|
|
||||||
|
fun basicTest() {
|
||||||
|
val stack = CommandStack(ConnectionTestUtil.createConnection())
|
||||||
|
stack.push(LiteralNode("unsigned"), "unsigned")
|
||||||
|
stack.push(ArgumentNode("message", MessageParser), "hi there. I am Moritz!")
|
||||||
|
|
||||||
|
val signature = stack.sign(DummyMessageSigner, SignatureTestUtil.key.pair.private, 0L, Instant.MIN)
|
||||||
|
assertEquals(signature.size, 1)
|
||||||
|
assertEquals(signature["message"], "hi there. I am Moritz!".encodeNetwork())
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Minosoft
|
||||||
|
* Copyright (C) 2020-2023 Moritz Zwerger
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package de.bixilon.minosoft.data.chat.signature.signer
|
||||||
|
|
||||||
|
import de.bixilon.minosoft.data.chat.signature.LastSeenMessageList
|
||||||
|
import de.bixilon.minosoft.data.text.ChatComponent
|
||||||
|
import de.bixilon.minosoft.protocol.ProtocolUtil.encodeNetwork
|
||||||
|
import java.security.PrivateKey
|
||||||
|
import java.time.Instant
|
||||||
|
import java.util.*
|
||||||
|
|
||||||
|
object DummyMessageSigner : MessageSigner {
|
||||||
|
|
||||||
|
override fun signMessage(privateKey: PrivateKey, message: String, preview: ChatComponent?, salt: Long, sender: UUID, time: Instant, lastSeen: LastSeenMessageList): ByteArray {
|
||||||
|
return message.encodeNetwork()
|
||||||
|
}
|
||||||
|
}
|
@ -21,9 +21,8 @@ import de.bixilon.minosoft.protocol.protocol.VersionSupport
|
|||||||
import de.bixilon.minosoft.protocol.versions.Versions
|
import de.bixilon.minosoft.protocol.versions.Versions
|
||||||
import de.bixilon.minosoft.test.ITUtil
|
import de.bixilon.minosoft.test.ITUtil
|
||||||
import org.testng.Assert
|
import org.testng.Assert
|
||||||
import org.testng.annotations.Test
|
|
||||||
|
|
||||||
@Test(groups = ["pixlyzer"], dependsOnGroups = ["version"], singleThreaded = false, threadPoolSize = 8)
|
// @Test(groups = ["pixlyzer"], dependsOnGroups = ["version"], singleThreaded = false, threadPoolSize = 8)
|
||||||
class PixLyzerLoadingTest {
|
class PixLyzerLoadingTest {
|
||||||
|
|
||||||
private fun VersionRegistry.test() {
|
private fun VersionRegistry.test() {
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Minosoft
|
* Minosoft
|
||||||
* Copyright (C) 2020-2022 Moritz Zwerger
|
* Copyright (C) 2020-2023 Moritz Zwerger
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
*
|
*
|
||||||
@ -31,6 +31,14 @@ class ChatNode(
|
|||||||
val peek = reader.peek()
|
val peek = reader.peek()
|
||||||
val node = getNode(reader, stack)
|
val node = getNode(reader, stack)
|
||||||
val string = parser.parse(reader)
|
val string = parser.parse(reader)
|
||||||
|
|
||||||
|
var thrown: Throwable? = null // throw it after sending ti
|
||||||
|
try {
|
||||||
|
node?.execute(CommandReader(string), stack)
|
||||||
|
} catch (error: Throwable) {
|
||||||
|
thrown = error
|
||||||
|
}
|
||||||
|
|
||||||
if (node != CLI.ROOT_NODE && string.isNotBlank()) {
|
if (node != CLI.ROOT_NODE && string.isNotBlank()) {
|
||||||
if (peek == '/'.code) {
|
if (peek == '/'.code) {
|
||||||
stack.connection.util.sendCommand("/$string", stack)
|
stack.connection.util.sendCommand("/$string", stack)
|
||||||
@ -38,7 +46,8 @@ class ChatNode(
|
|||||||
stack.connection.util.sendChatMessage(string)
|
stack.connection.util.sendChatMessage(string)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
node?.execute(CommandReader(string), stack)
|
|
||||||
|
thrown?.let { throw it }
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getNode(reader: CommandReader, stack: CommandStack): RootNode? {
|
private fun getNode(reader: CommandReader, stack: CommandStack): RootNode? {
|
||||||
|
@ -26,6 +26,6 @@ data class CommandStackEntry(
|
|||||||
) {
|
) {
|
||||||
|
|
||||||
fun sign(connection: PlayConnection, signer: MessageSigner, key: PrivateKey, salt: Long, time: Instant): ByteArray {
|
fun sign(connection: PlayConnection, signer: MessageSigner, key: PrivateKey, salt: Long, time: Instant): ByteArray {
|
||||||
return signer.signMessage(key, data.toString(), null, salt, connection.player.uuid, time, LastSeenMessageList(emptyArray()))
|
return signer.signMessage(key, data.toString(), null, salt, connection.account.uuid, time, LastSeenMessageList(emptyArray()))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user