summaryrefslogtreecommitdiff
path: root/src/web/service/proxy
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2016-12-29 07:49:51 +0900
committersyuilo <syuilotan@yahoo.co.jp>2016-12-29 07:49:51 +0900
commitb3f42e62af698a67c2250533c437569559f1fdf9 (patch)
treecdf6937576e99cccf85e6fa3aa8860a1173c7cfb /src/web/service/proxy
downloadsharkey-b3f42e62af698a67c2250533c437569559f1fdf9.tar.gz
sharkey-b3f42e62af698a67c2250533c437569559f1fdf9.tar.bz2
sharkey-b3f42e62af698a67c2250533c437569559f1fdf9.zip
Initial commit :four_leaf_clover:
Diffstat (limited to 'src/web/service/proxy')
-rw-r--r--src/web/service/proxy/proxy.ts30
-rw-r--r--src/web/service/proxy/server.ts17
2 files changed, 47 insertions, 0 deletions
diff --git a/src/web/service/proxy/proxy.ts b/src/web/service/proxy/proxy.ts
new file mode 100644
index 0000000000..34c1deafad
--- /dev/null
+++ b/src/web/service/proxy/proxy.ts
@@ -0,0 +1,30 @@
+import * as url from 'url';
+import * as express from 'express';
+import * as request from 'request';
+
+module.exports = (req: express.Request, res: express.Response) => {
+ const _url = req.params.url;
+
+ if (!_url) {
+ return;
+ }
+
+ request({
+ url: _url + url.parse(req.url, true).search,
+ encoding: null
+ }, (err, response, content) => {
+ if (err) {
+ console.error(err);
+ return;
+ }
+
+ const contentType = response.headers['content-type'];
+
+ if (/^text\//.test(contentType) || contentType === 'application/javascript') {
+ content = content.toString().replace(/http:\/\//g, `${config.secondary_scheme}://proxy.${config.secondary_host}/http://`);
+ }
+
+ res.header('Content-Type', contentType);
+ res.send(content);
+ });
+};
diff --git a/src/web/service/proxy/server.ts b/src/web/service/proxy/server.ts
new file mode 100644
index 0000000000..5b1b8d106c
--- /dev/null
+++ b/src/web/service/proxy/server.ts
@@ -0,0 +1,17 @@
+/**
+ * Forward Proxy Service
+ */
+
+import * as express from 'express';
+import * as cors from 'cors';
+
+/**
+ * Init app
+ */
+const app = express();
+app.disable('x-powered-by');
+app.use(cors());
+
+app.get('/:url(*)', require('./proxy'));
+
+module.exports = app;