diff --git a/doc/feindesign/netzwerk-protokoll.fodt b/doc/feindesign/netzwerk-protokoll.fodt index 3f7f273..fd2a2f7 100644 --- a/doc/feindesign/netzwerk-protokoll.fodt +++ b/doc/feindesign/netzwerk-protokoll.fodt @@ -1,28 +1,28 @@ - 2019-03-22T18:11:56.7688408422019-04-08T21:29:29.206012789PT3H32M54S124LibreOffice/6.2.2.2$Linux_X86_64 LibreOffice_project/20$Build-2Netzwerkprotokoll1.0.0 + 2019-03-22T18:11:56.7688408422019-04-15T16:56:42.500511105PT4H7M8S172LibreOffice/6.2.2.2$Linux_X86_64 LibreOffice_project/20$Build-2Netzwerkprotokoll1.1.0 - 268122 + 252767 0 - 22019 - 34331 + 43041 + 18597 true false view2 - 5211 - 283737 + 18307 + 260620 0 - 268122 - 22017 - 302451 + 252767 + 43039 + 271362 0 1 false - 65 + 120 false false @@ -114,7 +114,7 @@ true false true - 3722017 + 3832186 true false false @@ -177550,6 +177550,79 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -177807,91 +177880,153 @@ - + + + + + + + + + + + + + + + + + + - + - + + + + + + + + + + + + + - + - + - + - + - + - - - - + - - + + - - - + + - + + + + + + + + + + + + + - + - + - + - + - + - + - + - + + + + - + - + - - + + + + + + + + + + + + + + + + + + + + + + + + @@ -177924,29 +178059,41 @@ - + - + - + - + - + - + - + + + + + + + + + + + + + @@ -178264,6 +178411,162 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -178303,7 +178606,7 @@ - TextureSync Netzwerkprotokoll Version 1.0.0Seite 8/10 + TextureSync Netzwerkprotokoll Version 1.1.0Seite 11/11 @@ -178324,7 +178627,7 @@ - + Netzwerk-Protokoll TextureSync @@ -178346,7 +178649,7 @@ Version - 1.0.0 + 1.1.0 @@ -178377,7 +178680,7 @@ - + Inhaltsverzeichnis @@ -178477,15 +178780,16 @@ 2.5 Get Texture File7 2.6 Get Texture Preview8 2.7 Replace Texture9 - 3 Changelog10 - 4 Anmerkungen10 + 3 Fehlerhandhabung10 + 4 Changelog11 + 5 Anmerkungen11 Grundsätzliches Es wird eine Client-Server-Architektur verwendet. Um das Netzwerkprotokoll möglichst einfach und debuggbar zu halten, bietet sich JSON über TCP an. Dieses wird in eine eigene Paketstruktur verpackt, um so auch große Binär-Daten (z.B. Texturen) über die selbe Verbindung zu übertragen. - Eine Verbindung wird immer vom Client initiiert. Nach jeder Anfrage kann der Client die Verbindung für weitere Anfragen offen halten oder diese zur Beendigung schließen. - Der Server schließt Verbindungen bei Verletzungen des Protokolls oder wenn mindestens 10 Minuten lang kein Datenaustausch mehr stattgefunden hat. + Eine Verbindung wird immer vom Client initiiert. Nach jeder Anfrage kann der Client die Verbindung für weitere Anfragen offen halten oder diese zur Beendigung schließen. + Der Server schließt Verbindungen bei Verletzungen des Protokolls oder wenn mindestens 10 Minuten lang kein Datenaustausch mehr stattgefunden hat. Ports Der Server verwendet TCP-Port 10796 für eingehende Verbindungen. Es wird sowohl IPv6 als auch IPv4 akzeptiert. Paketformat @@ -178509,7 +178813,7 @@ 0 = Error - 1024 Bytes (Optionale Fehlerbeschreibung, UTF-8) + 1024 Bytes. (Siehe unten, Fehlerhandhabung für Details.) @@ -178517,7 +178821,7 @@ 1 = JSON - 16 MiB + 16 MiB @@ -178525,117 +178829,117 @@ 2 = Binary - 512 MiB + 512 MiB - Wird das maximale Payload überschritten, wird die Verbindung sofort geschlossen. Dies dient dazu, zu verhindern, dass ein Teilnehmer mehr Daten entgegen nimmt, als dieser im RAM behalten kann. + Wird das maximale Payload überschritten, wird die Verbindung sofort geschlossen. Dies dient dazu, zu verhindern, dass ein Teilnehmer mehr Daten entgegen nimmt, als dieser im RAM behalten kann. Befehle - Definitionen - Im Folgenden sind sind Datentypen für JSON definiert, welche in dem Protokoll wiederverwendet werden: - Für String, Number, Array von <..> siehe JSON-Standart. + Definitionen + Im Folgenden sind sind Datentypen für JSON definiert, welche in dem Protokoll wiederverwendet werden: + Für String, Number, Array von <..> siehe JSON-Standart. UUID ::= <String> UUID nach Version 4 Beispiele - + - "a78c59fc-4198-421a-8ba4-db232ad7b91e" + "a78c59fc-4198-421a-8ba4-db232ad7b91e" - "1f010407-130f-432c-8463-6c61fdfb8c14" + "1f010407-130f-432c-8463-6c61fdfb8c14" - "ecb109bb-d9d6-494d-9d5e-b1e44734e20d" + "ecb109bb-d9d6-494d-9d5e-b1e44734e20d" Format ::= "png" | "jpeg" Dateiformat Beispiele - + - "png" + "png" - "jpeg" + "jpeg" Resolution ::= [<Number>, <Number>] - Die erste Nummer stellt die Weite in Pixeln dar, die Höhe in Pixeln wird durch die zweite Nummer repräsentiert. + Die erste Nummer stellt die Weite in Pixeln dar, die Höhe in Pixeln wird durch die zweite Nummer repräsentiert. Beispiele - + - [1024, 1024] + [1024, 1024] - [2048, 512] + [2048, 512] - [13, 400] + [13, 400] Tag ::= <String> - Stellt ein Tag dar. Kann Groß- und Kleinbuchstaben beinhalten. + Stellt ein Tag dar. Kann Groß- und Kleinbuchstaben beinhalten. Hinweis: Vergleiche von Tags sind nicht Case-Sensitiv. Die Darstellung in der UI jedoch unter Umständen schon. Beispiele - + - "Holz" + "Holz" - "mEtALL" + "mEtALL" - "Chesse Cake" + "Chesse Cake" Date ::= <String> im Format "yyyy-MM-dd", siehe Javadoc unter java.text.SimpleDateFormat für mehr Informationen. - Beispiele - + Beispiele + - "2019-03-04" + "2019-03-04" - "2017-12-21" + "2017-12-21" Hash ::= <String> Sha256-Hash von z.B. Texturdaten oder anderen Binärdaten, in Hexadezimal-Darstellung. Kann Groß- oder Kleinbuchstaben enthalten. Dies wird genutzt, um auf diese zu verweisen. - Beispiele - + Beispiele + - "a98f43a976e5b501961635b981022ebaf98321b97055ead4d8d4de55114015e7" + "a98f43a976e5b501961635b981022ebaf98321b97055ead4d8d4de55114015e7" - "02a08f7d697a93937cc5ace273a534c2eb021ae76b7c15ba146d279d57898893" + "02a08f7d697a93937cc5ace273a534c2eb021ae76b7c15ba146d279d57898893" - "A6A04ADC2E6D580B8E37CE8F4784652BE6D668EC1FB340B971DD8E8A582CE6BC" + "A6A04ADC2E6D580B8E37CE8F4784652BE6D668EC1FB340B971DD8E8A582CE6BC" - "7bdc65d8550b0A4FBC899550bbda87DAA2E780D618A66a1F7813967ECF6C0831" + "7bdc65d8550b0A4FBC899550bbda87DAA2E780D618A66a1F7813967ECF6C0831" Texture ::= {id: <UUID>,name: <String>,tags: <Array von <Tag>>,format : <Format>,resolution: <Resolution>,added_on: <Date>,texture_hash: <Hash>} - Stellt einen Textur-Eintrag mit Metadaten dar. - + Stellt einen Textur-Eintrag mit Metadaten dar. + Ping Dieser Befehl dient zum Überprüfen der Verbindung. Client sendet nach Schema: type = JSON { - "ping": {} + "ping": {} } Server antwortet nach Schema: type = JSON { - "pong": {} + "pong": {} } Query Client sendet nach Schema: - Zusammenhänge Eingaben werden als <String> in einem Array übertragen. + Zusammenhänge Eingaben werden als <String> in einem Array übertragen. type = JSON { "query": { @@ -178645,22 +178949,22 @@ Server antwortet nach Schema: type = JSON <Array of <Texture>> - + Get Texture Client sendet nach Schema: type = JSON { "get_texture": { "id" : <UUID> | null, - "name" : <String> | null, + "name" : <String> | null, } } - Hierbei muss entweder das Feld "id" oder das Feld "name" gesetzt werden. Andernfalls wird type=Error gesendet, - Der Server antwortet nach Schema [Textur gefunden]: + Hierbei muss entweder das Feld "id" oder das Feld "name" gesetzt werden. Andernfalls wird Fehler 400 Bad Request gesendet, + Der Server antwortet nach Schema [Textur gefunden]: type = JSON <Texture> - Der Server antwortet nach Schema [Textur unbekannt]: - type = JSONnull + Der Server antwortet nach Schema [Textur unbekannt]: + type = JSONnull Get Texture File Client sendet nach Schema: type = JSON @@ -178669,12 +178973,12 @@ "texture_hash" : <Hash>, } } - Der Server antwortet nach Schema [Textur-Datei gefunden]: + Der Server antwortet nach Schema [Textur-Datei gefunden]: type = Binary Textur-Datei - Der Server antwortet nach Schema [Textur-Datei unbekannt] - type = ErrorFehlerbeschreibung = "texture not found" - + Der Server antwortet nach Schema [Textur-Datei unbekannt] + type = Error404 File Not Found. + Get Texture Preview Client sendet nach Schema: type = JSON @@ -178683,11 +178987,11 @@ "texture_hash" : <Hash>, } } - Der Server antwortet nach Schema [Textur-Datei gefunden]: + Der Server antwortet nach Schema [Textur-Datei gefunden]: type = Binary Textur-Preview - Der Server antwortet nach Schema [Textur-Datei unbekannt]: - type = ErrorFehlerbeschreibung = "texture not found" + Der Server antwortet nach Schema [Textur-Datei unbekannt]: + type = Error404 File Not Found. Replace Texture Client sendet nach Schema: @@ -178698,16 +179002,16 @@ "new": <Texture> | null, } } - Diese Anfrage dient dazu alte Texturen zu löschen und neue hinzufügen. Ein Löschen und gleichzeitiges Hinzufügen, ergibt ein Update der Textur. - Falls "old" != null, wird die hier angegebene Textur gelöscht. Wird diese nicht exakt gleich vorgefunden, schlägt diese Anfrage fehl (type = Error, Fehlerbeschreibung = "texture not found"). In diesem Fall wird "new" nicht berücksichtigt. - Falls "new" != null, wird die hier angegebene Textur zum System hinzugefügt. Sollte die angegebene "new.id" oder der angegebene "new.name" schon vorhanden sein, schlägt diese Anfrage fehl (type = Error). - Die Fehlerbeschreibung lautet "id already in use" für eine doppelte Id bzw. "name already in use" für einen doppelten Namen. - Diese Semantik wurde gewählt, damit ein Update atomar ist und doppelte Anfragen zu Fehlern führen. - Der Server antwortet nach Schema ["texture_hash" bekannt]: + Diese Anfrage dient dazu alte Texturen zu löschen und neue hinzufügen. Ein Löschen und gleichzeitiges Hinzufügen, ergibt ein Update der Textur. + Falls "old" != null, wird die hier angegebene Textur gelöscht. Wird diese nicht exakt gleich vorgefunden, schlägt diese Anfrage fehl (Fehler: 409 Conflict). In diesem Fall wird "new" nicht berücksichtigt. + Falls "new" != null, wird die hier angegebene Textur zum System hinzugefügt. Sollte die angegebene "new.id" oder der angegebene "new.name" schon vorhanden sein, schlägt diese Anfrage fehl (Fehler: 409 Conflict). + Diese Semantik wurde gewählt, damit ein Update atomar ist und doppelte Anfragen zu Fehlern führen. + Hinweis: Um zu überprüfen, ob ein Name bereits vergeben ist, sollte Get Texture verwendet werden. (IDs werden sowieso zufällig generiert.) + Der Server antwortet nach Schema ["texture_hash" bekannt]: type = JSON true - Die Anfrage wird damit beendet. - Der Server antwortet nach Schema ["texture_hash" unbekannt]: + Die Anfrage wird damit beendet. + Der Server antwortet nach Schema ["texture_hash" unbekannt]: type = JSON { "get_texture_file": { @@ -178717,10 +179021,103 @@ Woraufhin der Client die Textur-Datei sendet: type = Binary Textur-Datei - Der Server bestätigt dies dann mit: + Der Server bestätigt dies dann mit: type = JSON true - Changelog + Fehlerhandhabung + Fehlerbeschreibungen sind nach folgendem Schema aufgebaut: + <Fehlercode in Dezimal, Ascii><Leerzeichen><Fehlertext> + Bsp: + + + 500 Internal Server Error + + + + Die Fehlercodes sind an HTTP-Statuscodes angelehnt. + Das Folgende ist eine Aufstellung möglicher Fehlernachrichten, auf die in teilen oben verwiesen wurde. Der Fehlertext kann von dieser Aufstellung abweichen, um genauere Informationen wiederzugeben. Ein Vergleich muss daher immer anhand der Fehlernummer durchgeführt werden. + + + + + + + Nummer + + + Text + + + Beschreibung + + + + + 400 + + + Bad Request. + + + Anfrage hat ungültiges Format. Hierzu zählen: + + + Fehlerhalte Semantik. + + + Falsches Encoding. + + + + + + + 404 + + + File Not Found. + + + Unbekannte Textur-Datei angefordert. + + + + + 409 + + + Conflict. + + + Name oder Id bereits vorhanden. + Oder Löschversuch fehlgeschlagen, wegen möglicher Inkonsistenz. + + + + + 500 + + + Internal Server Error. + + + Unerwartbare seltene Sonstige Fehler. Z.b. Festplatte nicht lesbar etc. + + + + + 501 + + + Not Implemented. + + + Funktionalität wurde noch nicht implementiert. Dieser Fehlercode wird nur in der Entwicklungsphase verwendet. + + + + + Changelog @@ -178741,10 +179138,10 @@ - - 0.9.1 + + 0.9.1 - + Formulierung und Rechtschreibung @@ -178757,24 +179154,32 @@ - + 0.11.0 - + Server darf Verbindungen schließen, Fehlerbeschreibungen festgelegt - - 1.0.0 + + 1.0.0 - + Review fertig. + + + 1.1.0 + + + + Fehlerhandhabung: Genauere Aufstellung in extra Abschnitt. + + Anmerkungen - Dieses Dokument wird ergänzt, falls das WK#4 (Automatische Konfiguration des Clients) umgesetzt wird. + Dieses Dokument wird ergänzt, falls das WK#4 (Automatische Konfiguration des Clients) umgesetzt wird. \ No newline at end of file diff --git a/doc/feindesign/netzwerk-protokoll.pdf b/doc/feindesign/netzwerk-protokoll.pdf index 8778467..f904127 100644 Binary files a/doc/feindesign/netzwerk-protokoll.pdf and b/doc/feindesign/netzwerk-protokoll.pdf differ