@aserto/aserto-react
Advanced tools
Comparing version 0.1.32 to 0.1.33
@@ -76,3 +76,3 @@ "use strict"; | ||
var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(initOptions) { | ||
var asertoFromHook; | ||
var throwOnError, defaultMap, asertoFromHook; | ||
return regeneratorRuntime.wrap(function _callee$(_context) { | ||
@@ -82,8 +82,14 @@ while (1) { | ||
case 0: | ||
_context.prev = 0; | ||
throwOnError = initOptions.throwOnError; | ||
defaultMap = initOptions.defaultMap || { | ||
visible: true, | ||
enabled: true, | ||
allowed: false | ||
}; | ||
_context.prev = 2; | ||
setLoading(true); | ||
_context.next = 4; | ||
_context.next = 6; | ||
return (0, _asertoSpaJs["default"])(initOptions); | ||
case 4: | ||
case 6: | ||
asertoFromHook = _context.sent; | ||
@@ -94,8 +100,18 @@ setAsertoClient(asertoFromHook); | ||
setLoading(false); | ||
_context.next = 16; | ||
_context.next = 21; | ||
break; | ||
case 11: | ||
_context.prev = 11; | ||
_context.t0 = _context["catch"](0); | ||
case 13: | ||
_context.prev = 13; | ||
_context.t0 = _context["catch"](2); | ||
if (!throwOnError) { | ||
_context.next = 17; | ||
break; | ||
} | ||
throw _context.t0; | ||
case 17: | ||
console.error(_context.t0); | ||
setError(_context.t0); | ||
@@ -105,3 +121,3 @@ setIsLoaded(false); | ||
case 16: | ||
case 21: | ||
case "end": | ||
@@ -111,3 +127,3 @@ return _context.stop(); | ||
} | ||
}, _callee, null, [[0, 11]]); | ||
}, _callee, null, [[2, 13]]); | ||
})); | ||
@@ -126,19 +142,39 @@ | ||
case 0: | ||
if (asertoClient) { | ||
_context2.next = 4; | ||
_context2.prev = 0; | ||
if (!asertoClient) { | ||
_context2.next = 7; | ||
break; | ||
} | ||
throw new Error('aserto-react: must call init() before reload()'); | ||
case 4: | ||
setLoading(true); | ||
_context2.next = 7; | ||
_context2.next = 5; | ||
return asertoClient.reload(); | ||
case 7: | ||
case 5: | ||
setAccessMap(asertoClient.accessMap()); | ||
setLoading(false); | ||
case 7: | ||
_context2.next = 17; | ||
break; | ||
case 9: | ||
_context2.prev = 9; | ||
_context2.t0 = _context2["catch"](0); | ||
if (!throwOnError) { | ||
_context2.next = 13; | ||
break; | ||
} | ||
throw _context2.t0; | ||
case 13: | ||
console.error(_context2.t0); | ||
setError(_context2.t0); | ||
setIsLoaded(false); | ||
setLoading(false); | ||
case 17: | ||
case "end": | ||
@@ -148,3 +184,3 @@ return _context2.stop(); | ||
} | ||
}, _callee2); | ||
}, _callee2, null, [[0, 9]]); | ||
})); | ||
@@ -158,11 +194,24 @@ | ||
var resourceMap = function resourceMap(path) { | ||
if (!asertoClient) { | ||
throw new Error('aserto-react: must call init() before resourceMap()'); | ||
} | ||
if (asertoClient && path) { | ||
return asertoClient.resourceMap(path); | ||
} // no client or path | ||
if (!path) { | ||
throw new Error('path is a required parameter'); | ||
if (throwOnError) { | ||
if (!asertoClient) { | ||
throw new Error('aserto-react: must call init() before resourceMap()'); | ||
} | ||
if (!path) { | ||
throw new Error('aserto-react: path is a required parameter'); | ||
} | ||
} else { | ||
// return the default map | ||
return { | ||
GET: defaultMap, | ||
PUT: defaultMap, | ||
DELETE: defaultMap, | ||
POST: defaultMap | ||
}; | ||
} | ||
return asertoClient.resourceMap(path); | ||
}; | ||
@@ -205,2 +254,2 @@ /* | ||
exports.AsertoProvider = AsertoProvider; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJBc2VydG9Db250ZXh0IiwiUmVhY3QiLCJjcmVhdGVDb250ZXh0IiwidXNlQXNlcnRvIiwiQXNlcnRvUHJvdmlkZXIiLCJjaGlsZHJlbiIsImFzZXJ0b0NsaWVudCIsInNldEFzZXJ0b0NsaWVudCIsImxvYWRpbmciLCJzZXRMb2FkaW5nIiwiaXNMb2FkZWQiLCJzZXRJc0xvYWRlZCIsImVycm9yIiwic2V0RXJyb3IiLCJhY2Nlc3NNYXAiLCJzZXRBY2Nlc3NNYXAiLCJpbml0IiwiaW5pdE9wdGlvbnMiLCJhc2VydG9Gcm9tSG9vayIsInJlbG9hZCIsIkVycm9yIiwicmVzb3VyY2VNYXAiLCJwYXRoIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRU8sSUFBTUEsYUFBYSxnQkFBR0Msa0JBQU1DLGFBQU4sRUFBdEI7Ozs7QUFDQSxJQUFNQyxTQUFTLEdBQUcsU0FBWkEsU0FBWTtBQUFBLFNBQU0sdUJBQVdILGFBQVgsQ0FBTjtBQUFBLENBQWxCOzs7O0FBQ0EsSUFBTUksY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixPQUV4QjtBQUFBLE1BREpDLFFBQ0ksUUFESkEsUUFDSTs7QUFBQSxrQkFDb0Msc0JBRHBDO0FBQUE7QUFBQSxNQUNHQyxZQURIO0FBQUEsTUFDaUJDLGVBRGpCOztBQUFBLG1CQUUwQixxQkFBUyxLQUFULENBRjFCO0FBQUE7QUFBQSxNQUVHQyxPQUZIO0FBQUEsTUFFWUMsVUFGWjs7QUFBQSxtQkFHNEIscUJBQVMsS0FBVCxDQUg1QjtBQUFBO0FBQUEsTUFHR0MsUUFISDtBQUFBLE1BR2FDLFdBSGI7O0FBQUEsbUJBSXNCLHNCQUp0QjtBQUFBO0FBQUEsTUFJR0MsS0FKSDtBQUFBLE1BSVVDLFFBSlY7O0FBQUEsbUJBSzhCLHNCQUw5QjtBQUFBO0FBQUEsTUFLR0MsU0FMSDtBQUFBLE1BS2NDLFlBTGQ7O0FBT0osTUFBTUMsSUFBSTtBQUFBLHdFQUFHLGlCQUFPQyxXQUFQO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRVhSLGNBQUFBLFVBQVUsQ0FBQyxJQUFELENBQVY7QUFGVztBQUFBLHFCQUdrQiw2QkFBbUJRLFdBQW5CLENBSGxCOztBQUFBO0FBR0xDLGNBQUFBLGNBSEs7QUFJWFgsY0FBQUEsZUFBZSxDQUFDVyxjQUFELENBQWY7QUFDQUgsY0FBQUEsWUFBWSxDQUFDRyxjQUFjLENBQUNKLFNBQWYsRUFBRCxDQUFaO0FBQ0FILGNBQUFBLFdBQVcsQ0FBQyxJQUFELENBQVg7QUFDQUYsY0FBQUEsVUFBVSxDQUFDLEtBQUQsQ0FBVjtBQVBXO0FBQUE7O0FBQUE7QUFBQTtBQUFBO0FBU1hJLGNBQUFBLFFBQVEsYUFBUjtBQUNBRixjQUFBQSxXQUFXLENBQUMsS0FBRCxDQUFYO0FBQ0FGLGNBQUFBLFVBQVUsQ0FBQyxLQUFELENBQVY7O0FBWFc7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsS0FBSDs7QUFBQSxvQkFBSk8sSUFBSTtBQUFBO0FBQUE7QUFBQSxLQUFWOztBQWVBLE1BQU1HLE1BQU07QUFBQSx3RUFBRztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsa0JBQ1JiLFlBRFE7QUFBQTtBQUFBO0FBQUE7O0FBQUEsb0JBRUwsSUFBSWMsS0FBSixDQUFVLGdEQUFWLENBRks7O0FBQUE7QUFJWFgsY0FBQUEsVUFBVSxDQUFDLElBQUQsQ0FBVjtBQUpXO0FBQUEscUJBS0xILFlBQVksQ0FBQ2EsTUFBYixFQUxLOztBQUFBO0FBTVhKLGNBQUFBLFlBQVksQ0FBQ1QsWUFBWSxDQUFDUSxTQUFiLEVBQUQsQ0FBWjtBQUNBTCxjQUFBQSxVQUFVLENBQUMsS0FBRCxDQUFWOztBQVBXO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEtBQUg7O0FBQUEsb0JBQU5VLE1BQU07QUFBQTtBQUFBO0FBQUEsS0FBWjs7QUFXQSxNQUFNRSxXQUFXLEdBQUcsU0FBZEEsV0FBYyxDQUFDQyxJQUFELEVBQVU7QUFDNUIsUUFBSSxDQUFDaEIsWUFBTCxFQUFtQjtBQUNqQixZQUFNLElBQUljLEtBQUosQ0FBVSxxREFBVixDQUFOO0FBQ0Q7O0FBQ0QsUUFBSSxDQUFDRSxJQUFMLEVBQVc7QUFDVCxZQUFNLElBQUlGLEtBQUosQ0FBVSw4QkFBVixDQUFOO0FBQ0Q7O0FBQ0QsV0FBT2QsWUFBWSxDQUFDZSxXQUFiLENBQXlCQyxJQUF6QixDQUFQO0FBQ0QsR0FSRDtBQVVBO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdFLHNCQUNFLGdDQUFDLGFBQUQsQ0FBZSxRQUFmO0FBQ0UsSUFBQSxLQUFLLEVBQUU7QUFDTGQsTUFBQUEsT0FBTyxFQUFQQSxPQURLO0FBRUxNLE1BQUFBLFNBQVMsRUFBVEEsU0FGSztBQUdMRSxNQUFBQSxJQUFJLEVBQUpBLElBSEs7QUFJTEcsTUFBQUEsTUFBTSxFQUFOQSxNQUpLO0FBS0xFLE1BQUFBLFdBQVcsRUFBWEEsV0FMSztBQU1MWCxNQUFBQSxRQUFRLEVBQVJBLFFBTks7QUFPTEUsTUFBQUEsS0FBSyxFQUFMQTtBQVBLO0FBRFQsS0FXR1AsUUFYSCxDQURGO0FBZUQsQ0FsRk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlU3RhdGUsIHVzZUNvbnRleHQsIHVzZUNhbGxiYWNrIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgY3JlYXRlQXNlcnRvQ2xpZW50IGZyb20gJ0Bhc2VydG8vYXNlcnRvLXNwYS1qcydcblxuZXhwb3J0IGNvbnN0IEFzZXJ0b0NvbnRleHQgPSBSZWFjdC5jcmVhdGVDb250ZXh0KCk7XG5leHBvcnQgY29uc3QgdXNlQXNlcnRvID0gKCkgPT4gdXNlQ29udGV4dChBc2VydG9Db250ZXh0KTtcbmV4cG9ydCBjb25zdCBBc2VydG9Qcm92aWRlciA9ICh7XG4gIGNoaWxkcmVuXG59KSA9PiB7XG4gIGNvbnN0IFthc2VydG9DbGllbnQsIHNldEFzZXJ0b0NsaWVudF0gPSB1c2VTdGF0ZSgpO1xuICBjb25zdCBbbG9hZGluZywgc2V0TG9hZGluZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtpc0xvYWRlZCwgc2V0SXNMb2FkZWRdID0gdXNlU3RhdGUoZmFsc2UpO1xuICBjb25zdCBbZXJyb3IsIHNldEVycm9yXSA9IHVzZVN0YXRlKCk7XG4gIGNvbnN0IFthY2Nlc3NNYXAsIHNldEFjY2Vzc01hcF0gPSB1c2VTdGF0ZSgpO1xuXG4gIGNvbnN0IGluaXQgPSBhc3luYyAoaW5pdE9wdGlvbnMpID0+IHtcbiAgICB0cnkge1xuICAgIHNldExvYWRpbmcodHJ1ZSk7XG4gICAgY29uc3QgYXNlcnRvRnJvbUhvb2sgPSBhd2FpdCBjcmVhdGVBc2VydG9DbGllbnQoaW5pdE9wdGlvbnMpO1xuICAgIHNldEFzZXJ0b0NsaWVudChhc2VydG9Gcm9tSG9vayk7XG4gICAgc2V0QWNjZXNzTWFwKGFzZXJ0b0Zyb21Ib29rLmFjY2Vzc01hcCgpKTtcbiAgICBzZXRJc0xvYWRlZCh0cnVlKTsgICAgICBcbiAgICBzZXRMb2FkaW5nKGZhbHNlKTtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBzZXRFcnJvcihlcnJvcik7XG4gICAgc2V0SXNMb2FkZWQoZmFsc2UpO1xuICAgIHNldExvYWRpbmcoZmFsc2UpO1xuICB9XG59XG5cbiAgY29uc3QgcmVsb2FkID0gYXN5bmMgKCkgPT4ge1xuICAgIGlmICghYXNlcnRvQ2xpZW50KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2FzZXJ0by1yZWFjdDogbXVzdCBjYWxsIGluaXQoKSBiZWZvcmUgcmVsb2FkKCknKTtcbiAgICB9IGVsc2Uge1xuICAgICAgc2V0TG9hZGluZyh0cnVlKTtcbiAgICAgIGF3YWl0IGFzZXJ0b0NsaWVudC5yZWxvYWQoKTtcbiAgICAgIHNldEFjY2Vzc01hcChhc2VydG9DbGllbnQuYWNjZXNzTWFwKCkpO1xuICAgICAgc2V0TG9hZGluZyhmYWxzZSk7XG4gICAgfVxuICB9XG5cbiAgY29uc3QgcmVzb3VyY2VNYXAgPSAocGF0aCkgPT4ge1xuICAgIGlmICghYXNlcnRvQ2xpZW50KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ2FzZXJ0by1yZWFjdDogbXVzdCBjYWxsIGluaXQoKSBiZWZvcmUgcmVzb3VyY2VNYXAoKScpO1xuICAgIH0gXG4gICAgaWYgKCFwYXRoKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ3BhdGggaXMgYSByZXF1aXJlZCBwYXJhbWV0ZXInKTtcbiAgICB9XG4gICAgcmV0dXJuIGFzZXJ0b0NsaWVudC5yZXNvdXJjZU1hcChwYXRoKTtcbiAgfVxuXG4gIC8qXG4gIGNvbnN0IGluaXRDYWxsYmFjayA9IHVzZUNhbGxiYWNrKCguLi5wKSA9PiB7XG4gICAgYXN5bmMgZnVuY3Rpb24gY2FsbEluaXQoLi4ucCkge1xuICAgICAgcmV0dXJuIGluaXQoLi4ucCk7XG4gICAgfVxuICAgIHJldHVybiBjYWxsSW5pdCguLi5wKTtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwcyAgXG4gIH0sIFtdKTtcblxuICBjb25zdCBsb2FkQWNjZXNzTWFwQ2FsbGJhY2sgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgYXN5bmMgZnVuY3Rpb24gY2FsbExvYWQoKSB7XG4gICAgICByZXR1cm4gbG9hZCgpO1xuICAgIH1cbiAgICBpZiAoIWFzZXJ0b0NsaWVudCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdhc2VydG8tcmVhY3Q6IG11c3QgY2FsbCBpbml0KCkgYmVmb3JlIGxvYWRBY2Nlc3NNYXAoKScpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY2FsbExvYWQoKTsgICAgXG4gICAgfVxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3QtaG9va3MvZXhoYXVzdGl2ZS1kZXBzICBcbiAgfSwgW10pO1xuICAqL1xuXG4gIHJldHVybiAoXG4gICAgPEFzZXJ0b0NvbnRleHQuUHJvdmlkZXJcbiAgICAgIHZhbHVlPXt7XG4gICAgICAgIGxvYWRpbmcsXG4gICAgICAgIGFjY2Vzc01hcCxcbiAgICAgICAgaW5pdCxcbiAgICAgICAgcmVsb2FkLFxuICAgICAgICByZXNvdXJjZU1hcCxcbiAgICAgICAgaXNMb2FkZWQsXG4gICAgICAgIGVycm9yXG4gICAgICB9fVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0FzZXJ0b0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59OyJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["AsertoContext","React","createContext","useAserto","AsertoProvider","children","asertoClient","setAsertoClient","loading","setLoading","isLoaded","setIsLoaded","error","setError","accessMap","setAccessMap","init","initOptions","throwOnError","defaultMap","visible","enabled","allowed","asertoFromHook","console","reload","resourceMap","path","Error","GET","PUT","DELETE","POST"],"mappings":"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","sourcesContent":["import React, { useState, useContext, useCallback } from 'react'\nimport createAsertoClient from '@aserto/aserto-spa-js'\n\nexport const AsertoContext = React.createContext();\nexport const useAserto = () => useContext(AsertoContext);\nexport const AsertoProvider = ({\n  children\n}) => {\n  const [asertoClient, setAsertoClient] = useState();\n  const [loading, setLoading] = useState(false);\n  const [isLoaded, setIsLoaded] = useState(false);\n  const [error, setError] = useState();\n  const [accessMap, setAccessMap] = useState();\n\n  const init = async (initOptions) => {\n    const throwOnError = initOptions.throwOnError;\n    const defaultMap = initOptions.defaultMap || {\n      visible: true,\n      enabled: true,\n      allowed: false\n    };\n\n    try {\n      setLoading(true);\n      const asertoFromHook = await createAsertoClient(initOptions);\n      setAsertoClient(asertoFromHook);\n      setAccessMap(asertoFromHook.accessMap());\n      setIsLoaded(true);      \n      setLoading(false);\n    } catch (error) {\n      if (throwOnError) {\n        throw error;\n      }\n      console.error(error);\n      setError(error);\n      setIsLoaded(false);\n      setLoading(false);\n    }\n  }\n\n  const reload = async () => {\n    try {\n      if (asertoClient) {\n        setLoading(true);\n        await asertoClient.reload();\n        setAccessMap(asertoClient.accessMap());\n        setLoading(false);\n      }\n    } catch (error) {\n      if (throwOnError) {\n        throw error;\n      }\n      console.error(error);\n      setError(error);\n      setIsLoaded(false);\n      setLoading(false);\n    }\n  }\n\n  const resourceMap = (path) => {\n    if (asertoClient && path) {\n      return asertoClient.resourceMap(path);\n    }\n\n    // no client or path\n    if (throwOnError) {\n      if (!asertoClient) {\n        throw new Error('aserto-react: must call init() before resourceMap()');\n      } \n      if (!path) {\n        throw new Error('aserto-react: path is a required parameter');\n      }\n    } else {\n      // return the default map\n      return {\n        GET: defaultMap,\n        PUT: defaultMap,\n        DELETE: defaultMap,\n        POST: defaultMap\n      }\n    }\n  }\n\n  /*\n  const initCallback = useCallback((...p) => {\n    async function callInit(...p) {\n      return init(...p);\n    }\n    return callInit(...p);\n  // eslint-disable-next-line react-hooks/exhaustive-deps  \n  }, []);\n\n  const loadAccessMapCallback = useCallback(() => {\n    async function callLoad() {\n      return load();\n    }\n    if (!asertoClient) {\n      throw new Error('aserto-react: must call init() before loadAccessMap()');\n    } else {\n      return callLoad();    \n    }\n  // eslint-disable-next-line react-hooks/exhaustive-deps  \n  }, []);\n  */\n\n  return (\n    <AsertoContext.Provider\n      value={{\n        loading,\n        accessMap,\n        init,\n        reload,\n        resourceMap,\n        isLoaded,\n        error\n      }}\n    >\n      {children}\n    </AsertoContext.Provider>\n  );\n};"]} |
{ | ||
"name": "@aserto/aserto-react", | ||
"version": "0.1.32", | ||
"version": "0.1.33", | ||
"description": "Aserto React SDK", | ||
@@ -30,3 +30,3 @@ "main": "dist/index.js", | ||
"dependencies": { | ||
"@aserto/aserto-spa-js": "^0.1.18" | ||
"@aserto/aserto-spa-js": "^0.1.19" | ||
}, | ||
@@ -33,0 +33,0 @@ "devDependencies": { |
@@ -61,3 +61,3 @@ # Aserto React SDK | ||
init, | ||
loadAccessMap | ||
reload | ||
} = useAserto(); | ||
@@ -90,3 +90,2 @@ | ||
if (!accessMap) { | ||
init(); | ||
return <div>Loading...</div>; | ||
@@ -115,3 +114,9 @@ } else { | ||
endpointName: '/__accessmap', // defaults to '/__accessmap', | ||
accessToken: '<VALID ACCESS TOKEN>' // REQUIRED | ||
accessToken: '<VALID ACCESS TOKEN>', // REQUIRED | ||
throwOnError: false, // if true, re-throws errors; defaults to false | ||
defaultMap: { // an optional default resource map | ||
visible: true, | ||
enabled: true, | ||
allowed: false | ||
} | ||
}); | ||
@@ -141,3 +146,3 @@ | ||
The `path` argument is in the form `/path/to/resource`. It may contain a `{id}` component to indicate an parameter. | ||
The `path` argument is in the form `/path/to/resource`. It may contain a `__id` component to indicate an parameter - for example, `/cars/__id`. | ||
@@ -147,3 +152,3 @@ The returned map will be in the following format: | ||
{ | ||
get: { | ||
GET: { | ||
visible: true, | ||
@@ -153,3 +158,3 @@ enabled: false, | ||
}, | ||
post: { | ||
POST: { | ||
visible: true, | ||
@@ -159,6 +164,6 @@ enabled: false, | ||
}, | ||
put: { | ||
PUT: { | ||
//... | ||
}, | ||
delete: { | ||
DELETE: { | ||
//... | ||
@@ -177,9 +182,9 @@ } | ||
// use the map to retrieve visibility of an element | ||
const isVisible = resource.get.visible; | ||
const isVisible = resource.GET.visible; | ||
// use the map to determine whether an update operation is enabled | ||
const isUpdateEnabled = resource.put.enabled; | ||
const isUpdateEnabled = resource.PUT.enabled; | ||
// print out access values for each verb on a resource | ||
for (const verb of ['get', 'post', 'put', 'delete']) { | ||
for (const verb of ['GET', 'POST', 'PUT', 'DELETE']) { | ||
for (const access of ['visible', 'enabled', 'allowed']) { | ||
@@ -186,0 +191,0 @@ console.log(`${verb} ${path} ${access} is ${resource[verb][access]}`); |
23814
200
187