From bd92010dd2e16d6fd87012ebd17fde0e9c01c4f6 Mon Sep 17 00:00:00 2001 From: Sheogorath Date: Fri, 26 Jan 2018 14:00:48 +0100 Subject: [PATCH] Remove camel case from `imageuploadtype` in config This removes the only camel cased option of the config options **we** added to the config.json. In auth provider's config parts are a lot of camel cased options provided. We shouldn't touch them to keep them as similar as possible to the examples. Fixes #315 Signed-off-by: Sheogorath --- README.md | 8 ++++---- docs/guides/minio-image-upload.md | 4 ++-- docs/guides/s3-image-upload.md | 2 +- lib/config/default.js | 4 +++- lib/config/environment.js | 2 +- lib/config/index.js | 10 ++++++++-- lib/web/imageRouter.js | 4 ++-- 7 files changed, 21 insertions(+), 13 deletions(-) diff --git a/README.md b/README.md index b2ce691e..953dafd9 100644 --- a/README.md +++ b/README.md @@ -246,10 +246,10 @@ There are some configs you need to change in the files below | documentmaxlength | `100000` | note max length | | email | `true` or `false` | set to allow email signin | | allowemailregister | `true` or `false` | set to allow email register (only applied when email is set, default is `true`) | -| imageUploadType | `imgur`(default), `s3`, `minio` or `filesystem` | Where to upload image -| minio | `{ "accessKey": "YOUR_MINIO_ACCESS_KEY", "secretKey": "YOUR_MINIO_SECRET_KEY", "endpoint": "YOUR_MINIO_HOST", port: 9000, secure: true }` | When `imageUploadType` is set to `minio`, you need to set this key. Also checkout our [Minio Image Upload Guide](docs/guides/minio-image-upload.md) | -| s3 | `{ "accessKeyId": "YOUR_S3_ACCESS_KEY_ID", "secretAccessKey": "YOUR_S3_ACCESS_KEY", "region": "YOUR_S3_REGION" }` | When `imageUploadType` be set to `s3`, you would also need to setup this key, check our [S3 Image Upload Guide](docs/guides/s3-image-upload.md) | -| s3bucket | `YOUR_S3_BUCKET_NAME` | bucket name when `imageUploadType` is set to `s3` or `minio` | +| imageuploadtype | `imgur`(default), `s3`, `minio` or `filesystem` | Where to upload image +| minio | `{ "accessKey": "YOUR_MINIO_ACCESS_KEY", "secretKey": "YOUR_MINIO_SECRET_KEY", "endpoint": "YOUR_MINIO_HOST", port: 9000, secure: true }` | When `imageuploadtype` is set to `minio`, you need to set this key. Also checkout our [Minio Image Upload Guide](docs/guides/minio-image-upload.md) | +| s3 | `{ "accessKeyId": "YOUR_S3_ACCESS_KEY_ID", "secretAccessKey": "YOUR_S3_ACCESS_KEY", "region": "YOUR_S3_REGION" }` | When `imageuploadtype` be set to `s3`, you would also need to setup this key, check our [S3 Image Upload Guide](docs/guides/s3-image-upload.md) | +| s3bucket | `YOUR_S3_BUCKET_NAME` | bucket name when `imageuploadtype` is set to `s3` or `minio` | ## Third-party integration api key settings diff --git a/docs/guides/minio-image-upload.md b/docs/guides/minio-image-upload.md index 273bd8eb..c2ba25b5 100644 --- a/docs/guides/minio-image-upload.md +++ b/docs/guides/minio-image-upload.md @@ -62,7 +62,7 @@ Minio Guide for HackMD 8. Set upload type. ```JSON - "imageUploadType": "minio" + "imageuploadtype": "minio" ``` 9. Review your config. @@ -78,6 +78,6 @@ Minio Guide for HackMD "secure": false }, "s3bucket": "hackmd", - "imageUploadType": "minio" + "imageuploadtype": "minio" } ``` diff --git a/docs/guides/s3-image-upload.md b/docs/guides/s3-image-upload.md index dbbef474..ff9598a2 100644 --- a/docs/guides/s3-image-upload.md +++ b/docs/guides/s3-image-upload.md @@ -63,7 +63,7 @@ { "production": { ... - "imageUploadType": "s3", + "imageuploadtype": "s3", "s3": { "accessKeyId": "YOUR_S3_ACCESS_KEY_ID", "secretAccessKey": "YOUR_S3_ACCESS_KEY", diff --git a/lib/config/default.js b/lib/config/default.js index 28f4490c..38dc21a4 100644 --- a/lib/config/default.js +++ b/lib/config/default.js @@ -53,7 +53,9 @@ module.exports = { // document documentmaxlength: 100000, // image upload setting, available options are imgur/s3/filesystem - imageUploadType: 'filesystem', + imageuploadtype: 'filesystem', + // legacy variable name for imageuploadtype + imageUploadType: undefined, imgur: { clientID: undefined }, diff --git a/lib/config/environment.js b/lib/config/environment.js index e2112b6a..640f9e07 100644 --- a/lib/config/environment.js +++ b/lib/config/environment.js @@ -25,7 +25,7 @@ module.exports = { allowfreeurl: toBooleanConfig(process.env.HMD_ALLOW_FREEURL), defaultpermission: process.env.HMD_DEFAULT_PERMISSION, dburl: process.env.HMD_DB_URL, - imageUploadType: process.env.HMD_IMAGE_UPLOAD_TYPE, + imageuploadtype: process.env.HMD_IMAGE_UPLOAD_TYPE, imgur: { clientID: process.env.HMD_IMGUR_CLIENTID }, diff --git a/lib/config/index.js b/lib/config/index.js index 4f6b4b6a..0051e485 100644 --- a/lib/config/index.js +++ b/lib/config/index.js @@ -13,6 +13,7 @@ const debugConfig = { debug: (env === Environment.development) } +// Get version string from package.json const {version} = require(path.join(appRootPath, 'package.json')) const packageConfig = { @@ -20,7 +21,7 @@ const packageConfig = { minimumCompatibleVersion: '0.5.0' } -const configFilePath = path.join(__dirname, '../../config.json') +const configFilePath = path.join(appRootPath, 'config.json') const fileConfig = fs.existsSync(configFilePath) ? require(configFilePath)[env] : undefined let config = require('./default') @@ -97,8 +98,13 @@ config.isLDAPEnable = config.ldap.url config.isSAMLEnable = config.saml.idpSsoUrl config.isPDFExportEnable = config.allowpdfexport +// merge legacy values +if (config.imageUploadType && !config.imageuploadtype) { + config.imageuploadtype = config.imageUploadType +} + // figure out mime types for image uploads -switch (config.imageUploadType) { +switch (config.imageuploadtype) { case 'imgur': config.allowedUploadMimeTypes = [ 'image/jpeg', diff --git a/lib/web/imageRouter.js b/lib/web/imageRouter.js index b17cccbd..483be64b 100644 --- a/lib/web/imageRouter.js +++ b/lib/web/imageRouter.js @@ -19,7 +19,7 @@ imageRouter.post('/uploadimage', function (req, res) { form.keepExtensions = true - if (config.imageUploadType === 'filesystem') { + if (config.imageuploadtype === 'filesystem') { form.uploadDir = 'public/uploads' } @@ -30,7 +30,7 @@ imageRouter.post('/uploadimage', function (req, res) { if (config.debug) { logger.info('SERVER received uploadimage: ' + JSON.stringify(files.image)) } try { - switch (config.imageUploadType) { + switch (config.imageuploadtype) { case 'filesystem': res.send({ link: url.resolve(config.serverurl + '/', files.image.path.match(/^public\/(.+$)/)[1])