From ff9283f5612fc9192921ba32197f4bca48c45ce2 Mon Sep 17 00:00:00 2001 From: Victor Perron Date: Fri, 19 Jun 2015 11:41:10 +0200 Subject: [PATCH 1/2] Enable use behind a proxy The issue has been around for quite some time now. The fix seems to work for rlidwka/sinopia#232 . --- lib/index.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lib/index.js b/lib/index.js index 8e9c8ecc..238465fb 100644 --- a/lib/index.js +++ b/lib/index.js @@ -19,6 +19,11 @@ module.exports = function(config_hash) { // run in production mode by default, just in case // it shouldn't make any difference anyway app.set('env', process.env.NODE_ENV || 'production') + + // for nginx proxy + if (process.env.VIRTUAL_HOST) { + app.enable('trust proxy'); + } function error_reporting_middleware(req, res, next) { res.report_error = res.report_error || function(err) { From 17d6813e6f2b46ecdf07f3bd0606f388da1ff737 Mon Sep 17 00:00:00 2001 From: Victor Perron Date: Fri, 19 Jun 2015 11:50:06 +0200 Subject: [PATCH 2/2] Add a package.json for crissake --- package.json | 90 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 90 insertions(+) create mode 100644 package.json diff --git a/package.json b/package.json new file mode 100644 index 00000000..d13a0eab --- /dev/null +++ b/package.json @@ -0,0 +1,90 @@ +{ + "name": "sinopia", + "version": "1.4.0", + "description": "Private npm repository server", + "author": { + "name": "Alex Kocharin", + "email": "alex@kocharin.ru" + }, + "repository": { + "type": "git", + "url": "git://github.com/rlidwka/sinopia" + }, + "main": "index.js", + "bin": { + "sinopia": "./bin/sinopia" + }, + "dependencies": { + "express": ">=5.0.0-0 <6.0.0-0", + "express-json5": ">=0.1.0 <1.0.0-0", + "body-parser": ">=1.9.2 <2.0.0-0", + "compression": ">=1.2.0 <2.0.0-0", + "commander": ">=2.3.0 <3.0.0-0", + "js-yaml": ">=3.0.1 <4.0.0-0", + "cookies": ">=0.5.0 <1.0.0-0", + "request": ">=2.31.0 <3.0.0-0", + "async": ">=0.9.0 <1.0.0-0", + "es6-shim": "0.21.x", + "semver": ">=2.2.1 <5.0.0-0", + "minimatch": ">=0.2.14 <2.0.0-0", + "bunyan": ">=0.22.1 <2.0.0-0", + "handlebars": "2.x", + "highlight.js": "8.x", + "lunr": ">=0.5.2 <1.0.0-0", + "render-readme": ">=0.2.1", + "jju": "1.x", + "JSONStream": "1.x", + "mkdirp": ">=0.3.5 <1.0.0-0", + "sinopia-htpasswd": ">= 0.4.3", + "http-errors": ">=1.2.0", + "readable-stream": "~1.1.0" + }, + "optionalDependencies": { + "fs-ext": ">=0.4.1 <1.0.0-0", + "crypt3": ">=0.1.6 <1.0.0-0" + }, + "devDependencies": { + "rimraf": ">=2.2.5 <3.0.0-0", + "bluebird": "2 >=2.9", + "mocha": "2 >=2.2.3", + "eslint": ">= 0.18", + "browserify": "7.x", + "browserify-handlebars": "1.x", + "grunt": ">=0.4.4 <1.0.0-0", + "grunt-cli": "*", + "grunt-browserify": ">=2.0.8 <3.0.0-0", + "grunt-contrib-less": ">=0.11.0 <1.0.0-0", + "grunt-contrib-watch": ">=0.6.1 <1.0.0-0", + "unopinionate": ">=0.0.4 <1.0.0-0", + "onclick": ">=0.1.0 <1.0.0-0", + "transition-complete": ">=0.0.2 <1.0.0-0" + }, + "keywords": [ + "private", + "package", + "repository", + "registry", + "modules", + "proxy", + "server" + ], + "scripts": { + "test": "eslint --reset . && mocha ./test/functional ./test/unit", + "test-travis": "eslint --reset . && mocha -R spec ./test/functional ./test/unit", + "test-only": "mocha ./test/functional ./test/unit", + "lint": "eslint --reset .", + "prepublish": "js-yaml package.yaml > package.json", + "clean-shrinkwrap": "node -e '\n function clean(j) {\n if (!j) return\n for (var k in j) {\n delete j[k].from\n delete j[k].resolved\n if (j[k].dependencies) clean(j[k].dependencies)\n }\n }\n x = JSON.parse(require(\"fs\").readFileSync(\"./npm-shrinkwrap.json\"))\n clean(x.dependencies)\n x = JSON.stringify(x, null, \" \")\n require(\"fs\").writeFileSync(\"./npm-shrinkwrap.json\", x + \"\\n\")\n'\n" + }, + "engines": { + "node": ">=0.10" + }, + "preferGlobal": true, + "publishConfig": { + "registry": "https://registry.npmjs.org/" + }, + "license": { + "type": "WTFPL", + "url": "http://www.wtfpl.net/txt/copying/" + } +}