Others
WebSockets

WebSockets

⚠️

WebSockets is a feature reserved for founder members and, in the future, for subscribers.

WebSockets allow you to receive real-time notifications from the server.

Notifications supported:

NameSubscription codeCategoryTypeDescripiton
Event spawnevent_spawnEventsServerSend ActiveEventSchema when an event spawn.
Event removedevent_removedEventsServerSend ActiveEventSchema when an event expires and is removed.
Grand Exchange new ordergrandexchange_neworderGrand ExchangeServerSend GEOrderSchema when a sales order is created on the Grand Exchange
Grand Exchange sellgrandexchange_sellGrand ExchangeServerSend GeOrderHistorySchema when a sale is made on the Grand Exchange.
Achievement unlockachievement_unlockedAchievementsAccountSend AchievementSchema when an achievement is unlocked on your account.
TesttestTestTestSend Test message every 60 seconds.

How does it work?

The WebSocket server is: wss://realtime.artifactsmmo.com

Next, you need to include your token and the types of notifications you want to receive in the first message you send to the server.

message = {
        "token": token,
        "subscriptions": ["event_spawn", "event_removed", "grandexchange_neworder", "grandexchange_sell", "achievement_unlocked"]
    }    

If you want to receive all notifications, you don't need to include subscriptions.

Examples

Python
import asyncio
import websockets
import json
 
url = "wss://realtime.artifactsmmo.com"
token ="YOUR_TOKEN" # Replace with your  token
 
message = {
        "token": token,
        "subscriptions": ["event_spawn", "event_removed", "grandexchange_neworder", "grandexchange_sell", "achievement_unlocked"]
    }    
 
async def receive_messages():
 
    async with websockets.connect(url) as websocket:
        await websocket.send(json.dumps(message))
        
        print("Connected to the WebSocket server")
        try:
            while True:
               # Waits for a message from the server
                message_received = await websocket.recv()
                message_received = json.loads(message_received)
 
                print(f"Message received: {message_received}")
        except websockets.ConnectionClosed:
            print("Connection closed by the server")
 
 
 
# Start the WebSocket client
asyncio.run(receive_messages())
Javascript
const WebSocket = require('ws');
 
const url = "wss://realtime.artifactsmmo.com";
const token = "YOUR_TOKEN"; // Replace with your token
 
const message = {
    token: token,
    subscriptions: ["event_new", "grandexchange_sell", "my_grandexchange_sell", "grandexchange_neworder"]
};
 
async function receiveMessages() {
    const websocket = new WebSocket(url);
 
    websocket.on('open', () => {
        websocket.send(JSON.stringify(message));
        console.log("Connected to the WebSocket server");
    });
 
    websocket.on('message', (data) => {
        const messageReceived = JSON.parse(data);
        console.log("Message received:", messageReceived);
    });
 
    websocket.on('close', () => {
        console.log("Connection closed by the server");
    });
 
    websocket.on('error', (error) => {
        console.error("WebSocket error:", error);
    });
}
 
// Start the WebSocket client
receiveMessages();
Java
<dependency>
    <groupId>org.java-websocket</groupId>
    <artifactId>Java-WebSocket</artifactId>
    <version>1.5.7</version>
</dependency>
 
public class WebSocketHandler extends WebSocketClient {
 
    public WebSocketHandler(URI serverUri) {
        super(serverUri);
    }
 
    @Override
    public void onOpen(ServerHandshake handshakedata) {
        String message = """
        {"token": "%s",
        "subscriptions": ["event_spawn", "event_removed,"grandexchange_sell", "grandexchange_neworder", "achievement_unlocked"]};
        """.formatted(TOKEN);
        send(message);
        System.out.println("Connected to WebSocket server");
    }
 
    @Override
    public void onMessage(String message) {
        System.out.println("Received message: " + message);
    }
 
    @Override
    public void onClose(int code, String reason, boolean remote) {
        System.out.println("Disconnected from WebSocket server: " + reason);
    }
 
    @Override
    public void onError(Exception ex) {
        System.err.println("WebSocket error: " + ex.getMessage());
    }
 
    public static void main(String[] args){
        try {
            WebSocketHandler client = new WebSocketHandler(new URI("wss://realtime.artifactsmmo.com"));
            client.connectBlocking();
        } catch (URISyntaxException | InterruptedException e) {
            e.printStackTrace();
        }
    }
}

Server responses

Server messages always include notification type and data. Data is always the same schema returned by the API if possible.

Here's an example of a server message:

{
  'type': 'grandexchange_neworder', 
  'data': '{"id":"67337920ef441b2c7466d5e8","seller":"muigetsu","code":"copper_ore","quantity":1,"price":1,"created_at":"2024-11-12T15:49:52.343Z"}'
}