summaryrefslogtreecommitdiff
path: root/Year_3/TSDWL
diff options
context:
space:
mode:
authorSanto Cariotti <santo@dcariotti.me>2021-10-22 23:31:09 +0200
committerSanto Cariotti <santo@dcariotti.me>2021-10-22 23:54:03 +0200
commit3a892d9735205119b4765abf230d6045645b8c6c (patch)
treeae9f82f75c7ad66360badc4eebc86078c196327e /Year_3/TSDWL
parent7bc84e24948fc1a16827477d4a5055336f852eb7 (diff)
readme file
Diffstat (limited to 'Year_3/TSDWL')
-rw-r--r--Year_3/TSDWL/webserver/CMakeLists.txt5
-rw-r--r--Year_3/TSDWL/webserver/README.md65
-rw-r--r--Year_3/TSDWL/webserver/webserver.tar.xzbin0 -> 3908 bytes
3 files changed, 70 insertions, 0 deletions
diff --git a/Year_3/TSDWL/webserver/CMakeLists.txt b/Year_3/TSDWL/webserver/CMakeLists.txt
new file mode 100644
index 0000000..b3947fc
--- /dev/null
+++ b/Year_3/TSDWL/webserver/CMakeLists.txt
@@ -0,0 +1,5 @@
+cmake_minimum_required(VERSION 2.8.9)
+project(server)
+
+file(GLOB SOURCES "*.c")
+add_executable(${CMAKE_PROJECT_NAME} ${SOURCES})
diff --git a/Year_3/TSDWL/webserver/README.md b/Year_3/TSDWL/webserver/README.md
new file mode 100644
index 0000000..0fee76a
--- /dev/null
+++ b/Year_3/TSDWL/webserver/README.md
@@ -0,0 +1,65 @@
+# Installazione
+
+Scaricare la tarball:
+```
+http://git.dcariotti.me/unict/plain/Year_3/TSDWL/webserver/webserver.tar.xz
+tar -J -xvf webserver.tar.xz
+```
+
+(facoltativo) Creare una cartella per i file del server
+
+Farne la build
+```
+cmake .
+./server
+```
+
+Alternativamente a tutto ciò si può scaricare la cartella presente in
+```
+http://git.dcariotti.me/unict/tree/Year_3/TSDWL/webserver
+```
+e farne la build. Ma meglio non scaricare tutti i file presenti sulla repo visto
+che non c'entrano né col corso, né con l'esercizio.
+
+# Avvio
+Il file `./server` può essere eseguito come
+```
+./server <port> [root]
+```
+dove la `<port>` è obbligatoria, mentre la cartella `[root]`, ovvero quella
+specificata prima dove saranno i file e che il server andrà ad interrogare, sarà
+facoltativa. Di default andrà a cercare dentro una cartella `www` presente nella
+cartella corrente.
+
+# Test
+Aprire una connessione con `telnet` come
+```
+telnet <ip> <port>
+```
+
+Eseguira una chiamata GET come
+```
+GET / HTTP/2
+[...]
+
+
+```
+Tutti gli altri headers saranno ignorati. Al secondo invio verrà cercato il file
+all'interno del server. La path e la versione di HTTP sono chiaramente variabili.
+
+Il responso è completo nel caso di stato 200 o 206, per tutti gli altri sarà una
+riga con risposta 404 o 405.
+
+Attualmente il `Content-type` è staticamente a `text/txt`.
+
+Il test può essere fatto anche con client come Insomnia o cURL:
+```
+curl <ip>:<port>/<path>
+```
+
+# Nota
+Quando si passa come path la "/" si farà una ricerca al file `index.html`.
+
+---
+
+I numerosi commenti `TODO` e `FIXME` saranno sistemati in seguito.
diff --git a/Year_3/TSDWL/webserver/webserver.tar.xz b/Year_3/TSDWL/webserver/webserver.tar.xz
new file mode 100644
index 0000000..db0b5dd
--- /dev/null
+++ b/Year_3/TSDWL/webserver/webserver.tar.xz
Binary files differ