123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- #pragma once
- #include "../Include/KSGNetwork.h"
- #include <Critical.h>
- namespace KSGClient
- {
- // Wird verwendet um sich für Spiele anzumelden
- // Kann nur von eingeloggten Clients verwendet werden
- class AnmeldungClient : public AnmeldungServerClient
- {
- private:
- Framework::Text ip;
- unsigned short port;
- int cId;
- Network::Klient* k;
- char* key;
- unsigned char keyLen;
- Framework::Critical cs;
- Framework::Text err;
- public:
- // Konstruktor
- AnmeldungClient(int klientId, unsigned short port, const char* ip, const char* key, unsigned char keyLen);
- // Destruktor
- ~AnmeldungClient();
- // verbindet sich mit dem zugewiesenen Anmeldung Server
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool verbinde() override;
- // erstellt eine gruppe
- // karteId: Die Id der Karte für die die Gruppe erstellt werden soll
- // Gibt bei Erfolg die Id der Gruppe zurück. Bei misserfolg wird 0 zurückgegeben
- int gruppeErstellen(int karteId) override;
- // Betritt eine Gruppe
- // gruppeId: Die Id der Gruppe
- // mitglieder: Nach erfolgreichem Aufruf enthält diese Liste die Lister der Account Ids der Gruppenmitglieder
- // anzahl: Nach erfolgreichem Aufruf wird hier die Anzahl der Gruppenmitglieder gespeichert
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeBetreten(int gruppeId, Framework::Array< int >* mitglieder, int* anzahl) override;
- // Verlässt eine Gruppe
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeVerlassen(int gruppeId) override;
- // Trägt die Gruppe in die Warteschlange für die Karte ein (nur für den Gruppen Administrator)
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeAnmelden(int gruppeId) override;
- // Trägt die Gruppe aus der Warteschlange für die Karte aus (nur für den Gruppen Administrator)
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeAbmelden(int gruppeId) override;
- // läht Spieler ein die Gruppe zu betreten (nur für den Gruppen Administrator)
- // accountId: Die Id des Accounts
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeSpielerEinladen(int accountId, int gruppeId) override;
- // Zieht die Einladung eine Gruppe zu betreten zurück (nur für den Gruppen Administrator)
- // accountId: Die Id des Accounts
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeEinladungAbbrechen(int accountId, int gruppeId) override;
- // Einladung zur Gruppe ablehnen
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeEinladungAblehnen(int gruppeId) override;
- // wirft Spieler aus Gruppe (nur für den Gruppen Administrator)
- // accountId: Die Id des Accounts
- // gruppeId: Die Id der Gruppe
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool kickSpielerAusGruppe(int accountId, int gruppeId) override;
- // Legt fest, ob die Spieler in der Gruppe alleine spielen wollen, oder ob weitere Spieler aus der Warteschlange hinzugefügt werden sollen bis die Karte voll ist
- // gruppeId: Die Id der Gruppe
- // spielStarte: 1:=alleine spielen, 0:=auf volles Spiel warten
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeSpielStarten(int gruppeId, bool spielStarten) override;
- // Sendet eine Nachricht an den Gruppen Chat
- // gruppeId: Die Id der Gruppe
- // nachricht: Die Nachricht, die gesendet werden soll
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool gruppeNachricht(int gruppeId, const char* nachricht) override;
- // Meldet den eingeloggten Account in der Warteschlange für eine Karte an
- // karteId: Die Id der Karte
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool anmelden(int karteId) override;
- // Meldet den eingeloggten Account aus der Warteschlange ab
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- bool abmelden() override;
- // Erhält die Verbindung aufrecht
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- // Sollte während einer bestehenden Verbindung etwa einmal alle 60 Sekunden aufgerufen werden, da sonst der Router die Verbindung automatisch trennt
- bool keepAlive() override;
- // Trennt die Verbindung zum Server
- // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
- // Sollte erst nach einem erfolgreichen Aufruf von verbinde aufgerufen werden
- bool trenne(bool abmelden) override;
- // Gibt 1 zurück, falls der Client verbunden ist, 0 sonst
- bool istVerbunden() const override;
- // gibt den Letzten Fehlertext zuück
- // sollte erst aufgerufen werden, nachdem eine andere aufgerufene Methode fehlgeschlagen ist
- const char* getLetzterFehler() const override;
- };
- }
|