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 | 
