Files @ fa0448ce33b9
Branch filter:

Location: libtransport.git/docs/guide/developer_arch.textile

Jan Kaluza
Fix tailing the log output in Docker entry point
Spectrum 2 consist of several separate parts which cooperates together. This page describes them.

!backend.png!

h2. Where are all those things in git-tree?

|_. Directory|_. Description|
|./src|Libtransport source codes|
|./include/transport|Libtransport headers|
|./plugin/cpp|Libtransport-plugin source codes|
|./backends/*|Various Spectrum 2 backends source codes|

h2. Libtransport

Libtransport is library providing the high-level interface for creating XMPP transports. It's used by the Spectrum 2 and by several transports.

Libtransport contains NetworkPluginServer class, which acts as server to which backends connect. Libtransport spawns the backend's processes when they are needed (for example when new user logs in) and destroys them when they are not needed anymore (for example when there are no active users on the backend).

Libtransport is used by:

|_. Name|_. Reason|
|Spectrum 2|It's the Spectrum 2 core|
|Some backends|Connect the Spectrum2, use of Spectrum 2 database, parsing the config file, ...|

Libtransport uses:

|_. Name|_. Reason|
|Swiften library|Connecting to Jabber sever and sending/receiving data from XMPP users|
|log4cxx|Logging|
|protobuf|Protocol for libtransport - backends communication|
|mysql-client|MySQL support|
|sqlite3|SQLite3 support|
|pqxx|PostgreSQL support|

h2. Libtransport-plugin

Libtransport-plugin is subset of Libtransport library and contains only basic things for backend development. The goal is to have smaller library with the less dependencies than Libtransport.

The Libtransport-plugin contains NetworkPlugin class, which is the base class for every @C++@ backend. Programmer has to create his own class inherited from this one and implement all the virtual methods to create new backend.

Libtransport-plugin is used by:

|_. Name|_. Reason|
|All Backends|Connect the Spectrum 2, parsing the config file|

Libtransport-plugin uses:

|_. Name|_. Reason|
|log4cxx|Logging|
|protobuf|Protocol for libtransport - backends communication|

h2. Spectrum 2

Main Spectrum 2 binary just uses Libtransport and it's core classes to create particular Spectrum 2 instance.

Spectrum2 uses:

|_. Name|_. Reason|
|Libtransport|Core library...|

h2. Backends

Backends allow communication with particular legacy network and implements things like logging the user in, sending/receiving messages from legacy network and so on. Backend's life-cycle is controlled by the Spectrum 2 (or better said by the Libtransport's NetworkPluginServer class).

Spectrum 2 spawns the backend and gives it @"--host localhost --port 32453"@ parameters. Backend then has to connect the Spectrum 2 located at the given host/port and start receiving the commands sent by the Spectrum 2 main instance. For C++, there is wrapper class called NetworkPlugin which does the parsing and allows programmer to code backend just by implementing few virtual methods.