Mercurial > pidgin
annotate src/protocols/gg/protocol.txt @ 6371:8f94cce8faa5
[gaim-migrate @ 6876]
I think I touched almost every file. Here's what happened.
I started off fixing up the Makefile.am and configure.ac files to help with
the core/UI split some. Then I got annoyed with the
build_{allow,deny}_list() functions that everything used, and decided to
core/UI split privacy. While doing that, I decided to redesign the dialog.
So now, a lot has changed, but not really so much. Just that most files
got affected.
Oh yeah, and the UI stuff was taken out of internal.h and moved to
gtkinternal.h. If you use this, please be aware of this change.
committer: Tailor Script <tailor@pidgin.im>
author | Christian Hammond <chipx86@chipx86.com> |
---|---|
date | Tue, 05 Aug 2003 10:55:04 +0000 |
parents | 1ffac7cf4e94 |
children | 40d04a6570de |
rev | line source |
---|---|
2393 | 1 --------------------------------------------------------------------------- |
2 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
3 Protokół G*du-G*du 4.x |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
4 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
5 (C) Copyright 2001 by Wojtek Kaniewski <wojtekka@irc.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
6 Robert J. Woźny <speedy@atman.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
7 Tomasz Jarzynka <tomee@cpi.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
8 Adam Ludwikowski <adam.ludwikowski@wp.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
9 Marek Kozina <klith@hybrid.art.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
10 Rafał Florek <raf@regionet.regionet.pl>, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
11 Igor Popik <igipop@wsfiz.edu.pl> |
2393 | 12 |
13 --- 0) disclaimer --------------------------------------------------------- | |
14 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
15 opis protokołu bazują na doświadczeniach przeprowadzonych na moim |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
16 domowym komputerze oraz informacjach przysłanych do mnie przez różnych |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
17 ludzi. żaden klient g*du-g*du nie został skrzywdzony podczas |
2393 | 18 przeprowadzania badań, blabla. |
19 | |
20 --- 1) transmisja, format wszystkich pakietów ----------------------------- | |
21 | |
22 w przeciwieństwie do zabawek typu icq, g*du-g*du korzysta z protokołu tcp. | |
23 każdy pakiet zawiera dwa stałe pola: | |
24 | |
25 struct gg_header { | |
26 int type; /* typ pakietu */ | |
27 int length; /* długość reszty pakietu */ | |
28 }; | |
29 | |
30 dla ułatwienia przyjmuję następujące długości zmiennych: sizeof(char) = 1, | |
31 sizeof(short) = 2, sizeof(int) = 4. oczywiście wszystkie liczby są zgodnie | |
32 z intelowym endianem. zakładam też, że wszystkie zmienne są bez znaku. nie | |
33 chce mi się wszędzie pisać `unsigned'. | |
34 | |
35 pola, co do których znaczenia nie mam pewności, lub w ogóle nie mam pojęcia, | |
36 skąd się tam wzięły, oznaczam `dunno'. | |
37 | |
38 --- 2) zanim się połączymy ------------------------------------------------- | |
39 | |
40 żeby wiedzieć, z jakim serwerem mamy się połączyć, należy poudawać przez | |
41 chwilę Internet Explorera, połączyć się z hostem `appmsg.gadu-gadu.pl'. | |
42 | |
43 GET /appsvc/appmsg.asp?fmnumber=<tutaj_numerek_gg> HTTP/1.0 | |
44 Host: appmsg.gadu-gadu.pl | |
45 User-Agent: Mozilla/4.7 [en] (Win98; I) | |
46 Pragma: no-cache | |
47 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
48 oryginalny klient może wysłać jeden z podanych identyfikatorów przeglądarki: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
49 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
50 Mozilla/4.04 [en] (Win95; I ;Nav) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
51 Mozilla/4.7 [en] (Win98; I) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
52 Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
53 Mozilla/4.0 (compatible; MSIE 5.0; Windows NT) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
54 Mozilla/4.0 (compatible; MSIE 5.0; Windows 98; DigExt) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
55 Mozilla/4.0 (compatible; MSIE 5.0; Windows 98) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
56 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
57 nowsze wersje klienta do zapytania dodają również `version=...' opisujące, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
58 z jakim klientem serwer ma do czynienia. jednak ze względu na możliwe |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
59 różnice w protokole, lepiej pomijać ten parametr i uwagać GG 4.0. w każdym |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
60 razie na to zapytanie serwer powinien odpowiedzieć: |
2393 | 61 |
62 HTTP/1.0 200 OK | |
63 | |
64 0 1 0 217.17.33.21:8074 217.17.33.21 217.17.33.21 | |
65 | |
66 co to oznacza? nie mam pojęcia ;) wygląda na to, że cały g*du-g*du jest | |
67 przemyślany i w przyszłości będzie można używać różnych serwerów do różnych | |
68 rzeczy, typu szukanie, obsługa klientów itd. póki co, łączyć się trzeba na | |
69 pierwszy adres (tak, ten z portem). | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
70 Jeżeli połączenie z portem 8074 nie wyjdzie z jakiś specyficznych powodów - |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
71 można się łączyć na port 443. |
2393 | 72 |
73 --- 3) logowanie się ------------------------------------------------------- | |
74 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
75 po połączeniu się portem serwera g*du-g*du, dostajemy pakiet typu 0x0001, |
2393 | 76 który na potrzeby tego dokumentu nazwiemy: |
77 | |
78 #define GG_WELCOME 0x0001 | |
79 | |
80 reszta pakietu zawiera liczbę, na podstawie której liczony jest hash z hasła | |
81 klienta: | |
82 | |
83 struct gg_welcome { | |
84 int key; /* klucz szyfrowania hasła */ | |
85 }; | |
86 | |
87 kiedy mamy już tą wartość możemy odesłać pakiet logowania | |
88 | |
89 #define GG_LOGIN 0x000c | |
90 | |
91 musimy podać kilka informacji: | |
92 | |
93 struct gg_login { | |
94 int uin; /* twój numerek */ | |
95 int hash; /* hash hasła */ | |
96 int status; /* status na dzień dobry */ | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
97 int version; /* wersja klienta */ |
2393 | 98 int local_ip; /* mój adres ip */ |
99 short local_port; /* port, na którym słucham */ | |
100 }; | |
101 | |
102 jak obliczyć hash hasła? hmm... nic prostszego. do każdej literki hasła | |
103 dodaje się jedynkę, mnoży wszystko razem, a potem przez liczbę podaną przez | |
104 serwer. | |
105 | |
106 for (hash = 1; *passwd; passwd++) | |
107 hash *= (*passwd) + 1; | |
108 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
109 zrozumiałe, racja? liczba oznaczająca wersję może być jedną z poniższych: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
110 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
111 0x11 - 4.6.1 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
112 0x10 - 4.5.22, 4.5.21, 4.5.19, 4.5.17, 4.5.15 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
113 0x0f - 4.5.12 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
114 0x0b - 4.0.30, 4.0.29, 4.0.28, 4.0.25 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
115 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
116 oczywiście nie są to wszystkie możliwe wersje klientów, lecz te, które |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
117 udało się sprawdzić. najbezpieczniej będzie przedstawiać się jako ta |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
118 wersja, której ficzerów używamy. wiadomo, że 4.0.x nie obsługiwały trybu |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
119 ukrytego, ani tylko dla znajomych itd. |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
120 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
121 jeśli wszystko się powiedzie, dostaniemy w odpowiedzi pakiet typu |
2393 | 122 |
123 #define GG_LOGIN_OK 0x0003 | |
124 | |
125 z polem header->length = 0, lub pakiet | |
126 | |
127 #define GG_LOGIN_FAILED 0x0009 | |
128 | |
129 --- 4) zmiana statusu ----------------------------------------------------- | |
130 | |
131 g*du-g*du przewiduje trzy stany klienta, które zmieniamy pakietem | |
132 | |
133 #define GG_NEW_STATUS 0x0002 | |
134 | |
135 #define GG_STATUS_NOT_AVAIL 0x0001 /* rozłączony */ | |
136 #define GG_STATUS_AVAIL 0x0002 /* dostępny */ | |
137 #define GG_STATUS_BUSY 0x0003 /* zajęty */ | |
138 #define GG_STATUS_INVISIBLE 0x0014 /* niewidoczny */ | |
139 | |
140 #define GG_STATUS_FRIENDS_MASK 0x8000 /* tylko dla przyjaciół */ | |
141 | |
142 struct gg_new_status { | |
143 int status; /* na jaki zmienić? */ | |
144 } | |
145 | |
146 należy pamiętać, żeby przed rozłączeniem się z serwerem należy zmienić | |
147 stan na GG_STATUS_NOT_AVAIL. jeśli ma być widoczny tylko dla przyjaciół, | |
148 należy dodać GG_STATUS_FRIENDS do normalnej wartości stanu. | |
149 | |
150 --- 5) ludzie przychodzą, ludzie odchodzą --------------------------------- | |
151 | |
152 zaraz po zalogowaniu możemy wysłać serwerowi listę ludzików w naszej liście | |
153 kontaktów, żeby dowiedzieć się, czy są w tej chwili dostępni. pakiet zawiera | |
154 dowolną ilość struktur gg_notify: | |
155 | |
156 #define GG_NOTIFY 0x0010 | |
157 | |
158 struct gg_notify { | |
159 int uin; /* numerek danej osoby */ | |
160 char dunno1; /* == 3 */ | |
161 }; | |
162 | |
163 jeśli ktoś jest, serwer odpowie pakietem zawierającym jedną lub więcej | |
164 struktur gg_notify_reply: | |
165 | |
166 #define GG_NOTIFY_REPLY 0x000c /* tak, to samo co GG_LOGIN */ | |
167 | |
168 struct gg_notify_reply { | |
169 int uin; /* numerek */ | |
170 int status; /* status danej osoby */ | |
171 int remote_ip; /* adres ip delikwenta */ | |
172 short remote_port; /* port, na którym słucha klient */ | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
173 int version; /* wersja klienta */ |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
174 short dunno1; /* znowu port? */ |
2393 | 175 }; |
176 | |
177 jeśli klient nie obsługuje połączeń między klientami (np. g*du-g*du 3.x) | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
178 zamiast adresu ip jest 0, zamiast portu może być 0, 1, 2... nieważne ;) |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
179 port może przyjmować wartość 1, jeśli klient znajduje się za jakimś |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
180 firewallem lub innym urządzeniem robiącym NAT. w każdym razie, jeśli ktoś |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
181 się pojawi w trakcie pracy, również zostanie przysłany ten pakiet. |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
182 proste? proste :) |
2393 | 183 |
184 żeby dodać kogoś do listy w trakcie pracy, trzeba wysłać niżej opisany | |
185 pakiet. jego format jest identyczny jak przy GG_NOTIFY. | |
186 | |
187 #define GG_ADD 0x000d | |
188 | |
189 struct gg_add { | |
190 int uin; /* numerek */ | |
191 char dunno1; /* == 3 */ | |
192 }; | |
193 | |
194 jeśli ktoś opuści g*du-g*du lub zmieni stan, otrzymamy pakiet | |
195 | |
196 #define GG_STATUS 0x0002 | |
197 | |
198 struct gg_status { | |
199 int uin; /* numerek */ | |
200 int status; /* nowy stan */ | |
201 }; | |
202 | |
203 --- 6) wysyłanie wiadomości ------------------------------------------------ | |
204 | |
205 przejdźmy do sedna sprawy ;) | |
206 | |
207 #define GG_SEND_MSG 0x000b | |
208 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
209 #define GG_CLASS_QUEUED 0x0001 /* tylko przy odbieraniu */ |
2393 | 210 #define GG_CLASS_MSG 0x0004 |
211 #define GG_CLASS_CHAT 0x0008 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
212 #define GG_CLASS_UNKNOWN_1 0x0020 |
2393 | 213 |
214 struct gg_send_msg { | |
215 int recipient; | |
216 int seq; | |
217 int class; | |
218 char message[]; | |
219 }; | |
220 | |
221 wiadomo, odbiorca. numer sekwencyjny, który wykorzystujemy potem do | |
222 potwierdzenia. nie wykluczone, że w jakis sposób odróżnia się różne | |
223 rozmowy za pomocą części bajtów, ale raczej nie ma znaczenia. klasa | |
224 wiadomości pozwala odróżnić, czy wiadomość ma się pokazać w osobym | |
225 okienku czy jako kolejna linijka w okienku rozmowy. wygląda na to, | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
226 że to jakaś bitmapa, więc najlepiej olać inne bity niż 0x0e. (czasem |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
227 klienty wysyłają 0x04, czasem 0x24 -- widocznie 0x20 to też jakaś |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
228 flaga). jeśli odbiorca był niedostępny podczas wysyłania wiadomości, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
229 zostanie zaznaczony bit 0x01. |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
230 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
231 oryginalny klient wysyłając wiadomość do kilku użytkowników, wysyła po |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
232 prostu kilka takich samych pakietów z różnymi numerkami odbiorców. nie |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
233 ma osobnego pakietu do tego. natomiast jeśli chodzi o ,,konferencyjnę'' |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
234 do pakietu doklejana jest za ,,char message[];'' następująca struktura: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
235 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
236 struct gg_send_recipients { |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
237 char flag; /* == 1 */ |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
238 int count; /* ilość odbiorców */ |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
239 int recipients[]; /* tablica odbiorców */ |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
240 }; |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
241 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
242 na przykład, by wysłać do trzech ludzi, należy wysłać pakiet: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
243 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
244 - -- --- --+--+--+--+--+--+--+-----------+-----------+ |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
245 treść |\0|\1| 0x02 | uin1 | uin2 | |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
246 - -- -- ---+--+--+--+--+--+--+--+--+--+--+--+--+--+--+ |
2393 | 247 |
248 serwer po otrzymaniu wiadomości odsyła informację o tym. przy okazji | |
249 mówi, czy wiadomość dotarła do odbiorcy (status == GG_ACK_DELIVERED), | |
250 czy może jest offline i została zakolejkowana (GG_ACK_QUEUED): | |
251 | |
252 #define GG_SEND_MSG_ACK 0x0005 | |
253 | |
254 #define GG_ACK_DELIVERED 0x0002 | |
255 #define GG_ACK_QUEUED 0x0003 | |
256 | |
257 struct gg_send_msg_ack { | |
258 int status; | |
259 int recipient; | |
260 int seq; | |
261 }; | |
262 | |
263 numer sekwencyjny i adresat ten sam, co przy wysyłaniu. | |
264 | |
265 --- 7) otrzymywanie wiadomości --------------------------------------------- | |
266 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
267 zbyt wiele wyjaśnień chyba nie trzeba. wiadomo od kogo. drugie pole to |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
268 najprawdopodobniej jakiś numerek sekwencyjny. trzecie oznacza czas nadania |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
269 wiadomości. klasa wiadomości taka sama jak przy wysyłaniu: |
2393 | 270 |
271 #define GG_RECV_MSG 0x000a | |
272 | |
273 struct gg_recv_msg { | |
274 int sender; | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
275 int seq; |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
276 int time; |
2393 | 277 int class; |
278 char message[]; | |
279 }; | |
280 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
281 w przypadku pakietów ,,konferencyjnych'' na koncu pakietu doklejona jest |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
282 struktura identyczna ze struct gg_send_recipients zawierająca pozostałych |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
283 rozmówców. |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
284 |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
285 --- 8) ping/pong ----------------------------------------------------------- |
2393 | 286 |
287 od czasu do czasu klient wysyła pakiet a'la ping do serwera i dostaje pustą | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
288 odpowiedź. o ile dobrze pamiętam, serwer rozłącza się po upływie 5 minut od |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
289 otrzymania ostatniej informacji. |
2393 | 290 |
291 #define GG_PING 0x0008 | |
292 | |
293 /* nie ma niczego */ | |
294 | |
295 #define GG_PONG 0x0007 | |
296 | |
297 /* nie ma niczego */ | |
298 | |
299 --- 9) podziękowania ------------------------------------------------------- | |
300 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
301 swój wkład w poznanie protokołu mieli: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
302 - Robert J. Woźny <speedy@atman.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
303 opis nowości w protokole GG 4.6, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
304 - Tomasz Jarzynka <tomee@cpi.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
305 badanie timeoutów, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
306 - Adam Ludwikowski <adam.ludwikowski@wp.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
307 wiele różnych poprawek do tekstu, badanie wersji, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
308 - Marek Kozina <klith@hybrid.art.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
309 czas otrzymania wiadomości, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
310 - Rafał Florek <raf@regionet.regionet.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
311 konferencje, |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
312 - Igor Popik <igipop@wsfiz.edu.pl>: |
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
313 klasy wiadomości przy odbieraniu zakolejkowanej. |
2393 | 314 |
315 ---------------------------------------------------------------------------- | |
316 | |
2806
1ffac7cf4e94
[gaim-migrate @ 2819]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
2393
diff
changeset
|
317 $Id: protocol.txt 2819 2001-11-27 22:54:32Z warmenhoven $ |
2393 | 318 |