summaryrefslogtreecommitdiff
path: root/docs/server.txt
diff options
context:
space:
mode:
authorBjørn Lindeijer <bjorn@lindeijer.nl>2005-02-04 15:10:45 +0000
committerBjørn Lindeijer <bjorn@lindeijer.nl>2005-02-04 15:10:45 +0000
commit746aff7fb78102df27f896fcb2cb288a9b271262 (patch)
treec74c03f996fe35f40b4d8836d5b4a91e003ec3cc /docs/server.txt
parent8819c5c00e3278e0bcd6def6786d6e5fc9d7aa58 (diff)
downloadmana-746aff7fb78102df27f896fcb2cb288a9b271262.tar.gz
mana-746aff7fb78102df27f896fcb2cb288a9b271262.tar.bz2
mana-746aff7fb78102df27f896fcb2cb288a9b271262.tar.xz
mana-746aff7fb78102df27f896fcb2cb288a9b271262.zip
Committed start on server protocol description.
Diffstat (limited to 'docs/server.txt')
-rw-r--r--docs/server.txt163
1 files changed, 163 insertions, 0 deletions
diff --git a/docs/server.txt b/docs/server.txt
new file mode 100644
index 00000000..018fd772
--- /dev/null
+++ b/docs/server.txt
@@ -0,0 +1,163 @@
+-----------------------------
+THE MANA WORLD SERVER PROJECT
+-----------------------------
+
+1. INTRODUCTION
+2. MAP
+3. OBJECT
+4. BEING
+5. ITEM
+6. CHAT
+7. AUTHENTICATION
+
+
+1. INTRODUCTION
+
+First let me show you a screenshot of TMW. From left to right it shows a
+player, an enemy, a tree and an apple. In this document the player and enemy
+will go as beings, and the tree and apple will go as objectss. Finally, the
+thing they're on is a map.
+
+ ----------------- Fig. 1) screenshot of TMW showing three kind of objects
+ | |
+ | o O | MAP
+ | O <> |o | OBJECT
+ | | BEING
+ -----------------
+
+Each of these types has its own set of properties and things it can do in the
+game. A number of messages in the protocol can be grouped on these types. We'll
+go through each of them separately. Objects can be pickup up and change into
+items, we'll mention those too.
+
+The effects of using objects or items, talking to beings and attacking enemies
+are all calculated server side. It is interesting to think about approaches
+that allow a scripting language to be used in there areas.
+
+In the messages described the following datatypes are being used:
+
+ A - char array (null terminated)
+ S - short (2 bytes)
+ L - long (4 bytes)
+
+
+2. MAP
+
+- Stored as XML file (.tmx)
+- Refers to tileset images and potentially to music file(s) and objects
+- Beings can change from one map to another
+
+
+3. OBJECT
+
+- Most properties specified in XML file
+- Mostly static (at least doesn't move, but can change)
+- Has collision properties, which can change
+- Can be an item (allowing picking it up)
+- Can be animated (and change animation)
+- Can potentially be activated/used (door, chest, portal)
+
+ Server to client:
+
+ MSG_NEW_OBJECT { A name, L id, L x, L y }
+ MSG_REMOVE_OBJECT { L id }
+ MSG_CHANGE_OBJECT { L id, L x, L y, S currAnim, S flags }
+
+ Client to server:
+
+ MSG_PICKUP { L beingId, L objectId }
+ MSG_USE_OBJECT { L beingId, L objectId }
+
+
+4. BEING
+
+- Most properties specified in XML file.
+- Dynamic (can walk around)
+- Character animation, but could still show arbitrary animations.
+- Can equip stuff, which could change appearance
+- Has inventory
+- Connects to questing system
+- Can fight other beings
+- Dispositions: friendly, neutral, enemy
+- Can be shop
+- Can be talked to, potentially to gain quests
+- Controlled either by player or AI, AI could be either server or client side.
+- Carries money
+- Can be associated with a client
+
+ Server to client:
+
+ MSG_NEW_BEING { A name, L id, L clientId, L x, L y }
+ MSG_REMOVE_BEING { L id }
+ MSG_INVENTORY_UPD { L id, A itemName, L amount }
+ MSG_EQUIPMENT_UPD { L id, S slot, A itemName }
+ MSG_ATTACK { L attackerId, L targetId, L damage, S damType }
+ MSG_PATH { L id, A path }
+
+ Client to server:
+
+ MSG_TARGET { L id, L targetId }
+ MSG_WALK { L id, L x, L y }
+ MSG_START_TRADE { L id, L shopBeingId } // Needs more related messages
+ MSG_START_TALK { L id, L talkBeingId } // Needs more related messages
+
+
+5. ITEM
+
+- Properties specified in XML file
+- Beings can carry them around
+- Can be traded between beings
+- Can potentially be equipped (in a certain slot)
+- Can potentially be used
+
+ Client to server:
+
+ MSG_USE_ITEM { L id, A itemName }
+ MSG_EQUIP { L id, A itemName, S slot }
+
+
+6. CHAT
+
+There are several channels in the chat system:
+
+ Area - To players around you (default)
+ Region - To players on the same map (default)
+ Global - To all players in the game (default)
+ Team - To players in the same team (when in team)
+ Guild - To players in the same guild (when in guild)
+
+In addition to these there are also system messages, and accouncements made
+by moderators / administrators.
+
+ Server to client:
+
+ MSG_CHAT { L beingId, A name, A message, S channel }
+ MSG_SYSTEM { A message }
+ MSG_ANNOUNCEMENT { A message }
+
+ Client to server:
+
+ MSG_SAY { L beingId, A message, S channel }
+ MSG_ANNOUNCE { A message }
+
+
+7. AUTHENTICATION
+
+Of course before the client can send/receive any of this, he needs to login to
+the server. The idea is that the client will send login info to the server,
+and that the server either denies the request (giving a reason) or sends the
+client a client id. The client later uses the client id to determine which
+being(s) are to be controlled.
+
+ Server to client:
+
+ MSG_ACCEPT_GAME { L clientId } // Accepted into the game
+ MSG_ACCEPT_CREATE { } // Accepted into character creation
+ MSG_DENY { A reason }
+
+ Client to server:
+
+ MSG_LOGIN { A name, A password }
+ MSG_CHAR_CREATE { ... }
+
+The character creation process will need to be thought out.