2012-11-27 17:19:05 +01:00
|
|
|
#### Dependencies
|
|
|
|
|
2013-11-17 22:46:15 +01:00
|
|
|
The [Zulip API](https://zulip.com/api) Python bindings require the
|
|
|
|
following Python libraries:
|
2012-11-26 17:54:21 +01:00
|
|
|
|
2013-04-09 21:53:22 +02:00
|
|
|
* requests (version >= 0.12.1)
|
2016-12-14 07:15:22 +01:00
|
|
|
* simplejson
|
|
|
|
* six
|
|
|
|
* typing (version >= 3.5.2.2)
|
2013-01-31 21:58:34 +01:00
|
|
|
|
|
|
|
#### Installing
|
|
|
|
|
|
|
|
This package uses distutils, so you can just run:
|
|
|
|
|
|
|
|
python setup.py install
|
|
|
|
|
2012-11-27 17:19:05 +01:00
|
|
|
#### Using the API
|
|
|
|
|
|
|
|
For now, the only fully supported API operation is sending a message.
|
|
|
|
The other API queries work, but are under active development, so
|
|
|
|
please make sure we know you're using them so that we can notify you
|
|
|
|
as we make any changes to them.
|
|
|
|
|
|
|
|
The easiest way to use these API bindings is to base your tools off
|
2013-01-31 21:58:34 +01:00
|
|
|
of the example tools under examples/ in this distribution.
|
2012-11-27 17:19:05 +01:00
|
|
|
|
2013-08-07 17:36:46 +02:00
|
|
|
If you place your API key in the config file `~/.zuliprc` the Python
|
2013-02-05 22:00:00 +01:00
|
|
|
API bindings will automatically read it in. The format of the config
|
|
|
|
file is as follows:
|
2012-12-12 21:04:12 +01:00
|
|
|
|
|
|
|
[api]
|
|
|
|
key=<api key from the web interface>
|
|
|
|
email=<your email address>
|
2015-08-21 18:34:54 +02:00
|
|
|
site=<your Zulip server's URI>
|
2015-10-20 20:28:03 +02:00
|
|
|
insecure=<true or false, true means do not verify the server certificate>
|
|
|
|
cert_bundle=<path to a file containing CA or server certificates to trust>
|
|
|
|
|
|
|
|
If omitted, these settings have the following defaults:
|
|
|
|
|
|
|
|
insecure=false
|
|
|
|
cert_bundle=<the default CA bundle trusted by Python>
|
2013-12-04 21:17:18 +01:00
|
|
|
|
2016-12-14 07:15:22 +01:00
|
|
|
Alternatively, you may explicitly use "--user", "--api-key", and
|
|
|
|
`--site` in our examples, which is especially useful when testing. If
|
|
|
|
you are running several bots which share a home directory, we
|
|
|
|
recommend using `--config` to specify the path to the `zuliprc` file
|
|
|
|
for a specific bot.
|
2015-10-20 20:28:03 +02:00
|
|
|
|
|
|
|
The command line equivalents for other configuration options are:
|
|
|
|
|
|
|
|
--insecure
|
|
|
|
--cert-bundle=<file>
|
2013-05-29 20:00:27 +02:00
|
|
|
|
2013-08-06 21:32:15 +02:00
|
|
|
You can obtain your Zulip API key, create bots, and manage bots all
|
2016-12-14 07:15:22 +01:00
|
|
|
from your Zulip settings page; with current Zulip there's also a
|
|
|
|
button to download a `zuliprc` file for your account/server pair.
|
2012-11-27 17:19:05 +01:00
|
|
|
|
|
|
|
A typical simple bot sending API messages will look as follows:
|
|
|
|
|
|
|
|
At the top of the file:
|
|
|
|
|
2013-08-06 21:32:15 +02:00
|
|
|
# Make sure the Zulip API distribution's root directory is in sys.path, then:
|
2013-08-07 17:51:03 +02:00
|
|
|
import zulip
|
2013-12-06 23:50:55 +01:00
|
|
|
zulip_client = zulip.Client(email="your-bot@example.com", client="MyTestClient/0.1")
|
2012-11-27 17:19:05 +01:00
|
|
|
|
|
|
|
When you want to send a message:
|
|
|
|
|
|
|
|
message = {
|
|
|
|
"type": "stream",
|
|
|
|
"to": ["support"],
|
|
|
|
"subject": "your subject",
|
|
|
|
"content": "your content",
|
|
|
|
}
|
2013-08-07 17:51:03 +02:00
|
|
|
zulip_client.send_message(message)
|
2012-11-27 17:19:05 +01:00
|
|
|
|
2016-12-14 07:15:22 +01:00
|
|
|
If you are parsing arguments, you may find it useful to use Zulip's
|
|
|
|
option group; see any of our API examples for details on how to do this.
|
|
|
|
|
2012-11-27 17:19:05 +01:00
|
|
|
Additional examples:
|
|
|
|
|
2013-08-06 21:32:15 +02:00
|
|
|
client.send_message({'type': 'stream', 'content': 'Zulip rules!',
|
2012-11-27 17:19:05 +01:00
|
|
|
'subject': 'feedback', 'to': ['support']})
|
2013-08-06 21:32:15 +02:00
|
|
|
client.send_message({'type': 'private', 'content': 'Zulip rules!',
|
2012-11-27 17:19:05 +01:00
|
|
|
'to': ['user1@example.com', 'user2@example.com']})
|
|
|
|
|
|
|
|
send_message() returns a dict guaranteed to contain the following
|
|
|
|
keys: msg, result. For successful calls, result will be "success" and
|
|
|
|
msg will be the empty string. On error, result will be "error" and
|
|
|
|
msg will describe what went wrong.
|
2012-12-12 21:04:12 +01:00
|
|
|
|
2016-12-14 07:15:22 +01:00
|
|
|
#### Examples
|
|
|
|
|
|
|
|
The API bindings package comes with several nice example scripts that
|
|
|
|
show how to use the APIs; they are installed as part of the API
|
|
|
|
bindings bundle.
|
|
|
|
|
2013-10-30 20:56:43 +01:00
|
|
|
#### Logging
|
2016-12-14 07:15:22 +01:00
|
|
|
|
2013-10-30 20:56:43 +01:00
|
|
|
The Zulip API comes with a ZulipStream class which can be used with the
|
|
|
|
logging module:
|
|
|
|
|
|
|
|
```
|
|
|
|
import zulip
|
|
|
|
import logging
|
|
|
|
stream = zulip.ZulipStream(type="stream", to=["support"], subject="your subject")
|
|
|
|
logger = logging.getLogger("your_logger")
|
|
|
|
logger.addHandler(logging.StreamHandler(stream))
|
|
|
|
logger.setLevel(logging.DEBUG)
|
|
|
|
logger.info("This is an INFO test.")
|
|
|
|
logger.debug("This is a DEBUG test.")
|
|
|
|
logger.warn("This is a WARN test.")
|
|
|
|
logger.error("This is a ERROR test.")
|
|
|
|
```
|
|
|
|
|
2012-12-12 21:04:12 +01:00
|
|
|
#### Sending messages
|
|
|
|
|
2013-08-07 17:52:53 +02:00
|
|
|
You can use the included `zulip-send` script to send messages via the
|
2012-12-12 21:04:12 +01:00
|
|
|
API directly from existing scripts.
|
|
|
|
|
2013-08-07 17:52:53 +02:00
|
|
|
zulip-send hamlet@example.com cordelia@example.com -m \
|
2012-12-12 21:04:12 +01:00
|
|
|
"Conscience doth make cowards of us all."
|
2013-05-29 20:00:27 +02:00
|
|
|
|
2013-08-07 17:36:46 +02:00
|
|
|
Alternatively, if you don't want to use your ~/.zuliprc file:
|
2013-05-29 20:00:27 +02:00
|
|
|
|
2013-08-07 17:52:53 +02:00
|
|
|
zulip-send --user shakespeare-bot@example.com \
|
2013-05-29 20:00:27 +02:00
|
|
|
--api-key a0b1c2d3e4f5a6b7c8d9e0f1a2b3c4d5 \
|
2016-12-14 07:15:22 +01:00
|
|
|
--site https://zulip.example.com \
|
2013-05-29 20:00:27 +02:00
|
|
|
hamlet@example.com cordelia@example.com -m \
|
|
|
|
"Conscience doth make cowards of us all."
|
2015-10-20 20:28:03 +02:00
|
|
|
|
|
|
|
#### Working with an untrusted server certificate
|
|
|
|
|
|
|
|
If your server has either a self-signed certificate, or a certificate signed
|
|
|
|
by a CA that you don't wish to globally trust then by default the API will
|
|
|
|
fail with an SSL verification error.
|
|
|
|
|
|
|
|
You can add `insecure=true` to your .zuliprc file.
|
|
|
|
|
|
|
|
[api]
|
|
|
|
site=https://zulip.example.com
|
|
|
|
insecure=true
|
|
|
|
|
|
|
|
This disables verification of the server certificate, so connections are
|
|
|
|
encrypted but unauthenticated. This is not secure, but may be good enough
|
|
|
|
for a development environment.
|
|
|
|
|
|
|
|
|
|
|
|
You can explicitly trust the server certificate using `cert_bundle=<filename>`
|
|
|
|
in your .zuliprc file.
|
|
|
|
|
|
|
|
[api]
|
|
|
|
site=https://zulip.example.com
|
|
|
|
cert_bundle=/home/bots/certs/zulip.example.com.crt
|
|
|
|
|
|
|
|
You can also explicitly trust a different set of Certificate Authorities from
|
|
|
|
the default bundle that is trusted by Python. For example to trust a company
|
|
|
|
internal CA.
|
|
|
|
|
|
|
|
[api]
|
|
|
|
site=https://zulip.example.com
|
|
|
|
cert_bundle=/home/bots/certs/example.com.ca-bundle
|
|
|
|
|
|
|
|
Save the server certificate (or the CA certificate) in its own file,
|
|
|
|
converting to PEM format first if necessary.
|
|
|
|
Verify that the certificate you have saved is the same as the one on the
|
|
|
|
server.
|
|
|
|
|
|
|
|
The `cert_bundle` option trusts the server / CA certificate only for
|
|
|
|
interaction with the zulip site, and is relatively secure.
|
|
|
|
|
|
|
|
Note that a certificate bundle is merely one or more certificates combined
|
|
|
|
into a single file.
|