npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

mineflayer-viaproxy

v0.7.9

Published

ViaProxy support for mineflayer.

Readme

mineflayer-viaproxy

NPM version

A mineflayer plugin that allows you to connect to a server through a ViaVersion proxy.

Why? Because I'm tired of people asking for version updates.

If you have issues, join here for support. Alternatively, here for general mineflayer support.

Prerequisites

  • Node.js v16 or higher
  • Java Runtime Environment (JRE) installed and accessible via command line, preferably version 17 or higher.

TODOS

  • [x] Support bedrock versions
  • [x] Support adding accounts to ViaProxy gracefully.
  • [x] Make fix for prismarine-registry more robust (see patches)
  • [ ] Add support for more ViaVersion options
  • [x] Add support for more ViaProxy options
  • [x] Support Python

Installation

npm install mineflayer-viaproxy

Usage

Basic usage is simple. Just use createBot from this package instead of mineflayer.createBot.

Note! createBot is now asynchronous and must be awaited. This is because it needs to set up the ViaProxy before the bot can connect.

Additionally: the username must now STRICTLY match the in-game username of the account you want to use. This is because ViaProxy needs to authenticate with Mojang/Microsoft using that account's credentials, and the bot needs to use that account's credentials to connect to the server through ViaProxy.

const { createBot } = require('mineflayer-viaproxy')

// only difference is that this must be awaited now.
const bot = await createBot({...})

// if you want to pass viaProxy options, it'd be like so:

const orgBotOpts = {...}
const viaProxyOpts = {...}

// same object. 
const bot = await createBot({...orgBotOpts, ...viaProxyOpts});

More examples can be found in the examples/ folder.

Debugging

This package uses the debug library for logging. To enable debug output, set the DEBUG environment variable to include mineflayer-viaproxy.

Examples:

Enable all mineflayer-viaproxy logs:

# On Windows (PowerShell)
$env:DEBUG = "mineflayer-viaproxy:*"; node your-script.js

# On Windows (Command Prompt)
set DEBUG=mineflayer-viaproxy:* && node your-script.js

# On macOS/Linux
DEBUG=mineflayer-viaproxy:* node your-script.js

Enable specific module logs:

# macOS/Linux
DEBUG=mineflayer-viaproxy:openAuthMod node your-script.js

# Windows (PowerShell)
$env:DEBUG = "mineflayer-viaproxy:openAuthMod"; node your-script.js

Enable logs from multiple packages:

# macOS/Linux
DEBUG=mineflayer-viaproxy:*,minecraft-protocol node your-script.js

For more information on the debug library and its patterns, see the debug documentation.

API

Types

AuthType

export enum AuthType {
    NONE = "NONE",
    OPENAUTHMOD = "OPENAUTHMOD",
    ACCOUNT = "ACCOUNT",
}

| Name | Value | Description | | ------------- | --------------- | ---------------------------------------------- | | NONE | "NONE" | No authentication | | OPENAUTHMOD | "OPENAUTHMOD" | OpenAuthMod authentication | | ACCOUNT | "ACCOUNT" | Account authentication (requires manual setup) |

ViaProxyOpts

export interface ViaProxyOpts {
    forceViaProxy?: boolean;
    javaPath?: string;
    javaArgs?: string[];
    localPort?: number;
    localAuth?: AuthType;
    viaProxyLocation?: string;
    viaProxyWorkingDir?: string;
    autoUpdate?: boolean;
    viaProxyConfig?: Partial<ViaProxyConfig>;
    viaProxyStdoutCb?: (data: any) => void;
    viaProxyStderrCb?: (data: any) => void;
}

| Name | Type | Default | Description | | -------------------- | ------------------------- | ----------------- | ------------------------------------------------------------------------------------------------------------------------------------- | | forceViaProxy | boolean | false | Whether or not to force the use of ViaProxy. If set to true, it will always use ViaProxy regardless of the server version. | | javaPath | string | "java" | The path to the java executable. | | javaArgs | string[] | [] | Raw Java arguments to be passed directly. | localPort | number | auto determined | The port to listen on for the local server. If none is specified, it will automatically locate an open port for you on your computer. | | localAuth | AuthType | AuthType.NONE | The authentication type to use for the local server. | | viaProxyLocation | string | "" | The location of the ViaVersion proxy jar. If none specified, it will download automatically to the CWD + viaproxy. | | viaProxyWorkingDir | string | "" | The working directory for the ViaVersion proxy. If none specified, it will use the CWD + viaproxy. | | autoUpdate | boolean | true | Whether or not to automatically update the ViaVersion proxy. | | viaProxyConfig | Partial<ViaProxyConfig> | undefined | Configuration options for ViaProxy. | | viaProxyStdoutCb | (data: any) => void | undefined | A callback for the stdout of the ViaVersion proxy. | | viaProxyStderrCb | (data: any) => void | undefined | A callback for the stderr of the ViaVersion proxy. |

ViaProxyConfig

export interface ViaProxyConfig {
    backendProxyUrl: string;
    [key: string]: string | number | boolean;
}

| Name | Type | Description | | | | ----------------- | ------- | ----------------------------------------------------------------------------------- | -------- | ---------------------------------------------- | | backendProxyUrl | string | The URL of the backend proxy to connect to. If none specified, it will not use one. | | | | [key: string] | string \| number \| boolean | Additional configuration options for ViaProxy. |