我需要根据登录用户的类型访问以下资源。
R1:/mit/oss/12345/peers
R2:/mit/md/6879/ngrp
R1应该可以由ID为12345的用户访问.R2应该可以由ID为6879的用户访问。
问题是 - 如何根据记录的用户定义具有动态值的资源URL(例如:URL中的userId)。我知道aor-permissions库可以根据用户权限切换菜单,但是是否可以使用URL中的ID动态定义资源?
答案 0 :(得分:1)
您可以在休息客户端上编写一个可以拦截调用并动态生成URL的包装器。
基本上装饰其他客户端,就像在这里的文档中一样 - > https://marmelab.com/admin-on-rest/RestClients.html#decorating-your-rest-client-example-of-file-upload
然后,您可以检查下面的伪造的
案例if (type === 'AOR_REST_TYPE' && resource === 'BASE_RESOURCE') {
if (getUserFromLocalStorage === usr1) {
url = url1
} else {
url = url2
}
options.method = 'GET';
// other options
}
答案 1 :(得分:0)
以下是使用地图重新映射资源网址的简单示例。
import {simpleRestClient} from 'admin-on-rest';
// Update the remap table appropriately to map from a resource name to a different path
const remap = {
"resource1" : "resource1Remapped",
"releasepresets" : "productionintents/releasepresets"
}
const simpleRestClientWithResourceUrlRemap = (apiUrl) => {
var client = simpleRestClient(apiUrl);
return (type, resource, params) => {
if (remap[resource]) {
console.log('remapping resource from ' + resource + ' to ' + remap[resource]);
resource = remap[resource];
}
return client(type, resource, params);
}
}
export default (simpleRestClientWithResourceUrlRemap);
可以使用带逻辑的函数,而不是简单的重映射。