2015-03-21 23:08:44 +01:00
|
|
|
Connecting to Servers
|
|
|
|
======================
|
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
.. module:: minecraft.networking.connection
|
2015-03-21 23:08:44 +01:00
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
Your primary dealings when connecting to a server will be with the Connection class
|
2015-03-21 23:08:44 +01:00
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
.. autoclass:: Connection
|
2015-03-21 23:08:44 +01:00
|
|
|
:members:
|
|
|
|
|
2015-03-22 15:59:49 +01:00
|
|
|
Writing Packets
|
2015-03-21 23:08:44 +01:00
|
|
|
~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The packet class uses a lot of magic to work, here is how to use them.
|
2016-12-19 11:26:12 +01:00
|
|
|
Look up the particular packet you need to deal with, for this example
|
2017-08-09 21:53:54 +02:00
|
|
|
let's go with the ``serverbound.play.KeepAlivePacket``
|
2015-03-21 23:08:44 +01:00
|
|
|
|
2017-08-09 21:53:54 +02:00
|
|
|
.. autoclass:: minecraft.networking.packets.serverbound.play.KeepAlivePacket
|
2015-03-22 15:59:49 +01:00
|
|
|
:undoc-members:
|
2015-03-21 23:08:44 +01:00
|
|
|
:inherited-members:
|
2016-12-19 11:26:12 +01:00
|
|
|
:exclude-members: read, write, context, get_definition, get_id, id, packet_name, set_values
|
2015-03-21 23:08:44 +01:00
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
Pay close attention to the definition attribute, and how our class variable corresponds to
|
|
|
|
the name given from the definition::
|
2015-03-21 23:08:44 +01:00
|
|
|
|
2017-08-09 21:53:54 +02:00
|
|
|
from minecraft.networking.packets import serverbound
|
|
|
|
packet = serverbound.play.KeepAlivePacket()
|
2015-03-21 23:08:44 +01:00
|
|
|
packet.keep_alive_id = random.randint(0, 5000)
|
|
|
|
connection.write_packet(packet)
|
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
and just like that, the packet will be written out to the server.
|
|
|
|
|
|
|
|
It is possible to implement your own custom packets by subclassing
|
2017-08-09 21:53:54 +02:00
|
|
|
:class:`minecraft.networking.packets.Packet`. Read the docstrings and in
|
|
|
|
packets.py and follow the examples in its subpackages for more details on
|
|
|
|
how to do advanced tasks like having a packet that is compatible across
|
|
|
|
multiple protocol versions.
|
2015-03-22 15:59:49 +01:00
|
|
|
|
|
|
|
Listening for Certain Packets
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2020-08-17 17:49:25 +02:00
|
|
|
Let's look at how to listen for certain packets, the relevant decorator being
|
|
|
|
|
|
|
|
A decorator can be used to register a packet listener:
|
|
|
|
|
|
|
|
.. autodecorator:: Connection.listener
|
|
|
|
|
|
|
|
Example usage::
|
|
|
|
|
|
|
|
connection = Connection(options.address, options.port, auth_token=auth_token)
|
|
|
|
connection.connect()
|
|
|
|
|
|
|
|
from minecraft.networking.packets.clientbound.play import ChatMessagePacket
|
|
|
|
|
|
|
|
@connection.listener(ChatMessagePacket)
|
|
|
|
def print_chat(chat_packet):
|
|
|
|
print "Position: " + str(chat_packet.position)
|
|
|
|
print "Data: " + chat_packet.json_data
|
|
|
|
|
|
|
|
|
|
|
|
Altenatively, packet listeners can also be registered seperate from the function definition.
|
2015-03-22 15:59:49 +01:00
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
.. automethod:: Connection.register_packet_listener
|
2015-03-22 15:59:49 +01:00
|
|
|
|
|
|
|
An example of this can be found in the ``start.py`` headless client, it is recreated here::
|
|
|
|
|
2016-12-19 11:26:12 +01:00
|
|
|
connection = Connection(options.address, options.port, auth_token=auth_token)
|
2015-03-22 15:59:49 +01:00
|
|
|
connection.connect()
|
|
|
|
|
|
|
|
def print_chat(chat_packet):
|
|
|
|
print "Position: " + str(chat_packet.position)
|
|
|
|
print "Data: " + chat_packet.json_data
|
|
|
|
|
2017-08-09 21:53:54 +02:00
|
|
|
from minecraft.networking.packets.clientbound.play import ChatMessagePacket
|
2015-03-22 15:59:49 +01:00
|
|
|
connection.register_packet_listener(print_chat, ChatMessagePacket)
|
|
|
|
|
|
|
|
The field names ``position`` and ``json_data`` are inferred by again looking at the definition attribute as before
|
|
|
|
|
2020-08-17 17:49:25 +02:00
|
|
|
|
2017-08-09 21:53:54 +02:00
|
|
|
.. autoclass:: minecraft.networking.packets.clientbound.play.ChatMessagePacket
|
2015-03-22 15:59:49 +01:00
|
|
|
:undoc-members:
|
|
|
|
:inherited-members:
|
2017-08-09 21:53:54 +02:00
|
|
|
:exclude-members: read, write, context, get_definition, get_id, id, packet_name, set_values
|