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 🙏

© 2024 – Pkg Stats / Ryan Hefner

ptero-ws

v1.0.3

Published

A simple wrapper for handling websocket connection to a Pterodactyl Panel instance.

Downloads

12

Readme

Ptero WS

Ptero WS is a Node.js wrapper for handling websocket connections to a Pterodactyl Panel instance.

Features

  • ✨ Easy to use: Ptero WS is designed to be easy to use and understand.
  • 🛠️ Typescript support: Ptero WS is written in Typescript, so you can use it in your Typescript projects.
  • 📜 Fully typed: Ptero WS is fully typed, so you can use it in your Typescript projects without any issues.
  • 🔔 Event-based: Ptero WS is event-based, so you can listen to events and handle them accordingly.
  • ⚙️ Customizable: Ptero WS is customizable, so you can change the default settings to your liking.
  • 💡 Lightweight: Ptero WS is lightweight, so it won't slow down your application.

Installation

  1. Install the package using NPM:
    npm install ptero-ws
  2. Import the package in your project using ES6:
    import { pterows } from "ptero-ws";
    Or use CommonJS:
    const { pterows } = require("ptero-ws");

Usage

  1. Create a new instance of Ptero WS:

    const socket = new pterows(
      "https://panel.yourdomain.com",
      "CLIENT_KEY",
      "SERVER_ID"
    );

    Note that we append the following parameters to the class.

    • https://panel.yourdomain.com: Your Pterodactyl Panel instance base URL.
    • CLIENT_KEY: Your Pterodactyl Panel user's client key.
    • SERVER_ID: Your Pterodactyl Panel unique identifier for the server you want to connect to.

    You can also provide an option object to customize the options:

    {
     debug: false, // Whether or not messages should be displayed in the console when the socket is connected and closed.
    }
  2. Create your first event listener using Ptero WS:

    socket.on("open", () => {
      socket.listen("stats", (data) => {
        console.log(JSON.parse(data));
      });
    });

    Note that we wrap the inner listener with socket.on("open"). This is done to ensure that the socket has fully connected before creating an event listener.

  3. Once you have finished using Ptero WS, make sure to close the websocket connection to free system resources.

    socket.close();

Listeners

| Name | Arguments | Description | | ------------------------ | -------------------- | ---------------------------------------------------------- | | auth success | | The authentication was successful. | | backup complete | | Sent when a backup is complete. | | backup restore completed | | Sent when a backup has been restored to the server. | | console output | the output message | The output from the console (one line). | | daemon error | the error message | The daemon received an error (usually with the websocket). | | daemon message | the message | A message from the daemon. | | install completed | | Sent when a server's installation process is complete. | | install output | the output message | The output from the installation process. | | install started | | Sent when a server's installation process starts. | | jwt error | the error message | An error occurred with the authentication token. | | stats | statistics JSON data | Current statistics about the server. | | status | the power state | The power state of the server. | | token expired | | The token expired; connection will be closed shortly. | | token expiring | | Warning event: you should reauthenticate the connection. | | transfer logs | the output log | The logs from the transfer process. | | transfer status | the transfer state | The current transfer status. |

Sendable Events

| Name | Arguments | Description | | ------------ | ------------------------------------- | ----------------------------------------- | | auth | the websocket auth token | Authenticates the websocket connection. | | set state | "start", "stop", "restart", or "kill" | Sets the power state of the server. | | send command | the command | Sends a command to the server console. | | send logs | | Requests the console logs for the server. | | send stats | | Requests the server statistics. |

Questions

[!IMPORTANT] Please make sure to check the examples before-hand.

If you have any other questions or need help, feel free to open an issue on the GitHub repository.