Installation ~ TS3 Server Whitelist ~ Introduction ~ Examples ~ Changelog ~ Bugs ~ License
>> Click here to find out what's new in version 2.0.0. <<
This package provides a Python 3 API for
- TS3 query connections,
- TS3 query events,
- TS3 file transfers,
- the TS3 client query interface,
- and TS3 client events.
You can find a complete API documentation here.
import ts3
# Change the URI scheme from *ssh* to *telnet*, if your server does not
# support ssh.
with ts3.query.TS3ServerConnection("ssh://serveradmin:Z0YxRb7u@localhost:10022") as ts3conn:
# use sid=1
ts3conn.exec_("use", sid=1)
# clientlist -away -uid
clients = ts3conn.query("clientlist", "away", "uid").all()
This package is registered on PyPi, so you're done with:
$ pip3 install "ts3>=2.0.0b2" --upgrade
If you want to send lots of queries to the TS3 server, make sure, that you're
connection is not closed by the anti-flood protection of the TS3 server.
So it may be wise to add the host that runs the TS3 queries to the
query_ip_whitelist.txt
of your TS3 server:
$ echo "192.168.178.42" >> path/to/ts3/server/directory/query_ip_whitelist.txt
The easiest way to get to grips with this library is taking a look at the examples or simply read through the small ones in this README.
If you need information about the possible query commands, take a look at the TS3 Server Query Manual, which comes as a html file in the server installation folder, or at the TS3 Client Query Manual which is located in the client installation folder.
(Excerpt from the manual)
Query commands are made up of a command word, options and parameters (key-value pairs):
command key1=value1 key2=value2 key3=value3 -option1 -option1
This syntax translates into py-ts3 as follows:
ts3conn.exec_("command", "option1", "option2", key1=value1, key2=value2)
ts3conn.query("command", "option1", "option2", key1=value1, key2=value2).fetch()
The exec() method executes the command immediately and is often sufficient, while the query() method offers a slightly more sophisticated interface and supports pipelining:
# clientkick reasonid=5 reasonmsg=Go\saway! clid=1|clid=2|clid=3
resp = ts3conn.query("clientkick", reasonid=5, reasonmsg="Go away!")\
.pipe(clid=1).pipe(clid=2).pipe(clid=3).fetch()
# channellist -flags -icon
resp = ts3conn.query("channellist", "flags", "icon").fetch()
resp = ts3conn.query("channellist").options("flags", "icon").all()
resp = ts3conn.query("channellist").options("flags", "icon").first()
As a general rule of thumb, use exec_() if you don't need pipelining.
You can find more examples in the ts3.examples
package.
Show all clients on the virtual server with the server id 1:
#!/usr/bin/python3 import ts3 with ts3.query.TS3ServerConnection("telnet://serveradmin:Z0YxRb7u@localhost:10011") as ts3conn: ts3conn.exec_("use", sid=1) # exec_() returns a **TS3QueryResponse** instance with the response. resp = ts3conn.exec_("clientlist") print("Clients on the server:", resp.parsed) print("Error:", resp.error["id"], resp.error["msg"]) # Note, the TS3Response class and therefore the TS3QueryResponse # class too, can work as a rudimentary container. So, these two # commands are equal: for client in resp.parsed: print(client) for client in resp: print(client)
Say hello to all clients:
#!/usr/bin/python3 import ts3 with ts3.query.TS3ServerConnection("telnet://serveradmin:Z0YxRb7u@localhost:10011") as ts3conn: ts3conn.exec_("use", sid=1) for client in ts3conn.exec_("clientlist"): msg = "Hi {}".format(client["client_nickname"]) ts3conn.exec_("clientpoke", clid=client["clid"], msg=msg)
Event handling (Server Query):
#!/usr/bin/python3 import time import ts3 with ts3.query.TS3ServerConnection("telnet://serveradmin:Z0YxRb7u@localhost:10011") as ts3conn: ts3conn.exec_("use", sid=1) # Register for events ts3conn.exec_("servernotifyregister", event="server") while True: ts3conn.send_keepalive() try: event = ts3conn.wait_for_event(timeout=60) except ts3.query.TS3TimeoutError: pass else: # Greet new clients. if event[0]["reasonid"] == "0": print("client connected") ts3conn.exec_("clientpoke", clid=event[0]["clid"], msg="Hello :)")
A simple TS3 viewer:
#!/usr/bin/python3 import ts3 # The examples package already contains this implementation. # Note, that the examples.viewer module has an helpful class to # build a complete channel tree of a virtual server: ChannelTreeNode # # You may have to download it from GitHub first. from ts3_examples.viewer import view with ts3.query.TS3ServerConnection("telnet://serveradmin:Z0YxRb7u@localhost:10011") as ts3conn: view(ts3conn, sid=1)
Download and upload files:
#!/usr/bin/python3 import ts3 with ts3.query.TS3ServerConnection("telnet://serveradmin:Z0YxRb7u@localhost:10011") as ts3conn: ts3conn.exec_("use", sid=1) # Create a new TS3FileTransfer instance associated with the # TS3ServerConnection. ts3ft = ts3.filetransfer.TS3FileTransfer(ts3conn) # Upload the image *baz.png* to the channel with the id 2 on the # TS3 server. # Note the opening mode ("rb"). with open("baz.png", "rb") as file: ts3ft.init_upload(input_file=file, name="/baz.png", cid=2) # Download the file into *baz1.png*. with open("baz1.png", "wb") as file: ts3ft.init_download(output_file=file, name="/baz.png", cid=2)
Event handling (Client Query):
#!/usr/bin/python3 import time import ts3 with ts3.query.TS3ServerConnection("telnet://localhost:25639") as ts3conn: ts3conn.exec_("auth", apikey="AAAA-....-EEEE") # Register for events ts3conn.exec_("clientnotifyregister", event="any", schandlerid=0) while True: event = ts3conn.wait_for_event() print(event.parsed)
If you found a bug please report it or sent a pull request.
Please report grammar or spelling errors too.
For the version numbers, take a look at http://semver.org/.
This package is licensed under the MIT License.