mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			377 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			377 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
"use strict";
 | 
						|
 | 
						|
/*
 | 
						|
  Zulip's OpenAPI-based API documentation system is documented at
 | 
						|
  https://zulip.readthedocs.io/en/latest/documentation/api.html
 | 
						|
 | 
						|
  This file contains example code fenced off by comments, and is
 | 
						|
  designed to be run as part of Zulip's test-api test suite to verify
 | 
						|
  that the documented examples are all correct, runnable code.
 | 
						|
*/
 | 
						|
 | 
						|
const examples_handler = function () {
 | 
						|
    const config = {
 | 
						|
        username: process.env.ZULIP_USERNAME,
 | 
						|
        apiKey: process.env.ZULIP_API_KEY,
 | 
						|
        realm: process.env.ZULIP_REALM,
 | 
						|
    };
 | 
						|
    const examples = {};
 | 
						|
    const response_data = [];
 | 
						|
 | 
						|
    const make_result_object = (example, result, count = false) => {
 | 
						|
        const name = count !== false ? `${example.name}_${count}` : example.name;
 | 
						|
        return {
 | 
						|
            name,
 | 
						|
            endpoint: example.endpoint.split(":")[0],
 | 
						|
            method: example.endpoint.split(":")[1],
 | 
						|
            status_code: example.status_code.toString(),
 | 
						|
            result,
 | 
						|
        };
 | 
						|
    };
 | 
						|
 | 
						|
    const generate_validation_data = async (client, example) => {
 | 
						|
        let count = 0;
 | 
						|
        const console = {
 | 
						|
            log(result) {
 | 
						|
                response_data.push(make_result_object(example, result, count));
 | 
						|
                count += 1;
 | 
						|
            },
 | 
						|
        };
 | 
						|
        await example.func(client, console);
 | 
						|
    };
 | 
						|
 | 
						|
    const main = async () => {
 | 
						|
        const zulipInit = require("zulip-js");
 | 
						|
        const client = await zulipInit(config);
 | 
						|
 | 
						|
        await generate_validation_data(client, examples.send_message);
 | 
						|
        await generate_validation_data(client, examples.create_user);
 | 
						|
        await generate_validation_data(client, examples.get_custom_emoji);
 | 
						|
        await generate_validation_data(client, examples.delete_queue);
 | 
						|
        await generate_validation_data(client, examples.get_messages);
 | 
						|
        await generate_validation_data(client, examples.get_own_user);
 | 
						|
        await generate_validation_data(client, examples.get_stream_id);
 | 
						|
        await generate_validation_data(client, examples.get_stream_topics);
 | 
						|
        await generate_validation_data(client, examples.get_subscriptions);
 | 
						|
        await generate_validation_data(client, examples.get_users);
 | 
						|
        await generate_validation_data(client, examples.register_queue);
 | 
						|
        await generate_validation_data(client, examples.render_message);
 | 
						|
        await generate_validation_data(client, examples.set_typing_status);
 | 
						|
        await generate_validation_data(client, examples.add_subscriptions);
 | 
						|
        await generate_validation_data(client, examples.remove_subscriptions);
 | 
						|
        await generate_validation_data(client, examples.update_message_flags);
 | 
						|
        await generate_validation_data(client, examples.update_message);
 | 
						|
        await generate_validation_data(client, examples.get_events);
 | 
						|
        await generate_validation_data(client, examples.get_streams);
 | 
						|
 | 
						|
        console.log(JSON.stringify(response_data));
 | 
						|
        return;
 | 
						|
    };
 | 
						|
 | 
						|
    const add_example = (name, endpoint, status_code, func) => {
 | 
						|
        const example = {
 | 
						|
            name,
 | 
						|
            endpoint,
 | 
						|
            status_code,
 | 
						|
            func,
 | 
						|
        };
 | 
						|
        examples[name] = example;
 | 
						|
    };
 | 
						|
 | 
						|
    return {
 | 
						|
        main,
 | 
						|
        add_example,
 | 
						|
    };
 | 
						|
};
 | 
						|
 | 
						|
const {main, add_example} = examples_handler();
 | 
						|
 | 
						|
const send_test_message = async (client) => {
 | 
						|
    const params = {
 | 
						|
        to: "Verona",
 | 
						|
        type: "stream",
 | 
						|
        topic: "Castle",
 | 
						|
        // Use some random text for easier debugging if needed. We don't
 | 
						|
        // depend on the content of these messages for the tests.
 | 
						|
        content: `Random test message ${Math.random()}`,
 | 
						|
    };
 | 
						|
    const result = await client.messages.send(params);
 | 
						|
    // Only return the message id.
 | 
						|
    return result.id;
 | 
						|
};
 | 
						|
 | 
						|
// Declare all the examples below.
 | 
						|
 | 
						|
add_example("send_message", "/messages:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Send a stream message
 | 
						|
    let params = {
 | 
						|
        to: "social",
 | 
						|
        type: "stream",
 | 
						|
        topic: "Castle",
 | 
						|
        content: "I come not, friends, to steal away your hearts.",
 | 
						|
    };
 | 
						|
    console.log(await client.messages.send(params));
 | 
						|
 | 
						|
    // Send a private message
 | 
						|
    const user_id = 9;
 | 
						|
    params = {
 | 
						|
        to: [user_id],
 | 
						|
        type: "private",
 | 
						|
        content: "With mirth and laughter let old wrinkles come.",
 | 
						|
    };
 | 
						|
    console.log(await client.messages.send(params));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("create_user", "/users:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    const params = {
 | 
						|
        email: "notnewbie@zulip.com",
 | 
						|
        password: "temp",
 | 
						|
        full_name: "New User",
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.users.create(params));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_custom_emoji", "/realm/emoji:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    console.log(await client.emojis.retrieve());
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("delete_queue", "/events:delete", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Register a queue
 | 
						|
    const queueParams = {
 | 
						|
        event_types: ["message"],
 | 
						|
    };
 | 
						|
    const res = await client.queues.register(queueParams);
 | 
						|
 | 
						|
    // Delete a queue
 | 
						|
    const deregisterParams = {
 | 
						|
        queue_id: res.queue_id,
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.queues.deregister(deregisterParams));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_messages", "/messages:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    const readParams = {
 | 
						|
        anchor: "newest",
 | 
						|
        num_before: 100,
 | 
						|
        num_after: 0,
 | 
						|
        narrow: [
 | 
						|
            {operator: "sender", operand: "iago@zulip.com"},
 | 
						|
            {operator: "stream", operand: "Verona"},
 | 
						|
        ],
 | 
						|
    };
 | 
						|
 | 
						|
    // Get the 100 last messages sent by "iago@zulip.com" to the stream "Verona"
 | 
						|
    console.log(await client.messages.retrieve(readParams));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_own_user", "/users/me:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Get the profile of the user/bot that requests this endpoint,
 | 
						|
    // which is `client` in this case:
 | 
						|
    console.log(await client.users.me.getProfile());
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_stream_id", "/get_stream_id:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Get the ID of a given stream
 | 
						|
    console.log(await client.streams.getStreamId("Denmark"));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example(
 | 
						|
    "get_stream_topics",
 | 
						|
    "/users/me/{stream_id}/topics:get",
 | 
						|
    200,
 | 
						|
    async (client, console) => {
 | 
						|
        // {code_example|start}
 | 
						|
        // Get all the topics in stream with ID 1
 | 
						|
        console.log(await client.streams.topics.retrieve({stream_id: 1}));
 | 
						|
        // {code_example|end}
 | 
						|
    },
 | 
						|
);
 | 
						|
 | 
						|
add_example("get_subscriptions", "/users/me/subscriptions:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Get all streams that the user is subscribed to
 | 
						|
    console.log(await client.streams.subscriptions.retrieve());
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_users", "/users:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Get all users in the realm
 | 
						|
    console.log(await client.users.retrieve());
 | 
						|
 | 
						|
    // You may pass the `client_gravatar` query parameter as follows:
 | 
						|
    console.log(await client.users.retrieve({client_gravatar: true}));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("register_queue", "/register:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Register a queue
 | 
						|
    const params = {
 | 
						|
        event_types: ["message"],
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.queues.register(params));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("render_message", "/messages/render:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Render a message
 | 
						|
    const params = {
 | 
						|
        content: "**foo**",
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.messages.render(params));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("set_typing_status", "/typing:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    const user_id1 = 9;
 | 
						|
    const user_id2 = 10;
 | 
						|
 | 
						|
    const typingParams = {
 | 
						|
        op: "start",
 | 
						|
        to: [user_id1, user_id2],
 | 
						|
    };
 | 
						|
 | 
						|
    // The user has started to type in the group PM with Iago and Polonius
 | 
						|
    console.log(await client.typing.send(typingParams));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("add_subscriptions", "/users/me/subscriptions:post", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Subscribe to the streams "Verona" and "Denmark"
 | 
						|
    const meParams = {
 | 
						|
        subscriptions: JSON.stringify([{name: "Verona"}, {name: "Denmark"}]),
 | 
						|
    };
 | 
						|
    console.log(await client.users.me.subscriptions.add(meParams));
 | 
						|
 | 
						|
    // To subscribe another user to a stream, you may pass in
 | 
						|
    // the `principals` parameter, like so:
 | 
						|
    const user_id = 7;
 | 
						|
    const anotherUserParams = {
 | 
						|
        subscriptions: JSON.stringify([{name: "Verona"}, {name: "Denmark"}]),
 | 
						|
        principals: JSON.stringify([user_id]),
 | 
						|
    };
 | 
						|
    console.log(await client.users.me.subscriptions.add(anotherUserParams));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example(
 | 
						|
    "remove_subscriptions",
 | 
						|
    "/users/me/subscriptions:delete",
 | 
						|
    200,
 | 
						|
    async (client, console) => {
 | 
						|
        // {code_example|start}
 | 
						|
        // Unsubscribe from the stream "Denmark"
 | 
						|
        const meParams = {
 | 
						|
            subscriptions: JSON.stringify(["Denmark"]),
 | 
						|
        };
 | 
						|
        console.log(await client.users.me.subscriptions.remove(meParams));
 | 
						|
 | 
						|
        const user_id = 7;
 | 
						|
        // Unsubscribe Zoe from the stream "Denmark"
 | 
						|
        const zoeParams = {
 | 
						|
            subscriptions: JSON.stringify(["Denmark"]),
 | 
						|
            principals: JSON.stringify([user_id]),
 | 
						|
        };
 | 
						|
        console.log(await client.users.me.subscriptions.remove(zoeParams));
 | 
						|
        // {code_example|end}
 | 
						|
    },
 | 
						|
);
 | 
						|
 | 
						|
add_example("update_message_flags", "/messages/flags:post", 200, async (client, console) => {
 | 
						|
    // Send 3 messages to run this example on
 | 
						|
    const message_ids = [...Array.from({length: 3})];
 | 
						|
    for (let i = 0; i < message_ids.length; i = i + 1) {
 | 
						|
        message_ids[i] = await send_test_message(client);
 | 
						|
    }
 | 
						|
 | 
						|
    // {code_example|start}
 | 
						|
    // Add the "read" flag to the messages with IDs in "message_ids"
 | 
						|
    const addflag = {
 | 
						|
        messages: message_ids,
 | 
						|
        flag: "read",
 | 
						|
    };
 | 
						|
    console.log(await client.messages.flags.add(addflag));
 | 
						|
 | 
						|
    // Remove the "starred" flag from the messages with IDs in "message_ids"
 | 
						|
    const removeflag = {
 | 
						|
        messages: message_ids,
 | 
						|
        flag: "starred",
 | 
						|
    };
 | 
						|
    console.log(await client.messages.flags.remove(removeflag));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("update_message", "/messages/{message_id}:patch", 200, async (client, console) => {
 | 
						|
    const request = {
 | 
						|
        to: "Denmark",
 | 
						|
        type: "stream",
 | 
						|
        topic: "Castle",
 | 
						|
        content: "I come not, friends, to steal away your hearts.",
 | 
						|
    };
 | 
						|
    const result = await client.messages.send(request);
 | 
						|
    const message_id = result.id;
 | 
						|
 | 
						|
    // {code_example|start}
 | 
						|
    // Update a message with the given "message_id"
 | 
						|
    const params = {
 | 
						|
        message_id,
 | 
						|
        content: "New Content",
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.messages.update(params));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_events", "/events:get", 200, async (client, console) => {
 | 
						|
    // Register queue to receive messages for user.
 | 
						|
    const queueParams = {
 | 
						|
        event_types: ["message"],
 | 
						|
    };
 | 
						|
    const res = await client.queues.register(queueParams);
 | 
						|
    const queue_id = res.queue_id;
 | 
						|
    // For setup, we send a message to ensure there are events in the
 | 
						|
    // queue; this lets the automated tests complete quickly.
 | 
						|
    await send_test_message(client);
 | 
						|
 | 
						|
    // {code_example|start}
 | 
						|
    // Retrieve events from a queue with given "queue_id"
 | 
						|
    const eventParams = {
 | 
						|
        queue_id,
 | 
						|
        last_event_id: -1,
 | 
						|
    };
 | 
						|
 | 
						|
    console.log(await client.events.retrieve(eventParams));
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
add_example("get_streams", "/streams:get", 200, async (client, console) => {
 | 
						|
    // {code_example|start}
 | 
						|
    // Get all streams that the user has access to
 | 
						|
    console.log(await client.streams.retrieve());
 | 
						|
    // {code_example|end}
 | 
						|
});
 | 
						|
 | 
						|
main();
 |