I went on the LiveOverflow server it was pretty fun

This commit is contained in:
Charlotte Som 2022-09-19 08:01:57 +01:00
parent d6ff81fb16
commit a2e067bf4d
11 changed files with 137 additions and 14 deletions

3
.gitmodules vendored
View file

@ -1,9 +1,6 @@
[submodule "build_src/quilt-mappings-on-loom"]
path = build_src/quilt-mappings-on-loom
url = https://git.lavender.software/hibiscus-client/quilt-mappings-on-loom.git
[submodule "build_src/fabric-loom"]
path = build_src/fabric-loom
url = https://git.lavender.software/hibiscus-client/fabric-loom.git
[submodule "vendor"]
path = vendor
url = https://git.lavender.software/hibiscus-client/vendored-jars.git

View file

@ -1,4 +1,5 @@
import org.gradle.kotlin.dsl.accessors.runtime.extensionOf
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
import org.quiltmc.quiltmappings.loom.QuiltMappingsOnLoomPlugin
plugins {
@ -66,6 +67,7 @@ dependencies {
modImplementation(files("vendor/mods/iris-mc1.18.2-1.2.1-rc2-0cc372f0.jar"))
modImplementation(files("vendor/mods/sodium-fabric-mc1.18.2-0.4.1+build.15.jar"))
modRuntimeOnly(files("vendor/mods/lazydfu-0.1.2.jar"))
implementation(kotlin("stdlib-jdk8"))
}
loom {
@ -106,3 +108,11 @@ tasks {
withSourcesJar()
}
}
val compileKotlin: KotlinCompile by tasks
compileKotlin.kotlinOptions {
jvmTarget = "1.8"
}
val compileTestKotlin: KotlinCompile by tasks
compileTestKotlin.kotlinOptions {
jvmTarget = "1.8"
}

@ -1 +0,0 @@
Subproject commit 71c28bbcd075d6d0c45dcdde71246e61ccb661e3

View file

@ -5,13 +5,13 @@ org.gradle.warning.mode=all
minecraftVersion=1.18.2
quiltMappings=1.18.2+build.7
# Fabric https://fabricmc.net/develop/
loaderVersion=0.13.3
fabricVersion=0.47.10+1.18.2
loomVersion=0.10-SNAPSHOT
loaderVersion=0.14.9
fabricVersion=0.58.0+1.18.2
loomVersion=1.0-SNAPSHOT
# Mod Properties
modVersion=1.0.0
mavenGroup=codes.som
archivesBaseName=hibiscus-client
# Kotlin
systemProp.kotlinVersion=1.6.10
fabricKotlinVersion=1.7.1+kotlin.1.6.10
fabricKotlinVersion=1.8.3+kotlin.1.7.10

View file

@ -1,4 +1,3 @@
includeBuild("build_src/fabric-loom")
includeBuild("build_src/quilt-mappings-on-loom")
pluginManagement {

View file

@ -2,8 +2,7 @@ package codes.som.hibiscus.features
import codes.som.hibiscus.api.feature.Feature
import codes.som.hibiscus.features.combat.Criticals
import codes.som.hibiscus.features.exploits.AntiGhost
import codes.som.hibiscus.features.exploits.Ghost
import codes.som.hibiscus.features.exploits.*
import codes.som.hibiscus.features.movement.Flight
import codes.som.hibiscus.features.movement.Speed
import codes.som.hibiscus.features.overlay.Overlay
@ -33,6 +32,9 @@ fun FEATURE_CONSTRUCTORS(): Array<() -> Feature> = arrayOf(
::Fullbright,
::NoFog,
::SpeedMine,
::CivBreak,
::DropDirt,
::BotPretend,
)
class FeaturesRegistry : Resettable {

View file

@ -0,0 +1,64 @@
package codes.som.hibiscus.features.exploits
import codes.som.hibiscus.api.command.Command
import codes.som.hibiscus.api.feature.Feature
import codes.som.hibiscus.api.feature.FeatureCategory
import codes.som.hibiscus.events.NetworkMovingEvent
import codes.som.hibiscus.events.PlayerPreTickEvent
import codes.som.hibiscus.events.SendPacketEvent
import codes.som.hibiscus.mc
import codes.som.hibiscus.player
import net.minecraft.network.packet.c2s.play.PlayerMoveC2SPacket
class BotPretend : Feature("Bot Pretend", FeatureCategory.EXPLOITS) {
init {
on<NetworkMovingEvent> { e ->
val x = ((e.x * 100).toLong()) / 100.0
val z = ((e.z * 100).toLong()) / 100.0
// TODO: Collisions?
/* for (x in arrayOf(-1, 0, 1)) {
for (z in arrayOf(-1, 0, 1)) {
if (world.getCollisions(player, player.boundingBox.offset()))
}
} */
e.x = x
e.z = z
}
on<PlayerPreTickEvent> {
// player.updatePosition(player.x.roundToLong().toDouble(), player.y, player.z.roundToLong().toDouble())
}
on<SendPacketEvent> { e ->
val packet = e.packet
if (packet is PlayerMoveC2SPacket) {
if (packet.changesPosition()) {
println("Move: ${packet.getX(player.x)}, ${packet.getZ(player.z)}")
}
}
}
}
override fun createFeatureCommand(): Command {
return super.createFeatureCommand().apply {
branch("send", {
val x = (player.x * 10).toLong() / 10.0
val z = (player.z * 10).toLong() / 10.0
player.updatePosition(x, player.y, z)
mc.networkHandler!!.connection!!.send(
PlayerMoveC2SPacket.PositionAndOnGround(
x,
player.y,
z,
player.isOnGround
)
)
})
}
}
}

View file

@ -0,0 +1,33 @@
package codes.som.hibiscus.features.exploits
import codes.som.hibiscus.api.feature.Feature
import codes.som.hibiscus.api.feature.FeatureCategory
import codes.som.hibiscus.events.PlayerTickEvent
import codes.som.hibiscus.events.SendPacketEvent
import codes.som.hibiscus.player
import net.minecraft.network.Packet
import net.minecraft.network.listener.ServerPlayPacketListener
import net.minecraft.network.packet.c2s.play.PlayerActionC2SPacket
class CivBreak : Feature("Civ Break", FeatureCategory.EXPLOITS) {
private var endBreakPacket: Packet<ServerPlayPacketListener>? = null
init {
on { event: SendPacketEvent ->
val packet = event.packet
if (packet is PlayerActionC2SPacket) {
when (packet.action) {
PlayerActionC2SPacket.Action.START_DESTROY_BLOCK -> endBreakPacket = null
PlayerActionC2SPacket.Action.STOP_DESTROY_BLOCK -> endBreakPacket = packet
else -> {}
}
}
}
on<PlayerTickEvent> {
if (endBreakPacket != null)
player.networkHandler.sendPacket(endBreakPacket)
}
}
}

View file

@ -0,0 +1,17 @@
package codes.som.hibiscus.features.exploits
import codes.som.hibiscus.api.feature.Feature
import codes.som.hibiscus.api.feature.FeatureCategory
import codes.som.hibiscus.events.PlayerTickEvent
import codes.som.hibiscus.player
import net.minecraft.item.Items
class DropDirt : Feature("Drop Dirt", FeatureCategory.EXPLOITS) {
init {
on<PlayerTickEvent> {
if (player.age % 2 == 0)
if (player.mainHandStack?.item == Items.DIRT)
player.dropSelectedItem(false)
}
}
}

View file

@ -91,7 +91,7 @@ class Flight : Feature("Flight", FeatureCategory.MOVEMENT) {
on(cond = { spoofAbilityPackets }) { event: SendPacketEvent ->
val (packet) = event
if (packet is UpdatePlayerAbilitiesC2SPacket) {
requireExtension<MixinExtUpdatePlayerAbilitiesC2SPacket>(packet)
packet.setFlying(player.abilities.allowFlying)

View file

@ -48,8 +48,10 @@ object AccountsSubsystem {
fun deleteAccount(account: MinecraftAccount) {
val id = account.id.value
accounts = accounts.filter { it.id.value == id }
account.delete()
accounts = accounts.filter { it.id.value != id }
Hibiscus.data.txn {
account.delete()
}
}
fun reload() {