zulip/zerver/openapi/javascript_examples.js

378 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 channel 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 direct message
const user_id = 9;
params = {
to: [user_id],
type: "direct",
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: "channel", operand: "Verona"},
],
};
// Get the 100 last messages sent by "iago@zulip.com" to the channel "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 channel
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 channel 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 channels 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 typing in the group direct message
// 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 channels "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 channel, 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 channel "Denmark"
const meParams = {
subscriptions: JSON.stringify(["Denmark"]),
};
console.log(await client.users.me.subscriptions.remove(meParams));
const user_id = 7;
// Unsubscribe Zoe from the channel "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 = [];
for (let i = 0; i < 3; i += 1) {
message_ids.push(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 channels that the user has access to
console.log(await client.streams.retrieve());
// {code_example|end}
});
main();