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
|
# Installing
Follow these steps to install everything required for the project to run.
There is a script `setup.sh` on this repository. It will walk you through installing everything. It's not foolproof, so read carefully its prompts and give sensible answers.
The script will declare the installation to have succeeded in the end. If you don't see a message confirming the script's success, something has likely gone wrong.
After running the script there should be a new directory in the path you specified, named LYLLRuoka. This will be referenced to as the "BASE DIRECTORY" from now on.
> `setup.sh` has only been tested on Ubuntu 20.04 and requires `apt-get` to be available.
## Details about the prompts in setup.sh
Below is more information about the information `setup.sh` will ask you. Take a look here if you are unsure what you should type in.
* Install directory: this is the directory where LYLLRuoka should be installed. Supply an absolute path, ie. a path starting with `/`. You should have permissions to read, write and execute in the directory you give. The script will create the "BASE DIRECTORY" in the path you supply, and that directory will contain a folder with the server code and some things needed to run the server. If you are unsure, $HOME (supply as `/home/[username]` is a good choice.
* MySQL username: `setup.sh` will install and configure a MySQL server. On the go it will create a user the server will use to access the `lyllruoka`-database created on the MySQL server. Here you should supply the desired username. Anything goes, really, as long as it is a valid MySQL username. Don't include any quotations or the hostname: these are added automatically.
* TLS/SSL certificate: If you choose to let the script generate a self-signed certificate, it will ask a few questions detailed below. Remember to change the self-signed certificate to a certificate signed by a certificate authority. The certificate's private and public key should be placed in `["BASE DIRECTORY"]/Certificate/key.pem` and `["BASE DIRECTORY"]/cert.pem` respectively.
* Common name: insert here the domain name where the server will server content, eg. `food.example.com`. Don't include the protocol (eg. `http://`) or any path (eg. `example.com/lorem`),
* Email address: should be self explanatory.
# Required data
The server actually needs to know the food shifts somehow before it can actually serve them. After running the installation script mentioned above there should be a subdirectory called `Updation` in the "BASE DIRECTORY". It should contain three files: `shifts.txt`, `vanhalops.csv` and `uusilops.csv`. These files are empty, and you will have to populate them. This is data that should be updated in the beginning of every period.
## shifts.txt
1. Open Wilma: <https://lohja.inschool.fi>
2. Go to the message section.
3. Search the newest message with a header like "Periodin [some number] työpäivän keskimmäisen oppitunnin ruokailuvuorot ja oppitunti [date] alkaen"
4. Copy all the message contents starting from "MAANANTAISIN".
5. Paste it into `shifts.txt`
6. Profit.
## uusilops.csv and vanhalops.csv
If there are students studying two separate curriculums, one newer and one older, you will have to do this for both files. If not, using either one will suffice.
1. Get the Kurssitarjotin for the appropriate curriculum from junu or somewhere else as a spreadsheet file
2. Open the file
3. Search the period we are in
4. Copy and paste all the data about that period into uusilops.csv or vanhalops.csv. You know which one.
5. The output should look something like this:
```
t1 t2 t3 t4 t5 t6 t7 t8
UE11 KE11 BI11 GE11 RUB121 MAA31 ENA121 SAB321
TEKE SAKO LAMI PAHO MAOI JUMA VIHU
B101R A101R B101R B103R A204R B202R A203R TH
SAB221 BI12 KE31 UE12 RUB122 MAA32 FY33 RAB322
SABE PAHO MATI TEKE ANSU SAKO SALE
A202R B103R A101R B105R B109R B203R B101R TH
RUB123 MAA33 LI31 MU13 KU13 RAB321 HI52 VEB321
ANSU RIHO JUHO MAMY REOJ MASI JAJU
B109R B202R B201R A201R B210R B105R TH
HI42 MAB22 GE14 KU14 ÄI44 LI17 RUB124
JUSA JOTO PAHO REOJ VETU JUHO KAHU
B106R B104R B103R A201R B107R B209R
UE15 MAA34 TE15 BI15 RUB125 LI15 KU71
SATU MATI SATU HEIH KAHU ANSA REOJ
B108R B203R B108R B110R B103R A201R
FI81 PS22 FI16 KE16 UE16 RUB126 LI18
ALMA SATU ALMA MATI ALMA MAOI ANSA
B105R B108R B105R A101R B105R A204R
FY31 MAA35 KU17 RUB127 ÄI47 ENA37
ESRI SALE REOJ ANSU HAPA SABE
B102R B101R A201R B109R B108R B106R
MU81 ENA122 MU18 EAB331 RUA21 MAB21 KE18
MAMY VIHU MAMY VIHU SASA SAHE SAHE
B201R A203R B201R A203R A202R B101R A101R
FY111 LI31 FY32 GE18 MAB24
ESRI ANSA OLNU HEIH SAKO
B102R B104R A102R B203R
AT31 BI18
RIHO HEIH
A201R A102R
P E R I O D I IVB
t1 t2 t3 t4 t5 t6 t7 t8
UE11 KE21 BI11 GE11 RUB121 MAA41 ENA121 SAB321
TEKE SAKO LAMI PAHO MAOI JUMA VIHU
B101R A101R B101R B103R A204R B202R A203R TH
SAB221 BI12 KE31 UE12 RUB122 MAA42 FY33 RAB322
SABE PAHO MATI TEKE ANSU SAKO SALE
A202R B103R A101R B105R B109R B203R B101R TH
RUB123 MAA43 LI31 MU13 KU13 RAB321 HI52 VEB321
ANSU RIHO JUHO MAMY REOJ MASI JAJU
B109R B202R B201R A201R B210R B105R TH
HI42 MAB22 GE14 KU14 ÄI44 LI17 RUB124
JUSA JOTO PAHO REOJ VETU JUHO KAHU
B106R B104R B103R A201R B107R B209R
UE15 MAA44 TE15 BI15 RUB125 LI15 KU71
SATU MATI SATU HEIH KAHU ANSA REOJ
B108R B203R B108R B110R B103R A201R
FI81 PS22 FI16 KE26 UE16 RUB126 LI18
ALMA SATU ALMA MATI ALMA MAOI ANSA
B105R B108R B105R A101R B105R A204R
FY31 MAA45 KU17 RUB127 ÄI47 ENA37
ESRI SALE REOJ ANSU HAPA SABE
B102R B101R A201R B109R B108R B106R
MU81 ENA122 MU18 EAB331 RUA21 MAB21 KE28
MAMY VIHU MAMY VIHU SASA SAHE SAHE
B201R A203R B201R A203R A202R B101R A101R
FY111 LI32 FY32 GE18 MAB24
ESRI ANSA OLNU HEIH SAKO
B102R B104R A102R B203R
KU151 BI18
REOJ HEIH
A201R A102R
```
The server isn't very picky about what area you have copy-pasted here. The only requirement is that there should be no data from other periods visible. Otherwise the server will use that data too.
# Running
Now that you have given all required data to the server, you can run it. In the "BASE DIRECTORY" there should be a directory named `LYLLRuoka` (yes, there are two nested directories with the same name). Enter that directory. See the file `server.js`? Good. Now, in this directory, run as root `node server.js`. The output should look like this:
```
Shifts and classes updated.
Foods updated.
Servers Up And Running!
```
Great! Now you have the server running. If you restart the server or close the terminal window or anything else, you will obviously have to restart the server.
You can make the server run automatically on reboot.
Add to **roots** crontab (run `sudo crontab -e`):
```
@reboot BASE_DIR='["BASE_DIRECTORY"]' ["BASE_DIRECTORY"]/LYLLRuoka/init.sh
```
For example: `@reboot BASE_DIR='/home/foobar/LYLLRuoka' /home/foobar/LYLLRuoka/LYLLRuoka/init.sh`
If you need to troubleshoot the starting, you can find some logs in /tmp/slogs. Newest at the bottom.
# Adding cool data that isn't required for the server to run
## Notifying of unusual food shifts (eg. during exams or vacations)
Currently the notifications have to be added manually to the MySQL database. Here's an example:
```
USE lyllruoka;
INSERT INTO exams VALUES ('2021-11-22', '2021-11-30', '<h2>Koeviikko</h2>22.11. - 30.11..<br>Kouluruokaa on tarjolla 10:45-11:30.');
```
The first value in the parenthesis is the start date of the notification, the second the end date of the notification and the third value is the message to display. HTML is supported. The message will override the food shift result.
## Updating the developer table
Updating the developer table is pretty straightforward. You just need to provide the name of the developer, a description (eg. "Improved the performance of the server") and contact information:
```
INSERT INTO devs (name, description, contact) VALUES ('[name]', '[description]', '[contact]');
```
> Insert the values in the quotation marks, don't change the text before the `VALUES` keyword.
|