zulip/templates/zerver/help/add-a-bot-or-integration.md

64 lines
2.7 KiB
Markdown
Raw Normal View History

# Add a bot or integration
Bots and integrations are features that are accessible to all members of an organization.
## Add a bot
2018-04-11 23:35:24 +02:00
1. Go to the [Your bots](/#settings/your-bots)
{!settings.md!}
2. On this page, under the **Add a new bot** view, enter the bot type,
a name, an email, and optionally an avatar for your bot.
Then click the **Create bot** button to create your bot.
![Bots page](/static/images/help/add_a_new_bot.png)
2017-01-17 02:42:23 +01:00
3. An entry such as the following should appear above the **Add a new bot** view, confirming
the creation of your bot.
![Example bot](/static/images/help/bot_example.png)
4. You now have access to your bot's API key and API
configuration file (`.zuliprc`) which you will need for integrations that you would like
to use with this bot. You can click on the download
(<i class="icon-vector-download-alt"></i>) icon to download your `.zuliprc` file.
### Bot types
You can create three types of bots:
![Bot types](/static/images/help/bot_types.png)
* **Generic bot:** A generic bot can send *and* receive messages.
2017-08-22 14:47:18 +02:00
Choose this type if you want to:
* *test* and deploy a simple Python bot using the [Zulip bots](
https://github.com/zulip/python-zulip-api/tree/master/zulip_bots) framework.
* interact with Zulip using the [Zulip Python API](
https://github.com/zulip/python-zulip-api/tree/master/zulip).
* **Incoming webhook:** The API keys for such bots are limited to
only sending messages and can't receive messages. Thus, this bot
type lessens the security risks associated with exposing such API
2017-08-22 14:47:18 +02:00
keys to third-party services.
Choose this type if you want to:
* deploy one of our [integrations](/integrations).
* develop your own integration that posts to Zulip. Note that
`Incoming Webhook` integrations can only be developed in the [Zulip repository](
https://github.com/zulip/zulip/tree/master/zerver/webhooks).
* **Outgoing webhook:** Bots of this type are the same as a **Generic bot**,
except **Outgoing webhooks** bots have an extra field for the Endpoint URL of the
2017-08-22 14:47:18 +02:00
third-party service being requested. **Outgoing webhook** bots send POST requests
to this Endpoint URL.
2017-08-22 14:47:18 +02:00
Choose this type if you want to:
* make Zulip post messages to a URL.
* deploy Zulip's [botserver](https://github.com/zulip/python-zulip-api/tree/master/zulip_botserver).
*This is the default way of deploying bots used in production.*
## Add an integration
The [Integrations page](/integrations) offers a complete list of all the
integrations currently supported by Zulip. To add an integration to your
organization, select the integration that you would like to use from the list
and follow the installation instructions accordingly.