diff options
author | Noah Loomans <noahloomans@gmail.com> | 2016-09-05 19:55:53 +0200 |
---|---|---|
committer | Noah Loomans <noahloomans@gmail.com> | 2016-09-05 19:55:53 +0200 |
commit | 0acf4e0774e0daeed2c386e4d9c0ac36da70a244 (patch) | |
tree | 839f0db637e379d433f1a82eb23ade74f0569522 /routes/getUserIndex.js | |
parent | 0bf0cddc5c6c8bce34a9df1e376759eb5773d16b (diff) |
you can now search by name
Diffstat (limited to 'routes/getUserIndex.js')
-rw-r--r-- | routes/getUserIndex.js | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/routes/getUserIndex.js b/routes/getUserIndex.js new file mode 100644 index 0000000..4e958d4 --- /dev/null +++ b/routes/getUserIndex.js @@ -0,0 +1,118 @@ +const express = require('express') +const router = express.Router() +const Promise = require('bluebird') +const cheerio = require('cheerio') +const request = Promise.promisify(require('request')) +const getURLOfUsers = require('../lib/getURLOfUsers') +const encoding = require('encoding') + +// function moveItem (array, oldIndex, newIndex) { +// while (oldIndex < 0) { +// oldIndex += array.length +// } +// while (newIndex < 0) { +// newIndex += array.length +// } +// if (newIndex >= array.length) { +// var k = newIndex - array.length +// while ((k--) + 1) { +// array.push(undefined) +// } +// } +// array.splice(newIndex, 0, array.splice(oldIndex, 1)[0]) +// return array +// } + +function getStandardUsers () { + return new Promise(function (resolve, reject) { + request(`http://www.meetingpointmco.nl/Roosters-AL/doc/dagroosters/frames/navbar.htm`) + .then(function (page) { + page = page.body + + const $ = cheerio.load(page) + const $script = $('script').eq(1) + const scriptText = $script.text() + + const regexs = [/var classes = \[(.+)\];/, /var teachers = \[(.+)\];/, /var rooms = \[(.+)\];/, /var students = \[(.+)\];/] + const items = regexs.map(function (regex) { + return scriptText.match(regex)[1].split(',').map(function (item) { + return item.replace(/"/g, '') + }) + }) + + resolve([] + .concat(items[0].map(function (item, index) { + return { + type: 'c', + value: item, + index: index, + other: '' + } + })) + .concat(items[1].map(function (item, index) { + return { + type: 't', + value: item, + index: index, + other: '' + } + })) + .concat(items[2].map(function (item, index) { + return { + type: 'r', + value: item, + index: index, + other: '' + } + })) + .concat(items[3].map(function (item, index) { + return { + type: 's', + value: item, + index: index, + other: '' + } + }))) + }) + }) +} + +function addExtendedUsers (standardUsers) { + const standardUsersLength = standardUsers.length + for (let i = 0; i < standardUsersLength; i++) { + // for (let i = 200; i < 220; i++) { + request(getURLOfUsers(0, standardUsers[i].type, standardUsers[i].index + 1)) + .then(page => page.body) + .then(page => encoding.convert(page, 'UTF-8', 'Windows-1252')) + .then(function (page) { + const $ = cheerio.load(page) + let extendedName = $('font').eq(2).text().trim() + + if (standardUsers[i].type === 's' || standardUsers[i].type === 't') { + extendedName = extendedName.split(/\s+/).reverse().join(' ') + } + + if (extendedName.indexOf(standardUsers[i].value) === -1 && + extendedName.indexOf(standardUsers[i].value.substring(2, standardUsers[i].value.length))) { + console.log(`added ${extendedName}: ${standardUsers[i].value}`) + standardUsers[i].other = extendedName + standardUsers.push({ + type: standardUsers[i].type, + index: standardUsers[i].index, + value: extendedName, + other: standardUsers[i].value + }) + } + }) + } +} + +getStandardUsers().then(users => { + addExtendedUsers(users) + + router.get('/', function (req, res, next) { + res.json(users) + }) +}) + +module.exports = router |