├── .github └── workflows │ └── gradle.yml ├── README.md ├── build.gradle ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── src └── main ├── java └── dev │ └── sim0n │ └── client │ ├── Client.java │ ├── command │ ├── Command.java │ └── impl │ │ └── ModCommand.java │ ├── event │ ├── Event.java │ ├── EventFactory.java │ ├── EventHandler.java │ ├── LambdaBasedEventHandler.java │ ├── forge │ │ ├── FEventListener.java │ │ └── impl │ │ │ ├── FClientTickListener.java │ │ │ ├── FLivingUpdateListener.java │ │ │ ├── FPacketListener.java │ │ │ └── FRenderTickListener.java │ └── impl │ │ ├── network │ │ └── PacketEvent.java │ │ ├── player │ │ ├── ClientTickEvent.java │ │ └── PlayerUpdateEvent.java │ │ └── render │ │ └── RenderTickEvent.java │ ├── manager │ ├── CommandManager.java │ ├── EventManager.java │ └── ModManager.java │ ├── mod │ ├── Mod.java │ ├── ModType.java │ └── impl │ │ └── combat │ │ ├── AutoClicker.java │ │ ├── Reach.java │ │ └── Velocity.java │ ├── setting │ ├── Setting.java │ └── impl │ │ ├── BooleanSetting.java │ │ ├── DoubleSetting.java │ │ └── IntegerSetting.java │ ├── start │ └── ClientMod.java │ └── util │ ├── MathUtil.java │ ├── MouseUtil.java │ └── ReflectionUtil.java └── resources └── mcmod.info /.github/workflows/gradle.yml: -------------------------------------------------------------------------------- 1 | # This workflow will build a Java project with Gradle 2 | # For more information see: https://help.github.com/actions/language-and-framework-guides/building-and-testing-java-with-gradle 3 | 4 | name: Java CI with Gradle 5 | 6 | on: 7 | push: 8 | branches: [ master ] 9 | pull_request: 10 | branches: [ master ] 11 | 12 | jobs: 13 | build: 14 | 15 | runs-on: ubuntu-latest 16 | 17 | steps: 18 | - uses: actions/checkout@v2 19 | - name: Set up JDK 8 20 | uses: actions/setup-java@v2 21 | with: 22 | java-version: '8' 23 | distribution: 'adopt' 24 | - name: Grant execute permission for gradlew 25 | run: chmod +x gradlew 26 | - name: Build with Gradle 27 | run: ./gradlew build 28 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## Cobalt Client 2 | Cobalt Client is a utility mod with the purpose to test anticheat checks as most client's features are inaccurate. Using Cobalt you'll have a much easier time testing as you can set the exact values. It also features an auto clicker so you won't have to click all the time. 3 | 4 | ## Usage 5 | Cobalt is command based, the prefix is `.` 6 | 7 | ## Commands 8 | .autoclicker 9 | 10 | .reach 11 | 12 | .velocity 13 | -------------------------------------------------------------------------------- /build.gradle: -------------------------------------------------------------------------------- 1 | 2 | // For those who want the bleeding edge 3 | buildscript { 4 | repositories { 5 | jcenter() 6 | maven { 7 | name = "forge" 8 | url = "http://files.minecraftforge.net/maven" 9 | } 10 | } 11 | dependencies { 12 | classpath 'net.minecraftforge.gradle:ForgeGradle:2.1-SNAPSHOT' 13 | } 14 | } 15 | apply plugin: 'net.minecraftforge.gradle.forge' 16 | 17 | /* 18 | // for people who want stable - not yet functional for MC 1.8.8 - we require the forgegradle 2.1 snapshot 19 | plugins { 20 | id "net.minecraftforge.gradle.forge" version "2.0.2" 21 | } 22 | */ 23 | version = "1.0" 24 | group= "com.yourname.modid" // http://maven.apache.org/guides/mini/guide-naming-conventions.html 25 | archivesBaseName = "cobalt" 26 | 27 | minecraft { 28 | version = "1.8.9-11.15.1.1722" 29 | runDir = "run" 30 | 31 | // the mappings can be changed at any time, and must be in the following format. 32 | // snapshot_YYYYMMDD snapshot are built nightly. 33 | // stable_# stables are built at the discretion of the MCP team. 34 | // Use non-default mappings at your own risk. they may not allways work. 35 | // simply re-run your setup task after changing the mappings to update your workspace. 36 | mappings = "stable_20" 37 | // makeObfSourceJar = false // an Srg named sources jar is made by default. uncomment this to disable. 38 | } 39 | 40 | dependencies { 41 | compile "org.projectlombok:lombok:1.16.18" 42 | // you may put jars on which you depend on in ./libs 43 | // or you may define them like so.. 44 | //compile "some.group:artifact:version:classifier" 45 | //compile "some.group:artifact:version" 46 | 47 | // real examples 48 | //compile 'com.mod-buildcraft:buildcraft:6.0.8:dev' // adds buildcraft to the dev env 49 | //compile 'com.googlecode.efficient-java-matrix-library:ejml:0.24' // adds ejml to the dev env 50 | 51 | // the 'provided' configuration is for optional dependencies that exist at compile-time but might not at runtime. 52 | //provided 'com.mod-buildcraft:buildcraft:6.0.8:dev' 53 | 54 | // the deobf configurations: 'deobfCompile' and 'deobfProvided' are the same as the normal compile and provided, 55 | // except that these dependencies get remapped to your current MCP mappings 56 | //deobfCompile 'com.mod-buildcraft:buildcraft:6.0.8:dev' 57 | //deobfProvided 'com.mod-buildcraft:buildcraft:6.0.8:dev' 58 | 59 | // for more info... 60 | // http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html 61 | // http://www.gradle.org/docs/current/userguide/dependency_management.html 62 | 63 | } 64 | 65 | processResources 66 | { 67 | // this will ensure that this task is redone when the versions change. 68 | inputs.property "version", project.version 69 | inputs.property "mcversion", project.minecraft.version 70 | 71 | // replace stuff in mcmod.info, nothing else 72 | from(sourceSets.main.resources.srcDirs) { 73 | include 'mcmod.info' 74 | 75 | // replace version and mcversion 76 | expand 'version':project.version, 'mcversion':project.minecraft.version 77 | } 78 | 79 | // copy everything else, thats not the mcmod.info 80 | from(sourceSets.main.resources.srcDirs) { 81 | exclude 'mcmod.info' 82 | } 83 | } 84 | 85 | apply plugin: 'java' 86 | compileJava { 87 | sourceCompatibility = '1.8' 88 | targetCompatibility = '1.8' 89 | } -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sim0n/Cobalt-Client/c7ed0a18397c4dcc75866cbac3212622916d1626/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Mon Dec 28 16:07:17 CET 2020 2 | distributionBase=GRADLE_USER_HOME 3 | distributionPath=wrapper/dists 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | distributionUrl=https\://services.gradle.org/distributions/gradle-2.7-all.zip 7 | -------------------------------------------------------------------------------- /gradlew: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | 3 | ############################################################################## 4 | ## 5 | ## Gradle start up script for UN*X 6 | ## 7 | ############################################################################## 8 | 9 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 10 | DEFAULT_JVM_OPTS="" 11 | 12 | APP_NAME="Gradle" 13 | APP_BASE_NAME=`basename "$0"` 14 | 15 | # Use the maximum available, or set MAX_FD != -1 to use that value. 16 | MAX_FD="maximum" 17 | 18 | warn ( ) { 19 | echo "$*" 20 | } 21 | 22 | die ( ) { 23 | echo 24 | echo "$*" 25 | echo 26 | exit 1 27 | } 28 | 29 | # OS specific support (must be 'true' or 'false'). 30 | cygwin=false 31 | msys=false 32 | darwin=false 33 | case "`uname`" in 34 | CYGWIN* ) 35 | cygwin=true 36 | ;; 37 | Darwin* ) 38 | darwin=true 39 | ;; 40 | MINGW* ) 41 | msys=true 42 | ;; 43 | esac 44 | 45 | # For Cygwin, ensure paths are in UNIX format before anything is touched. 46 | if $cygwin ; then 47 | [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` 48 | fi 49 | 50 | # Attempt to set APP_HOME 51 | # Resolve links: $0 may be a link 52 | PRG="$0" 53 | # Need this for relative symlinks. 54 | while [ -h "$PRG" ] ; do 55 | ls=`ls -ld "$PRG"` 56 | link=`expr "$ls" : '.*-> \(.*\)$'` 57 | if expr "$link" : '/.*' > /dev/null; then 58 | PRG="$link" 59 | else 60 | PRG=`dirname "$PRG"`"/$link" 61 | fi 62 | done 63 | SAVED="`pwd`" 64 | cd "`dirname \"$PRG\"`/" >&- 65 | APP_HOME="`pwd -P`" 66 | cd "$SAVED" >&- 67 | 68 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar 69 | 70 | # Determine the Java command to use to start the JVM. 71 | if [ -n "$JAVA_HOME" ] ; then 72 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then 73 | # IBM's JDK on AIX uses strange locations for the executables 74 | JAVACMD="$JAVA_HOME/jre/sh/java" 75 | else 76 | JAVACMD="$JAVA_HOME/bin/java" 77 | fi 78 | if [ ! -x "$JAVACMD" ] ; then 79 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME 80 | 81 | Please set the JAVA_HOME variable in your environment to match the 82 | location of your Java installation." 83 | fi 84 | else 85 | JAVACMD="java" 86 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 87 | 88 | Please set the JAVA_HOME variable in your environment to match the 89 | location of your Java installation." 90 | fi 91 | 92 | # Increase the maximum file descriptors if we can. 93 | if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then 94 | MAX_FD_LIMIT=`ulimit -H -n` 95 | if [ $? -eq 0 ] ; then 96 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then 97 | MAX_FD="$MAX_FD_LIMIT" 98 | fi 99 | ulimit -n $MAX_FD 100 | if [ $? -ne 0 ] ; then 101 | warn "Could not set maximum file descriptor limit: $MAX_FD" 102 | fi 103 | else 104 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" 105 | fi 106 | fi 107 | 108 | # For Darwin, add options to specify how the application appears in the dock 109 | if $darwin; then 110 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" 111 | fi 112 | 113 | # For Cygwin, switch paths to Windows format before running java 114 | if $cygwin ; then 115 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` 116 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` 117 | 118 | # We build the pattern for arguments to be converted via cygpath 119 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` 120 | SEP="" 121 | for dir in $ROOTDIRSRAW ; do 122 | ROOTDIRS="$ROOTDIRS$SEP$dir" 123 | SEP="|" 124 | done 125 | OURCYGPATTERN="(^($ROOTDIRS))" 126 | # Add a user-defined pattern to the cygpath arguments 127 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then 128 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" 129 | fi 130 | # Now convert the arguments - kludge to limit ourselves to /bin/sh 131 | i=0 132 | for arg in "$@" ; do 133 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` 134 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option 135 | 136 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition 137 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` 138 | else 139 | eval `echo args$i`="\"$arg\"" 140 | fi 141 | i=$((i+1)) 142 | done 143 | case $i in 144 | (0) set -- ;; 145 | (1) set -- "$args0" ;; 146 | (2) set -- "$args0" "$args1" ;; 147 | (3) set -- "$args0" "$args1" "$args2" ;; 148 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;; 149 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; 150 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; 151 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; 152 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; 153 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; 154 | esac 155 | fi 156 | 157 | # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules 158 | function splitJvmOpts() { 159 | JVM_OPTS=("$@") 160 | } 161 | eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS 162 | JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" 163 | 164 | exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" 165 | -------------------------------------------------------------------------------- /gradlew.bat: -------------------------------------------------------------------------------- 1 | @if "%DEBUG%" == "" @echo off 2 | @rem ########################################################################## 3 | @rem 4 | @rem Gradle startup script for Windows 5 | @rem 6 | @rem ########################################################################## 7 | 8 | @rem Set local scope for the variables with windows NT shell 9 | if "%OS%"=="Windows_NT" setlocal 10 | 11 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 12 | set DEFAULT_JVM_OPTS= 13 | 14 | set DIRNAME=%~dp0 15 | if "%DIRNAME%" == "" set DIRNAME=. 16 | set APP_BASE_NAME=%~n0 17 | set APP_HOME=%DIRNAME% 18 | 19 | @rem Find java.exe 20 | if defined JAVA_HOME goto findJavaFromJavaHome 21 | 22 | set JAVA_EXE=java.exe 23 | %JAVA_EXE% -version >NUL 2>&1 24 | if "%ERRORLEVEL%" == "0" goto init 25 | 26 | echo. 27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 28 | echo. 29 | echo Please set the JAVA_HOME variable in your environment to match the 30 | echo location of your Java installation. 31 | 32 | goto fail 33 | 34 | :findJavaFromJavaHome 35 | set JAVA_HOME=%JAVA_HOME:"=% 36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 37 | 38 | if exist "%JAVA_EXE%" goto init 39 | 40 | echo. 41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 42 | echo. 43 | echo Please set the JAVA_HOME variable in your environment to match the 44 | echo location of your Java installation. 45 | 46 | goto fail 47 | 48 | :init 49 | @rem Get command-line arguments, handling Windowz variants 50 | 51 | if not "%OS%" == "Windows_NT" goto win9xME_args 52 | if "%@eval[2+2]" == "4" goto 4NT_args 53 | 54 | :win9xME_args 55 | @rem Slurp the command line arguments. 56 | set CMD_LINE_ARGS= 57 | set _SKIP=2 58 | 59 | :win9xME_args_slurp 60 | if "x%~1" == "x" goto execute 61 | 62 | set CMD_LINE_ARGS=%* 63 | goto execute 64 | 65 | :4NT_args 66 | @rem Get arguments from the 4NT Shell from JP Software 67 | set CMD_LINE_ARGS=%$ 68 | 69 | :execute 70 | @rem Setup the command line 71 | 72 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 73 | 74 | @rem Execute Gradle 75 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% 76 | 77 | :end 78 | @rem End local scope for the variables with windows NT shell 79 | if "%ERRORLEVEL%"=="0" goto mainEnd 80 | 81 | :fail 82 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 83 | rem the _cmd.exe /c_ return code! 84 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 85 | exit /b 1 86 | 87 | :mainEnd 88 | if "%OS%"=="Windows_NT" endlocal 89 | 90 | :omega 91 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/Client.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client; 2 | 3 | import dev.sim0n.client.event.forge.FEventListener; 4 | import dev.sim0n.client.event.forge.impl.FClientTickListener; 5 | import dev.sim0n.client.event.forge.impl.FLivingUpdateListener; 6 | import dev.sim0n.client.event.forge.impl.FPacketListener; 7 | import dev.sim0n.client.event.forge.impl.FRenderTickListener; 8 | import dev.sim0n.client.manager.CommandManager; 9 | import dev.sim0n.client.manager.ModManager; 10 | import lombok.Getter; 11 | 12 | import java.util.HashSet; 13 | import java.util.Set; 14 | 15 | @Getter 16 | public class Client { 17 | @Getter 18 | private static Client instance; 19 | 20 | private ModManager modManager; 21 | private CommandManager commandManager; 22 | 23 | private final Set forgeListeners = new HashSet<>(); 24 | 25 | public Client() { 26 | instance = this; 27 | 28 | start(); 29 | } 30 | 31 | public void start() { 32 | System.out.println("Starting client..."); 33 | 34 | registerManagers(); 35 | registerEvents(); 36 | } 37 | 38 | private void registerManagers() { 39 | modManager = new ModManager(); 40 | commandManager = new CommandManager(); 41 | } 42 | 43 | private void registerEvents() { 44 | forgeListeners.add(new FRenderTickListener()); 45 | forgeListeners.add(new FClientTickListener()); 46 | forgeListeners.add(new FPacketListener()); 47 | forgeListeners.add(new FLivingUpdateListener()); 48 | 49 | forgeListeners.forEach(FEventListener::register); 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/command/Command.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.command; 2 | 3 | import lombok.Getter; 4 | import lombok.RequiredArgsConstructor; 5 | import net.minecraft.client.Minecraft; 6 | import net.minecraft.util.ChatComponentText; 7 | 8 | import java.util.List; 9 | 10 | @RequiredArgsConstructor 11 | public abstract class Command { 12 | protected final Minecraft mc = Minecraft.getMinecraft(); 13 | 14 | @Getter 15 | private final String name; 16 | 17 | public abstract void handle(List args); 18 | 19 | protected void sendMessage(String message) { 20 | mc.thePlayer.addChatMessage(new ChatComponentText(message)); 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/command/impl/ModCommand.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.command.impl; 2 | 3 | import dev.sim0n.client.command.Command; 4 | import dev.sim0n.client.mod.Mod; 5 | import dev.sim0n.client.setting.Setting; 6 | import dev.sim0n.client.setting.impl.BooleanSetting; 7 | import dev.sim0n.client.setting.impl.DoubleSetting; 8 | import dev.sim0n.client.setting.impl.IntegerSetting; 9 | import net.minecraft.util.EnumChatFormatting; 10 | 11 | import java.util.List; 12 | import java.util.Optional; 13 | 14 | public class ModCommand extends Command { 15 | private final Mod mod; 16 | 17 | public ModCommand(Mod mod) { 18 | super(mod.getName()); 19 | 20 | this.mod = mod; 21 | } 22 | 23 | @Override 24 | public void handle(List args) { 25 | int length = args.size(); 26 | 27 | if (length != 2) { 28 | StringBuilder sb = new StringBuilder(); 29 | 30 | sb.append(" \n").append(String.format(EnumChatFormatting.BLUE + "%s", mod.getName())).append("\n").append(EnumChatFormatting.GRAY); 31 | 32 | mod.getSettings().forEach(setting -> { 33 | sb.append(EnumChatFormatting.GRAY).append(setting.getName()).append(" - ").append(setting.getDescription()).append("\n"); 34 | 35 | sb.append(EnumChatFormatting.BLUE).append(setting.getValue()).append(" ").append(EnumChatFormatting.GRAY); 36 | if (setting instanceof DoubleSetting) { 37 | DoubleSetting doubleSetting = (DoubleSetting) setting; 38 | 39 | sb.append(doubleSetting.getMin()).append("-").append(doubleSetting.getMax()); 40 | } else if (setting instanceof IntegerSetting) { 41 | IntegerSetting doubleSetting = (IntegerSetting) setting; 42 | 43 | sb.append(doubleSetting.getMin()).append("-").append(doubleSetting.getMax()); 44 | } 45 | 46 | sb.append("\n"); 47 | }); 48 | 49 | sendMessage(sb.toString()); 50 | } else { 51 | String settingName = args.get(0); 52 | 53 | Optional setting = mod.getSettings().stream() 54 | .filter(s -> s.getName().replace(" ", "").equalsIgnoreCase(settingName)) 55 | .findFirst(); 56 | 57 | if (setting.isPresent()) { 58 | Setting handle = setting.get(); 59 | 60 | String value = args.get(1); 61 | 62 | try { 63 | if (handle instanceof BooleanSetting) { 64 | handle.setValue(Boolean.parseBoolean(value)); 65 | } else if (handle instanceof DoubleSetting) { 66 | handle.setValue(Double.parseDouble(value)); 67 | } else if (handle instanceof IntegerSetting) { 68 | handle.setValue(Integer.parseInt(value)); 69 | } 70 | 71 | sendMessage(String.format("%sSet %s to %s", EnumChatFormatting.GREEN, settingName, value)); 72 | } catch (Exception e) { 73 | sendMessage(String.format("%sUnable to set %s to %s",EnumChatFormatting.RED, handle.getName(), value)); 74 | } 75 | 76 | } else { 77 | sendMessage(String.format("%sCouldn't find a setting by the name of %s",EnumChatFormatting.RED, settingName)); 78 | } 79 | } 80 | } 81 | } 82 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/Event.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event; 2 | 3 | import lombok.Getter; 4 | import lombok.Setter; 5 | 6 | @Getter @Setter 7 | public abstract class Event { 8 | private boolean cancelled; 9 | } 10 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/EventFactory.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event; 2 | 3 | import java.util.function.Consumer; 4 | import java.util.function.Predicate; 5 | 6 | public final class EventFactory { 7 | 8 | public static EventHandler create(Class clazz, Consumer handlerConsumer, Predicate condition) { 9 | return new LambdaBasedEventHandler(clazz, handlerConsumer, condition); 10 | } 11 | 12 | public static EventHandler create(Class clazz, Consumer handlerConsumer) { 13 | return new LambdaBasedEventHandler(clazz, handlerConsumer); 14 | } 15 | 16 | } 17 | 18 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/EventHandler.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event; 2 | 3 | public interface EventHandler { 4 | Class getType(); 5 | 6 | void handle(T event); 7 | } 8 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/LambdaBasedEventHandler.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event; 2 | 3 | import lombok.Getter; 4 | 5 | import java.util.function.Consumer; 6 | import java.util.function.Predicate; 7 | 8 | @Getter 9 | public class LambdaBasedEventHandler implements EventHandler { 10 | private final Class type; 11 | 12 | private final Consumer handlerConsumer; 13 | 14 | private Predicate condition = t -> true; 15 | 16 | public LambdaBasedEventHandler(Class type, Consumer handlerConsumer, Predicate condition) { 17 | this.type = type; 18 | this.handlerConsumer = handlerConsumer; 19 | this.condition = condition; 20 | } 21 | 22 | public LambdaBasedEventHandler(Class type, Consumer handlerConsumer) { 23 | this.type = type; 24 | this.handlerConsumer = handlerConsumer; 25 | } 26 | 27 | @Override 28 | public void handle(T event) { 29 | if (condition.test(event)) 30 | handlerConsumer.accept(event); 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/forge/FEventListener.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.forge; 2 | 3 | import dev.sim0n.client.Client; 4 | import dev.sim0n.client.manager.EventManager; 5 | import dev.sim0n.client.event.impl.render.RenderTickEvent; 6 | import net.minecraftforge.fml.common.eventhandler.Event; 7 | import net.minecraftforge.fml.common.eventhandler.EventPriority; 8 | import net.minecraftforge.fml.common.eventhandler.IEventListener; 9 | import net.minecraftforge.fml.common.eventhandler.ListenerList; 10 | import net.minecraftforge.fml.common.gameevent.TickEvent; 11 | 12 | public abstract class FEventListener implements IEventListener { 13 | protected final Client client = Client.getInstance(); 14 | 15 | private final Class[] eventClasses; 16 | 17 | private boolean registered = false; 18 | 19 | public FEventListener(Class... eventClasses) { 20 | this.eventClasses = eventClasses; 21 | } 22 | 23 | public void register() { 24 | try { 25 | for (Class clazz : eventClasses) { 26 | ListenerList listenerList = clazz.newInstance().getListenerList(); 27 | 28 | if (clazz == TickEvent.RenderTickEvent.class) { 29 | listenerList.register(0, EventPriority.HIGH, this); 30 | } else { 31 | listenerList.register(0, EventPriority.NORMAL, this); 32 | } 33 | } 34 | 35 | this.registered = true; 36 | } catch (Exception e) { 37 | throw new RuntimeException(e); 38 | } 39 | } 40 | 41 | public void unregister() { 42 | try { 43 | for (Class clazz : eventClasses) { 44 | ListenerList listenerList = clazz.newInstance().getListenerList(); 45 | 46 | listenerList.unregister(0, this); 47 | } 48 | 49 | this.registered = false; 50 | } catch (Exception e) { 51 | throw new RuntimeException(e); 52 | } 53 | } 54 | 55 | @Override 56 | public final void invoke(Event event) { 57 | if (registered) { 58 | // because Forge is retarded 59 | if (event instanceof TickEvent.RenderTickEvent) { 60 | EventManager.INSTANCE.post(new RenderTickEvent()); 61 | } 62 | 63 | onEvent(event); 64 | } 65 | } 66 | 67 | public abstract void onEvent(Event event); 68 | 69 | } 70 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/forge/impl/FClientTickListener.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.forge.impl; 2 | 3 | import dev.sim0n.client.event.forge.FEventListener; 4 | import dev.sim0n.client.event.impl.player.ClientTickEvent; 5 | import dev.sim0n.client.manager.EventManager; 6 | import net.minecraftforge.fml.common.eventhandler.Event; 7 | import net.minecraftforge.fml.common.gameevent.TickEvent; 8 | 9 | public class FClientTickListener extends FEventListener { 10 | public FClientTickListener() { 11 | super(TickEvent.ClientTickEvent.class); 12 | } 13 | 14 | @Override 15 | public void onEvent(Event event) { 16 | switch (((TickEvent.ClientTickEvent) event).phase) { 17 | case START: 18 | EventManager.INSTANCE.post(new ClientTickEvent(TickEvent.Phase.START)); 19 | break; 20 | 21 | case END: 22 | EventManager.INSTANCE.post(new ClientTickEvent(TickEvent.Phase.END)); 23 | break; 24 | } 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/forge/impl/FLivingUpdateListener.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.forge.impl; 2 | 3 | import dev.sim0n.client.event.forge.FEventListener; 4 | import dev.sim0n.client.event.impl.player.PlayerUpdateEvent; 5 | import dev.sim0n.client.manager.EventManager; 6 | import net.minecraft.client.Minecraft; 7 | import net.minecraftforge.event.entity.living.LivingEvent; 8 | import net.minecraftforge.fml.common.eventhandler.Event; 9 | 10 | public class FLivingUpdateListener extends FEventListener { 11 | 12 | public FLivingUpdateListener() { 13 | super(LivingEvent.LivingUpdateEvent.class); 14 | } 15 | 16 | @Override 17 | public void onEvent(Event event) { 18 | if (((LivingEvent.LivingUpdateEvent) event).entity.equals(Minecraft.getMinecraft().thePlayer)) { 19 | EventManager.INSTANCE.post(new PlayerUpdateEvent()); 20 | } 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/forge/impl/FPacketListener.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.forge.impl; 2 | 3 | import dev.sim0n.client.event.forge.FEventListener; 4 | import io.netty.channel.ChannelDuplexHandler; 5 | import io.netty.channel.ChannelHandlerContext; 6 | import io.netty.channel.ChannelPipeline; 7 | import io.netty.channel.ChannelPromise; 8 | import net.minecraft.client.Minecraft; 9 | import net.minecraft.client.gui.GuiNewChat; 10 | import net.minecraft.client.network.NetHandlerPlayClient; 11 | import net.minecraft.network.play.client.C01PacketChatMessage; 12 | import net.minecraftforge.fml.common.eventhandler.Event; 13 | import net.minecraftforge.fml.common.gameevent.TickEvent; 14 | 15 | public class FPacketListener extends FEventListener { 16 | public FPacketListener() { 17 | super(TickEvent.ClientTickEvent.class); 18 | } 19 | 20 | @Override 21 | public void onEvent(Event event) { 22 | ChannelPipeline pipeline = getPipeline(); 23 | 24 | if (pipeline == null) { 25 | return; 26 | } 27 | 28 | try { 29 | if (pipeline.get(PacketHandler.class) == null && pipeline.get("packet_handler") != null) { 30 | pipeline.addBefore("packet_handler", String.valueOf(System.currentTimeMillis()), new PacketHandler()); 31 | } 32 | } catch (Exception e) { 33 | e.printStackTrace(); 34 | } 35 | } 36 | 37 | @Override 38 | public void unregister() { 39 | super.unregister(); 40 | 41 | ChannelPipeline pipeline = getPipeline(); 42 | 43 | if (pipeline == null) { 44 | return; 45 | } 46 | 47 | if (pipeline.get(PacketHandler.class) != null) { 48 | pipeline.remove(PacketHandler.class); 49 | } 50 | } 51 | 52 | private ChannelPipeline getPipeline() { 53 | NetHandlerPlayClient netHandler = Minecraft.getMinecraft().getNetHandler(); 54 | 55 | if (netHandler == null) { 56 | return null; 57 | } 58 | 59 | if (netHandler.getNetworkManager() == null) { 60 | return null; 61 | } 62 | 63 | try { 64 | return netHandler.getNetworkManager().channel().pipeline(); 65 | } catch (Exception e) { 66 | throw new RuntimeException(e); 67 | } 68 | } 69 | 70 | private class PacketHandler extends ChannelDuplexHandler { 71 | 72 | @Override 73 | public void write(ChannelHandlerContext ctx, Object msg, ChannelPromise promise) throws Exception { 74 | if (msg instanceof C01PacketChatMessage) { 75 | String message = ((C01PacketChatMessage) msg).getMessage(); 76 | 77 | 78 | if (message.startsWith(".") && FPacketListener.this.client.getCommandManager().handleCommand(message.substring(1))) { 79 | return; // cancel chat message 80 | } 81 | } 82 | 83 | super.write(ctx, msg, promise); 84 | } 85 | 86 | @Override 87 | public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { 88 | 89 | super.channelRead(ctx, msg); 90 | } 91 | 92 | } 93 | } 94 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/forge/impl/FRenderTickListener.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.forge.impl; 2 | 3 | import dev.sim0n.client.event.forge.FEventListener; 4 | import net.minecraftforge.fml.common.eventhandler.Event; 5 | import net.minecraftforge.fml.common.gameevent.TickEvent; 6 | 7 | public class FRenderTickListener extends FEventListener { 8 | public FRenderTickListener() { 9 | super(TickEvent.RenderTickEvent.class); 10 | } 11 | 12 | @Override 13 | public void onEvent(Event event) { 14 | if (((TickEvent.RenderTickEvent) event).phase == TickEvent.Phase.END) { 15 | 16 | } 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/impl/network/PacketEvent.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.impl.network; 2 | 3 | import dev.sim0n.client.event.Event; 4 | import lombok.AllArgsConstructor; 5 | import lombok.Getter; 6 | import lombok.Setter; 7 | import net.minecraft.network.Packet; 8 | 9 | @Getter @Setter 10 | @AllArgsConstructor 11 | public class PacketEvent extends Event { 12 | private Packet packet; 13 | } 14 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/impl/player/ClientTickEvent.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.impl.player; 2 | 3 | import dev.sim0n.client.event.Event; 4 | import lombok.Getter; 5 | import lombok.RequiredArgsConstructor; 6 | import net.minecraftforge.fml.common.gameevent.TickEvent; 7 | 8 | @Getter 9 | @RequiredArgsConstructor 10 | public class ClientTickEvent extends Event { 11 | private final TickEvent.Phase phase; 12 | } 13 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/impl/player/PlayerUpdateEvent.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.impl.player; 2 | 3 | import dev.sim0n.client.event.Event; 4 | 5 | public class PlayerUpdateEvent extends Event { 6 | } 7 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/event/impl/render/RenderTickEvent.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.event.impl.render; 2 | 3 | import dev.sim0n.client.event.Event; 4 | 5 | public class RenderTickEvent extends Event { 6 | } 7 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/manager/CommandManager.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.manager; 2 | 3 | import dev.sim0n.client.Client; 4 | import dev.sim0n.client.command.Command; 5 | import dev.sim0n.client.command.impl.ModCommand; 6 | 7 | import java.util.ArrayList; 8 | import java.util.Arrays; 9 | import java.util.List; 10 | import java.util.Optional; 11 | 12 | public class CommandManager { 13 | private final List commands = new ArrayList<>(); 14 | 15 | public CommandManager() { 16 | Client.getInstance().getModManager().getMods().forEach(mod -> commands.add(new ModCommand(mod))); 17 | } 18 | 19 | public boolean handleCommand(String message) { 20 | String[] parts = message.split(" "); 21 | 22 | Optional command = commands.stream() 23 | .filter(cmd -> cmd.getName().equalsIgnoreCase(parts[0])) 24 | .findFirst(); 25 | 26 | if (!command.isPresent()) 27 | return false; 28 | 29 | String[] args = new String[parts.length - 1]; 30 | 31 | System.arraycopy(parts, 1, args, 0, parts.length - 1); 32 | 33 | command.get().handle(Arrays.asList(args)); 34 | return true; 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/manager/EventManager.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.manager; 2 | 3 | import dev.sim0n.client.event.Event; 4 | import dev.sim0n.client.event.EventHandler; 5 | 6 | import java.util.List; 7 | import java.util.concurrent.CopyOnWriteArrayList; 8 | 9 | public enum EventManager { 10 | INSTANCE; 11 | 12 | private final List> handlers = new CopyOnWriteArrayList<>(); 13 | 14 | public void register(EventHandler handler) { 15 | handlers.add(handler); 16 | } 17 | 18 | public void unregister(EventHandler handler) { 19 | handlers.add(handler); 20 | } 21 | 22 | public T post(T event) { 23 | for (EventHandler eventHandler : handlers) { 24 | 25 | if (eventHandler.getType() != event.getClass()) 26 | continue; 27 | 28 | eventHandler.handle(event); 29 | 30 | if (event.isCancelled()) 31 | break; 32 | } 33 | 34 | return event; 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/manager/ModManager.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.manager; 2 | 3 | import dev.sim0n.client.mod.Mod; 4 | import dev.sim0n.client.mod.impl.combat.AutoClicker; 5 | import dev.sim0n.client.mod.impl.combat.Reach; 6 | import dev.sim0n.client.mod.impl.combat.Velocity; 7 | import lombok.Getter; 8 | 9 | import java.util.Arrays; 10 | import java.util.HashSet; 11 | import java.util.List; 12 | import java.util.Set; 13 | 14 | public class ModManager { 15 | private static final List> MOD_CLASSES = Arrays.asList( 16 | AutoClicker.class, Reach.class, Velocity.class 17 | ); 18 | 19 | @Getter 20 | private final Set mods = new HashSet<>(); 21 | 22 | public ModManager() { 23 | MOD_CLASSES.forEach(clazz -> { 24 | try { 25 | mods.add(clazz.newInstance()); 26 | } catch (InstantiationException | IllegalAccessException e) { 27 | e.printStackTrace(); 28 | } 29 | }); 30 | 31 | mods.forEach(Mod::toggle); 32 | } 33 | 34 | public T getMod(Class clazz) { 35 | return (T) mods.stream() 36 | .filter(mod -> mod.getClass() == clazz) 37 | .findFirst() 38 | .orElse(null); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/mod/Mod.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.mod; 2 | 3 | import dev.sim0n.client.event.Event; 4 | import dev.sim0n.client.event.EventFactory; 5 | import dev.sim0n.client.event.EventHandler; 6 | import dev.sim0n.client.manager.EventManager; 7 | import dev.sim0n.client.setting.Setting; 8 | import dev.sim0n.client.setting.impl.BooleanSetting; 9 | import dev.sim0n.client.setting.impl.DoubleSetting; 10 | import lombok.Getter; 11 | import lombok.Setter; 12 | import net.minecraft.client.Minecraft; 13 | 14 | import java.util.*; 15 | import java.util.function.Consumer; 16 | import java.util.function.Predicate; 17 | 18 | @Getter 19 | public abstract class Mod { 20 | protected final Minecraft mc = Minecraft.getMinecraft(); 21 | 22 | private final List settings = new LinkedList<>(); 23 | 24 | private final String name; 25 | private final ModType type; 26 | 27 | @Setter 28 | private boolean state; 29 | 30 | private Set> eventHandlers = new HashSet<>(); 31 | 32 | public Mod(String name, ModType type) { 33 | this.name = name; 34 | this.type = type; 35 | } 36 | 37 | protected final void registerEventHandler(Class clazz, Consumer handlerConsumer, Predicate condition) { 38 | eventHandlers.add(EventFactory.create((Class) clazz, handlerConsumer, condition)); 39 | } 40 | 41 | protected final void registerEventHandler(Class clazz, Consumer handlerConsumer) { 42 | eventHandlers.add(EventFactory.create((Class) clazz, handlerConsumer)); 43 | } 44 | 45 | protected void addSetting(T t) { 46 | settings.add(t); 47 | } 48 | 49 | protected void addSettings(T... t) { 50 | Collections.addAll(settings, t); 51 | } 52 | 53 | @SuppressWarnings("unchecked") private T getSetting(String name) { 54 | return (T) settings.stream() 55 | .filter(setting -> setting.getName().equals(name)) 56 | .findFirst() 57 | .orElse(null); 58 | } 59 | 60 | protected T getBooleanSetting(String name) { 61 | return this.getSetting(name); 62 | } 63 | 64 | protected T getFloatSetting(String name) { 65 | return this.getSetting(name); 66 | } 67 | 68 | public void onEnable() { 69 | eventHandlers.forEach(EventManager.INSTANCE::register); 70 | } 71 | 72 | public void toggle() { 73 | state = !state; 74 | 75 | if (state) 76 | onEnable(); 77 | else 78 | onDisable(); 79 | } 80 | 81 | public void onDisable() { 82 | eventHandlers.forEach(EventManager.INSTANCE::unregister); 83 | } 84 | } 85 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/mod/ModType.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.mod; 2 | 3 | public enum ModType { 4 | COMBAT, 5 | RENDER, 6 | PLAYER, 7 | OTHER 8 | } 9 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/mod/impl/combat/AutoClicker.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.mod.impl.combat; 2 | 3 | import dev.sim0n.client.event.impl.player.ClientTickEvent; 4 | import dev.sim0n.client.event.impl.render.RenderTickEvent; 5 | import dev.sim0n.client.mod.Mod; 6 | import dev.sim0n.client.mod.ModType; 7 | import dev.sim0n.client.setting.impl.BooleanSetting; 8 | import dev.sim0n.client.setting.impl.IntegerSetting; 9 | import dev.sim0n.client.util.MathUtil; 10 | import dev.sim0n.client.util.MouseUtil; 11 | import dev.sim0n.client.util.ReflectionUtil; 12 | import net.minecraft.client.Minecraft; 13 | import net.minecraft.client.settings.KeyBinding; 14 | import net.minecraft.util.MovingObjectPosition; 15 | import net.minecraftforge.fml.common.gameevent.TickEvent; 16 | import org.lwjgl.input.Mouse; 17 | 18 | import java.lang.reflect.Field; 19 | 20 | public class AutoClicker extends Mod { 21 | private Field clickCounterField; 22 | 23 | private long nextLUp, nextLDown; 24 | 25 | private long nextDrop; 26 | private long nextExhaust; 27 | 28 | private double dropRate; 29 | 30 | private boolean dropping; 31 | 32 | private final IntegerSetting minCps = new IntegerSetting("Min CPS", "The minimum CPS", 0, 20, 7); 33 | private final IntegerSetting maxCps = new IntegerSetting("Max CPS", "The maximum CPS", 0, 20, 13); 34 | 35 | private final BooleanSetting disableClickDelay = new BooleanSetting("Disable Click Delay", "Disables MC's between hits attack delay", true); 36 | private final BooleanSetting disableOnBlock = new BooleanSetting("Disable On Blocks", "Stops clicking if you're digging a block", true); 37 | 38 | public AutoClicker() { 39 | super("AutoClicker", ModType.COMBAT); 40 | 41 | try { 42 | clickCounterField = ReflectionUtil.getField(Minecraft.class, "leftClickCounter"); 43 | } catch (IllegalArgumentException e) { 44 | clickCounterField = ReflectionUtil.getField(Minecraft.class, "field_71429_W"); 45 | } 46 | 47 | addSettings(minCps, maxCps, disableClickDelay, disableOnBlock); 48 | 49 | registerEventHandler(ClientTickEvent.class, (ClientTickEvent event) -> { 50 | if (mc.thePlayer == null) 51 | return; 52 | 53 | if (event.getPhase() == TickEvent.Phase.END && disableClickDelay.getValue()) { 54 | ReflectionUtil.setFieldValue(clickCounterField, mc, 0); 55 | } 56 | }); 57 | 58 | registerEventHandler(RenderTickEvent.class, event -> { 59 | long now = System.currentTimeMillis(); 60 | 61 | if (mc.currentScreen == null) { 62 | Mouse.poll(); 63 | 64 | if (Mouse.isButtonDown(0)) { 65 | if (disableOnBlock.getValue()) { 66 | if (mc.objectMouseOver != null && mc.objectMouseOver.typeOfHit == MovingObjectPosition.MovingObjectType.BLOCK) { 67 | KeyBinding.setKeyBindState(this.mc.gameSettings.keyBindAttack.getKeyCode(), true); 68 | return; 69 | } 70 | } 71 | 72 | if (nextLDown > 0L && nextLUp > 0L) { 73 | if (now > nextLDown) { 74 | MouseUtil.sendClick(0, true); 75 | randomiseLeft(); 76 | } else if (now > nextLUp) { 77 | MouseUtil.sendClick(0, false); 78 | } 79 | } else { 80 | randomiseLeft(); 81 | } 82 | } else { 83 | nextLUp = nextLDown = 0L; 84 | } 85 | } 86 | }); 87 | } 88 | 89 | private void randomiseLeft() { 90 | double minCps = this.minCps.getValue(); 91 | double maxCps = this.maxCps.getValue(); 92 | 93 | double cps = minCps + (MathUtil.RANDOM.nextDouble() * (maxCps - minCps)); 94 | long delay = (int) Math.round(1000.0D / cps); 95 | 96 | long now = System.currentTimeMillis(); 97 | 98 | if (now > nextDrop) { 99 | if (!dropping && MathUtil.RANDOM.nextInt(100) >= 83) { 100 | dropping = true; 101 | dropRate = 1.1D + (MathUtil.RANDOM.nextDouble() * 0.2D); 102 | } else { 103 | dropping = false; 104 | } 105 | 106 | nextDrop = now + 450L + (long) MathUtil.RANDOM.nextInt(1500); 107 | } 108 | 109 | if (dropping) { 110 | delay *= dropRate; 111 | } 112 | 113 | if (now > nextExhaust) { 114 | if (MathUtil.RANDOM.nextInt(100) >= 77) { 115 | delay += (50L + (long) MathUtil.RANDOM.nextInt(150)); 116 | } 117 | 118 | nextExhaust = System.currentTimeMillis() + 450L + (long) MathUtil.RANDOM.nextInt(1500); 119 | } 120 | 121 | nextLDown = System.currentTimeMillis() + delay; 122 | nextLUp = System.currentTimeMillis() + (delay / 2) - MathUtil.RANDOM.nextInt(10) + MathUtil.RANDOM.nextInt(10); 123 | } 124 | } 125 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/mod/impl/combat/Reach.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.mod.impl.combat; 2 | 3 | import dev.sim0n.client.mod.Mod; 4 | import dev.sim0n.client.mod.ModType; 5 | import dev.sim0n.client.setting.impl.DoubleSetting; 6 | import net.minecraft.client.renderer.EntityRenderer; 7 | import net.minecraft.entity.Entity; 8 | import net.minecraft.entity.EntityLivingBase; 9 | import net.minecraft.entity.item.EntityItemFrame; 10 | import net.minecraft.util.AxisAlignedBB; 11 | import net.minecraft.util.MovingObjectPosition; 12 | import net.minecraft.util.Vec3; 13 | 14 | import java.lang.reflect.Method; 15 | import java.util.List; 16 | 17 | public class Reach extends Mod { 18 | private final Method canRiderInteractMethod; 19 | 20 | private final DoubleSetting range = new DoubleSetting("Range", "Extends your attack range", 0D, 6D, 3D); 21 | private final DoubleSetting expansion = new DoubleSetting("Expansion", "Expands your attack hitbox", 0D, 1D, 0D); 22 | 23 | public Reach() { 24 | super("Reach", ModType.COMBAT); 25 | 26 | addSettings(range, expansion); 27 | 28 | try { 29 | this.canRiderInteractMethod = Entity.class.getDeclaredMethod("canRiderInteract"); 30 | } catch (Exception e) { 31 | throw new RuntimeException(e); 32 | } 33 | 34 | mc.entityRenderer = new ReachEntityRenderer(); 35 | } 36 | 37 | @Override 38 | public void onEnable() { 39 | super.onEnable(); 40 | } 41 | 42 | @Override 43 | public void onDisable() { 44 | super.onDisable(); 45 | 46 | } 47 | 48 | private class ReachEntityRenderer extends EntityRenderer { 49 | 50 | private Entity pointedEntity; 51 | 52 | public ReachEntityRenderer() { 53 | super(mc, mc.getResourceManager()); 54 | } 55 | 56 | @Override 57 | public void getMouseOver(float p_78473_1_) { 58 | if (mc.getRenderViewEntity() != null) { 59 | if (mc.theWorld != null) { 60 | mc.pointedEntity = null; 61 | double d0 = mc.playerController.getBlockReachDistance(); 62 | mc.objectMouseOver = mc.getRenderViewEntity().rayTrace(d0, p_78473_1_); 63 | double d1 = d0; 64 | Vec3 vec3 = mc.getRenderViewEntity().getPositionEyes(p_78473_1_); 65 | 66 | if (mc.playerController.extendedReach()) { 67 | d0 = 6.0D; 68 | d1 = 6.0D; 69 | } else { 70 | if (d0 > range.getValue()) { 71 | d1 = range.getValue(); 72 | } 73 | 74 | d0 = d1; 75 | } 76 | 77 | if (mc.objectMouseOver != null) { 78 | d1 = mc.objectMouseOver.hitVec.distanceTo(vec3); 79 | } 80 | 81 | Vec3 vec31 = mc.getRenderViewEntity().getLook(p_78473_1_); 82 | Vec3 vec32 = vec3.addVector(vec31.xCoord * d0, vec31.yCoord * d0, vec31.zCoord * d0); 83 | this.pointedEntity = null; 84 | Vec3 vec33 = null; 85 | float f1 = 1.0F; 86 | List list = mc.theWorld.getEntitiesWithinAABBExcludingEntity(mc.getRenderViewEntity(), mc.getRenderViewEntity().getEntityBoundingBox().addCoord(vec31.xCoord * d0, vec31.yCoord * d0, vec31.zCoord * d0).expand(f1, f1, f1)); 87 | double d2 = d1; 88 | 89 | for (Object o : list) { 90 | Entity entity = (Entity) o; 91 | 92 | if (entity.canBeCollidedWith()) { 93 | float f2 = entity.getCollisionBorderSize(); 94 | float expand = expansion.getValue().floatValue(); 95 | AxisAlignedBB axisalignedbb = entity.getEntityBoundingBox().expand(f2, f2, f2).expand(expand, expand, expand); 96 | MovingObjectPosition movingobjectposition = axisalignedbb.calculateIntercept(vec3, vec32); 97 | 98 | if (axisalignedbb.isVecInside(vec3)) { 99 | if (0.0D < d2 || d2 == 0.0D) { 100 | this.pointedEntity = entity; 101 | vec33 = movingobjectposition == null ? vec3 : movingobjectposition.hitVec; 102 | d2 = 0.0D; 103 | } 104 | } else if (movingobjectposition != null) { 105 | double d3 = vec3.distanceTo(movingobjectposition.hitVec); 106 | 107 | if (d3 < d2 || d2 == 0.0D) { 108 | if (entity == mc.getRenderViewEntity().ridingEntity && !canRiderInteract(entity)) { 109 | if (d2 == 0.0D) { 110 | this.pointedEntity = entity; 111 | vec33 = movingobjectposition.hitVec; 112 | } 113 | } else { 114 | this.pointedEntity = entity; 115 | vec33 = movingobjectposition.hitVec; 116 | d2 = d3; 117 | } 118 | } 119 | } 120 | } 121 | } 122 | 123 | if (this.pointedEntity != null && (d2 < d1 || mc.objectMouseOver == null)) { 124 | mc.objectMouseOver = new MovingObjectPosition(this.pointedEntity, vec33); 125 | 126 | if (this.pointedEntity instanceof EntityLivingBase || this.pointedEntity instanceof EntityItemFrame) { 127 | mc.pointedEntity = this.pointedEntity; 128 | } 129 | } 130 | } 131 | } 132 | } 133 | 134 | private boolean canRiderInteract(Entity entity) { 135 | try { 136 | return (boolean) canRiderInteractMethod.invoke(entity); 137 | } catch (Exception e) { 138 | e.printStackTrace(); 139 | return false; 140 | } 141 | } 142 | } 143 | 144 | } 145 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/mod/impl/combat/Velocity.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.mod.impl.combat; 2 | 3 | import dev.sim0n.client.event.impl.player.PlayerUpdateEvent; 4 | import dev.sim0n.client.mod.Mod; 5 | import dev.sim0n.client.mod.ModType; 6 | import dev.sim0n.client.setting.impl.DoubleSetting; 7 | import dev.sim0n.client.setting.impl.IntegerSetting; 8 | import net.minecraft.entity.player.EntityPlayer; 9 | 10 | public class Velocity extends Mod { 11 | private final DoubleSetting horizontal = new DoubleSetting("Horizontal", "The horizontal factor", 0D, 2D, 1D); 12 | private final DoubleSetting vertical = new DoubleSetting("Vertical", "The vertical factor", 0D, 2D, 1D); 13 | 14 | private final IntegerSetting delay = new IntegerSetting("Delay", "The delay until enabled", 0, 9, 0); 15 | 16 | public Velocity() { 17 | super("Velocity", ModType.COMBAT); 18 | 19 | addSettings(horizontal, vertical, delay); 20 | 21 | registerEventHandler(PlayerUpdateEvent.class, event -> { 22 | EntityPlayer player = mc.thePlayer; 23 | 24 | if (player.maxHurtResistantTime - delay.getValue() == player.hurtResistantTime && player.maxHurtResistantTime != 0) { 25 | player.setVelocity( 26 | player.motionX * horizontal.getValue(), 27 | player.motionY * vertical.getValue(), 28 | player.motionZ * horizontal.getValue() 29 | ); 30 | } 31 | }); 32 | 33 | /*registerEventHandler(PacketEvent.class, event -> { 34 | S12PacketEntityVelocity packet = (S12PacketEntityVelocity) event.getPacket(); 35 | 36 | }, event -> { 37 | if (event.getPacket() instanceof S12PacketEntityVelocity) { 38 | S12PacketEntityVelocity packet = (S12PacketEntityVelocity) event.getPacket(); 39 | 40 | return packet.getEntityID() == mc.thePlayer.getEntityId(); 41 | } 42 | 43 | return false; 44 | });*/ 45 | } 46 | } 47 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/setting/Setting.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.setting; 2 | 3 | public interface Setting { 4 | String getName(); 5 | 6 | String getDescription(); 7 | 8 | T getValue(); 9 | 10 | void setValue(T value); 11 | } 12 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/setting/impl/BooleanSetting.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.setting.impl; 2 | 3 | import dev.sim0n.client.setting.Setting; 4 | import lombok.AllArgsConstructor; 5 | import lombok.Getter; 6 | import lombok.Setter; 7 | 8 | @Getter @Setter 9 | @AllArgsConstructor 10 | public class BooleanSetting implements Setting { 11 | private final String name, description; 12 | 13 | private Boolean value; 14 | } 15 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/setting/impl/DoubleSetting.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.setting.impl; 2 | 3 | import dev.sim0n.client.setting.Setting; 4 | import lombok.AllArgsConstructor; 5 | import lombok.Getter; 6 | import lombok.RequiredArgsConstructor; 7 | import lombok.Setter; 8 | 9 | @Getter @Setter 10 | @AllArgsConstructor 11 | public class DoubleSetting implements Setting { 12 | private final String name, description; 13 | 14 | private final Double min, max; 15 | 16 | private Double value; 17 | } 18 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/setting/impl/IntegerSetting.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.setting.impl; 2 | 3 | import dev.sim0n.client.setting.Setting; 4 | import lombok.AllArgsConstructor; 5 | import lombok.Getter; 6 | import lombok.Setter; 7 | 8 | @Getter @Setter 9 | @AllArgsConstructor 10 | public class IntegerSetting implements Setting { 11 | private final String name, description; 12 | 13 | private final Integer min, max; 14 | 15 | private Integer value; 16 | } 17 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/start/ClientMod.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.start; 2 | 3 | import dev.sim0n.client.Client; 4 | import net.minecraft.init.Blocks; 5 | import net.minecraftforge.fml.common.Mod; 6 | import net.minecraftforge.fml.common.event.FMLInitializationEvent; 7 | 8 | @Mod(modid = "cobalt client", version = "1.3.3.7") 9 | public class ClientMod { 10 | 11 | @Mod.EventHandler 12 | public void init(FMLInitializationEvent event) 13 | { 14 | new Client(); 15 | } 16 | 17 | } 18 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/util/MathUtil.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.util; 2 | 3 | import lombok.experimental.UtilityClass; 4 | 5 | import java.security.SecureRandom; 6 | 7 | @UtilityClass 8 | public class MathUtil { 9 | public final SecureRandom RANDOM = new SecureRandom(); 10 | } 11 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/util/MouseUtil.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.util; 2 | 3 | import lombok.experimental.UtilityClass; 4 | import net.minecraft.client.Minecraft; 5 | import net.minecraft.client.settings.KeyBinding; 6 | import net.minecraftforge.client.event.MouseEvent; 7 | import net.minecraftforge.common.MinecraftForge; 8 | import net.minecraftforge.fml.client.FMLClientHandler; 9 | import net.minecraftforge.fml.common.FMLCommonHandler; 10 | import net.minecraftforge.fml.common.event.FMLEvent; 11 | import net.minecraftforge.fml.common.eventhandler.EventBus; 12 | import org.lwjgl.input.Mouse; 13 | 14 | import java.lang.reflect.Field; 15 | import java.nio.ByteBuffer; 16 | 17 | @UtilityClass 18 | public class MouseUtil { 19 | 20 | private Field buttonStateField; 21 | private Field buttonField; 22 | 23 | private Field buttonsField; 24 | 25 | static { 26 | try { 27 | buttonField = MouseEvent.class.getDeclaredField("button"); 28 | buttonField.setAccessible(true); 29 | } catch (NoSuchFieldException e) { 30 | // 31 | } 32 | 33 | try { 34 | buttonStateField = MouseEvent.class.getDeclaredField("buttonstate"); 35 | buttonStateField.setAccessible(true); 36 | } catch (NoSuchFieldException e) { 37 | // 38 | } 39 | 40 | try { 41 | buttonsField = Mouse.class.getDeclaredField("buttons"); 42 | buttonsField.setAccessible(true); 43 | } catch (NoSuchFieldException e) { 44 | // 45 | } 46 | } 47 | 48 | public void sendClick(int button, boolean state) { 49 | Minecraft mc = Minecraft.getMinecraft(); 50 | int keyBind = button == 0 ? mc.gameSettings.keyBindAttack.getKeyCode() : mc.gameSettings.keyBindUseItem.getKeyCode(); 51 | 52 | KeyBinding.setKeyBindState(button == 0 ? mc.gameSettings.keyBindAttack.getKeyCode() : mc.gameSettings.keyBindUseItem.getKeyCode(), state); 53 | if (state) { 54 | KeyBinding.onTick(keyBind); 55 | } 56 | 57 | try { 58 | MouseEvent mouseEvent = new MouseEvent(); 59 | 60 | // buttonField.setAccessible(true); 61 | buttonField.set(mouseEvent, button); 62 | // buttonField.setAccessible(false); 63 | 64 | // buttonStateField.setAccessible(true); 65 | buttonStateField.set(mouseEvent, state); 66 | // buttonStateField.setAccessible(false); 67 | 68 | //buttonsField.setAccessible(true); 69 | ByteBuffer buffer = (ByteBuffer) buttonsField.get(null); 70 | // buttonsField.setAccessible(false); 71 | 72 | buffer.put(button, (byte) (state ? 1 : 0)); 73 | 74 | } catch (Exception e) { 75 | e.printStackTrace(); 76 | // 77 | } 78 | } 79 | } 80 | 81 | -------------------------------------------------------------------------------- /src/main/java/dev/sim0n/client/util/ReflectionUtil.java: -------------------------------------------------------------------------------- 1 | package dev.sim0n.client.util; 2 | 3 | import lombok.experimental.UtilityClass; 4 | 5 | import java.lang.reflect.Field; 6 | 7 | @UtilityClass 8 | public class ReflectionUtil { 9 | 10 | public Field getField(Class clazz, String fieldName) { 11 | try { 12 | Field field = clazz.getDeclaredField(fieldName); 13 | 14 | field.setAccessible(true); 15 | 16 | return field; 17 | } catch (Exception e) { 18 | throw new IllegalArgumentException(clazz.getSimpleName() + ":" + fieldName); 19 | } 20 | } 21 | 22 | public T getFieldValue(Field field, Object instance) { 23 | try { 24 | return (T) field.get(instance); 25 | } catch (IllegalAccessException e) { 26 | throw new IllegalArgumentException(e); 27 | } 28 | } 29 | 30 | public void setFieldValue(Field field, Object instance, Object value) { 31 | try { 32 | field.set(instance, value); 33 | } catch (IllegalAccessException e) { 34 | throw new IllegalArgumentException(); 35 | } 36 | } 37 | } 38 | 39 | -------------------------------------------------------------------------------- /src/main/resources/mcmod.info: -------------------------------------------------------------------------------- 1 | [ 2 | { 3 | "modid": "examplemod", 4 | "name": "Example Mod", 5 | "description": "Example placeholder mod.", 6 | "version": "${version}", 7 | "mcversion": "${mcversion}", 8 | "url": "", 9 | "updateUrl": "", 10 | "authorList": ["ExampleDude"], 11 | "credits": "The Forge and FML guys, for making this example", 12 | "logoFile": "", 13 | "screenshots": [], 14 | "dependencies": [] 15 | } 16 | ] 17 | --------------------------------------------------------------------------------