initial commit, super basic implementation

This commit is contained in:
2026-04-08 14:47:36 -05:00
commit 7e956ccf2b
3 changed files with 61 additions and 0 deletions
+1
View File
@@ -0,0 +1 @@
TypeScript client for Tether
+48
View File
@@ -0,0 +1,48 @@
const subscribedQueries = new Map<string, (data: any) => void>();
let ws: WebSocket | null = null;
export const connect = async (url: string): Promise<WebSocket> => {
ws = new WebSocket(url);
ws.onopen = () => {
console.log('Connected to Tether');
};
ws.onmessage = (event) => {
const data = JSON.parse(event.data);
if (data.type === 'query') {
subscribedQueries.forEach((callback, query) => {
if (data.query === query) {
callback(data.data);
}
});
} else if (data.type === 'error') {
console.error(data.error);
}
};
ws.onclose = () => {
console.log('Disconnected from Tether');
};
return ws;
};
export const disconnect = (ws: WebSocket) => {
ws.close();
};
export const subscribe = (query: string, callback: (data: any) => void) => {
subscribedQueries.set(query, callback);
};
export const unsubscribe = (query: string) => {
subscribedQueries.delete(query);
};
export const sendMutation = (mutationName: string, params: any) => {
if (!ws) {
throw new Error('Not connected to Tether');
}
ws.send(JSON.stringify({
type: 'mutation',
name: mutationName,
payload: params,
}));
};
+12
View File
@@ -0,0 +1,12 @@
{
"name": "tether-ts",
"version": "1.0.0",
"description": "TypeScript client for Tether",
"license": "ISC",
"author": "wisplite",
"type": "module",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
}
}