Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 17 additions & 3 deletions 01-basic-cs/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,29 @@ const assert = require('assert')

const database = require('./database.json')

const total = 0 // TODO
let total = 0 // TODO

const hats = _.flatMap(database, 'hats')
if (hats.length > 0) {
const countHatsById = _.countBy(hats, 'id')
const topHatsIds = _.chain(countHatsById)
.entries()
.orderBy(['1', '0'], ['desc', 'asc'])
.take(3)
.map('0')
.value()
total = _.sum(_.values(_.pick(countHatsById, topHatsIds)))
} else {
console.log('no hats in db')
}
// Throws error on failure
assert.equal(total, 23, `Invalid result: ${total} != 23`)

console.log('Success!')

/**
* Time and space complexity in O() notation is:
* - time complexity: TODO
* - space complexity: TODO
* - time complexity: O(n)
* - space complexity: O(n)

*/
34 changes: 34 additions & 0 deletions 02-nodejs/controllers/user.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
const User = require('../models/User')
const createCsvWriter = require('csv-writer').createObjectCsvWriter
const path = require('path')

const csvWriter = createCsvWriter({
path: 'bd.csv',
header: [
{ id: '_id', title: '_id' },
{ id: 'name', title: 'name' },
{ id: 'email', title: 'email' }
]
})
exports.users = async (req, res, next) => {
const find = User.find({}).lean().cursor()
find.eachAsync(async (user) => {
await csvWriter.writeRecords([user])
console.log(user.email)
})
.then(() => {
console.log('CSV File generated')
res.download(path.join(__dirname, '../../bd.csv'), 'bd.csv', (error) => {
if (error) {
console.error('Download error in CSV File:', error)
res.status(500).send('Download error in CSV File:')
} else {
console.log('CSV file download OK.')
}
})
})
.catch((error) => {
console.error('Error to generate CSV file:', error)
res.status(500).send('Error to generate CSV file:')
})
}
5 changes: 3 additions & 2 deletions 02-nodejs/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,12 @@

const express = require('express')

const User = require('./models/User')
const userRoutes = require('./routes/user')

// Setup Express.js app
const app = express()

// TODO: everything else
app.use('/api', userRoutes)

app.listen(3000)
app.listen(3000, () => console.log('server init'))
2 changes: 1 addition & 1 deletion 02-nodejs/models/User.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ const mongoose = require('mongoose')

// Setup database
mongoose.Promise = Promise
mongoose.connect('mongodb://localhost/mediastream-challenge')
mongoose.connect('mongodb://localhost:2701/mediastream-challenge')

const User = mongoose.model('User', {
name: String,
Expand Down
8 changes: 8 additions & 0 deletions 02-nodejs/routes/user.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
const express = require('express')
const router = express.Router()

const { users } = require('../controllers/user')

router.get('/users', users)

module.exports = router
Loading