-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
73 lines (55 loc) · 1.76 KB
/
index.js
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
const express = require("express")
const {google} = require("googleapis")
require("dotenv").config()
const fs = require('fs');
const app = express()
app.set("view engine", "ejs");
app.use(express.static(__dirname + "/views"));
app.use(express.urlencoded({ extended: true }));
const Port = process.env.PORT || 3000
app.get("/", (req, res) => {
res.render("index")
});
app.post("/", async (req, res) => {
const auth = new google.auth.GoogleAuth({
keyFile: "credentials.json",
scopes: "https://www.googleapis.com/auth/spreadsheets"
})
const client = await auth.getClient()
const googleSheets = google.sheets({version: "v4", auth: client})
const getRows = await googleSheets.spreadsheets.values.get({
auth,
spreadsheetId: process.env.SHEET_ID,
range: "Sheet1!B:C"
});
let rows = (getRows.data.values)
rows.shift()
const regex = /^(22|23)[A-Za-z]{3,4}\d{3}$/;
rows = rows.filter((row) => {
row[1] = row[1].toUpperCase()
return regex.test(row[1])
});
// shuffle the array
for (let i = rows.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[rows[i], rows[j]] = [rows[j], rows[i]];
}
// make group of 5
const groups = [];
for (let i = 0; i < rows.length; i += 5) {
// groups.push(rows.slice(i, i + 5));
const group = rows.slice(i, i+5).map((member)=>{
return {
email: member[0],
roll: member[1]
}
});
groups.push(group);
}
// return res.json(groups);
return res.render("template.ejs", { data:groups });
});
app.listen(Port, (err)=>{
if(err) throw err;
console.log(`Server is running on port ${Port}`)
})