|
|
@@ -21,6 +21,8 @@ const validator = {
|
|
|
]),
|
|
|
body('hideRestrictedByOwner').if(value => value != null).isBoolean(),
|
|
|
body('hideRestrictedByGroup').if(value => value != null).isBoolean(),
|
|
|
+ ],
|
|
|
+ shareLinkSetting: [
|
|
|
body('disableLinkSharing').if(value => value != null).isBoolean(),
|
|
|
],
|
|
|
authenticationSetting: [
|
|
|
@@ -130,6 +132,12 @@ const validator = {
|
|
|
* hideRestrictedByGroup:
|
|
|
* type: boolean
|
|
|
* description: enable hide by group
|
|
|
+ * ShareLinkSetting:
|
|
|
+ * type: object
|
|
|
+ * properties:
|
|
|
+ * disableLinkSharing:
|
|
|
+ * type: boolean
|
|
|
+ * description: disable link sharing
|
|
|
* LocalSetting:
|
|
|
* type: object
|
|
|
* properties:
|
|
|
@@ -364,6 +372,8 @@ module.exports = (crowi) => {
|
|
|
hideRestrictedByGroup: await crowi.configManager.getConfig('crowi', 'security:list-policy:hideRestrictedByGroup'),
|
|
|
wikiMode: await crowi.configManager.getConfig('crowi', 'security:wikiMode'),
|
|
|
sessionMaxAge: await crowi.configManager.getConfig('crowi', 'security:sessionMaxAge'),
|
|
|
+ },
|
|
|
+ shareLinkSetting: {
|
|
|
disableLinkSharing: await crowi.configManager.getConfig('crowi', 'security:disableLinkSharing'),
|
|
|
},
|
|
|
localSetting: {
|
|
|
@@ -574,7 +584,6 @@ module.exports = (crowi) => {
|
|
|
'security:sessionMaxAge': parseInt(req.body.sessionMaxAge),
|
|
|
'security:restrictGuestMode': req.body.restrictGuestMode,
|
|
|
'security:pageCompleteDeletionAuthority': req.body.pageCompleteDeletionAuthority,
|
|
|
- 'security:disableLinkSharing': req.body.disableLinkSharing,
|
|
|
'security:list-policy:hideRestrictedByOwner': req.body.hideRestrictedByOwner,
|
|
|
'security:list-policy:hideRestrictedByGroup': req.body.hideRestrictedByGroup,
|
|
|
};
|
|
|
@@ -589,7 +598,6 @@ module.exports = (crowi) => {
|
|
|
sessionMaxAge: await crowi.configManager.getConfig('crowi', 'security:sessionMaxAge'),
|
|
|
restrictGuestMode: await crowi.configManager.getConfig('crowi', 'security:restrictGuestMode'),
|
|
|
pageCompleteDeletionAuthority: await crowi.configManager.getConfig('crowi', 'security:pageCompleteDeletionAuthority'),
|
|
|
- disableLinkSharing: await crowi.configManager.getConfig('crowi', 'security:disableLinkSharing'),
|
|
|
hideRestrictedByOwner: await crowi.configManager.getConfig('crowi', 'security:list-policy:hideRestrictedByOwner'),
|
|
|
hideRestrictedByGroup: await crowi.configManager.getConfig('crowi', 'security:list-policy:hideRestrictedByGroup'),
|
|
|
};
|
|
|
@@ -603,6 +611,46 @@ module.exports = (crowi) => {
|
|
|
}
|
|
|
});
|
|
|
|
|
|
+ /**
|
|
|
+ * @swagger
|
|
|
+ *
|
|
|
+ * /_api/v3/security-setting/share-link-setting:
|
|
|
+ * put:
|
|
|
+ * tags: [SecuritySetting, apiv3]
|
|
|
+ * description: Update ShareLink Setting
|
|
|
+ * requestBody:
|
|
|
+ * required: true
|
|
|
+ * content:
|
|
|
+ * application/json:
|
|
|
+ * schema:
|
|
|
+ * $ref: '#/components/schemas/ShareLinkSetting'
|
|
|
+ * responses:
|
|
|
+ * 200:
|
|
|
+ * description: Succeeded to update ShareLink Setting
|
|
|
+ * content:
|
|
|
+ * application/json:
|
|
|
+ * schema:
|
|
|
+ * $ref: '#/components/schemas/ShareLinkSetting'
|
|
|
+ */
|
|
|
+ router.put('/share-link-setting', loginRequiredStrictly, adminRequired, csrf, validator.generalSetting, apiV3FormValidator, async(req, res) => {
|
|
|
+ const updateData = {
|
|
|
+ 'security:disableLinkSharing': req.body.disableLinkSharing,
|
|
|
+ };
|
|
|
+ try {
|
|
|
+ await crowi.configManager.updateConfigsInTheSameNamespace('crowi', updateData);
|
|
|
+ const securitySettingParams = {
|
|
|
+ disableLinkSharing: crowi.configManager.getConfig('crowi', 'security:disableLinkSharing'),
|
|
|
+ };
|
|
|
+
|
|
|
+ return res.apiv3({ securitySettingParams });
|
|
|
+ }
|
|
|
+ catch (err) {
|
|
|
+ const msg = 'Error occurred in updating security setting';
|
|
|
+ logger.error('Error', err);
|
|
|
+ return res.apiv3Err(new ErrorV3(msg, 'update-secuirty-setting failed'));
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
|
|
|
/**
|
|
|
* @swagger
|