Project

General

Profile

Architecture » History » Revision 21

Revision 20 (Greg Burri, 11/02/2009 11:21 AM) → Revision 21/32 (Greg Burri, 04/13/2010 11:17 AM)

h1. Architecture 

 This page shows the architecture with two component diagrams, one for the Core and one for the GUI. The responsibilities of each component are then listed. 

 For more information, see the BOUML project in the repository : source:/doc/uml 

 h2. Core 

 !core_components.png! 

 h3. [[FileManager]] (FM) 

 * Keep Kept up to date a list of shared files. 
 * Cut Cuts file in chunks. 
 * Each chunk has a hash and can be read or write. 
 * Can make fast search with indexed words. 
 * Can return the chunk associated to a given hash code. 
 * The directory structure can be browse. 
 * Theses data (files/dirs/chunks/hashes) are persisted to avoid re-hashing. 


 h3. [[NetworkListener]] (NL) 

 * Listens for new TCP connections from peers. Forward it to the _PeerManager_. 
 * Listens for new UDP datagrams. 
 * Provides some interfaces to listen some events. 
 ** New chat message. 
 ** New search result. 
 * Sent periodically an UDP datagram to show its presence. 
 ** This message contains the top needed chunks given by the _DownloadManager_. 
 ** For each answer the known IPs associated to a chunk are given to the _DownloadManager_. 


 h3. [[DownloadManager]] (DM) 

 * Has a download queue with different status. 
 * Has a pool of downloader which will choose a free chunk and : 
 ** Ask the chunk's peer source for the hashes if they are unknown. 
 ** Download it from a known peer. 

 h3. [[UploadManager]] (UM) 

 * Listens the _PeerManager_ for new upload requests. 
 * Manage a pool of uploaders which will read a chunk from _FileManager_ and send it to the remote peer. 


 h3. [[PeerManager]] (PM) 

 * Knows all other peers and different information about them like nick, amount of sharing and speed transfer. 
 * Each peer has a connection (socket) pool. 
 * Treats new messages (TCP) from other peers. 


 h3. [[RemoteControlManager]] (RCM) 
 
 * Manages all connections from remote controllers. 
 * Send periodically the state of the core to the controllers. 
 * Send asynchronous events to the controllers. 
 * Dispatch the controllers commands. 


 h2. GUI 


 h2. Common 

 h3. [[LogManager]] (LM) 

 * Logs some kind of severity messages 
 * Can store the log in a file 
 * Used by Core and GUI