如何在admin-on-rest中为资源设置动态URL?

时间:2017-06-27 05:48:59

标签: admin-on-rest

我需要根据登录用户的类型访问以下资源。

R1:/mit/oss/12345/peers

R2:/mit/md/6879/ngrp

R1应该可以由ID为12345的用户访问.R2应该可以由ID为6879的用户访问。

问题是 - 如何根据记录的用户定义具有动态值的资源URL(例如:URL中的userId)。我知道aor-permissions库可以根据用户权限切换菜单,但是是否可以使用URL中的ID动态定义资源?

2 个答案:

答案 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);

可以使用带逻辑的函数,而不是简单的重映射。