16098d01
grouille
MAJ README
|
1
2
3
4
|
# Protocôles de communication
## UDP
|
ef04e1cb
grouille
MAJ README
|
5
6
|
Port : 4242
Contenu du paquet :
|
16098d01
grouille
MAJ README
|
7
8
9
10
11
|
- _Identifiant du bot_ : 6 octets
- _Temps de vie (nombre de secondes depuis le démarrage)_ 4 octets
## TCP
|
ef04e1cb
grouille
MAJ README
|
12
13
|
Port : 4242
Commandes :
|
16098d01
grouille
MAJ README
|
14
15
16
17
18
|
- _STAT_ : retourne le status du bot (la réponse comprend son temps de vie, le nombre de charges utiles téléversées, le nombre d'exécution de charges utiles)
- _QUIT_ : deconnexion du C&C par rapport au bot
### Installation de la charge utile sur un bot
|
ef04e1cb
grouille
MAJ README
|
19
20
21
22
23
24
25
26
27
28
29
|
- _$C&C_ : "upload?\n"
- _$BOT_ : "OKupload\n"
- _$C&C_ : "%d\n", charge.name.size
- _$BOT_ : "OKname_size\n"
- _$C&C_ : "%s\n", charge.name
- _$BOT_ : "OKname\n"
- _$C&C_ : "%d\n", charge.data.size
- _$BOT_ : "OKdata_size\n"
- _$C&C_ : "%s\n", charge.data // On envoie octect par octet
- _$BOT_ : "bye"\n" // Lorsque tous les octets sont reçus
- _$C&C_ : "bye"\n"
|
16098d01
grouille
MAJ README
|
30
31
32
|
### Exécution d'une charge sur un bot
|
ef04e1cb
grouille
MAJ README
|
33
34
35
36
37
38
39
40
41
42
|
- _$C&C_ : "execute?\n"
- _$BOT_ : "OKexecute\n"
- _$C&C_ : "%d\n", charge.name.size
- _$BOT_ : "OKname_size\n"
- _$C&C_ : "%s\n", charge.name
- _$BOT_ : "OKname\n" // si la charge n'est pas presente sur le bot alors se dernier envoi un autre message "NOKname\n" et ca stop l'echange
- _$BOT_ : "%d\n", id //indice de l'execution dans la structure de donne choisie (liste chaine, table de hashage...a definir) pour stocker les resultats d'execution sur le bot
- _$C&C_ : "OKid\n"
- _$BOT_ : "bye"\n"
- _$C&C_ : "bye"\n"
|
16098d01
grouille
MAJ README
|
43
44
45
|
### Suppression d'une charge sur un bot
|
ef04e1cb
grouille
MAJ README
|
46
47
48
49
50
51
52
53
|
- _$C&C_ : "delet?\n"
- _$BOT_ : "OKdelet\n"
- _$C&C_ : "%d\n", charge.name.size
- _$BOT_ : "OKname_size\n"
- _$C&C_ : "%s\n", charge.name
- _$BOT_ : "OKname\n" //si la charge n'est pas presente sur le bot alors se dernier envoi "NOKname\n" et ca stop l'echange
- _$C&C_ : "bye"\n"
- _$BOT_ : "bye"\n"
|
16098d01
grouille
MAJ README
|
54
55
56
|
### Demander à un bot de résultat de l'exécution d'une charge
|
ef04e1cb
grouille
MAJ README
|
57
58
59
60
61
62
63
64
65
|
- _$C&C_ : "result?\n"
- _$BOT_ : "OKresult\n"
- _$C&C_ : "%d\n", id
- _$BOT_ : "OKid" //si id existe pas, renvoie "NOKid\n" et stop l'echange
- _$BOT_ : "%d\n", executions[id].result.size
- _$C&C_ : "OKresult_size\n"
- _$BOT_ : "%s\n", executions[id].result //on envoi octect par octet
- _$C&C_ : "bye"\n" //qd a recu tt les packets
- _$BOT_ : "bye"\n"
|
16098d01
grouille
MAJ README
|
66
67
68
69
70
|
### Demander l'état d'un bot (IDEM STAT)
**En cours de discussion**
|
ef04e1cb
grouille
MAJ README
|
71
72
73
74
75
76
77
|
- _$C&C_ : "state?\n"
- _$BOT_ : "%d\n", nbCharge
- _$C&C_ : "OKnbCharge\n"
- _$BOT_ : "%d\n", nbExecs
- _$C&C_ : "OKnbExecs\n"
- _$BOT_ : "bye"\n"
- _$C&C_ : "bye"\n"
|
16098d01
grouille
MAJ README
|
78
79
80
|
**Veuillez ne pas modifier ce README sans en parler à tout le monde !**
|