2020-01-23 16:59:50 +01:00
|
|
|
/**
|
|
|
|
* Policies util
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2018-03-30 17:05:24 +02:00
|
|
|
const _ = require('lodash');
|
2020-01-23 16:59:50 +01:00
|
|
|
|
|
|
|
const get = (policy, plugin, apiName) => {
|
|
|
|
if (globalPolicyExists(policy)) {
|
|
|
|
return parsePolicy(getGlobalPolicy(policy));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pluginPolicyExists(policy)) {
|
|
|
|
return parsePolicy(getPluginPolicy(policy));
|
|
|
|
}
|
|
|
|
|
2020-06-10 18:04:47 +02:00
|
|
|
if (adminPolicyExists(policy)) {
|
|
|
|
return parsePolicy(getAdminPolicy(policy));
|
|
|
|
}
|
|
|
|
|
2020-01-29 15:30:53 +01:00
|
|
|
if (APIPolicyExists(policy)) {
|
|
|
|
return parsePolicy(getAPIPolicy(policy));
|
|
|
|
}
|
|
|
|
|
|
|
|
let [absoluteApiName, policyName] = policy.split('.');
|
|
|
|
let absoluteApi = _.get(strapi.api, absoluteApiName);
|
|
|
|
if (policyExistsIn(absoluteApi, policyName)) {
|
|
|
|
return parsePolicy(getPolicyIn(absoluteApi, policyName));
|
|
|
|
}
|
|
|
|
|
2020-01-23 16:59:50 +01:00
|
|
|
const pluginPolicy = `${PLUGIN_PREFIX}${plugin}.${policy}`;
|
|
|
|
|
2020-01-29 15:30:53 +01:00
|
|
|
if (plugin && pluginPolicyExists(pluginPolicy)) {
|
2020-01-23 16:59:50 +01:00
|
|
|
return parsePolicy(getPluginPolicy(pluginPolicy));
|
|
|
|
}
|
|
|
|
|
|
|
|
const api = _.get(strapi.api, apiName);
|
2020-01-29 15:30:53 +01:00
|
|
|
if (api && policyExistsIn(api, policy)) {
|
2020-01-23 16:59:50 +01:00
|
|
|
return parsePolicy(getPolicyIn(api, policy));
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new Error(`Could not find policy "${policy}"`);
|
|
|
|
};
|
|
|
|
|
|
|
|
const globalPolicy = ({ method, endpoint, controller, action, plugin }) => {
|
|
|
|
return async (ctx, next) => {
|
|
|
|
ctx.request.route = {
|
|
|
|
endpoint: `${method} ${endpoint}`,
|
|
|
|
controller: _.toLower(controller),
|
|
|
|
action: _.toLower(action),
|
|
|
|
splittedEndpoint: endpoint,
|
|
|
|
verb: _.toLower(method),
|
|
|
|
plugin,
|
2018-04-10 11:47:01 +02:00
|
|
|
};
|
2020-01-23 16:59:50 +01:00
|
|
|
|
|
|
|
await next();
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const parsePolicy = policy => {
|
|
|
|
if (_.isFunction(policy)) {
|
|
|
|
return policy;
|
|
|
|
}
|
|
|
|
|
|
|
|
return policy.handler;
|
|
|
|
};
|
|
|
|
|
2020-02-10 12:50:11 +01:00
|
|
|
const GLOBAL_PREFIX = 'global::';
|
|
|
|
const PLUGIN_PREFIX = 'plugins::';
|
2020-06-10 18:04:47 +02:00
|
|
|
const ADMIN_PREFIX = 'admin::';
|
2020-01-29 15:30:53 +01:00
|
|
|
const APPLICATION_PREFIX = 'application::';
|
2020-01-23 16:59:50 +01:00
|
|
|
|
|
|
|
const getPolicyIn = (container, policy) => {
|
2020-01-29 15:30:53 +01:00
|
|
|
return _.get(container, ['config', 'policies', _.toLower(policy)]);
|
2020-01-23 16:59:50 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
const policyExistsIn = (container, policy) => {
|
|
|
|
return !_.isUndefined(getPolicyIn(container, policy));
|
|
|
|
};
|
|
|
|
|
|
|
|
const isGlobal = policy => _.startsWith(policy, GLOBAL_PREFIX);
|
|
|
|
|
|
|
|
const getGlobalPolicy = policy => {
|
|
|
|
const strippedPolicy = policy.replace(GLOBAL_PREFIX, '');
|
|
|
|
return getPolicyIn(strapi, strippedPolicy);
|
|
|
|
};
|
|
|
|
|
|
|
|
const globalPolicyExists = policy => {
|
|
|
|
return isGlobal(policy) && !_.isUndefined(getGlobalPolicy(policy));
|
|
|
|
};
|
|
|
|
|
|
|
|
const getPluginPolicy = policy => {
|
2020-02-10 12:50:11 +01:00
|
|
|
const strippedPolicy = policy.replace(PLUGIN_PREFIX, '');
|
|
|
|
const [plugin = '', policyName = ''] = strippedPolicy.split('.');
|
2020-01-23 16:59:50 +01:00
|
|
|
return getPolicyIn(_.get(strapi, ['plugins', plugin]), policyName);
|
|
|
|
};
|
|
|
|
|
2020-06-10 18:04:47 +02:00
|
|
|
const pluginPolicyExists = policy =>
|
|
|
|
isPluginPolicy(policy) && !_.isUndefined(getPluginPolicy(policy));
|
2020-01-23 16:59:50 +01:00
|
|
|
|
|
|
|
const isPluginPolicy = policy => _.startsWith(policy, PLUGIN_PREFIX);
|
|
|
|
|
2020-06-10 18:04:47 +02:00
|
|
|
const getAdminPolicy = policy => {
|
|
|
|
const strippedPolicy = policy.replace(ADMIN_PREFIX, '');
|
|
|
|
return getPolicyIn(_.get(strapi, 'admin'), strippedPolicy);
|
|
|
|
};
|
|
|
|
|
|
|
|
const isAdminPolicy = policy => _.startsWith(policy, ADMIN_PREFIX);
|
|
|
|
|
|
|
|
const adminPolicyExists = policy => isAdminPolicy(policy) && !_.isUndefined(getAdminPolicy(policy));
|
|
|
|
|
2020-01-29 15:30:53 +01:00
|
|
|
const getAPIPolicy = policy => {
|
|
|
|
const [, policyWithoutPrefix] = policy.split('::');
|
|
|
|
const [api = '', policyName = ''] = policyWithoutPrefix.split('.');
|
|
|
|
return getPolicyIn(_.get(strapi, ['api', api]), policyName);
|
|
|
|
};
|
|
|
|
|
|
|
|
const APIPolicyExists = policy => {
|
|
|
|
return isAPIPolicy(policy) && !_.isUndefined(getAPIPolicy(policy));
|
|
|
|
};
|
|
|
|
|
|
|
|
const isAPIPolicy = policy => _.startsWith(policy, APPLICATION_PREFIX);
|
|
|
|
|
2020-01-23 16:59:50 +01:00
|
|
|
module.exports = {
|
|
|
|
get,
|
|
|
|
globalPolicy,
|
2018-03-30 17:05:24 +02:00
|
|
|
};
|