-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathserver.js
64 lines (53 loc) · 1.96 KB
/
server.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
'use strict'
const path = require('path')
const cors = require('cors')
const express = require('express')
const app = express()
const http = require('http').Server(app)
const io = require('socket.io')(http)
const tw = require('./src/twitter.js')
app.use('/api', cors())
app.use(express.static(path.join(__dirname, 'www')))
app.get('/api/:user', async (req, res) => {
const user = req.params.user
try {
const tweets = await tw.getUserTweets(user)
console.log(`[server] /api/:user got tweets for user ${user}`)
res.json({ error: null, tweets: tweets })
} catch (err) {
console.log(`[server] /api/:user got tweets for user ${user} with error:`)
console.error(err)
let message = `Error fetching tweets for user ${user}`
if (err.statusCode) {
res.status(err.statusCode)
res.status(500)
} else {
}
if (err.message) {
message = err.message
}
res.json({ error: message, tweets: null })
}
})
io.set('origins', '*:*')
io.on('connection', (socket) => {
console.log(`[server] Socket connected: ${socket.id}`)
socket.on('get-user-tweets', async (user) => {
console.log(`[server] received "get-user-tweets" socket.io event for twitter user "${user}"`)
if (typeof user !== 'string') {
const err = TypeError('user must be a string type')
io.emit('got-user-tweets', err, user, null)
return
}
try {
const tweets = await tw.getUserTweets(user)
io.emit('got-user-tweets', null, user, tweets)
console.log(`[server] emit socket.io event "got-user-tweets"`)
} catch (err) {
io.emit('got-user-tweets', err, user, null)
console.log(`[server] emit socket.io event "got-user-tweets" with error:`)
console.error(err)
}
})
})
http.listen(3000, () => { console.log('[server] Listening on http://0.0.0.0:3000') })