Core for pimi-launcher (Minecraft)
Find a file
2019-08-12 21:06:54 -04:00
components Added and fixed some overrides. URL overrides 2019-08-12 21:06:54 -04:00
.gitattributes Init 2018-10-29 18:13:58 -04:00
.gitignore Removed a unneeded require 2018-12-09 18:13:20 -05:00
.travis.yml messing around on dev 2019-05-22 20:24:53 -04:00
index.js rewrite 2019-05-22 18:28:48 -04:00
LICENSE Update License and reformat some things 2019-04-18 17:35:39 -04:00
package-lock.json Checksum, fix random version file request, removed node-fetch 2019-05-07 19:12:24 -04:00
package.json Added and fixed some overrides. URL overrides 2019-08-12 21:06:54 -04:00
README.md Added and fixed some overrides. URL overrides 2019-08-12 21:06:54 -04:00

logo

This project is near complete.

Build Status

MCLC is a NodeJS solution for launching modded and vanilla Minecraft without having to download and format everything yourself. Basically a core for your Electron or script based launchers.

Getting support

Since people seem to use this, I've created a Discord server for anyone who needs to get in contact with me or get help! https://discord.gg/8uYVbXP

Installing

npm i minecraft-launcher-core

Standard Example

const { Client, Authenticator } = require('minecraft-launcher-core');

let opts = {
    clientPackage: null,
    authorization: Authenticator.getAuth("username", "password"),
    root: "./minecraft",
    os: "windows",
    version: {
        number: "1.14",
        type: "release"
    },
    memory: {
        max: "6000",
        min: "4000"
    }
}

const launcher = new Client();
launcher.launch(opts);

launcher.on('debug', (e) => console.log(e));
launcher.on('data', (e) => console.log(e.toString('utf-8')));
launcher.on('error', (e) => console.log(e.toString('utf-8')));

Documentation

Client Functions

Function Type Description
launch Promise Launches the client with the specified options as a parameter. Returns child the process
launch
Parameter Type Description Required
options.clientPackage String Path or URL to the client package zip file. False
options.installer String Path to installer being executed. False
options.root String Path where you want the launcher to work in. like C:/Users/user/AppData/Roaming/.mc, True
options.os String windows, osx or linux. MCLC with auto determine the OS if this field isn't provided. False
options.customArgs Array Array of custom java arguments you want to add. False
options.version.number String Minecraft version that is going to be launched. True
options.version.type String Any string. The actual Minecraft launcher uses release and snapshot. True
options.version.custom String The name of the folder, jar file, and version json in the version folder. False
options.memory.max String Max amount of memory being used by Minecraft. True
options.memory.min String Min amount of memory being used by Minecraft. True
options.forge String Path to Universal Forge Jar. (Only for versions below 1.13+ False
options.javaPath String Path to the JRE executable file, will default to java if not entered. False
options.server.host String Host url to the server, don't include the port. False
options.server.port String Port of the host url, will default to 25565 if not entered. False
options.proxy.host String Host url to the proxy, don't include the port. False
options.proxy.port String Port of the host proxy, will default to 8080 if not entered. False
options.proxy.username String Username for the proxy. False
options.proxy.password String Password for the proxy. False
options.timeout Integer Timeout on download requests. False
options.window.width String Width of the Minecraft Client False
options.window.height String Height of the Minecraft Client. False
options.overrides Object Json object redefining paths for better customization. Example below. False
options.overrides.minArgs Integer The amount of launch arguments specified in the version file before it adds the default again False
let opts = {
   otherOps...,
   overrides: {
       minecraftJar: "",
       versionJson: "",
       directory: "", // where the Minecraft jar and version json are located.
       natives: "", // all native paths are required if you use this.
       assetRoot: "",
       cwd: "", // working directory of the java process
       classes: [], // all class paths are required if you use this.
       minArgs: 11,
       maxSockets: 2, // max sockets for downloadAsync.
       // The following is for launcher developers located in countries that have the Minecraft and Forge resource servers
       // blocked for what ever reason. They obviously need to mirror the formatting of the original JSONs / file structures.
       url: {
           meta: "https://launchermeta.mojang.com", // List of versions.
           resource: "https://resources.download.minecraft.net", // Minecraft resources.
           mavenForge: "http://files.minecraftforge.net/maven/", // Forge resources.
           defaultRepoForge: "https://libraries.minecraft.net/" // for Forge only, you need to redefine the library url
                                                                // in the version json.
       }
   }
}

Notes

Custom

If you are loading up a client outside of vanilla Minecraft or Forge (Optifine and for an example), you'll need to download the needed files yourself if you don't provide downloads url downloads like Forge and Fabric. Still need to provide the version jar.

Installer

You'll need to provide the folder created in the versions if you're running the new forge like so

{
    "version": {
        "number": "1.14.2",
        "type": "release",
        "custom": "1.14.2-forge-26.0.63"
    },
    "installer": "forge-1.14.2-26.0.63-installer.jar"
}

Authenticator Functions

getAuth
Parameter Type Description Required
username String Email or username True
password String Password for the Mojang account being used if online mode. False
validate
Parameter Type Description Required
access_token String Token being checked if it can be used to login with (online mode). True
client_token String Client token being checked to see if there was a change of client (online mode). True
refreshAuth
Parameter Type Description Required
access_token String Token being checked if it can be used to login with (online mode). True
client_token String Token being checked if it's the same client that the access_token was created from. True
selected_profile Object Json Object that was returned from Mojang's auth api. True
invalidate
Parameter Type Description Required
access_token String Token being checked if it can be used to login with (online mode). True
client_token String Token being checked if it's the same client that the access_token was created from. True
signOut
Parameter Type Description Required
username String Username used to login with True
password String Password used to login with True

Events

Event Name Type Description
arguments Object Emitted when launch arguments are set for the Minecraft Jar.
data Buffer Emitted when information is returned from the Minecraft Process
close Integer Code number that is returned by the Minecraft Process
package-extract null Emitted when clientPackage finishes being extracted
download String Emitted when a file successfully downloads
download-status Object Emitted when data is received while downloading
debug String Emitted when functions occur, made to help debug if errors occur

What should it look like running from console?

Showing the emitted information from debug and data, also using getPid after the process has been created. gif

Contributors

These are the people that helped out that aren't listed here!

  • Pyker - Forge dependency parsing.
  • Khionu - Research on how Minecraft'snatives are handled.
  • Coding-Kiwi - Pointed out I didn't pass clientToken in initial authentication function.
  • maxbsoft - Pointed out that a certain JVM option causes OSX Minecraft to bug out.