Sitema di backup remoto
L'applicazione ha il compito di fornire un sistema di incremental backup del contenuto di una cartella definita dall'utente. Una volta lanciata, un processo in background provvede a sincronizzare il contenuto della cartella scelta dall'utente con un'analoga sul server.
L'environment scelto per lo sviluppo dell'applicativo si basa su Docker container. La scelta ricade su questo tipo di tecnologia per i seguenti motivi:
-
virtualizzazione: tramite virtualizzazione si abbattono le differenze provenienti dai vari sistemi, di conseguenza ogni sviluppatore può interagire con lo stesso identico environment che utilizzeranno anche gli altri. Questo permette di evitare conflitti dovuti a diverse versioni di librerie e permette di evitare il classico problema del "Funziona sul mio pc".
-
filesystem: la tecnologia dei container si basa sul concetto di image. Vista da un punto di vista molto astratto un immagine docker non è nient'altro che un filesystem; questo oltre a risolvere il problema di avere diverse versioni di librerie si presta molto al contesto dell'applicazione da sviluppare. Utilizzando diversi container infatti si può testare in maniera semplice la sincronizzazione di una cartella tra versione locale e remota. Ogni container infatti ha il suo filesystem che è isolato da quello degli altri.
-
network: la tecnologia docker permette di creare in maniera molto comoda delle reti sulle quali i container possono comunicare. In questo modo si possono simulare dei contesti di rete che sono fedeli a quelli nei quali si viene a trovare l'applicativo da distribuire.
-
docker-compose: docker compose è un tool che permette in maniera molto semplice di coordinare diversi container, in questo modo è possibile simulare diversi client che agiscono sul sistema, ma anche creare delle repliche del server nell'ottica di rendere più scalabile l'applicazione.
Per utilizzare comodamente docker su Linux può risultare utile aggiungere docker ad un gruppo.
-
Creare il gruppo con il comando:
sudo groupadd docker
-
Aggiungere utente al gruppo docker:
sudo usermod -aG docker $USER
-
A questo punto effettuare logout e login per rendere effettive le modifiche, alternativamente eseguire il comando:
newgrp docker
-
Testare eseguendo il comando:
docker run hello-world
.
Dopo aver lanciato i vari servizi aprire una finestra di terminale ed eseguire il seguente comando:
docker exec -it remote_backup_<nome_servizio>_<id_progressivo_servizio> /bin/bash
Dopo aver lanciato i vari servizi aprire una finestra di terminale ed eseguire i seguenti comandi in ordine:
-
docker exec -it remote_backup_db_<id_progressivo_db> /bin/bash
. -
Una volta entrati all'interno del container, loggarsi tramite il comando
mysql -u root -p
. A questo punto verrà richiesta la password che nel nostro caso èexample
. -
Una volta effettuato il login è possibile eseguire comandi SQL a piacere. Alcuni comandi utili:
-
show databases;
: permette di visualizzare quali databases esistono all'interno del server. -
use <db_name>;
: permette di porsi all'interno di un db, solo da qui sono eseguibili le query per questo determinato db.
-
-
Una volta selezionato il dabase, eseguire tali comandi per interagire col db:
-
show tables;
: permette di elencare le tabelle presenti all'interno del db precedentemente selezionato. -
describe <tablename>;
: permette di mostrare la struttura della tabella (nomi e tipo campi...) selezionata. -
SELECT * from <tablename>;
: Permette di visualizzare il contenuto della tabella selezionata.
-
Link utili per gestione IPC e tray app: menubar, electron tray, ipc main, ipc render.
POST /auth/signup
-
Descrizione: Endpoint che permette di registrare un nuovo utente, ponendo l'hashed_status = "empty_hashed_status"
-
Authenticated:
FALSE
- Parametri:
{ username : username , password : password , password : password }
- Risposta: In caso negativo viene generato un messaggio HTTP 1.1 400
{ err_msg : message here }
, in caso positivo invece viene inviata una risposta HTTP 1.1 200 OK con relativo token generato nell'header della risposta.
POST /auth/signin
-
Descrizione: Endpoint che permette di autenticare un utente precedentemente registrato
-
Authenticated:
FALSE
- Parametri:
{ username : username , password : password }
- Risposta: In caso negativo viene generato un messaggio HTTP 1.1 400
{ err_msg : message here }
, in caso positivo invece viene inviata una risposta HTTP 1.1 200 OK con relativo token generato nell'header della risposta.
POST /chunk/{chunk_id}/{chunk_hash}/{num_chunks}/{file_pathBASE64}/{local_last_change}
-
Descrizione: endpoint che permette, se il client è autenticato, di aggiungere un file appena creato.
{chunk_id}
corrisponde al numero di chunk che stiamo inviando, 0 per il primo chunk. Il parametro{chunk_size}
corrisponde alla dimensione del chunk che stiamo inviando, questo corrisponde afull
se si invia un chunk di dimensione massima (2MB), altrimenti la dimensione in byte. -
Authenticated:
TRUE
- Parametri: HTTP headers: MIME: application/octect-stream body:
binary data here
- Risposta: In caso negativo viene generato un messaggio HTTP 1.1 400
{ err_msg : message here }
, in caso positivo invece viene inviata una risposta HTTP 1.1 200 OK senza alcun body all'interno.
GET /status/list/{num_pages}/{timestamp_locale}
-
Descrizione: endpoint che permette di ottenere il JSON file del server con i dettagli sullo stato della cartella remota.
-
Authenticated:
TRUE
GET /chunk/{chunk_id}/{file_pathBASE64}
-
Descrizione: endpoint che permette di ottenere un chunk di un file dal server.
-
Authenticated:
TRUE
L'interfaccia grafica è rappresentata da una tray app creata utilizzando Electron. Essendo questo un framework basato su node js occorre soddisfare alcuni prerequisiti per poter essere utilizzata:
- node js: testato con v10.17.0
- npm: testato con v6.14.6
- yarn: installato con comando
npm install -g yarn
per un'installazione globale
Una volta verificati i prerequisiti posizionarsi nella cartella ui
ed accertarsi che esista la cartella node_modules
, altrimenti eseguire il comando npm install
. A questo punto è possibile eseguire l'applicazione tramite il comando npm start
.
Una volta posizionati nella cartella relativa al progetto tramite terminale, eseguire docker-compose up --build
. Questo comando permette di eseguire i vari servizi che compongono l'applicativo. La terminazione può essere fatta tranquillamente in maniera ordinata con il comando CTRL+C
. Nel caso si voglia rendere un servizio scalabile si può apporre un opzione --scale <nome_servizio>=<num_repliche>
per ogni servizio che si vuole replicare.
N.B: al primo avvio nel file docker-compose, nel servizio di mysql, è necessario commentare l'opzione
command
riguardante il plugin di autenticazione con password e lasciare semplicemnte l'opzionecommand
che fa riferimento all'inizializzazione dei db, a questo punto spegnere tramiteCTRL+C
e riavviare con le opzioni invertite (init off e plugin on).
Gli eventi da monitorare sono:
- Creazione di un file
- Aggiornamento file
- Eliminazione file esistente
- Rinominazione file
- Error su FileWatcher