summaryrefslogtreecommitdiff
path: root/10-entwurfsheft/sections/glossar.tex
blob: 9caad876959940287676d84ed0958f227856823b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
\makeglossaries

\newglossaryentry{spa}
{
    name=Single-Page-Application,
    description={
        ist ein Webseiten-Modell, bei welchem dem Nutzer nur ein Webdokument
        bereitgestellt wird. Mit einem Skript wird der Inhalt der Seite
        dynamisch mit Daten einer API befüllt. Außerdem verwaltet die Seite
        (nicht der Server), welcher Inhalt bei welchem Pfad angezeigt wird. Dies
        erzeugt geringere Serverlast und eine bessere Nutzererfahrung, da die
        Seitenstruktur beim Laden von neuen Inhalten erhalten bleibt}
}

\newglossaryentry{packagemanager}
{
    name=Paketmanager,
    description={
        ist ein Programm, welches Pakete und dessen Abhängigkeiten verwaltet,
        installiert, entfernt und aktualisiert. Pakete können andere Programme,
        Plugins oder Software-Bibliotheken sein}
}

\newglossaryentry{bundler}
{
    name=Bundler,
    description={
        ist ein Programm, welches genutzte Teile von Abhängigkeiten eines
        Software-Projekts in passender Reihenfolge zusammensucht und daraus
        Dateien erstellt, die für den Nutzer bereitgestellt werden können. Dabei
        kann der Bundler mit zusätzlichen Modulen Dateien erzeugen, die
        rückwärtskompatibel oder für den Nutzer schwerer einsehbar sind}
}

\newglossaryentry{java}
{
    name=Java,
    description={
        ist eine objekt-orientierte interpretierte kompilierte
        Programmiersprache, welche plattformunabhängig auf einer virtuellen
        Maschine ausgeführt wird}
}

\newglossaryentry{db}
{
    name=Datenbank,
    plural=Datenbanken,
    description={
        ist ein System um Daten persistent zu speichern und effizient zu
        verwalten. Am meisten verbreitet sind relationale Datenbanken, welche
        Daten in Tabellen mit Referenzen zu Einträgen anderer Tabellen
        speichern. Programme können dann über eine Anfragesprache (Structured
        Query Language - \Gls{SQL}) komplexe Operationen auf den Daten ausführen}
}

\newglossaryentry{docker}
{
    name=Docker,
    description={
        ist ein Programm, das virtualisierte Container ausführt. Ein Programm in
        so einem Container läuft in seiner eigenen virtuellen Umgebung, wodurch
        das Host-System sicher bleibt. Zudem lassen sich die Container leicht
        auf andere Systeme verteilen}
}

% RESTfull-API, JSON, RSS-Feed, Salting and Hasing, OAuth, Cookie, Garbage
% Collection, DSGVO, Podcast, Podcatcher, Episode, Gpodder, 

\newglossaryentry{podcatcher}
{
    name=Podcatcher,
    plural=Podcatchern,
    description={
        ist ein Programm, über welches man Podcasts entdecken, abonnieren und
        Episoden von Podcasts hören kann. Mit einem Account auf einer Plattform,
        welche eine Gpodder-API zur Verfügung stellt, können Ereignisse, die von
        einem Nutzer ausgehen, auf anderen Podcatchern des Nutzers
        synchronisiert werden}
}

\newglossaryentry{podcast}
{
    name=Podcast,
    description={
        ist ein RSS-Feed, dessen Einträge die Episoden darstellen}
}

\newglossaryentry{episode}
{
    name=Episode,
    plural=Episoden,
    description={
        ist ein Eintrag in einem Podcast. Eine URL in dem Eintrag zeigt auf eine
        Medien-Datei, welche vom Podcatcher abgespielt werden kann}
}

\newglossaryentry{rest-api}
{
    name=RESTful-API,
    description={
        ist ein Schnittstellenentwurf über das Hypertext Transfer Protocol
        (HTTP), bei dem die Schnittstellen strukturiert als Pfad an einem
        Endpunkt erreichbar sind. Mittels verschiedener HTTP-Methoden können an
        der Schnittstelle Daten abgefragt (GET), gesendet (PUT), gelöscht
        (DELETE) oder geändert (POST) werden. Die Daten, die über die
        Schnittstelle gesendet werden liegen meist im JSON-Format vor}
}


\newglossaryentry{gpodder}
{
    name=Gpodder-API,
    description={
        wird von gpodder.net benutzt und entwickelt. Die API wird als
        Schnittstelle zwischen Podcatchern und Podcast Synchronisationsservern
        verwendet. Weitere Details sind unter
        "https://gpoddernet.readthedocs.io/en/latest/api/" zu finden}
}

\newglossaryentry{json}
{
    name=JSON,
    description={
        (JavaScript Object Notation) ist ein Datenformat und wird zur
        Übertragung von Strukturen und Daten eingesetzt. JSON besteht dabei aus
        grundlegenden Datentypen sowie Objekten mit Schlüssel-Wert Paaren und
        Listen}
}

\newglossaryentry{oauth}
{
    name=OAuth,
    description={
        (Open Authorization) ist ein offenes Protokoll, welches es Nutzern
        ermöglicht, sich mit bereits bestehenden Accounts bei anderen Diensten
        zu registrieren. Dabei werden benötigte Daten für die Registrierung über
        die bereitgestellte Schnittstelle zur Verfügung gestellt}
}

\newglossaryentry{garbage-collection}
{
    name=Garbage Collection,
    description={
        ist eine automatische Speicherbereinigung, welche nicht mehr benötigten
        Speicherplatz wieder freigibt. Die Bereinigung kann dabei in determinierten
        Zeitintervallen erfolgen oder durch bestimmte Ereignisse ausgelöst
        werden}
}

\newglossaryentry{salt-hash}
{
    name=Salting und Hashing,
    description={
        ist eine Methode um Passwörter so zu kodieren, dass sie nicht als
        Klartext gespeichert werden und auch sicher vor Hash-Wörterbüchern sind. 
        Dafür wird dem Passwort ein bekanntes Wort, der Salt, angefügt, bevor
        aus dem kompletten Wort eine Prüfsumme, ein Hash, generiert wird. Beim
        Anmelden wird die Prüfsumme der Anmeldung mit der bekannten
        Prüfsumme des Passworts verglichen}
}

\newglossaryentry{rss}
{
    name=RSS,
    description={
        (Really Simple Syndication) zeigt strukturiert Listen von Nachrichten
        an. Die Änderungen werden im XML-Format in sogenannte RSS-Dateien
        geschrieben, welche über einen Link abgerufen werden können}
}

\newglossaryentry{dsgvo}
{
    name=Datenschutz-Grundverordnung,
    description={
        (DSGVO) ist eine im europäischen Wirtschaftsraum
        geltende Verordnung. Sie sorgt für eine Reglementierung bei der
        Verarbeitung personenbezogener Daten. Unter anderem muss einsehbar sein,
        welche Daten von Nutzern erhoben werden. Außerdem muss für einen Nutzer
        die Möglichkeit bestehen, seine erhobenen Daten abrufen zu können}
}

\newglossaryentry{push-pull}
{
    name=Push und Pull,
    description={
        sind Methoden, um Daten auszutauschen. Bei der Pull-Methode
        stellt Akteur A einem Akteur B eine Anfrage auf Daten und erhält diese
        als Antwort. Damit Akteur A und B immer auf dem selben Stand sind, muss
        Akteur A chronisch Anfragen an Akteur B stellen. Im Gegensatz dazu steht
        die Push-Methode, bei der Akteur B den Akteuren mitteilt, dass er neue
        Änderungen hat. Dafür muss Akteur B allerdings wissen mit welchen
        anderen Akteuren er in Verbindung steht und diese Verbindung aufrecht
        erhalten}
}

\newglossaryentry{ui-lib}
{
    name=UI-Bibliothek,
    plural=UI-Bibliotheken,
    description={
        kümmert sich um das Layout einer Webseite. Dabei unterscheidet man
        zwischen Design-Bibliotheken (wie Bootstrap), welche fertige
        UI-Komponenten bereitstellen, und Layout-Bibliotheken (wie Vue oder
        React.js), welche die Komponenten basierend auf Daten dynamisch
        anzeigen}
}

\newglossaryentry{responsive}
{
    name=Responsive,
    description={
        Design ist ein Design-Prinzip für Webseiten, bei dem die selbe Webseite ihre
        Komponenten dynamisch der Bildschirmbreite anpasst}
}

\newglossaryentry{pseudoprotocol}
{
    name=Pseudoprotokoll,
    description={
        ist ein URL-Schema, auf das Webseiten hören können, wenn sie sich das
        URL-Schema im Browser anmelden. Bekannt Pseudoprotokolle sind:
        ,,mailto:'', ,,tel:'' oder ,,irc:''}
}

\newglossaryentry{dashboard}
{
    name=Dashboard,
    description={
        ist die erste Seite auf der man landet, wenn man angemeldet ist}
}

\newglossaryentry{abo}
{
    name=Abonnement,
    description={
        ist ein abonnierter Podcast}
}

\newglossaryentry{discovery}
{
    name=Discovery,
    description={
        ist ein Feature der Gpodder-API, welches dem Nutzer eine Reihe von
        Podcasts zum abonnieren anbietet}
}

\newglossaryentry{session-token}
{
    name=Session-Token,
    description={
        ist ein Wort, dass vom Client gespeichert wird solange der Nutzer
        eingeloggt ist und bei jeder Anfrage an den Server mitgeschickt wird. 
        Der Server kann den Session-Token einem Nutzer zuordnen und so mit
        nutzerspezifischen Daten antworten}
}

\newglossaryentry{cookie}
{
    name=Cookie,
    description={
        ist ein kleiner webseitenspezifischer Speicher im Browser, welcher vom
        Server und von der Webseite gesetzt werden kann und bei jeder weiteren
        Anfrage an den Server mitgesendet wird. Cookies bleiben entweder
        temporär im Browserspeicher, bis der Browser geschlossen wird oder
        permanent, bis ein optionales Verfallsdatum erreicht ist}
}

\newglossaryentry{uiComponent}
{
    name=UI-Komponente,
    plural=UI-Komponenten,
    description={
        In Vue.js werden die grafischen Elemente einer Webseite in einzelne
        Komponenten zerteilt. 
        Diese reagieren automatisch auf Änderungen und können ohne Neuladen
        der Seite ihr Aussehen verändern und somit Änderungen direkt anzeigen}
}

\newglossaryentry{spring}
{
	name=Spring,
	description={
		Ein Java-Framework, welches die Entwicklung von Web-Applikationen erleichtert.
		Dazu wird eine Reihe von Werkzeugsets zur Verfügung gestellt.
		Unter anderem sind das Spring Web für das Erstellen von Webanwendungen,
		Spring Security für die Verwaltung von Benutzerauthentifizierungen und
		Spring Data JPA für die Arbeit mit relationalen Datenbanken
    }
}

\newglossaryentry{api}
{
	name=API,
    plural=APIs,
	description={
		Eine Schnittstelle, welche es ermöglicht auf Funktionalitäten einer Anwendung
        zuzugreifen. APIs für Webanwendungen heißen WebAPIs.
        Ein Beispiel für eine WebAPI ist die REST-API
    }
}

\newglossaryentry{business}
{
	name=Geschäftslogik,
	description={
		Eine Schicht in der Anwendungsentwicklung, in der die Art und Weise, wie das
        Programm auf Eingaben reagiert, wie Daten verarbeitet und wie sie gespeichert
        werden sollen, festgelegt ist
    }
}

\newglossaryentry{solid}
{
	name=SOLID,
	description={
		Eine Sammlung an Prinzipien, welche zu gutem objektorientierten Design führen soll.
        Jedes Prinzip steht für einen Buchstaben in SOLID:
        \textbf{S}ingle-Responsibility Prinzip,
        \textbf{O}pen-Closed Prinzip,
        \textbf{L}iskovsches Substitutionsprinzip,
        \textbf{I}nterface Segregation Prinzip und
        \textbf{D}ependency Inversion Prinzip
    }
}

\newglossaryentry{crud}
{
	name=CRUD,
	description={
		CRUD steht für \textbf{C}reate, \textbf{R}ead, \textbf{U}pdate und \textbf{D}elete.
        Hierbei handelt es sich um die grundlegenden Funktionen einer Anwendung,
        die mit einer Datenbank arbeitet.
        Hierbei können Daten angelegt, abgerufen, aktualisiert und gelöscht werden.
        Auch in Web-Applikationen ist CRUD mit HTTP über die Anfragen POST, GET, PUT und DELETE
        vertreten
    }
}

\newglossaryentry{SQL}
{
    name=SQL,
    description={
        SQL (Structured Query Language) ist eine Sprache, die einen strukturierten Zugriff auf Datenbanken ermöglicht.
        Daten können hierbei hinzugefügt, abgefragt, geändert und gelöscht werden.
        Das besondere hierbei ist der strukturierte Zugriff auf Daten, indem explizit Daten mit bestimmten Kriterien und
        Relationen ausgewählt und bearbeitet werden können.
        SQL wird fast von allen verbreiteten Datenbanksystemen unterstützt
    }
}

\newglossaryentry{Base64}
{
    name=Base64,
    description={
        Mithilfe von Base64 können 8-Bit-Binärdaten in eine ASCII-Zeichenkette
        kodiert werden. So werden zum Beispiel E-Mail-Anhänge versendet
    }
}

\newglossaryentry{JSONP}
{
    name=JSONP,
    description={
        JSONP ermöglicht die Übertragung von JSON-Daten zwischen verschiedenen Domains.
        Dies wäre durch die Same-Origin-Policy nicht möglich.
        JSONP nutzt allerdings die Tatsache aus,
        dass sich Skripte domainübergreifend übertragen lassen.
        Dazu werden die JSON-Daten als Argument einer übergebenen Funktion über
        ein Skript-Element eingebunden
    }
}