@com1killer/hackmud-chat-api

A client for the Hackmud Chat API.

Usage no npm install needed!

<script type="module">
  import com1killerHackmudChatApi from 'https://cdn.skypack.dev/@com1killer/hackmud-chat-api';
</script>

README

hackmud-chat-api

A client for the Hackmud Chat API.

Additional docs for the chat API

Installation

npm i -s @com1killer/hackmud-chat-api for module use

npm i -g @com1killer/hackmud-chat-api for CLI use

CLI Usage

hm-pass2token <chat pass>
Converts your chat pass to a chat token.

Usage example

var HackmudChatAPI = require("@com1killer/hackmud-chat-api");
var chat = new HackmudChatAPI("YOUR_CHAT_TOKEN_OR_CHAT_PASS");
console.log(chat.token);

chat.on("poll", function pollHandler(messages) { // When messages are polled
    let cleanMessages = messages.filter(message => message.to_user == "my_bot_user" && messages.to_user != messages.from_user); // Filter messages. Only messages sent to bot user remains, and echo is removed.

    messages.forEach(message => { // For every message
        chat.tell("my_bot_user", "my_user", message.from_user + " said:\n" + message.msg); // Relay message to another user
    })
});

Reference

new HackmudChatAPI

Creates a HackmudChatAPI instance. Converts chat pass into chat token if needed, does initial account sync, and sets up timers.

Arguments:

  • tokenOrPass: Chat token or chat pass. If chat pass, it will be converted to chat token.
  • pollInterval: Polling frequency in milliseconds. Must be over 700ms to avoid ratelimits. Recommended to be over 2s. Default: 2s
  • accountSyncInterval: Account sync (updated usernames) frequency in milliseconds. Must be over 5s to avoid ratelimits, but a much bigger frequency is enough. Default: 30m
  • url: URL of Chat API. Doesn't need to be touched. Default: "https://www.hackmud.com/mobile"

Properties

  • token: Chat token.
  • users: An object of users, where the user is the key, and an array of their joined channels is the value.
  • lastPoll: The JS timestamp of the last poll.

on

Adds an event handler.

Arguments:

  • name: Name of event. (poll, error, accountSync)
  • handler: Event handler. Argument:
    • poll: An array of messages.
    • error: An error.
    • accountSync: An object of users, where the user is the key, and an array of their joined channels is the value.

supervise

Adds an event handler for every event.

Arguments:

  • handler: Event handler. See argument above.

send

Sends a message to a channel.

Arguments:

  • from: Username to send the message from.
  • channel: Channel to send the message to.
  • message: Message to send.

Returns:

  • ok: Success?

tell

Sends a tell to a user.

Arguments:

  • from: Username to send the message from.
  • to: Username to send the message to.
  • message: Message to send.

Returns:

  • ok: Success?

destroy

Destroys HackmudChatAPI instance.

Message

A message object.

Properties:

  • id: Message ID
  • t: JS timestamp of message
  • from_user: Username of sender
  • msg: Message
  • is_join: Whether the chat message is a channel join, not present if false
  • is_leave: Whether the chat message is a channel leave, not present if false
  • channel: Channel of message, not present in tells
  • to_user: Username of recipient