X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=app.js;h=4570b07a4e92bfbd8d33ead26c45cc6de3e0240e;hb=5c6f8c0a837a09bc876c9705c0941888cdf3a4f6;hp=a13ce032a436d1debde3ccb0d5da219fbb0775a3;hpb=cfe24a278b68cd859e8f98cb0d8be92d49508a32;p=perso%2FImmae%2FProjets%2FNodejs%2FSurfer.git diff --git a/app.js b/app.js index a13ce03..4570b07 100755 --- a/app.js +++ b/app.js @@ -2,39 +2,44 @@ 'use strict'; + var express = require('express'), morgan = require('morgan'), passport = require('passport'), path = require('path'), + ejs = require('ejs'), + fs = require('fs'), compression = require('compression'), session = require('express-session'), bodyParser = require('body-parser'), cookieParser = require('cookie-parser'), lastMile = require('connect-lastmile'), multipart = require('./src/multipart'), + mkdirp = require('mkdirp'), auth = require('./src/auth.js'), - files = require('./src/files.js')(path.resolve(__dirname, 'files')); + files = require('./src/files.js')(path.resolve(__dirname, process.argv[2] || 'files')); var app = express(); var router = new express.Router(); var multipart = multipart({ maxFieldsSize: 2 * 1024, limit: '512mb', timeout: 3 * 60 * 1000 }); -router.get('/api/files/*', auth.ldap, files.get); -router.put('/api/files/*', auth.ldap, multipart, files.put); +router.get ('/api/files/*', auth.ldap, files.get); +router.put ('/api/files/*', auth.ldap, multipart, files.put); router.delete('/api/files/*', auth.ldap, files.del); -// healthcheck in case / does not serve up any file yet -router.get('/', function (req, res) { res.sendFile(path.join(__dirname, '/app/welcome.html')); }); +// welcome screen in case / does not serve up any file yet +var appUrl = process.env.APP_ORIGIN ? process.env.APP_ORIGIN : 'http://localhost:3000'; +router.get('/', function (req, res) { res.status(200).send(ejs.render(fs.readFileSync(path.join(__dirname, '/app/welcome.html'), 'utf8'), { appUrl: appUrl })); }); app.use(morgan('dev')); app.use(compression()); app.use('/settings', express.static(__dirname + '/app')); -app.use(express.static(__dirname + '/files')); +app.use(express.static(path.resolve(__dirname, process.argv[2] || 'files'))); app.use(bodyParser.json()); -app.use(bodyParser.urlencoded()); +app.use(bodyParser.urlencoded({ extended: false, limit: '100mb' })); app.use(cookieParser()); -app.use(session({ secret: 'surfin surfin' })); +app.use(session({ secret: 'surfin surfin', resave: false, saveUninitialized: false })); app.use(passport.initialize()); app.use(passport.session()); app.use(router); @@ -44,5 +49,9 @@ var server = app.listen(3000, function () { var host = server.address().address; var port = server.address().port; + var basePath = path.resolve(__dirname, process.argv[2] || 'files'); + mkdirp.sync(basePath); + console.log('Surfer listening at http://%s:%s', host, port); -}); \ No newline at end of file + console.log('Using base path', basePath); +});