(function() { 'use strict'; if (!global.cloudcmd) return console.log( '# server.js' + '\n' + '# -----------' + '\n' + '# Module is part of Cloud Commander,' + '\n' + '# easy to use web server.' + '\n' + '# http://cloudcmd.io' + '\n'); var main = global.cloudcmd.main, DIR = main.DIR, LIBDIR = main.LIBDIR, SRVDIR = main.SRVDIR, URL = main.url, Path = main.path, Querystring = main.querystring, Minify = main.minify, CloudFunc = main.cloudfunc, AppCache = main.appcache, Socket = main.socket, http = main.http, https = main.https, Util = main.util, express = main.express, expressApp = express.getApp(controller), Server, Rest, Route; /* базовая инициализация */ function init(pAppCachProcessing) { var config = main.config; /* создаём файл app cache */ if (config.appcache && AppCache && config.server ) Util.exec( pAppCachProcessing ); } /** * start server function * @param pConfig * @param pProcessing {index, appcache, rest} */ function start(pProcessing) { var lConfig = main.config; if (!pProcessing) pProcessing = {}; Rest = pProcessing.rest; Route = pProcessing.route; init(pProcessing.appcache); var lPort = process.env.PORT || /* c9 */ process.env.app_port || /* nodester */ process.env.VCAP_APP_PORT || /* cloudfoundry */ lConfig.port, lIP = process.env.IP || /* c9 */ lConfig.ip || (main.WIN32 ? '127.0.0.1' : '0.0.0.0'), lSSL = pProcessing.ssl, lSSLPort = lConfig.sslPort, lHTTP = 'http://', lHTTPS = 'https://', lSockets = function(pServer) { var lListen, msg, status; if (lConfig.socket && Socket) lListen = Socket.listen(pServer); status = lListen ? 'on' : 'off'; msg = CloudFunc.formatMsg('sockets', '', status); Util.log(msg); }, lHTTPServer = function() { Server = http.createServer(expressApp || controller); Server.on('error', Util.log); Server.listen(lPort, lIP); lServerLog(lHTTP, lPort); lSockets(Server); }, lServerLog = function(pHTTP, pPort) { Util.log('* Server running at ' + pHTTP + lIP + ':' + pPort); }; /* server mode or testing mode */ if (lConfig.server) { if (lSSL) { Util.log('* Redirection http -> https is setted up'); lServerLog(lHTTP, lPort); var lRedirectServer = http.createServer( function(pReq, pRes) { var lHost = pReq.headers.host; main.redirect({ response: pRes, url: lHTTPS + lHost + pReq.url }); }); lRedirectServer.listen(lPort, lIP); Server = https.createServer( lSSL, controller ); Server.on('error', function (pError) { Util.log('Could not use https port: ' + lSSLPort); Util.log(pError); lRedirectServer.close(); Util.log('* Redirection http -> https removed'); lHTTPServer(); }); lSockets(Server); Server.listen(lSSLPort, lIP); lServerLog(lHTTPS, lSSLPort); } else lHTTPServer(); } else Util.log('Cloud Commander testing mode'); } /** * Главная функция, через которую проихсодит * взаимодействие, обмен данными с клиентом * @param req - запрос клиента (Request) * @param res - ответ сервера (Response) */ function controller(pReq, pRes) { /* Читаем содержимое папки, переданное в url */ var lRet, lName, lMin, lExt, lResult, lConfig = main.config, lParsedUrl = URL.parse(pReq.url), lQuery = lParsedUrl.search || '', lPath = lParsedUrl.pathname; /* added supporting of Russian language in directory names */ lPath = Querystring.unescape(lPath); if (!expressApp) Util.log(pReq.method + ' ' + lPath + lQuery); var lData = { name : lPath, request : pReq, response : pRes }; if (lConfig.rest ) lRet = Util.exec(Rest, lData); if (!lRet && Route) lRet = Util.exec(Route, lData); if (!lRet) { lName = lData.name; /* watching is file changed */ if (lConfig.appcache) AppCache.watch(lName); lName = Path.join(DIR, lName); lMin = lConfig.minify, lExt = Util.getExtension(lName), lResult = lMin && Util.strCmp(lExt, ['.js', '.css', '.html']); Util.ifExec(!lResult, function(pParams) { var lSendName = pParams && pParams.name || lName; main.sendFile({ name : lSendName, cache : lConfig.cache, gzip : true, request : pReq, response : pRes }); }, function(pCallBack) { Minify.optimize(lName, { callback : pCallBack, returnName : true }); }); } } exports.start = start; })();