]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server.js
Server: check the host key is not present in configurations
[github/Chocobozzz/PeerTube.git] / server.js
CommitLineData
a030a9b2
C
1'use strict'
2
3// ----------- Node modules -----------
13ce1d01 4const bodyParser = require('body-parser')
b9ab2e25 5const cors = require('cors')
13ce1d01
C
6const express = require('express')
7const expressValidator = require('express-validator')
8const http = require('http')
9const morgan = require('morgan')
10const path = require('path')
11const TrackerServer = require('bittorrent-tracker').Server
12const WebSocketServer = require('ws').Server
a030a9b2 13
9f540774
C
14process.title = 'peertube'
15
a030a9b2 16// Create our main app
13ce1d01 17const app = express()
a030a9b2 18
00057e85 19// ----------- Database -----------
13ce1d01 20const constants = require('./server/initializers/constants')
13ce1d01 21const database = require('./server/initializers/database')
13ce1d01 22const logger = require('./server/helpers/logger')
00057e85
C
23
24database.connect()
25
69b0a27c
C
26// ----------- Checker -----------
27const checker = require('./server/initializers/checker')
28
b65c27aa
C
29const missed = checker.checkMissedConfig()
30if (missed.length !== 0) {
31 throw new Error('Miss some configurations keys : ' + missed)
32}
33
34const errorMessage = checker.checkConfig()
35if (errorMessage !== null) {
36 throw new Error(errorMessage)
69b0a27c
C
37}
38
00057e85 39// ----------- PeerTube modules -----------
5f698b82 40const customValidators = require('./server/helpers/custom-validators')
00057e85 41const installer = require('./server/initializers/installer')
00d6b0dd 42const migrator = require('./server/initializers/migrator')
00057e85 43const mongoose = require('mongoose')
13ce1d01 44const routes = require('./server/controllers')
00057e85 45const Request = mongoose.model('Request')
a030a9b2 46
a030a9b2
C
47// ----------- Command line -----------
48
49// ----------- App -----------
50
51// For the logger
52app.use(morgan('combined', { stream: logger.stream }))
53// For body requests
def16d33 54app.use(bodyParser.json({ limit: '500kb' }))
a030a9b2
C
55app.use(bodyParser.urlencoded({ extended: false }))
56// Validate some params for the API
57app.use(expressValidator({
d57d6f26
C
58 customValidators: Object.assign(
59 {},
60 customValidators.misc,
61 customValidators.pods,
62 customValidators.users,
63 customValidators.videos
64 )
a030a9b2
C
65}))
66
67// ----------- Views, routes and static files -----------
68
a030a9b2 69// API routes
bc503c2a
C
70const apiRoute = '/api/' + constants.API_VERSION
71app.use(apiRoute, routes.api)
a030a9b2 72
bd324a66 73// Static files
dc009132 74app.use('/client', express.static(path.join(__dirname, '/client/dist'), { maxAge: constants.STATIC_MAX_AGE }))
bd324a66 75// 404 for static files not found
41a2aee3 76app.use('/client/*', function (req, res, next) {
bd324a66
C
77 res.sendStatus(404)
78})
79
a2647f7a 80const torrentsPhysicalPath = path.join(__dirname, constants.CONFIG.STORAGE.TORRENTS_DIR)
dc009132 81app.use(constants.STATIC_PATHS.TORRENTS, cors(), express.static(torrentsPhysicalPath, { maxAge: constants.STATIC_MAX_AGE }))
052937db 82
b3d92510 83// Videos path for webseeding
a2647f7a 84const videosPhysicalPath = path.join(__dirname, constants.CONFIG.STORAGE.VIDEOS_DIR)
dc009132 85app.use(constants.STATIC_PATHS.WEBSEED, cors(), express.static(videosPhysicalPath, { maxAge: constants.STATIC_MAX_AGE }))
052937db 86
cbe2f7c3 87// Thumbnails path for express
a2647f7a 88const thumbnailsPhysicalPath = path.join(__dirname, constants.CONFIG.STORAGE.THUMBNAILS_DIR)
dc009132 89app.use(constants.STATIC_PATHS.THUMBNAILS, express.static(thumbnailsPhysicalPath, { maxAge: constants.STATIC_MAX_AGE }))
cbe2f7c3 90
6f4e2522
C
91// Client application
92app.use('/*', function (req, res, next) {
4a6995be 93 res.sendFile(path.join(__dirname, 'client/dist/index.html'))
6f4e2522 94})
a030a9b2
C
95
96// ----------- Tracker -----------
97
13ce1d01 98const trackerServer = new TrackerServer({
a030a9b2
C
99 http: false,
100 udp: false,
101 ws: false,
102 dht: false
103})
104
105trackerServer.on('error', function (err) {
106 logger.error(err)
107})
108
109trackerServer.on('warning', function (err) {
110 logger.error(err)
111})
112
13ce1d01
C
113const server = http.createServer(app)
114const wss = new WebSocketServer({server: server, path: '/tracker/socket'})
a030a9b2
C
115wss.on('connection', function (ws) {
116 trackerServer.onWebSocketConnection(ws)
117})
118
119// ----------- Errors -----------
120
121// Catch 404 and forward to error handler
122app.use(function (req, res, next) {
13ce1d01 123 const err = new Error('Not Found')
a030a9b2
C
124 err.status = 404
125 next(err)
126})
127
6f4e2522
C
128app.use(function (err, req, res, next) {
129 logger.error(err)
130 res.sendStatus(err.status || 500)
131})
a030a9b2 132
d16b5172 133const port = constants.CONFIG.LISTEN.PORT
37dc07b2 134installer.installApplication(function (err) {
9457bf88 135 if (err) throw err
9457bf88 136
00d6b0dd
C
137 // Run the migration scripts if needed
138 migrator.migrate(function (err) {
139 if (err) throw err
a030a9b2 140
a6375e69
C
141 // ----------- Make the server listening -----------
142 server.listen(port, function () {
143 // Activate the pool requests
144 Request.activate()
052937db 145
a6375e69 146 logger.info('Server listening on port %d', port)
763381de
C
147 logger.info('Webserver: %s', constants.CONFIG.WEBSERVER.URL)
148
a6375e69 149 app.emit('ready')
8c308c2b
C
150 })
151 })
a030a9b2 152})
8c308c2b 153
a030a9b2 154module.exports = app