Bot sviluppato in Node.js che permette la prenotazione e il successivo invio dello screenshot di quest'ultima tramite un bot di telegram
Node.js è un runtime system open source, compatibile con MacOS, linux e windows, per maggiori informazioni visitare questo link. Per installare Node.js sulla propria macchina si può procedere scaricando il pacchetto dal sito ufficiale (link) oppure tramite NVM(Node Version Manager), al seguente link.
N.B: si consiglia di utilizzare la versione 15.14.0 di Node.js sulla quale è stata sviluppato e testato l'applicativo, e di conseguenza di utilizzare NVM per l'installazione
Non sono richiesti alcuni requisiti di hardware, ma affinché il Bot prenoti in automatico l'aula desiderata è fortemente consigliato un dispositivo che rimanga acceso 24/7. Si possono utilizzare dei siti di Hosting online, come ad esempio AWS, Azure, Heroku, etc...
-
Clonare la repository di git
-
Creare un file chiamato
config.json
-
Compilare il file
config.json
, tenendo conto che al suo interno vi deve essere un JSON.
Per prima cosa è fortemente consigliato copiare e incollare la sottostante configurazione.
{
"BOT_TOKEN": "<BOT TOKEN>",
"orario": "<ORARIO FORMATO CRON>",
"viewport": {
"width": "<WIDTH>",
"height": "<HEIGHT>"
},
"config": {
"headless": "<MODE>"
},
"users": {
"user1": {
"credentials": {
"username": "<ESSE3 USERNAME>",
"password": "<ESSE3 PASSWORD>",
"tg_username": "<TELEGRAM USERNAME>"
},
"Sunday": [ ],
"Monday": [ "<SP>" ],
"Tuesday": [ "<SP>" ],
"Wednesday": [ "<SP>" ],
"Thursday": [ "<SP>" ],
"Friday": [ "<SP>" ],
"Saturday": [ ]
},
"user2": {
"credentials": {
"username": "<ESSE3 USERNAME>",
"password": "<ESSE3 PASSWORD>",
"tg_username": "<TELEGRAM USERNAME>"
},
"Sunday": [ ],
"Monday": [ "<SP>" ],
"Tuesday": [ "<SP>" ],
"Wednesday": [ "<SP>" ],
"Thursday": [ "<SP>" ],
"Friday": [ "<SP>" ],
"Saturday": [ ]
}
}
}
Nella chiave BOT_TOKEN
va specificato come stringa(tra virgolette) il token del bot da voi creato e sul quale si vuole ricevere gli screenshot della prenotazione.
N.B la chiave deve essere presente nell'oggetto di configurazione e deve essere specificato un valore corretto
Nella chiave orario
va specificato l'ora e i minuti in cui il bot in automatico andrà ad attivarsi.
Questo dato è una stringa ed esiste un formato da rispettare chiamato Cron time string format, vi lasciamo un
link in cui è spiegato l'utilizzo e nel quale vi sono alcuni esempi.
N.B la chiave deve essere presente nell'oggetto di configurazione e deve essere specificato un valore corretto
La proprietà viewport
va compilata con un oggetto nel quale siano presenti le chiavi width
e height
, ciascuna di esse deve essere di tipo numerico.
Tramite width
(larghezza) e height
(altezza) si andranno a settare le dimensioni della pagina del browser e di conseguenza dello screenshot della prenotazione.
N.B la chiave deve essere presente nell'oggetto di configurazione e deve essere specificato un valore corretto
La chiave config
va compilata come oggetto.
Può essere lasciata come oggetto vuoto {}
in tal caso si useranno le configurazioni di default.
L'unica chiave che consigliamo di specificare è headless
che assume valori booleani (true
o false
) e determina la apertura programmatica di un browser in modalità background o meno;
La configurazione consigliata per la chiave config
nel caso in cui si utilizzi un Raspberry py è la seguente:
"config": {
"headless": true,
"executablePath": "/usr/bin/chromium-browser",
"args": ["--no-sandbox", "--disable-setuid-sandbox"]
}
N.B la chiave deve essere presente nell'oggetto ma può essere compilata come oggetto vuoto. Per maggiori informazioni sugli argomenti che è possibile passare nella chiave
args
è possibile trovare la documentazione ufficiale in questo link
La chiave users
va compilata come oggetto.
Al suo interno è possibile specificare un numero arbitrario di utenti.
Il programma prenoterà l'aula per ciascuno degli utenti configurati nel file.
Ogni utente viene definito da un identificativo non rilevante ai fini dell'esecuzione (user1
), questo identificativo è anche la chiave che contiene tutte le informazioni di un utente.
N.B la chiave deve essere presente nell'oggetto di configurazione e deve essere specificato un valore corretto
La chiave credentials
va compilata come oggetto.
Al suo interno vanno inserite le chiavi:
username
il nome utente di ESSE3.
password
la password di ESSE3.
tg_username
username di telegram per permette al bot di inviarvi un messaggio.
N.B lo username di telegram va inserito senza mettere la @.
Ogni aula del nostro dipartimento viene codificata da un codice sp.
I codici corrispondono a un'aula e a un determinato orario.
Questo codice viene inserito alla fine dell'url seguendo lo schema sotto riportato:
(https://presenze.unimore.it/spacemr/#?page=s__prsncdd&sp= (CODICE DA COPIARE))
Bisogna inserire questo codice in formato stringa.
Nel caso nell'arco di una giornata sia necessario prenotare più di un'aula, inserisci i codici come segue:
"Monday": ["1", "2"]
N.B nel caso un giorno non si voglia prenotare nessuna aula, lasciare il campo
sp
vuoto.
Per installare i node modules scrivere il comando npm i
N.B Assicurarsi d'installare il modulo pm2 globalmente tramite il comando
npm i -g pm2
.
Nella cartella photos
è possibile inserire una foto in formato jpeg del proprio green pass.
Il bot di telegram provvederà a inviarlo assieme allo screenshot della prenotazione.
Salvare la foto come segue: pass-(tg_username).jpeg
.
N.B questo punto è facoltativo e non inciderà sull'esecuzione del programma.
Per avviare il bot usare il comando npm start
Per stoppare il bot avviato con pm2 utilizzare il comando da terminale npm stop
Per avviare il bot in modalità development utilizzare il comando da terminale npm run dev
.
Questa modalità vi permetterà di avviare una sola volta il bot,
il quale al termine dei processi si stopperà da solo