Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mumble-voip/mumble.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorStefan Hacker <dd0t@users.sourceforge.net>2010-01-24 18:36:50 +0300
committerStefan Hacker <dd0t@users.sourceforge.net>2010-01-24 18:44:40 +0300
commite54854686f98f9a5b0ba4f0150b97754893a9103 (patch)
tree9ea297ba80726b412ceb026ba9af3535a46aef25 /doc
parent2322bec99036ca57c51f8a5b8a99681e59c0440a (diff)
Initial import of WIP mumble protocol description
Diffstat (limited to 'doc')
-rw-r--r--doc/mumble-protocol.pdfbin0 -> 278836 bytes
-rw-r--r--doc/mumble-protocol.tex192
-rw-r--r--doc/resources/mumble_connection_setup.odgbin0 -> 14226 bytes
-rw-r--r--doc/resources/mumble_connection_setup.pdfbin0 -> 34092 bytes
-rw-r--r--doc/resources/mumble_crypt_types.odgbin0 -> 14179 bytes
-rw-r--r--doc/resources/mumble_crypt_types.pdfbin0 -> 24393 bytes
-rw-r--r--doc/resources/mumble_packet.odgbin0 -> 10876 bytes
-rw-r--r--doc/resources/mumble_packet.pdfbin0 -> 31287 bytes
-rw-r--r--doc/resources/mumble_protocol_stack.odgbin0 -> 10826 bytes
-rw-r--r--doc/resources/mumble_protocol_stack.pdfbin0 -> 20088 bytes
-rw-r--r--doc/resources/mumble_system_overview.odgbin0 -> 13715 bytes
-rw-r--r--doc/resources/mumble_system_overview.pdfbin0 -> 25520 bytes
12 files changed, 192 insertions, 0 deletions
diff --git a/doc/mumble-protocol.pdf b/doc/mumble-protocol.pdf
new file mode 100644
index 000000000..1394dc6af
--- /dev/null
+++ b/doc/mumble-protocol.pdf
Binary files differ
diff --git a/doc/mumble-protocol.tex b/doc/mumble-protocol.tex
new file mode 100644
index 000000000..c20c9eb06
--- /dev/null
+++ b/doc/mumble-protocol.tex
@@ -0,0 +1,192 @@
+% !TEX TS-program = pdflatex
+% !TEX encoding = UTF-8 Unicode
+
+% This is a simple template for a LaTeX document using the "article" class.
+% See "book", "report", "letter" for other types of document.
+
+\documentclass[11pt]{article} % use larger type; default would be 10pt
+
+\usepackage[utf8]{inputenc} % set input encoding (not needed with XeLaTeX)
+
+%%% Examples of Article customizations
+% These packages are optional, depending whether you want the features they provide.
+% See the LaTeX Companion or other references for full information.
+
+%%% PAGE DIMENSIONS
+\usepackage{geometry} % to change the page dimensions
+\geometry{a4paper} % or letterpaper (US) or a5paper or....
+% \geometry{margins}{2cm} % for example, change the margins to 2 inches all round
+% \geometry{landscape} % set up the page for landscape
+% read geometry.pdf for detailed page layout information
+
+\usepackage{graphicx} % support the \includegraphics command and options
+\usepackage{hyperref}
+
+\usepackage[parfill]{parskip} % Activate to begin paragraphs with an empty line rather than an indent
+
+%%% PACKAGES
+\usepackage{booktabs} % for much better looking tables
+\usepackage{array} % for better arrays (eg matrices) in maths
+\usepackage{paralist} % very flexible & customisable lists (eg. enumerate/itemize, etc.)
+\usepackage{verbatim} % adds environment for commenting out blocks of text & for better verbatim
+\usepackage{subfig} % make it possible to include more than one captioned figure/table in a single float
+% These packages are all incorporated in the memoir class to one degree or another...
+
+% Configure fancyvrb for our listings
+\usepackage{fancyvrb}
+\fvset{frame=leftline, framesep=5mm, tabsize=8, numbers=left}
+
+%%% HEADERS & FOOTERS
+\usepackage{fancyhdr} % This should be set AFTER setting up the page geometry
+\pagestyle{fancy} % options: empty , plain , fancy
+\renewcommand{\headrulewidth}{0pt} % customise the layout...
+\lhead{}\chead{}\rhead{}
+\lfoot{}\cfoot{\thepage}\rfoot{}
+
+%%% SECTION TITLE APPEARANCE
+\usepackage{sectsty}
+\allsectionsfont{\sffamily\mdseries\upshape} % (See the fntguide.pdf for font help)
+% (This matches ConTeXt defaults)
+
+%%% ToC (table of contents) APPEARANCE
+\usepackage[nottoc,notlof,notlot]{tocbibind} % Put the bibliography in the ToC
+\usepackage[titles,subfigure]{tocloft} % Alter the style of the Table of Contents
+\renewcommand{\cftsecfont}{\rmfamily\mdseries\upshape}
+\renewcommand{\cftsecpagefont}{\rmfamily\mdseries\upshape} % No bold!
+
+%%% END Article customizations
+
+%%% The "real" document content comes below...
+
+\title{Mumble protocol 1.2.X reference (WIP)}
+\author{Stefan Hacker}
+%\date{} % Activate to display a given date or no date (if empty),
+ % otherwise the current date is printed
+
+\begin{document}
+\maketitle
+
+\newpage
+\section*{DISCLAIMER}
+
+THIS DOCUMENTATION IS PROVIDED BY THE MUMBLE PROJECT "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE MUMBLE PROJECT BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS DOCUMENTATION, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+\tableofcontents
+\newpage
+
+\section{Introduction}
+This document is meant to be a reference for the Mumble VoIP 1.2.X server-client communication protocol. It reflects the state of the protocol implemented in the Mumble 1.2.2 client and might be outdated by the time you are reading this. Be sure to check for newer revisions of this document on our website \url{http://www.mumble.info} . At the moment this document is work in progress.
+
+\section{Overview}
+
+\begin{figure}[ht]
+ \centering
+ \includegraphics[width=\linewidth]{resources/mumble_system_overview}
+ \caption{Mumble system overview}
+ \label{fig:mumble_system_overview}
+\end{figure}
+
+Mumble is based on a standard server-client communication model. It utilizes two channels of communication, the first one is a TCP connection which is used to reliably transfer control data between the client and the server. The second one is a UDP connection which is used for unreliable, low latency transfer of voice data.
+
+\begin{figure}[ht]
+ \centering
+ \includegraphics[width=0.5\linewidth]{resources/mumble_crypt_types}
+ \caption{Mumble crypto types}
+ \label{fig:mumble_crypt_types}
+\end{figure}
+
+Both are protected by strong cryptography, this encryption is mandatory and cannot be disabled. The TCP control channel uses TLSv1 AES256-SHA\footnote{\url{http://en.wikipedia.org/wiki/Transport_Layer_Security }} while the voice channel is encrypted with OCB-AES128\footnote{\url{http://www.cs.ucdavis.edu/~rogaway/ocb/ocb-back.htm}}.
+
+While the TCP connection is mandatory the UDP connection can be compensated by tunnelling the UDP packets through the TCP connection as described in the protocol description later.
+
+\section{Protocol stack (TCP)}
+
+\begin{figure}[ht]
+ \centering
+ \includegraphics[width=0.3\linewidth]{resources/mumble_protocol_stack}
+ \caption{Mumble protocol stack}
+ \label{fig:mumble_protocol_stack}
+\end{figure}
+
+Mumble has a shallow and easy to understand stack. Basically it uses Googles Protocol Buffers\footnote{\url{http://code.google.com/p/protobuf/}} with simple prefixing to distinguish the different kinds of packets sent through an TLSv1 encrypted connection. This makes the protocol very easily expandable.
+
+\begin{figure}[ht]
+ \centering
+ \includegraphics[width=0.8\linewidth]{resources/mumble_packet}
+ \caption{Mumble packet}
+ \label{fig:mumble_packet}
+\end{figure}
+
+The prefix consists out of the two bytes defining the type of the packet in the payload and 4 bytes stating the length of the payload in bytes followed by the payload itself. The following packet types are available in the current protocol and all but UDPTunnel are simple protobuf messages. If not mentioned otherwise all fields are little-endian encoded.
+
+%FIGURE GOES HERE
+
+For raw representation of each packet type see the attached Mumble.proto file.
+
+\section{Establishing a connection}
+The following section is going to describe the communication between the server and the client during connection establishing, note that the first part of this section only contains the procedures for the TCP connection. After this the client will be visible to the other clients on the server and able to send other types of messages.
+
+\begin{figure}[ht]
+ \centering
+ \includegraphics[width=0.7\linewidth]{resources/mumble_connection_setup}
+ \caption{Mumble connection setup}
+ \label{fig:mumble_connection_setup}
+\end{figure}
+
+\subsection{Connect}
+As a basis for the synchronization procedure you first have to establish the TCP connection to the server and do a common TLSv1 handshake. To be able to use the complete feature set of the Mumble protocol it is recommended that your client provides a strong certificate to the server. This however is not mandatory, you can connect to the server without providing a certificate, we do recommend to check the servers certificate though.
+
+\subsection{Version exchange}
+Once the TLS handshake is completed the server will send a Version packet to the client containing following information:
+
+%FIGURE GOES HERE
+
+The client is supposed to send a Version packet with his information before any other messages. The version field of the packet contains the (major, minor, patch) tuple (e.g. 1.2.0) encoded like described in the following figure.
+
+%FIGURE GOES HERE
+
+The release, os and os\_version fields are common strings containing additional information about the client. This information is not interpreted in any way at the moment.
+
+\subsection{Crypt setup}
+Once the Version packets are exchanged the server will send a CryptSetup packet to the client. It contains the necessary cryptographic information to establish the OCB-AES128 encrypted UDP Voice channel. This will be described later in the section.
+
+\subsection{Authenticate}
+Before the client can be synchronized with the server state it has to authenticate itself to the server. This is done by sending an Authenticate packet.
+
+%FIGURE GOES HERE
+
+The username and password are encoded as simple strings. Be aware that the server can impose restrictions on the username, also once the client registered a certificate with the server this field is only displayed in brackets behind the name the client posessed when he registered, for more information see the server documentation. The password must only be provided if the server is passworded, the client provided no certificate but wants to authenticate to an account which has a password set, or to access the SuperUser account. The third field called tokens contains a list of zero or more strings called tokens which are basically password which can give you access to a certain ACL group without actually being a registered member in them, again see the server documentation for more information.
+
+\subsection{Channel states}
+
+After the client is successfully authenticated the server starts synchronizing the state by transmitting a ChannelState message for every channel on this server. Note that these do not yet contain channel links. These are transmitted as updated directly after every channel has been transmitted. It contains the following information:
+
+%FIGURE GOES HERE
+For more information pease refer to \nameref{appendix:mumble_proto} in the appendix.
+
+\subsection{User states}
+
+When the channels are synchronized the server send a UserState message for every user connected to the client containing the following data:
+
+%FIGURE GOES HERE
+For more information pease refer to \nameref{appendix:mumble_proto} in the appendix.
+
+\subsection {Server sync}
+The client has now received a copy of the parts of the server state he needs to know about. To complete the synchronization the server transmits a ServerSync message containing the session id of the clients session, the maximum bandwidth allowed on this server, the servers welcome text as well as the permissions the client has in the channel he ended up.
+
+%FIGURE GOES HERE
+For more information pease refer to \nameref{appendix:mumble_proto} in the appendix.
+
+\subsection {PacketDataStream}
+The PacketDataStream class is used to serialize/deserialize the data packets received on the UDP connection or via the TCP-Tunneling. As the name implies it provides a stream based access to the data it contains. To pull data from it the user has to know what is located on the current position in the stream (e.g. a uint32, utf8 string and so on), the class itself is not aware of it's contents.
+
+\section {This document is WIP}
+SORRY BUT THIS DOCUMENT IS WORK IN PROGRESS. AT THE MOMENT IT LACKS A LOT OF IMPORTANT INFORMATION BUT WE HOPE TO BE ABLE TO FINISH THIS DOCUMENT SOMEDAY :-)
+
+\appendix
+\section{Appendix}
+\subsection{Mumble.proto}
+\label{appendix:mumble_proto}
+\VerbatimInput{../src/Mumble.proto}
+
+\end{document}
diff --git a/doc/resources/mumble_connection_setup.odg b/doc/resources/mumble_connection_setup.odg
new file mode 100644
index 000000000..aea62e2e8
--- /dev/null
+++ b/doc/resources/mumble_connection_setup.odg
Binary files differ
diff --git a/doc/resources/mumble_connection_setup.pdf b/doc/resources/mumble_connection_setup.pdf
new file mode 100644
index 000000000..1b8764533
--- /dev/null
+++ b/doc/resources/mumble_connection_setup.pdf
Binary files differ
diff --git a/doc/resources/mumble_crypt_types.odg b/doc/resources/mumble_crypt_types.odg
new file mode 100644
index 000000000..84dbb982a
--- /dev/null
+++ b/doc/resources/mumble_crypt_types.odg
Binary files differ
diff --git a/doc/resources/mumble_crypt_types.pdf b/doc/resources/mumble_crypt_types.pdf
new file mode 100644
index 000000000..f30b011d1
--- /dev/null
+++ b/doc/resources/mumble_crypt_types.pdf
Binary files differ
diff --git a/doc/resources/mumble_packet.odg b/doc/resources/mumble_packet.odg
new file mode 100644
index 000000000..af90fe1e4
--- /dev/null
+++ b/doc/resources/mumble_packet.odg
Binary files differ
diff --git a/doc/resources/mumble_packet.pdf b/doc/resources/mumble_packet.pdf
new file mode 100644
index 000000000..59431b61c
--- /dev/null
+++ b/doc/resources/mumble_packet.pdf
Binary files differ
diff --git a/doc/resources/mumble_protocol_stack.odg b/doc/resources/mumble_protocol_stack.odg
new file mode 100644
index 000000000..d405a8f88
--- /dev/null
+++ b/doc/resources/mumble_protocol_stack.odg
Binary files differ
diff --git a/doc/resources/mumble_protocol_stack.pdf b/doc/resources/mumble_protocol_stack.pdf
new file mode 100644
index 000000000..350b29cf1
--- /dev/null
+++ b/doc/resources/mumble_protocol_stack.pdf
Binary files differ
diff --git a/doc/resources/mumble_system_overview.odg b/doc/resources/mumble_system_overview.odg
new file mode 100644
index 000000000..02a4d54fb
--- /dev/null
+++ b/doc/resources/mumble_system_overview.odg
Binary files differ
diff --git a/doc/resources/mumble_system_overview.pdf b/doc/resources/mumble_system_overview.pdf
new file mode 100644
index 000000000..8ac7e3a8a
--- /dev/null
+++ b/doc/resources/mumble_system_overview.pdf
Binary files differ