From ef60f2a0c42c9a55f8eb08c4ee58a0bc978cba9a Mon Sep 17 00:00:00 2001 From: Scitizen-publish-bot Date: Sun, 6 Mar 2022 11:35:04 +0000 Subject: [PATCH] chore(release): 0.0.3-next.0 [skip ci] --- CHANGELOG.md | 7 + docs/.nojekyll | 1 + docs/CHANGELOG.html | 73 + docs/assets/code-blocks.css | 15 + docs/assets/css/main.css | 2679 ----------------- docs/assets/css/pages.css | 64 - docs/assets/highlight.css | 106 + docs/assets/icons.css | 1043 +++++++ docs/assets/{images => }/icons.png | Bin docs/assets/{images => }/icons@2x.png | Bin docs/assets/images/page-icon.svg | 1 - docs/assets/js/main.js | 1 - docs/assets/js/search.js | 1 - docs/assets/js/search.json | 1 - docs/assets/main.js | 52 + docs/assets/pages.css | 30 + docs/assets/search.js | 1 + docs/assets/style.css | 1413 +++++++++ docs/assets/{images => }/widgets.png | Bin docs/assets/{images => }/widgets@2x.png | Bin docs/classes/CaslModule.html | 267 +- docs/index.html | 349 +-- docs/interfaces/CaslAbilityFactory.html | 258 +- docs/interfaces/ICaslRootConfig.html | 222 +- docs/interfaces/IPolicy.html | 258 +- docs/modules.html | 649 +--- docs/modules/PoliciesMask.html | 194 +- docs/modules/Policy.html | 194 +- docs/pages/Changelog/CHANGELOG.html | 190 -- .../pages/Guides/better-type-constraints.html | 292 -- docs/pages/Guides/getting-started.html | 311 -- docs/pages/Guides/use-with-guards.html | 572 ---- docs/pages/guide/better-type-constraints.html | 48 + docs/pages/guide/getting-started.html | 51 + docs/pages/guide/use-with-guards.html | 119 + package-lock.json | 2 +- package.json | 2 +- 37 files changed, 3116 insertions(+), 6350 deletions(-) create mode 100644 docs/.nojekyll create mode 100644 docs/CHANGELOG.html create mode 100755 docs/assets/code-blocks.css delete mode 100644 docs/assets/css/main.css delete mode 100644 docs/assets/css/pages.css create mode 100644 docs/assets/highlight.css create mode 100644 docs/assets/icons.css rename docs/assets/{images => }/icons.png (100%) rename docs/assets/{images => }/icons@2x.png (100%) delete mode 100644 docs/assets/images/page-icon.svg delete mode 100644 docs/assets/js/main.js delete mode 100644 docs/assets/js/search.js delete mode 100644 docs/assets/js/search.json create mode 100644 docs/assets/main.js create mode 100755 docs/assets/pages.css create mode 100644 docs/assets/search.js create mode 100644 docs/assets/style.css rename docs/assets/{images => }/widgets.png (100%) rename docs/assets/{images => }/widgets@2x.png (100%) delete mode 100644 docs/pages/Changelog/CHANGELOG.html delete mode 100644 docs/pages/Guides/better-type-constraints.html delete mode 100644 docs/pages/Guides/getting-started.html delete mode 100644 docs/pages/Guides/use-with-guards.html create mode 100644 docs/pages/guide/better-type-constraints.html create mode 100644 docs/pages/guide/getting-started.html create mode 100644 docs/pages/guide/use-with-guards.html diff --git a/CHANGELOG.md b/CHANGELOG.md index 950af3d1..47518f42 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,13 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. +### [0.0.3-next.0](https://github.com/Scitizen/nest-casl/compare/v0.0.2...v0.0.3-next.0) (2022-03-06) + + +### Bug Fixes + +* change how injectable definition is done ([efd306a](https://github.com/Scitizen/nest-casl/commit/efd306aa8de7ccdf751f602023f008c0c2449e0f)) + ### [0.0.2](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.7...v0.0.2) (2021-11-06) ### [0.0.2-next.7](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.6...v0.0.2-next.7) (2021-10-08) diff --git a/docs/.nojekyll b/docs/.nojekyll new file mode 100644 index 00000000..e2ac6616 --- /dev/null +++ b/docs/.nojekyll @@ -0,0 +1 @@ +TypeDoc added this file to prevent GitHub Pages from using Jekyll. You can turn off this behavior by setting the `githubPages` option to false. \ No newline at end of file diff --git a/docs/CHANGELOG.html b/docs/CHANGELOG.html new file mode 100644 index 00000000..04762914 --- /dev/null +++ b/docs/CHANGELOG.html @@ -0,0 +1,73 @@ +Changelog | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu
+ +

Changelog

+
+

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

+ + +

0.0.3-next.0 (2022-03-06)

+ + + +

Bug Fixes

+
+
    +
  • change how injectable definition is done (efd306a)
  • +
+ + +

0.0.2 (2021-11-06)

+ + + +

0.0.2-next.7 (2021-10-08)

+ + + +

0.0.2-next.6 (2021-10-08)

+ + + +

0.0.2-next.5 (2021-10-08)

+ + + +

0.0.2-next.4 (2021-10-07)

+ + + +

0.0.2-next.3 (2021-10-06)

+ + + +

0.0.2-next.2 (2021-10-06)

+ + + +

Features

+
+
    +
  • policies.guard: allow async handlers (9594542)
  • +
+ + +

Bug Fixes

+
+
    +
  • add policy metadata in the correct order (467354a)
  • +
  • or.guard: properly waterfall canActivate, stop further checks on first success, use promises (f92f45e)
  • +
+ + +

0.0.2-next.1 (2021-10-06)

+ + + +

0.0.2-next.0 (2021-10-06)

+ + + +

0.0.1 (2021-10-06)

+ +

Initial release

+

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/assets/code-blocks.css b/docs/assets/code-blocks.css new file mode 100755 index 00000000..d15bf138 --- /dev/null +++ b/docs/assets/code-blocks.css @@ -0,0 +1,15 @@ +.code-block { + tab-size: 4; + background-color: var(--color-toolbar); + padding: 0.5em; +} +.code-block > p, +.code-block > summary > p { + margin: 0 0 0.25em; + display: inline-block; + font-weight: bolder; +} + +details.code-block summary { + cursor: pointer; +} \ No newline at end of file diff --git a/docs/assets/css/main.css b/docs/assets/css/main.css deleted file mode 100644 index 1ffd2a30..00000000 --- a/docs/assets/css/main.css +++ /dev/null @@ -1,2679 +0,0 @@ -/*! normalize.css v1.1.3 | MIT License | git.io/normalize */ -/* ========================================================================== - * * HTML5 display definitions - * * ========================================================================== */ -/** - * * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */ -article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { - display: block; -} - -/** - * * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */ -audio, canvas, video { - display: inline-block; - *display: inline; - *zoom: 1; -} - -/** - * * Prevent modern browsers from displaying `audio` without controls. - * * Remove excess height in iOS 5 devices. */ -audio:not([controls]) { - display: none; - height: 0; -} - -/** - * * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4. - * * Known issue: no IE 6 support. */ -[hidden] { - display: none; -} - -/* ========================================================================== - * * Base - * * ========================================================================== */ -/** - * * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using - * * `em` units. - * * 2. Prevent iOS text size adjust after orientation change, without disabling - * * user zoom. */ -html { - font-size: 100%; - /* 1 */ - -ms-text-size-adjust: 100%; - /* 2 */ - -webkit-text-size-adjust: 100%; - /* 2 */ - font-family: sans-serif; -} - -/** - * * Address `font-family` inconsistency between `textarea` and other form - * * elements. */ -button, input, select, textarea { - font-family: sans-serif; -} - -/** - * * Address margins handled incorrectly in IE 6/7. */ -body { - margin: 0; -} - -/* ========================================================================== - * * Links - * * ========================================================================== */ -/** - * * Address `outline` inconsistency between Chrome and other browsers. */ -a:focus { - outline: thin dotted; -} -a:active, a:hover { - outline: 0; -} - -/** - * * Improve readability when focused and also mouse hovered in all browsers. */ -/* ========================================================================== - * * Typography - * * ========================================================================== */ -/** - * * Address font sizes and margins set differently in IE 6/7. - * * Address font sizes within `section` and `article` in Firefox 4+, Safari 5, - * * and Chrome. */ -h1 { - font-size: 2em; - margin: 0.67em 0; -} - -h2 { - font-size: 1.5em; - margin: 0.83em 0; -} - -h3 { - font-size: 1.17em; - margin: 1em 0; -} - -h4, .tsd-index-panel h3 { - font-size: 1em; - margin: 1.33em 0; -} - -h5 { - font-size: 0.83em; - margin: 1.67em 0; -} - -h6 { - font-size: 0.67em; - margin: 2.33em 0; -} - -/** - * * Address styling not present in IE 7/8/9, Safari 5, and Chrome. */ -abbr[title] { - border-bottom: 1px dotted; -} - -/** - * * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */ -b, strong { - font-weight: bold; -} - -blockquote { - margin: 1em 40px; -} - -/** - * * Address styling not present in Safari 5 and Chrome. */ -dfn { - font-style: italic; -} - -/** - * * Address differences between Firefox and other browsers. - * * Known issue: no IE 6/7 normalization. */ -hr { - box-sizing: content-box; - height: 0; -} - -/** - * * Address styling not present in IE 6/7/8/9. */ -mark { - background: #ff0; - color: #000; -} - -/** - * * Address margins set differently in IE 6/7. */ -p, pre { - margin: 1em 0; -} - -/** - * * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */ -code, kbd, pre, samp { - font-family: monospace, serif; - _font-family: "courier new", monospace; - font-size: 1em; -} - -/** - * * Improve readability of pre-formatted text in all browsers. */ -pre { - white-space: pre; - white-space: pre-wrap; - word-wrap: break-word; -} - -/** - * * Address CSS quotes not supported in IE 6/7. */ -q { - quotes: none; -} -q:before, q:after { - content: ""; - content: none; -} - -/** - * * Address `quotes` property not supported in Safari 4. */ -/** - * * Address inconsistent and variable font size in all browsers. */ -small { - font-size: 80%; -} - -/** - * * Prevent `sub` and `sup` affecting `line-height` in all browsers. */ -sub { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; -} - -sup { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; - top: -0.5em; -} - -sub { - bottom: -0.25em; -} - -/* ========================================================================== - * * Lists - * * ========================================================================== */ -/** - * * Address margins set differently in IE 6/7. */ -dl, menu, ol, ul { - margin: 1em 0; -} - -dd { - margin: 0 0 0 40px; -} - -/** - * * Address paddings set differently in IE 6/7. */ -menu, ol, ul { - padding: 0 0 0 40px; -} - -/** - * * Correct list images handled incorrectly in IE 7. */ -nav ul, nav ol { - list-style: none; - list-style-image: none; -} - -/* ========================================================================== - * * Embedded content - * * ========================================================================== */ -/** - * * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3. - * * 2. Improve image quality when scaled in IE 7. */ -img { - border: 0; - /* 1 */ - -ms-interpolation-mode: bicubic; -} - -/* 2 */ -/** - * * Correct overflow displayed oddly in IE 9. */ -svg:not(:root) { - overflow: hidden; -} - -/* ========================================================================== - * * Figures - * * ========================================================================== */ -/** - * * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */ -figure, form { - margin: 0; -} - -/* ========================================================================== - * * Forms - * * ========================================================================== */ -/** - * * Correct margin displayed oddly in IE 6/7. */ -/** - * * Define consistent border, margin, and padding. */ -fieldset { - border: 1px solid #c0c0c0; - margin: 0 2px; - padding: 0.35em 0.625em 0.75em; -} - -/** - * * 1. Correct color not being inherited in IE 6/7/8/9. - * * 2. Correct text not wrapping in Firefox 3. - * * 3. Correct alignment displayed oddly in IE 6/7. */ -legend { - border: 0; - /* 1 */ - padding: 0; - white-space: normal; - /* 2 */ - *margin-left: -7px; -} - -/* 3 */ -/** - * * 1. Correct font size not being inherited in all browsers. - * * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5, - * * and Chrome. - * * 3. Improve appearance and consistency in all browsers. */ -button, input, select, textarea { - font-size: 100%; - /* 1 */ - margin: 0; - /* 2 */ - vertical-align: baseline; - /* 3 */ - *vertical-align: middle; -} - -/* 3 */ -/** - * * Address Firefox 3+ setting `line-height` on `input` using `!important` in - * * the UA stylesheet. */ -button, input { - line-height: normal; -} - -/** - * * Address inconsistent `text-transform` inheritance for `button` and `select`. - * * All other form control elements do not inherit `text-transform` values. - * * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+. - * * Correct `select` style inheritance in Firefox 4+ and Opera. */ -button, select { - text-transform: none; -} - -/** - * * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` - * * and `video` controls. - * * 2. Correct inability to style clickable `input` types in iOS. - * * 3. Improve usability and consistency of cursor style between image-type - * * `input` and others. - * * 4. Remove inner spacing in IE 7 without affecting normal text inputs. - * * Known issue: inner spacing remains in IE 6. */ -button, html input[type=button] { - -webkit-appearance: button; - /* 2 */ - cursor: pointer; - /* 3 */ - *overflow: visible; -} - -/* 4 */ -input[type=reset], input[type=submit] { - -webkit-appearance: button; - /* 2 */ - cursor: pointer; - /* 3 */ - *overflow: visible; -} - -/* 4 */ -/** - * * Re-set default cursor for disabled elements. */ -button[disabled], html input[disabled] { - cursor: default; -} - -/** - * * 1. Address box sizing set to content-box in IE 8/9. - * * 2. Remove excess padding in IE 8/9. - * * 3. Remove excess padding in IE 7. - * * Known issue: excess padding remains in IE 6. */ -input { - /* 3 */ -} -input[type=checkbox], input[type=radio] { - box-sizing: border-box; - /* 1 */ - padding: 0; - /* 2 */ - *height: 13px; - /* 3 */ - *width: 13px; -} -input[type=search] { - -webkit-appearance: textfield; - /* 1 */ - /* 2 */ - box-sizing: content-box; -} -input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration { - -webkit-appearance: none; -} - -/** - * * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. - * * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome - * * (include `-moz` to future-proof). */ -/** - * * Remove inner padding and search cancel button in Safari 5 and Chrome - * * on OS X. */ -/** - * * Remove inner padding and border in Firefox 3+. */ -button::-moz-focus-inner, input::-moz-focus-inner { - border: 0; - padding: 0; -} - -/** - * * 1. Remove default vertical scrollbar in IE 6/7/8/9. - * * 2. Improve readability and alignment in all browsers. */ -textarea { - overflow: auto; - /* 1 */ - vertical-align: top; -} - -/* 2 */ -/* ========================================================================== - * * Tables - * * ========================================================================== */ -/** - * * Remove most spacing between table cells. */ -table { - border-collapse: collapse; - border-spacing: 0; -} - -/* * - * *Visual Studio-like style based on original C# coloring by Jason Diamond */ -.hljs { - display: inline-block; - padding: 0.5em; - background: white; - color: black; -} - -.hljs-comment, .hljs-annotation, .hljs-template_comment, .diff .hljs-header, .hljs-chunk, .apache .hljs-cbracket { - color: #008000; -} - -.hljs-keyword, .hljs-id, .hljs-built_in, .css .smalltalk .hljs-class, .hljs-winutils, .bash .hljs-variable, .tex .hljs-command, .hljs-request, .hljs-status, .nginx .hljs-title { - color: #00f; -} - -.xml .hljs-tag { - color: #00f; -} -.xml .hljs-tag .hljs-value { - color: #00f; -} - -.hljs-string, .hljs-title, .hljs-parent, .hljs-tag .hljs-value, .hljs-rules .hljs-value { - color: #a31515; -} - -.ruby .hljs-symbol { - color: #a31515; -} -.ruby .hljs-symbol .hljs-string { - color: #a31515; -} - -.hljs-template_tag, .django .hljs-variable, .hljs-addition, .hljs-flow, .hljs-stream, .apache .hljs-tag, .hljs-date, .tex .hljs-formula, .coffeescript .hljs-attribute { - color: #a31515; -} - -.ruby .hljs-string, .hljs-decorator, .hljs-filter .hljs-argument, .hljs-localvars, .hljs-array, .hljs-attr_selector, .hljs-pseudo, .hljs-pi, .hljs-doctype, .hljs-deletion, .hljs-envvar, .hljs-shebang, .hljs-preprocessor, .hljs-pragma, .userType, .apache .hljs-sqbracket, .nginx .hljs-built_in, .tex .hljs-special, .hljs-prompt { - color: #2b91af; -} - -.hljs-phpdoc, .hljs-javadoc, .hljs-xmlDocTag { - color: #808080; -} - -.vhdl .hljs-typename { - font-weight: bold; -} -.vhdl .hljs-string { - color: #666666; -} -.vhdl .hljs-literal { - color: #a31515; -} -.vhdl .hljs-attribute { - color: #00b0e8; -} - -.xml .hljs-attribute { - color: #f00; -} - -ul.tsd-descriptions > li > :first-child, .tsd-panel > :first-child, .col > :first-child, .col-11 > :first-child, .col-10 > :first-child, .col-9 > :first-child, .col-8 > :first-child, .col-7 > :first-child, .col-6 > :first-child, .col-5 > :first-child, .col-4 > :first-child, .col-3 > :first-child, .col-2 > :first-child, .col-1 > :first-child, -ul.tsd-descriptions > li > :first-child > :first-child, -.tsd-panel > :first-child > :first-child, -.col > :first-child > :first-child, -.col-11 > :first-child > :first-child, -.col-10 > :first-child > :first-child, -.col-9 > :first-child > :first-child, -.col-8 > :first-child > :first-child, -.col-7 > :first-child > :first-child, -.col-6 > :first-child > :first-child, -.col-5 > :first-child > :first-child, -.col-4 > :first-child > :first-child, -.col-3 > :first-child > :first-child, -.col-2 > :first-child > :first-child, -.col-1 > :first-child > :first-child, -ul.tsd-descriptions > li > :first-child > :first-child > :first-child, -.tsd-panel > :first-child > :first-child > :first-child, -.col > :first-child > :first-child > :first-child, -.col-11 > :first-child > :first-child > :first-child, -.col-10 > :first-child > :first-child > :first-child, -.col-9 > :first-child > :first-child > :first-child, -.col-8 > :first-child > :first-child > :first-child, -.col-7 > :first-child > :first-child > :first-child, -.col-6 > :first-child > :first-child > :first-child, -.col-5 > :first-child > :first-child > :first-child, -.col-4 > :first-child > :first-child > :first-child, -.col-3 > :first-child > :first-child > :first-child, -.col-2 > :first-child > :first-child > :first-child, -.col-1 > :first-child > :first-child > :first-child { - margin-top: 0; -} -ul.tsd-descriptions > li > :last-child, .tsd-panel > :last-child, .col > :last-child, .col-11 > :last-child, .col-10 > :last-child, .col-9 > :last-child, .col-8 > :last-child, .col-7 > :last-child, .col-6 > :last-child, .col-5 > :last-child, .col-4 > :last-child, .col-3 > :last-child, .col-2 > :last-child, .col-1 > :last-child, -ul.tsd-descriptions > li > :last-child > :last-child, -.tsd-panel > :last-child > :last-child, -.col > :last-child > :last-child, -.col-11 > :last-child > :last-child, -.col-10 > :last-child > :last-child, -.col-9 > :last-child > :last-child, -.col-8 > :last-child > :last-child, -.col-7 > :last-child > :last-child, -.col-6 > :last-child > :last-child, -.col-5 > :last-child > :last-child, -.col-4 > :last-child > :last-child, -.col-3 > :last-child > :last-child, -.col-2 > :last-child > :last-child, -.col-1 > :last-child > :last-child, -ul.tsd-descriptions > li > :last-child > :last-child > :last-child, -.tsd-panel > :last-child > :last-child > :last-child, -.col > :last-child > :last-child > :last-child, -.col-11 > :last-child > :last-child > :last-child, -.col-10 > :last-child > :last-child > :last-child, -.col-9 > :last-child > :last-child > :last-child, -.col-8 > :last-child > :last-child > :last-child, -.col-7 > :last-child > :last-child > :last-child, -.col-6 > :last-child > :last-child > :last-child, -.col-5 > :last-child > :last-child > :last-child, -.col-4 > :last-child > :last-child > :last-child, -.col-3 > :last-child > :last-child > :last-child, -.col-2 > :last-child > :last-child > :last-child, -.col-1 > :last-child > :last-child > :last-child { - margin-bottom: 0; -} - -.container { - max-width: 1200px; - margin: 0 auto; - padding: 0 40px; -} -@media (max-width: 640px) { - .container { - padding: 0 20px; - } -} - -.container-main { - padding-bottom: 200px; -} - -.row { - display: -ms-flexbox; - display: flex; - position: relative; - margin: 0 -10px; -} -.row:after { - visibility: hidden; - display: block; - content: ""; - clear: both; - height: 0; -} - -.col, .col-11, .col-10, .col-9, .col-8, .col-7, .col-6, .col-5, .col-4, .col-3, .col-2, .col-1 { - box-sizing: border-box; - float: left; - padding: 0 10px; -} - -.col-1 { - width: 8.3333333333%; -} - -.offset-1 { - margin-left: 8.3333333333%; -} - -.col-2 { - width: 16.6666666667%; -} - -.offset-2 { - margin-left: 16.6666666667%; -} - -.col-3 { - width: 25%; -} - -.offset-3 { - margin-left: 25%; -} - -.col-4 { - width: 33.3333333333%; -} - -.offset-4 { - margin-left: 33.3333333333%; -} - -.col-5 { - width: 41.6666666667%; -} - -.offset-5 { - margin-left: 41.6666666667%; -} - -.col-6 { - width: 50%; -} - -.offset-6 { - margin-left: 50%; -} - -.col-7 { - width: 58.3333333333%; -} - -.offset-7 { - margin-left: 58.3333333333%; -} - -.col-8 { - width: 66.6666666667%; -} - -.offset-8 { - margin-left: 66.6666666667%; -} - -.col-9 { - width: 75%; -} - -.offset-9 { - margin-left: 75%; -} - -.col-10 { - width: 83.3333333333%; -} - -.offset-10 { - margin-left: 83.3333333333%; -} - -.col-11 { - width: 91.6666666667%; -} - -.offset-11 { - margin-left: 91.6666666667%; -} - -.tsd-kind-icon { - display: block; - position: relative; - padding-left: 20px; - text-indent: -20px; -} -.tsd-kind-icon:before { - content: ""; - display: inline-block; - vertical-align: middle; - width: 17px; - height: 17px; - margin: 0 3px 2px 0; - background-image: url(../images/icons.png); -} -@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { - .tsd-kind-icon:before { - background-image: url(../images/icons@2x.png); - background-size: 238px 204px; - } -} - -.tsd-signature.tsd-kind-icon:before { - background-position: 0 -153px; -} - -.tsd-kind-object-literal > .tsd-kind-icon:before { - background-position: 0px -17px; -} -.tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -17px; -} -.tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -17px; -} - -.tsd-kind-class > .tsd-kind-icon:before { - background-position: 0px -34px; -} -.tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -34px; -} -.tsd-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -34px; -} - -.tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before { - background-position: 0px -51px; -} -.tsd-kind-class.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -51px; -} -.tsd-kind-class.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -51px; -} - -.tsd-kind-interface > .tsd-kind-icon:before { - background-position: 0px -68px; -} -.tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -68px; -} -.tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -68px; -} - -.tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before { - background-position: 0px -85px; -} -.tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -85px; -} -.tsd-kind-interface.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -85px; -} - -.tsd-kind-namespace > .tsd-kind-icon:before { - background-position: 0px -102px; -} -.tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -102px; -} -.tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -102px; -} - -.tsd-kind-module > .tsd-kind-icon:before { - background-position: 0px -102px; -} -.tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -102px; -} -.tsd-kind-module.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -102px; -} - -.tsd-kind-enum > .tsd-kind-icon:before { - background-position: 0px -119px; -} -.tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -119px; -} -.tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -119px; -} - -.tsd-kind-enum-member > .tsd-kind-icon:before { - background-position: 0px -136px; -} -.tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -136px; -} -.tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -136px; -} - -.tsd-kind-signature > .tsd-kind-icon:before { - background-position: 0px -153px; -} -.tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -153px; -} -.tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -153px; -} - -.tsd-kind-type-alias > .tsd-kind-icon:before { - background-position: 0px -170px; -} -.tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -170px; -} -.tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -170px; -} - -.tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before { - background-position: 0px -187px; -} -.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { - background-position: -17px -187px; -} -.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { - background-position: -34px -187px; -} - -.tsd-kind-variable > .tsd-kind-icon:before { - background-position: -136px -0px; -} -.tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -0px; -} -.tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -0px; -} -.tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -0px; -} -.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -0px; -} -.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -0px; -} -.tsd-kind-variable.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -0px; -} -.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -0px; -} -.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -0px; -} -.tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -0px; -} - -.tsd-kind-property > .tsd-kind-icon:before { - background-position: -136px -0px; -} -.tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -0px; -} -.tsd-kind-property.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -0px; -} -.tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -0px; -} -.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -0px; -} -.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -0px; -} -.tsd-kind-property.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -0px; -} -.tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -0px; -} -.tsd-kind-property.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -0px; -} -.tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -0px; -} -.tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -0px; -} - -.tsd-kind-get-signature > .tsd-kind-icon:before { - background-position: -136px -17px; -} -.tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -17px; -} -.tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -17px; -} -.tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -17px; -} - -.tsd-kind-set-signature > .tsd-kind-icon:before { - background-position: -136px -34px; -} -.tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -34px; -} -.tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -34px; -} -.tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -34px; -} - -.tsd-kind-accessor > .tsd-kind-icon:before { - background-position: -136px -51px; -} -.tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -51px; -} -.tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -51px; -} -.tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -51px; -} - -.tsd-kind-function > .tsd-kind-icon:before { - background-position: -136px -68px; -} -.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -68px; -} -.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -68px; -} -.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -68px; -} -.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -68px; -} -.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -68px; -} -.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -68px; -} -.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -68px; -} -.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -68px; -} -.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -68px; -} - -.tsd-kind-method > .tsd-kind-icon:before { - background-position: -136px -68px; -} -.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -68px; -} -.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -68px; -} -.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -68px; -} -.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -68px; -} -.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -68px; -} -.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -68px; -} -.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -68px; -} -.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -68px; -} -.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -68px; -} - -.tsd-kind-call-signature > .tsd-kind-icon:before { - background-position: -136px -68px; -} -.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -68px; -} -.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -68px; -} -.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -68px; -} - -.tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before { - background-position: -136px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -85px; -} -.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -85px; -} - -.tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before { - background-position: -136px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -85px; -} -.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -85px; -} - -.tsd-kind-constructor > .tsd-kind-icon:before { - background-position: -136px -102px; -} -.tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -102px; -} -.tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -102px; -} -.tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -102px; -} - -.tsd-kind-constructor-signature > .tsd-kind-icon:before { - background-position: -136px -102px; -} -.tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -102px; -} -.tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -102px; -} -.tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -102px; -} - -.tsd-kind-index-signature > .tsd-kind-icon:before { - background-position: -136px -119px; -} -.tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -119px; -} -.tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -119px; -} -.tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -119px; -} - -.tsd-kind-event > .tsd-kind-icon:before { - background-position: -136px -136px; -} -.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -136px; -} -.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -136px; -} -.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -136px; -} -.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -136px; -} -.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -136px; -} -.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -136px; -} -.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -136px; -} -.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -136px; -} -.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -136px; -} -.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -136px; -} -.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -136px; -} -.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -136px; -} - -.tsd-is-static > .tsd-kind-icon:before { - background-position: -136px -153px; -} -.tsd-is-static.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -153px; -} -.tsd-is-static.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -153px; -} -.tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -153px; -} -.tsd-is-static.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -153px; -} -.tsd-is-static.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -153px; -} -.tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -153px; -} -.tsd-is-static.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -153px; -} -.tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -153px; -} -.tsd-is-static.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -153px; -} -.tsd-is-static.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -153px; -} -.tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -153px; -} -.tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -153px; -} - -.tsd-is-static.tsd-kind-function > .tsd-kind-icon:before { - background-position: -136px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -170px; -} -.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -170px; -} - -.tsd-is-static.tsd-kind-method > .tsd-kind-icon:before { - background-position: -136px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -170px; -} -.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -170px; -} - -.tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before { - background-position: -136px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -170px; -} -.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -170px; -} - -.tsd-is-static.tsd-kind-event > .tsd-kind-icon:before { - background-position: -136px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { - background-position: -153px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { - background-position: -51px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -68px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { - background-position: -85px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -102px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { - background-position: -170px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { - background-position: -187px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { - background-position: -119px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before { - background-position: -204px -187px; -} -.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before { - background-position: -221px -187px; -} - -@keyframes fade-in { - from { - opacity: 0; - } - to { - opacity: 1; - } -} -@keyframes fade-out { - from { - opacity: 1; - visibility: visible; - } - to { - opacity: 0; - } -} -@keyframes fade-in-delayed { - 0% { - opacity: 0; - } - 33% { - opacity: 0; - } - 100% { - opacity: 1; - } -} -@keyframes fade-out-delayed { - 0% { - opacity: 1; - visibility: visible; - } - 66% { - opacity: 0; - } - 100% { - opacity: 0; - } -} -@keyframes shift-to-left { - from { - transform: translate(0, 0); - } - to { - transform: translate(-25%, 0); - } -} -@keyframes unshift-to-left { - from { - transform: translate(-25%, 0); - } - to { - transform: translate(0, 0); - } -} -@keyframes pop-in-from-right { - from { - transform: translate(100%, 0); - } - to { - transform: translate(0, 0); - } -} -@keyframes pop-out-to-right { - from { - transform: translate(0, 0); - visibility: visible; - } - to { - transform: translate(100%, 0); - } -} -body { - background: #fdfdfd; - font-family: "Segoe UI", sans-serif; - font-size: 16px; - color: #222; -} - -a { - color: #4da6ff; - text-decoration: none; -} -a:hover { - text-decoration: underline; -} - -code, pre { - font-family: Menlo, Monaco, Consolas, "Courier New", monospace; - padding: 0.2em; - margin: 0; - font-size: 14px; - background-color: rgba(0, 0, 0, 0.04); -} - -pre { - padding: 10px; -} -pre code { - padding: 0; - font-size: 100%; - background-color: transparent; -} - -.tsd-typography { - line-height: 1.333em; -} -.tsd-typography ul { - list-style: square; - padding: 0 0 0 20px; - margin: 0; -} -.tsd-typography h4, .tsd-typography .tsd-index-panel h3, .tsd-index-panel .tsd-typography h3, .tsd-typography h5, .tsd-typography h6 { - font-size: 1em; - margin: 0; -} -.tsd-typography h5, .tsd-typography h6 { - font-weight: normal; -} -.tsd-typography p, .tsd-typography ul, .tsd-typography ol { - margin: 1em 0; -} - -@media (min-width: 901px) and (max-width: 1024px) { - html.default .col-content { - width: 72%; - } - html.default .col-menu { - width: 28%; - } - html.default .tsd-navigation { - padding-left: 10px; - } -} -@media (max-width: 900px) { - html.default .col-content { - float: none; - width: 100%; - } - html.default .col-menu { - position: fixed !important; - overflow: auto; - -webkit-overflow-scrolling: touch; - z-index: 1024; - top: 0 !important; - bottom: 0 !important; - left: auto !important; - right: 0 !important; - width: 100%; - padding: 20px 20px 0 0; - max-width: 450px; - visibility: hidden; - background-color: #fff; - transform: translate(100%, 0); - } - html.default .col-menu > *:last-child { - padding-bottom: 20px; - } - html.default .overlay { - content: ""; - display: block; - position: fixed; - z-index: 1023; - top: 0; - left: 0; - right: 0; - bottom: 0; - background-color: rgba(0, 0, 0, 0.75); - visibility: hidden; - } - html.default.to-has-menu .overlay { - animation: fade-in 0.4s; - } - html.default.to-has-menu header, -html.default.to-has-menu footer, -html.default.to-has-menu .col-content { - animation: shift-to-left 0.4s; - } - html.default.to-has-menu .col-menu { - animation: pop-in-from-right 0.4s; - } - html.default.from-has-menu .overlay { - animation: fade-out 0.4s; - } - html.default.from-has-menu header, -html.default.from-has-menu footer, -html.default.from-has-menu .col-content { - animation: unshift-to-left 0.4s; - } - html.default.from-has-menu .col-menu { - animation: pop-out-to-right 0.4s; - } - html.default.has-menu body { - overflow: hidden; - } - html.default.has-menu .overlay { - visibility: visible; - } - html.default.has-menu header, -html.default.has-menu footer, -html.default.has-menu .col-content { - transform: translate(-25%, 0); - } - html.default.has-menu .col-menu { - visibility: visible; - transform: translate(0, 0); - } -} - -.tsd-page-title { - padding: 70px 0 20px 0; - margin: 0 0 40px 0; - background: #fff; - box-shadow: 0 0 5px rgba(0, 0, 0, 0.35); -} -.tsd-page-title h1 { - margin: 0; -} - -.tsd-breadcrumb { - margin: 0; - padding: 0; - color: #808080; -} -.tsd-breadcrumb a { - color: #808080; - text-decoration: none; -} -.tsd-breadcrumb a:hover { - text-decoration: underline; -} -.tsd-breadcrumb li { - display: inline; -} -.tsd-breadcrumb li:after { - content: " / "; -} - -html.minimal .container { - margin: 0; -} -html.minimal .container-main { - padding-top: 50px; - padding-bottom: 0; -} -html.minimal .content-wrap { - padding-left: 300px; -} -html.minimal .tsd-navigation { - position: fixed !important; - overflow: auto; - -webkit-overflow-scrolling: touch; - box-sizing: border-box; - z-index: 1; - left: 0; - top: 40px; - bottom: 0; - width: 300px; - padding: 20px; - margin: 0; -} -html.minimal .tsd-member .tsd-member { - margin-left: 0; -} -html.minimal .tsd-page-toolbar { - position: fixed; - z-index: 2; -} -html.minimal #tsd-filter .tsd-filter-group { - right: 0; - transform: none; -} -html.minimal footer { - background-color: transparent; -} -html.minimal footer .container { - padding: 0; -} -html.minimal .tsd-generator { - padding: 0; -} -@media (max-width: 900px) { - html.minimal .tsd-navigation { - display: none; - } - html.minimal .content-wrap { - padding-left: 0; - } -} - -dl.tsd-comment-tags { - overflow: hidden; -} -dl.tsd-comment-tags dt { - float: left; - padding: 1px 5px; - margin: 0 10px 0 0; - border-radius: 4px; - border: 1px solid #808080; - color: #808080; - font-size: 0.8em; - font-weight: normal; -} -dl.tsd-comment-tags dd { - margin: 0 0 10px 0; -} -dl.tsd-comment-tags dd:before, dl.tsd-comment-tags dd:after { - display: table; - content: " "; -} -dl.tsd-comment-tags dd pre, dl.tsd-comment-tags dd:after { - clear: both; -} -dl.tsd-comment-tags p { - margin: 0; -} - -.tsd-panel.tsd-comment .lead { - font-size: 1.1em; - line-height: 1.333em; - margin-bottom: 2em; -} -.tsd-panel.tsd-comment .lead:last-child { - margin-bottom: 0; -} - -.toggle-protected .tsd-is-private { - display: none; -} - -.toggle-public .tsd-is-private, -.toggle-public .tsd-is-protected, -.toggle-public .tsd-is-private-protected { - display: none; -} - -.toggle-inherited .tsd-is-inherited { - display: none; -} - -.toggle-only-exported .tsd-is-not-exported { - display: none; -} - -.toggle-externals .tsd-is-external { - display: none; -} - -#tsd-filter { - position: relative; - display: inline-block; - height: 40px; - vertical-align: bottom; -} -.no-filter #tsd-filter { - display: none; -} -#tsd-filter .tsd-filter-group { - display: inline-block; - height: 40px; - vertical-align: bottom; - white-space: nowrap; -} -#tsd-filter input { - display: none; -} -@media (max-width: 900px) { - #tsd-filter .tsd-filter-group { - display: block; - position: absolute; - top: 40px; - right: 20px; - height: auto; - background-color: #fff; - visibility: hidden; - transform: translate(50%, 0); - box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); - } - .has-options #tsd-filter .tsd-filter-group { - visibility: visible; - } - .to-has-options #tsd-filter .tsd-filter-group { - animation: fade-in 0.2s; - } - .from-has-options #tsd-filter .tsd-filter-group { - animation: fade-out 0.2s; - } - #tsd-filter label, -#tsd-filter .tsd-select { - display: block; - padding-right: 20px; - } -} - -footer { - border-top: 1px solid #eee; - background-color: #fff; -} -footer.with-border-bottom { - border-bottom: 1px solid #eee; -} -footer .tsd-legend-group { - font-size: 0; -} -footer .tsd-legend { - display: inline-block; - width: 25%; - padding: 0; - font-size: 16px; - list-style: none; - line-height: 1.333em; - vertical-align: top; -} -@media (max-width: 900px) { - footer .tsd-legend { - width: 50%; - } -} - -.tsd-hierarchy { - list-style: square; - padding: 0 0 0 20px; - margin: 0; -} -.tsd-hierarchy .target { - font-weight: bold; -} - -.tsd-index-panel .tsd-index-content { - margin-bottom: -30px !important; -} -.tsd-index-panel .tsd-index-section { - margin-bottom: 30px !important; -} -.tsd-index-panel h3 { - margin: 0 -20px 10px -20px; - padding: 0 20px 10px 20px; - border-bottom: 1px solid #eee; -} -.tsd-index-panel ul.tsd-index-list { - -moz-column-count: 3; - -ms-column-count: 3; - -o-column-count: 3; - column-count: 3; - -moz-column-gap: 20px; - -ms-column-gap: 20px; - -o-column-gap: 20px; - column-gap: 20px; - padding: 0; - list-style: none; - line-height: 1.333em; -} -@media (max-width: 900px) { - .tsd-index-panel ul.tsd-index-list { - -moz-column-count: 1; - -ms-column-count: 1; - -o-column-count: 1; - column-count: 1; - } -} -@media (min-width: 901px) and (max-width: 1024px) { - .tsd-index-panel ul.tsd-index-list { - -moz-column-count: 2; - -ms-column-count: 2; - -o-column-count: 2; - column-count: 2; - } -} -.tsd-index-panel ul.tsd-index-list li { - -webkit-page-break-inside: avoid; - -moz-page-break-inside: avoid; - -ms-page-break-inside: avoid; - -o-page-break-inside: avoid; - page-break-inside: avoid; -} -.tsd-index-panel a, -.tsd-index-panel .tsd-parent-kind-module a { - color: #9600ff; -} -.tsd-index-panel .tsd-parent-kind-interface a { - color: #7da01f; -} -.tsd-index-panel .tsd-parent-kind-enum a { - color: #cc9900; -} -.tsd-index-panel .tsd-parent-kind-class a { - color: #4da6ff; -} -.tsd-index-panel .tsd-kind-module a { - color: #9600ff; -} -.tsd-index-panel .tsd-kind-interface a { - color: #7da01f; -} -.tsd-index-panel .tsd-kind-enum a { - color: #cc9900; -} -.tsd-index-panel .tsd-kind-class a { - color: #4da6ff; -} -.tsd-index-panel .tsd-is-private a { - color: #808080; -} - -.tsd-flag { - display: inline-block; - padding: 1px 5px; - border-radius: 4px; - color: #fff; - background-color: #808080; - text-indent: 0; - font-size: 14px; - font-weight: normal; -} - -.tsd-anchor { - position: absolute; - top: -100px; -} - -.tsd-member { - position: relative; -} -.tsd-member .tsd-anchor + h3 { - margin-top: 0; - margin-bottom: 0; - border-bottom: none; -} - -.tsd-navigation { - margin: 0 0 0 40px; -} -.tsd-navigation a { - display: block; - padding-top: 2px; - padding-bottom: 2px; - border-left: 2px solid transparent; - color: #222; - text-decoration: none; - transition: border-left-color 0.1s; -} -.tsd-navigation a:hover { - text-decoration: underline; -} -.tsd-navigation ul { - margin: 0; - padding: 0; - list-style: none; -} -.tsd-navigation li { - padding: 0; -} - -.tsd-navigation.primary { - padding-bottom: 40px; -} -.tsd-navigation.primary a { - display: block; - padding-top: 6px; - padding-bottom: 6px; -} -.tsd-navigation.primary ul li a { - padding-left: 5px; -} -.tsd-navigation.primary ul li li a { - padding-left: 25px; -} -.tsd-navigation.primary ul li li li a { - padding-left: 45px; -} -.tsd-navigation.primary ul li li li li a { - padding-left: 65px; -} -.tsd-navigation.primary ul li li li li li a { - padding-left: 85px; -} -.tsd-navigation.primary ul li li li li li li a { - padding-left: 105px; -} -.tsd-navigation.primary > ul { - border-bottom: 1px solid #eee; -} -.tsd-navigation.primary li { - border-top: 1px solid #eee; -} -.tsd-navigation.primary li.current > a { - font-weight: bold; -} -.tsd-navigation.primary li.label span { - display: block; - padding: 20px 0 6px 5px; - color: #808080; -} -.tsd-navigation.primary li.globals + li > span, .tsd-navigation.primary li.globals + li > a { - padding-top: 20px; -} - -.tsd-navigation.secondary { - max-height: calc(100vh - 1rem - 40px); - overflow: auto; - position: -webkit-sticky; - position: sticky; - top: calc(.5rem + 40px); - transition: 0.3s; -} -.tsd-navigation.secondary.tsd-navigation--toolbar-hide { - max-height: calc(100vh - 1rem); - top: 0.5rem; -} -.tsd-navigation.secondary ul { - transition: opacity 0.2s; -} -.tsd-navigation.secondary ul li a { - padding-left: 25px; -} -.tsd-navigation.secondary ul li li a { - padding-left: 45px; -} -.tsd-navigation.secondary ul li li li a { - padding-left: 65px; -} -.tsd-navigation.secondary ul li li li li a { - padding-left: 85px; -} -.tsd-navigation.secondary ul li li li li li a { - padding-left: 105px; -} -.tsd-navigation.secondary ul li li li li li li a { - padding-left: 125px; -} -.tsd-navigation.secondary ul.current a { - border-left-color: #eee; -} -.tsd-navigation.secondary li.focus > a, -.tsd-navigation.secondary ul.current li.focus > a { - border-left-color: #000; -} -.tsd-navigation.secondary li.current { - margin-top: 20px; - margin-bottom: 20px; - border-left-color: #eee; -} -.tsd-navigation.secondary li.current > a { - font-weight: bold; -} - -@media (min-width: 901px) { - .menu-sticky-wrap { - position: static; - } -} - -.tsd-panel { - margin: 20px 0; - padding: 20px; - background-color: #fff; - box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); -} -.tsd-panel:empty { - display: none; -} -.tsd-panel > h1, .tsd-panel > h2, .tsd-panel > h3 { - margin: 1.5em -20px 10px -20px; - padding: 0 20px 10px 20px; - border-bottom: 1px solid #eee; -} -.tsd-panel > h1.tsd-before-signature, .tsd-panel > h2.tsd-before-signature, .tsd-panel > h3.tsd-before-signature { - margin-bottom: 0; - border-bottom: 0; -} -.tsd-panel table { - display: block; - width: 100%; - overflow: auto; - margin-top: 10px; - word-break: normal; - word-break: keep-all; -} -.tsd-panel table th { - font-weight: bold; -} -.tsd-panel table th, .tsd-panel table td { - padding: 6px 13px; - border: 1px solid #ddd; -} -.tsd-panel table tr { - background-color: #fff; - border-top: 1px solid #ccc; -} -.tsd-panel table tr:nth-child(2n) { - background-color: #f8f8f8; -} - -.tsd-panel-group { - margin: 60px 0; -} -.tsd-panel-group > h1, .tsd-panel-group > h2, .tsd-panel-group > h3 { - padding-left: 20px; - padding-right: 20px; -} - -#tsd-search { - transition: background-color 0.2s; -} -#tsd-search .title { - position: relative; - z-index: 2; -} -#tsd-search .field { - position: absolute; - left: 0; - top: 0; - right: 40px; - height: 40px; -} -#tsd-search .field input { - box-sizing: border-box; - position: relative; - top: -50px; - z-index: 1; - width: 100%; - padding: 0 10px; - opacity: 0; - outline: 0; - border: 0; - background: transparent; - color: #222; -} -#tsd-search .field label { - position: absolute; - overflow: hidden; - right: -40px; -} -#tsd-search .field input, -#tsd-search .title { - transition: opacity 0.2s; -} -#tsd-search .results { - position: absolute; - visibility: hidden; - top: 40px; - width: 100%; - margin: 0; - padding: 0; - list-style: none; - box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); -} -#tsd-search .results li { - padding: 0 10px; - background-color: #fdfdfd; -} -#tsd-search .results li:nth-child(even) { - background-color: #fff; -} -#tsd-search .results li.state { - display: none; -} -#tsd-search .results li.current, -#tsd-search .results li:hover { - background-color: #eee; -} -#tsd-search .results a { - display: block; -} -#tsd-search .results a:before { - top: 10px; -} -#tsd-search .results span.parent { - color: #808080; - font-weight: normal; -} -#tsd-search.has-focus { - background-color: #eee; -} -#tsd-search.has-focus .field input { - top: 0; - opacity: 1; -} -#tsd-search.has-focus .title { - z-index: 0; - opacity: 0; -} -#tsd-search.has-focus .results { - visibility: visible; -} -#tsd-search.loading .results li.state.loading { - display: block; -} -#tsd-search.failure .results li.state.failure { - display: block; -} - -.tsd-signature { - margin: 0 0 1em 0; - padding: 10px; - border: 1px solid #eee; - font-family: Menlo, Monaco, Consolas, "Courier New", monospace; - font-size: 14px; - overflow-x: auto; -} -.tsd-signature.tsd-kind-icon { - padding-left: 30px; -} -.tsd-signature.tsd-kind-icon:before { - top: 10px; - left: 10px; -} -.tsd-panel > .tsd-signature { - margin-left: -20px; - margin-right: -20px; - border-width: 1px 0; -} -.tsd-panel > .tsd-signature.tsd-kind-icon { - padding-left: 40px; -} -.tsd-panel > .tsd-signature.tsd-kind-icon:before { - left: 20px; -} - -.tsd-signature-symbol { - color: #808080; - font-weight: normal; -} - -.tsd-signature-type { - font-style: italic; - font-weight: normal; -} - -.tsd-signatures { - padding: 0; - margin: 0 0 1em 0; - border: 1px solid #eee; -} -.tsd-signatures .tsd-signature { - margin: 0; - border-width: 1px 0 0 0; - transition: background-color 0.1s; -} -.tsd-signatures .tsd-signature:first-child { - border-top-width: 0; -} -.tsd-signatures .tsd-signature.current { - background-color: #eee; -} -.tsd-signatures.active > .tsd-signature { - cursor: pointer; -} -.tsd-panel > .tsd-signatures { - margin-left: -20px; - margin-right: -20px; - border-width: 1px 0; -} -.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon { - padding-left: 40px; -} -.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before { - left: 20px; -} -.tsd-panel > a.anchor + .tsd-signatures { - border-top-width: 0; - margin-top: -20px; -} - -ul.tsd-descriptions { - position: relative; - overflow: hidden; - padding: 0; - list-style: none; -} -ul.tsd-descriptions.active > .tsd-description { - display: none; -} -ul.tsd-descriptions.active > .tsd-description.current { - display: block; -} -ul.tsd-descriptions.active > .tsd-description.fade-in { - animation: fade-in-delayed 0.3s; -} -ul.tsd-descriptions.active > .tsd-description.fade-out { - animation: fade-out-delayed 0.3s; - position: absolute; - display: block; - top: 0; - left: 0; - right: 0; - opacity: 0; - visibility: hidden; -} -ul.tsd-descriptions h4, ul.tsd-descriptions .tsd-index-panel h3, .tsd-index-panel ul.tsd-descriptions h3 { - font-size: 16px; - margin: 1em 0 0.5em 0; -} - -ul.tsd-parameters, -ul.tsd-type-parameters { - list-style: square; - margin: 0; - padding-left: 20px; -} -ul.tsd-parameters > li.tsd-parameter-signature, -ul.tsd-type-parameters > li.tsd-parameter-signature { - list-style: none; - margin-left: -20px; -} -ul.tsd-parameters h5, -ul.tsd-type-parameters h5 { - font-size: 16px; - margin: 1em 0 0.5em 0; -} -ul.tsd-parameters .tsd-comment, -ul.tsd-type-parameters .tsd-comment { - margin-top: -0.5em; -} - -.tsd-sources { - font-size: 14px; - color: #808080; - margin: 0 0 1em 0; -} -.tsd-sources a { - color: #808080; - text-decoration: underline; -} -.tsd-sources ul, .tsd-sources p { - margin: 0 !important; -} -.tsd-sources ul { - list-style: none; - padding: 0; -} - -.tsd-page-toolbar { - position: fixed; - z-index: 1; - top: 0; - left: 0; - width: 100%; - height: 40px; - color: #333; - background: #fff; - border-bottom: 1px solid #eee; - transition: transform 0.3s linear; -} -.tsd-page-toolbar a { - color: #333; - text-decoration: none; -} -.tsd-page-toolbar a.title { - font-weight: bold; -} -.tsd-page-toolbar a.title:hover { - text-decoration: underline; -} -.tsd-page-toolbar .table-wrap { - display: table; - width: 100%; - height: 40px; -} -.tsd-page-toolbar .table-cell { - display: table-cell; - position: relative; - white-space: nowrap; - line-height: 40px; -} -.tsd-page-toolbar .table-cell:first-child { - width: 100%; -} - -.tsd-page-toolbar--hide { - transform: translateY(-100%); -} - -.tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before { - content: ""; - display: inline-block; - width: 40px; - height: 40px; - margin: 0 -8px 0 0; - background-image: url(../images/widgets.png); - background-repeat: no-repeat; - text-indent: -1024px; - vertical-align: bottom; -} -@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { - .tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before { - background-image: url(../images/widgets@2x.png); - background-size: 320px 40px; - } -} - -.tsd-widget { - display: inline-block; - overflow: hidden; - opacity: 0.6; - height: 40px; - transition: opacity 0.1s, background-color 0.2s; - vertical-align: bottom; - cursor: pointer; -} -.tsd-widget:hover { - opacity: 0.8; -} -.tsd-widget.active { - opacity: 1; - background-color: #eee; -} -.tsd-widget.no-caption { - width: 40px; -} -.tsd-widget.no-caption:before { - margin: 0; -} -.tsd-widget.search:before { - background-position: 0 0; -} -.tsd-widget.menu:before { - background-position: -40px 0; -} -.tsd-widget.options:before { - background-position: -80px 0; -} -.tsd-widget.options, .tsd-widget.menu { - display: none; -} -@media (max-width: 900px) { - .tsd-widget.options, .tsd-widget.menu { - display: inline-block; - } -} -input[type=checkbox] + .tsd-widget:before { - background-position: -120px 0; -} -input[type=checkbox]:checked + .tsd-widget:before { - background-position: -160px 0; -} - -.tsd-select { - position: relative; - display: inline-block; - height: 40px; - transition: opacity 0.1s, background-color 0.2s; - vertical-align: bottom; - cursor: pointer; -} -.tsd-select .tsd-select-label { - opacity: 0.6; - transition: opacity 0.2s; -} -.tsd-select .tsd-select-label:before { - background-position: -240px 0; -} -.tsd-select.active .tsd-select-label { - opacity: 0.8; -} -.tsd-select.active .tsd-select-list { - visibility: visible; - opacity: 1; - transition-delay: 0s; -} -.tsd-select .tsd-select-list { - position: absolute; - visibility: hidden; - top: 40px; - left: 0; - margin: 0; - padding: 0; - opacity: 0; - list-style: none; - box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); - transition: visibility 0s 0.2s, opacity 0.2s; -} -.tsd-select .tsd-select-list li { - padding: 0 20px 0 0; - background-color: #fdfdfd; -} -.tsd-select .tsd-select-list li:before { - background-position: 40px 0; -} -.tsd-select .tsd-select-list li:nth-child(even) { - background-color: #fff; -} -.tsd-select .tsd-select-list li:hover { - background-color: #eee; -} -.tsd-select .tsd-select-list li.selected:before { - background-position: -200px 0; -} -@media (max-width: 900px) { - .tsd-select .tsd-select-list { - top: 0; - left: auto; - right: 100%; - margin-right: -5px; - } - .tsd-select .tsd-select-label:before { - background-position: -280px 0; - } -} - -img { - max-width: 100%; -} \ No newline at end of file diff --git a/docs/assets/css/pages.css b/docs/assets/css/pages.css deleted file mode 100644 index 0bb4aa3d..00000000 --- a/docs/assets/css/pages.css +++ /dev/null @@ -1,64 +0,0 @@ -h2 code { - font-size: 1em; -} - -h3 code { - font-size: 1em; -} - -.tsd-navigation.primary ul { - border-bottom: none; -} - -.tsd-navigation.primary li { - border-top: none; -} - -.tsd-navigation li.label.pp-nav.pp-group:first-child span { - padding-top: 0; -} - -.tsd-navigation li.label.pp-nav.pp-group { - font-weight: 700; - border-bottom: 1px solid #eee; -} - -.tsd-navigation li.label.pp-nav.pp-group span { - color: #222; -} - -.tsd-navigation li.pp-nav.pp-page.current { - background-color: #f8f8f8; - border-left: 2px solid #222; -} - -.tsd-navigation li.pp-nav.pp-page.current a { - color: #222; -} - -.tsd-navigation li.pp-nav.pp-page.pp-parent.pp-active { - border-left: 2px solid #eee; -} - -.tsd-navigation li.pp-nav.pp-page.pp-child { - border-left: 2px solid #eee; - padding-left: 15px; -} - -.tsd-navigation li.pp-nav.pp-page.pp-child.current { - border-left: 2px solid #222; -} - -.tsd-kind-page .tsd-kind-icon:before { - display: inline-block; - vertical-align: middle; - height: 16px; - width: 16px; - content: ""; - background-image: url("../images/page-icon.svg"); - background-size: 16px 16px; -} - -#tsd-search .results span.parent { - color: #b3b2b2 !important; -} \ No newline at end of file diff --git a/docs/assets/highlight.css b/docs/assets/highlight.css new file mode 100644 index 00000000..3196eb78 --- /dev/null +++ b/docs/assets/highlight.css @@ -0,0 +1,106 @@ +:root { + --light-hl-0: #000000; + --dark-hl-0: #D4D4D4; + --light-hl-1: #795E26; + --dark-hl-1: #DCDCAA; + --light-hl-2: #0000FF; + --dark-hl-2: #569CD6; + --light-hl-3: #008000; + --dark-hl-3: #6A9955; + --light-hl-4: #001080; + --dark-hl-4: #9CDCFE; + --light-hl-5: #267F99; + --dark-hl-5: #4EC9B0; + --light-hl-6: #A31515; + --dark-hl-6: #CE9178; + --light-hl-7: #0070C1; + --dark-hl-7: #4FC1FF; + --light-hl-8: #AF00DB; + --dark-hl-8: #C586C0; + --light-hl-9: #EE0000; + --dark-hl-9: #D7BA7D; + --light-hl-10: #CD3131; + --dark-hl-10: #F44747; + --light-hl-11: #000000FF; + --dark-hl-11: #D4D4D4; + --light-code-background: #F5F5F5; + --dark-code-background: #1E1E1E; +} + +@media (prefers-color-scheme: light) { :root { + --hl-0: var(--light-hl-0); + --hl-1: var(--light-hl-1); + --hl-2: var(--light-hl-2); + --hl-3: var(--light-hl-3); + --hl-4: var(--light-hl-4); + --hl-5: var(--light-hl-5); + --hl-6: var(--light-hl-6); + --hl-7: var(--light-hl-7); + --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --code-background: var(--light-code-background); +} } + +@media (prefers-color-scheme: dark) { :root { + --hl-0: var(--dark-hl-0); + --hl-1: var(--dark-hl-1); + --hl-2: var(--dark-hl-2); + --hl-3: var(--dark-hl-3); + --hl-4: var(--dark-hl-4); + --hl-5: var(--dark-hl-5); + --hl-6: var(--dark-hl-6); + --hl-7: var(--dark-hl-7); + --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --code-background: var(--dark-code-background); +} } + +body.light { + --hl-0: var(--light-hl-0); + --hl-1: var(--light-hl-1); + --hl-2: var(--light-hl-2); + --hl-3: var(--light-hl-3); + --hl-4: var(--light-hl-4); + --hl-5: var(--light-hl-5); + --hl-6: var(--light-hl-6); + --hl-7: var(--light-hl-7); + --hl-8: var(--light-hl-8); + --hl-9: var(--light-hl-9); + --hl-10: var(--light-hl-10); + --hl-11: var(--light-hl-11); + --code-background: var(--light-code-background); +} + +body.dark { + --hl-0: var(--dark-hl-0); + --hl-1: var(--dark-hl-1); + --hl-2: var(--dark-hl-2); + --hl-3: var(--dark-hl-3); + --hl-4: var(--dark-hl-4); + --hl-5: var(--dark-hl-5); + --hl-6: var(--dark-hl-6); + --hl-7: var(--dark-hl-7); + --hl-8: var(--dark-hl-8); + --hl-9: var(--dark-hl-9); + --hl-10: var(--dark-hl-10); + --hl-11: var(--dark-hl-11); + --code-background: var(--dark-code-background); +} + +.hl-0 { color: var(--hl-0); } +.hl-1 { color: var(--hl-1); } +.hl-2 { color: var(--hl-2); } +.hl-3 { color: var(--hl-3); } +.hl-4 { color: var(--hl-4); } +.hl-5 { color: var(--hl-5); } +.hl-6 { color: var(--hl-6); } +.hl-7 { color: var(--hl-7); } +.hl-8 { color: var(--hl-8); } +.hl-9 { color: var(--hl-9); } +.hl-10 { color: var(--hl-10); } +.hl-11 { color: var(--hl-11); } +pre, code { background: var(--code-background); } diff --git a/docs/assets/icons.css b/docs/assets/icons.css new file mode 100644 index 00000000..776a3562 --- /dev/null +++ b/docs/assets/icons.css @@ -0,0 +1,1043 @@ +.tsd-kind-icon { + display: block; + position: relative; + padding-left: 20px; + text-indent: -20px; +} +.tsd-kind-icon:before { + content: ""; + display: inline-block; + vertical-align: middle; + width: 17px; + height: 17px; + margin: 0 3px 2px 0; + background-image: url(./icons.png); +} +@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { + .tsd-kind-icon:before { + background-image: url(./icons@2x.png); + background-size: 238px 204px; + } +} + +.tsd-signature.tsd-kind-icon:before { + background-position: 0 -153px; +} + +.tsd-kind-object-literal > .tsd-kind-icon:before { + background-position: 0px -17px; +} +.tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -17px; +} +.tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -17px; +} + +.tsd-kind-class > .tsd-kind-icon:before { + background-position: 0px -34px; +} +.tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -34px; +} +.tsd-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -34px; +} + +.tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -51px; +} +.tsd-kind-class.tsd-has-type-parameter.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -17px -51px; +} +.tsd-kind-class.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -51px; +} + +.tsd-kind-interface > .tsd-kind-icon:before { + background-position: 0px -68px; +} +.tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -68px; +} +.tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -68px; +} + +.tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -85px; +} +.tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -17px -85px; +} +.tsd-kind-interface.tsd-has-type-parameter.tsd-is-private + > .tsd-kind-icon:before { + background-position: -34px -85px; +} + +.tsd-kind-namespace > .tsd-kind-icon:before { + background-position: 0px -102px; +} +.tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -102px; +} +.tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -102px; +} + +.tsd-kind-module > .tsd-kind-icon:before { + background-position: 0px -102px; +} +.tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -102px; +} +.tsd-kind-module.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -102px; +} + +.tsd-kind-enum > .tsd-kind-icon:before { + background-position: 0px -119px; +} +.tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -119px; +} +.tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -119px; +} + +.tsd-kind-enum-member > .tsd-kind-icon:before { + background-position: 0px -136px; +} +.tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -136px; +} +.tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -136px; +} + +.tsd-kind-signature > .tsd-kind-icon:before { + background-position: 0px -153px; +} +.tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -153px; +} +.tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -153px; +} + +.tsd-kind-type-alias > .tsd-kind-icon:before { + background-position: 0px -170px; +} +.tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before { + background-position: -17px -170px; +} +.tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before { + background-position: -34px -170px; +} + +.tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: 0px -187px; +} +.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -17px -187px; +} +.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private + > .tsd-kind-icon:before { + background-position: -34px -187px; +} + +.tsd-kind-variable > .tsd-kind-icon:before { + background-position: -136px -0px; +} +.tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -0px; +} +.tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -0px; +} +.tsd-kind-variable.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -0px; +} +.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -0px; +} +.tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -0px; +} + +.tsd-kind-property > .tsd-kind-icon:before { + background-position: -136px -0px; +} +.tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -0px; +} +.tsd-kind-property.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -0px; +} +.tsd-kind-property.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -0px; +} +.tsd-kind-property.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -0px; +} +.tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -0px; +} +.tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -0px; +} + +.tsd-kind-get-signature > .tsd-kind-icon:before { + background-position: -136px -17px; +} +.tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -17px; +} +.tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -17px; +} +.tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -17px; +} + +.tsd-kind-set-signature > .tsd-kind-icon:before { + background-position: -136px -34px; +} +.tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -34px; +} +.tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -34px; +} +.tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -34px; +} + +.tsd-kind-accessor > .tsd-kind-icon:before { + background-position: -136px -51px; +} +.tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -51px; +} +.tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -51px; +} +.tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -51px; +} + +.tsd-kind-function > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-function.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-method > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-call-signature > .tsd-kind-icon:before { + background-position: -136px -68px; +} +.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -68px; +} +.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -68px; +} +.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -68px; +} + +.tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: -136px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -153px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class + > .tsd-kind-icon:before { + background-position: -51px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum + > .tsd-kind-icon:before { + background-position: -170px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -85px; +} +.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -85px; +} + +.tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before { + background-position: -136px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -153px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class + > .tsd-kind-icon:before { + background-position: -51px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum + > .tsd-kind-icon:before { + background-position: -170px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -85px; +} +.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -85px; +} + +.tsd-kind-constructor > .tsd-kind-icon:before { + background-position: -136px -102px; +} +.tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -102px; +} +.tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -102px; +} +.tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -102px; +} + +.tsd-kind-constructor-signature > .tsd-kind-icon:before { + background-position: -136px -102px; +} +.tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -102px; +} +.tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -102px; +} +.tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -102px; +} + +.tsd-kind-index-signature > .tsd-kind-icon:before { + background-position: -136px -119px; +} +.tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -119px; +} +.tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -119px; +} +.tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -119px; +} + +.tsd-kind-event > .tsd-kind-icon:before { + background-position: -136px -136px; +} +.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -136px; +} +.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -136px; +} +.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -136px; +} +.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -136px; +} +.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -136px; +} +.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -136px; +} + +.tsd-is-static > .tsd-kind-icon:before { + background-position: -136px -153px; +} +.tsd-is-static.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -153px; +} +.tsd-is-static.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before { + background-position: -68px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before { + background-position: -85px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -153px; +} +.tsd-is-static.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -153px; +} +.tsd-is-static.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before { + background-position: -187px -153px; +} +.tsd-is-static.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -153px; +} +.tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before { + background-position: -204px -153px; +} +.tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -153px; +} + +.tsd-is-static.tsd-kind-function > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-method > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before { + background-position: -136px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -153px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class + > .tsd-kind-icon:before { + background-position: -51px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum + > .tsd-kind-icon:before { + background-position: -170px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -170px; +} +.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -170px; +} + +.tsd-is-static.tsd-kind-event > .tsd-kind-icon:before { + background-position: -136px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before { + background-position: -153px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before { + background-position: -51px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -68px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -85px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -102px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before { + background-position: -170px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected + > .tsd-kind-icon:before { + background-position: -187px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private + > .tsd-kind-icon:before { + background-position: -119px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface + > .tsd-kind-icon:before { + background-position: -204px -187px; +} +.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited + > .tsd-kind-icon:before { + background-position: -221px -187px; +} diff --git a/docs/assets/images/icons.png b/docs/assets/icons.png similarity index 100% rename from docs/assets/images/icons.png rename to docs/assets/icons.png diff --git a/docs/assets/images/icons@2x.png b/docs/assets/icons@2x.png similarity index 100% rename from docs/assets/images/icons@2x.png rename to docs/assets/icons@2x.png diff --git a/docs/assets/images/page-icon.svg b/docs/assets/images/page-icon.svg deleted file mode 100644 index 4fe78d91..00000000 --- a/docs/assets/images/page-icon.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/docs/assets/js/main.js b/docs/assets/js/main.js deleted file mode 100644 index 1cc4dd86..00000000 --- a/docs/assets/js/main.js +++ /dev/null @@ -1 +0,0 @@ -!function(){var e=function(t){var r=new e.Builder;return r.pipeline.add(e.trimmer,e.stopWordFilter,e.stemmer),r.searchPipeline.add(e.stemmer),t.call(r,r),r.build()};e.version="2.3.7",e.utils={},e.utils.warn=function(e){return function(t){e.console&&console.warn&&console.warn(t)}}(this),e.utils.asString=function(e){return null==e?"":e.toString()},e.utils.clone=function(e){if(null==e)return e;for(var t=Object.create(null),r=Object.keys(e),i=0;i=this.length)return e.QueryLexer.EOS;var t=this.str.charAt(this.pos);return this.pos+=1,t},e.QueryLexer.prototype.width=function(){return this.pos-this.start},e.QueryLexer.prototype.ignore=function(){this.start==this.pos&&(this.pos+=1),this.start=this.pos},e.QueryLexer.prototype.backup=function(){this.pos-=1},e.QueryLexer.prototype.acceptDigitRun=function(){for(var t,r;47<(r=(t=this.next()).charCodeAt(0))&&r<58;);t!=e.QueryLexer.EOS&&this.backup()},e.QueryLexer.prototype.more=function(){return this.pos=this.scrollTop||0===this.scrollTop,isShown!==this.showToolbar&&(this.toolbar.classList.toggle("tsd-page-toolbar--hide"),this.secondaryNav.classList.toggle("tsd-navigation--toolbar-hide")),this.lastY=this.scrollTop},Viewport}(typedoc.EventTarget);typedoc.Viewport=Viewport,typedoc.registerService(Viewport,"viewport")}(typedoc||(typedoc={})),function(typedoc){function Component(options){this.el=options.el}typedoc.Component=Component}(typedoc||(typedoc={})),function(typedoc){typedoc.pointerDown="mousedown",typedoc.pointerMove="mousemove",typedoc.pointerUp="mouseup",typedoc.pointerDownPosition={x:0,y:0},typedoc.preventNextClick=!1,typedoc.isPointerDown=!1,typedoc.isPointerTouch=!1,typedoc.hasPointerMoved=!1,typedoc.isMobile=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),document.documentElement.classList.add(typedoc.isMobile?"is-mobile":"not-mobile"),typedoc.isMobile&&"ontouchstart"in document.documentElement&&(typedoc.isPointerTouch=!0,typedoc.pointerDown="touchstart",typedoc.pointerMove="touchmove",typedoc.pointerUp="touchend"),document.addEventListener(typedoc.pointerDown,function(e){typedoc.isPointerDown=!0,typedoc.hasPointerMoved=!1;var t="touchstart"==typedoc.pointerDown?e.targetTouches[0]:e;typedoc.pointerDownPosition.y=t.pageY||0,typedoc.pointerDownPosition.x=t.pageX||0}),document.addEventListener(typedoc.pointerMove,function(e){if(typedoc.isPointerDown&&!typedoc.hasPointerMoved){var t="touchstart"==typedoc.pointerDown?e.targetTouches[0]:e,x=typedoc.pointerDownPosition.x-(t.pageX||0),y=typedoc.pointerDownPosition.y-(t.pageY||0);typedoc.hasPointerMoved=10scrollTop;)index-=1;for(;index"+match+""}),parent=row.parent||"";(parent=parent.replace(new RegExp(this.query,"i"),function(match){return""+match+""}))&&(name=''+parent+"."+name);var item=document.createElement("li");item.classList.value=row.classes,item.innerHTML='\n '+name+"\n ",this.results.appendChild(item)}}},Search.prototype.setLoadingState=function(value){this.loadingState!=value&&(this.el.classList.remove(SearchLoadingState[this.loadingState].toLowerCase()),this.loadingState=value,this.el.classList.add(SearchLoadingState[this.loadingState].toLowerCase()),this.updateResults())},Search.prototype.setHasFocus=function(value){this.hasFocus!=value&&(this.hasFocus=value,this.el.classList.toggle("has-focus"),value?(this.setQuery(""),this.field.value=""):this.field.value=this.query)},Search.prototype.setQuery=function(value){this.query=value.trim(),this.updateResults()},Search.prototype.setCurrentResult=function(dir){var current=this.results.querySelector(".current");if(current){var rel=1==dir?current.nextElementSibling:current.previousElementSibling;rel&&(current.classList.remove("current"),rel.classList.add("current"))}else(current=this.results.querySelector(1==dir?"li:first-child":"li:last-child"))&¤t.classList.add("current")},Search.prototype.gotoCurrentResult=function(){var current=this.results.querySelector(".current");if(current||(current=this.results.querySelector("li:first-child")),current){var link=current.querySelector("a");link&&(window.location.href=link.href),this.field.blur()}},Search.prototype.bindEvents=function(){var _this=this;this.results.addEventListener("mousedown",function(){_this.resultClicked=!0}),this.results.addEventListener("mouseup",function(){_this.resultClicked=!1,_this.setHasFocus(!1)}),this.field.addEventListener("focusin",function(){_this.setHasFocus(!0),_this.loadIndex()}),this.field.addEventListener("focusout",function(){_this.resultClicked?_this.resultClicked=!1:setTimeout(function(){return _this.setHasFocus(!1)},100)}),this.field.addEventListener("input",function(){_this.setQuery(_this.field.value)}),this.field.addEventListener("keydown",function(e){13==e.keyCode||27==e.keyCode||38==e.keyCode||40==e.keyCode?(_this.preventPress=!0,e.preventDefault(),13==e.keyCode?_this.gotoCurrentResult():27==e.keyCode?_this.field.blur():38==e.keyCode?_this.setCurrentResult(-1):40==e.keyCode&&_this.setCurrentResult(1)):_this.preventPress=!1}),this.field.addEventListener("keypress",function(e){_this.preventPress&&e.preventDefault()}),document.body.addEventListener("keydown",function(e){e.altKey||e.ctrlKey||e.metaKey||!_this.hasFocus&&47this.groups.length-1&&(index=this.groups.length-1),this.index!=index){var to=this.groups[index];if(-1 This module is compatible with `nestjs@^8.0.0`.\n\n# Setup & configuration\n\nFirst, install the module:\n\n```bash\nnpm install @scitizen/nest-casl\n```\n\nThen, declare a provider that generate a CASL Ability from the current request.\n\n{@codeblock test/basic-use.e2e-spec.ts#AbilityFactory | src/ability-factory.service.ts}\n\nImport the {@link CaslModule `CaslModule`} in your `AppModule`, and configure it to use your ability factory.\n\n{@codeblock test/basic-use.e2e-spec.ts#AppModule | src/app.module.ts}\n\nYou can now start using policy decorators ({@link Policy `Policy`} and {@link PoliciesMask `PoliciesMask`}) in your controllers !\n\n# Basic usage\n\nYou can protect all methods of your controller using the {@link Policy `Policy`} class decorator.\n\n{@codeblock test/basic-use.e2e-spec.ts#CatOwnerController | src/cat-owner.controller.ts}\n\nThis decorator can also be used to protect individual methods.\n\n{@codeblock test/basic-use.e2e-spec.ts#CatCareController | src/cat-care.controller.ts}\n\nIf you want to group various policies in the same decorator at the controller level, use the {@link PoliciesMask `PoliciesMask`} decorator.\n\n{@codeblock test/basic-use.e2e-spec.ts#CatController | src/cat.controller.ts}\n\nCheck the tests !\n\n{@codeblock folded test/basic-use.e2e-spec.ts#Test | test/cats.e2e-spec.ts}\n\n# What next ?\n\n{@page Use with guards}","pagesPluginParent":"Guides / "},{"id":27,"kind":1,"name":"Use with guards","url":"pages/Guides/use-with-guards.html","classes":"tsd-kind-page","pagesPluginContent":"Most of the times, you want to execute some guards before checking CASL policies, to extract some user informations before generating its abilities.\n\nThis page will show you the various way to do.\n\nLet's assume you have the following {@link CaslAbilityFactory `CaslAbilityFactory`}:\n\n{@codeblock test/use-with-guards/ability-factory.service.ts | src/ability-factory.service.ts}\n\n# The naïve approach\n\n> This method is **not recommanded**. You might skip directly to the [recommended approach](#the-recommended-approach)\n\n## Without any more dependencies\n\nThis method does not require any external dependency, and is as close to NestJS as possible.\n\n{@codeblock folded test/use-with-guards/naive.guard.ts | src/guards/naive.guard.ts}\n\nAssuming the guard does the following (see above for an example implementation):\n* Users without an `Authorization` header will see an `Unauthorized` exception.\n* Users with an invalid `Authorization` header will see a `Forbidden` exception.\n* Users with a valid `Authorization` header will be allowed to continue, and the property `user` is set on the `request`.\n\n> Yeah, I'm aware that in an ideal world, a [`Middleware`](https://docs.nestjs.com/middleware) or an [`Interceptor`](https://docs.nestjs.com/interceptors) should take care of setting the `user` property on the `Request`. But fact is that [`@nestjs/passport`](https://www.npmjs.com/package/@nestjs/passport) does it [in a guard](https://github.com/nestjs/passport/blob/6aef921c7566766d0eb9e79d2c8235177c539863/lib/auth.guard.ts#L58)\n\n{@codeblock test/use-with-guards/naive.controller.ts | src/controllers/naive.controller.ts}\n\nNow,\n* Users without an `Authorization` header will see an `Unauthorized` exception (from the `NaiveGuard`).\n* Users with an invalid `Authorization` header will see a `Forbidden` exception (from the `NaiveGuard`).\n* Users with an `Authorization` header that does not give them access to the ressource will see a `Forbidden` exception (from the {@link PoliciesGuard `PoliciesGuard`}).\n* Users with an `Authorization` header that give them access to the ressource will succeed.\n\n## Using [`@nestjs/passport`](https://www.npmjs.com/package/@nestjs/passport)\n\nIf you're using `passport`, you can delegate the user retrieval. Let's say you have a JWT `passport` strategy.\n\n{@codeblock folded test/use-with-guards/jwt-passport.strategy.ts | src/strategies/jwt-passport.strategy.ts}\n\nStill using the naive approach, you can then declare the controller like this:\n\n{@codeblock test/use-with-guards/passport-naive.controller.ts | src/controllers/passport-naive.controller.ts}\n\n## The tests\n\nWanna see the behavior as tests ? Here you are !\n\n{@codeblock folded test/use-with-guards/naive-test.e2e-spec.ts}\n\n# The recommended approach\n\nWhat's the problem about the naïve approach above ? Well, there are 2.\n1. *The readability*: The `UseGuards` decorator is placed **below** the {@link Policy `Policy`} decorator, but is ran **before** it.\n2. *The reusability*: If you're using multiple authentication strategies in the same app, you might have to apply guards **and** the policies on each method depending on the context. Moreover, if you want to type-check your policies, you might prefer to have abilities presets.\n\n## About readability\n\nYou can use {@link Policy.usingGuard `Policy.usingGuard`} or {@link PoliciesMask.usingGuard `PoliciesMask.usingGuard`} to prepended guards to the decorator factory. Those calls are cumulative, and you can do multiple subsequent calls to join guards using an `and` condition. If you provide an array of guards, they be evaluated using an `or` condition.\n\n{@codeblock test/use-with-guards/recommended.controller.ts#Recommended simple controller | src/controllers/recommended.controller.ts}\n\n## About reusability\n\nYou can even prepare a policy decorator with guards or {@link PolicyDescriptor `PolicyDescriptor`}:\n\n{@codeblock test/use-with-guards/recommended.controller.ts#Recommended bound | src/policies.ts}\n\nThen, use those presets in your controller:\n\n{@codeblock test/use-with-guards/recommended.controller.ts#Recommended bound controller | src/recommended-bound.controller.ts}\n\nNow, both `method1` and `method2` will run if\n* the user is authenticated through `jwt` strategy\n* it passes either `ExtraGuard1` or `ExtraGuard2`\n* and he has admin role.\n\n> Note that you can use {@link bindPolicyDecorators `bindPolicyDecorators`} to bind *both* {@link Policy `Policy`} and {@link PoliciesMask `PoliciesMask`}\n\n## The tests\n\nThis is tested, of course. Just see by yourself.\n\n{@codeblock folded test/use-with-guards/recommended-test.e2e-spec.ts}\n\n# What next ?\n\n{@page Better type constraints}","pagesPluginParent":"Guides / "},{"id":28,"kind":1,"name":"Better type constraints","url":"pages/Guides/better-type-constraints.html","classes":"tsd-kind-page","pagesPluginContent":"So far, we were able to configure your policies. But we can't yet check that our `action`s or `subject`s are actually matching what we declared.\n\n# Define the ability type\n\nLet's configure our ability types:\n\n{@codeblock test/better-types/ability.ts}\n\nUsing `MyAbility`, we can't pass anything to `can` or `cannot`: types are constrained.\n\n{@codeblock test/better-types/ability.typecheck.e2e-spec.ts}\n\nThat's great. This will greatly reduce our chances of typos. Moreover, your IDE might now suggest `action`s & `subject`s for you.\n\n# Use the ability type\n\n## With the {@link CaslAbilityFactory `CaslAbilityFactory`}\n\nLet's now use this type in your {@link CaslAbilityFactory `CaslAbilityFactory`}:\n\n{@codeblock test/better-types/ability-factory.service.ts | src/ability-factory.service.ts}\n\n## With decorators\n\nYou can pass your ability as a type parameter to your decorators to constraint your `action`s and `subject`s:\n\n{@codeblock test/better-types/test.controller.ts | src/test.controller.ts}\n\nBut the boring part here is that you have to pass your ability type to **every** decorator in order to constrain them. Hopefully, you can solve this:\n\n{@codeblock test/better-types/my-policies.ts | src/my-policies.ts}\n\nThen, simply enjoy type contraints !\n\n{@codeblock test/better-types/test-bound.controller.ts | src/test-bound.controller.ts}\n","pagesPluginParent":"Guides / "},{"id":29,"kind":1,"name":"Changelog","url":"pages/Changelog/CHANGELOG.html","classes":"tsd-kind-page","pagesPluginContent":"# Changelog\n\nAll notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.\n\n### [0.0.2](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.7...v0.0.2) (2021-11-06)\n\n### [0.0.2-next.7](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.6...v0.0.2-next.7) (2021-10-08)\n\n### [0.0.2-next.6](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.5...v0.0.2-next.6) (2021-10-08)\n\n### [0.0.2-next.5](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.4...v0.0.2-next.5) (2021-10-08)\n\n### [0.0.2-next.4](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.3...v0.0.2-next.4) (2021-10-07)\n\n### [0.0.2-next.3](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.2...v0.0.2-next.3) (2021-10-06)\n\n### [0.0.2-next.2](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.1...v0.0.2-next.2) (2021-10-06)\n\n\n### Features\n\n* **policies.guard:** allow async handlers ([9594542](https://github.com/Scitizen/nest-casl/commit/95945423b9d78ecb1353fe6c1a2228d5c9571cec))\n\n\n### Bug Fixes\n\n* add policy metadata in the correct order ([467354a](https://github.com/Scitizen/nest-casl/commit/467354a0434a6518f52697c7ab46642ed9384f8e))\n* **or.guard:** properly waterfall canActivate, stop further checks on first success, use promises ([f92f45e](https://github.com/Scitizen/nest-casl/commit/f92f45e023c36a7fdfebe01851315d839a2f5a9f))\n\n### [0.0.2-next.1](https://github.com/Scitizen/nest-casl/compare/v0.0.2-next.0...v0.0.2-next.1) (2021-10-06)\n\n### [0.0.2-next.0](https://github.com/Scitizen/nest-casl/compare/v0.0.1...v0.0.2-next.0) (2021-10-06)\n\n### [0.0.1](https://github.com/Scitizen/nest-casl/compare/78f16a2f9e103be41b9d6a872f547eb54bc0d80e...v0.0.1) (2021-10-06)\n\nInitial release\n","pagesPluginParent":"Changelog / "}],"index":{"version":"2.3.9","fields":["pagesPluginContent","name","parent"],"fieldVectors":[["pagesPluginContent/0",[]],["name/0",[0,32.165]],["parent/0",[]],["pagesPluginContent/1",[]],["name/1",[1,15.072]],["parent/1",[]],["pagesPluginContent/2",[]],["name/2",[1,15.072]],["parent/2",[]],["pagesPluginContent/3",[]],["name/3",[2,26.74]],["parent/3",[1,0.78]],["pagesPluginContent/4",[]],["name/4",[3,16.591]],["parent/4",[]],["pagesPluginContent/5",[]],["name/5",[3,16.591]],["parent/5",[]],["pagesPluginContent/6",[]],["name/6",[2,26.74]],["parent/6",[3,0.859]],["pagesPluginContent/7",[]],["name/7",[4,26.74]],["parent/7",[]],["pagesPluginContent/8",[]],["name/8",[5,26.74]],["parent/8",[]],["pagesPluginContent/9",[]],["name/9",[6,32.165]],["parent/9",[5,1.385]],["pagesPluginContent/10",[]],["name/10",[1,15.072]],["parent/10",[7,1.385]],["pagesPluginContent/11",[]],["name/11",[3,16.591]],["parent/11",[7,1.385]],["pagesPluginContent/12",[]],["name/12",[8,20.497]],["parent/12",[]],["pagesPluginContent/13",[]],["name/13",[9,32.165]],["parent/13",[8,1.061]],["pagesPluginContent/14",[]],["name/14",[10,32.165]],["parent/14",[8,1.061]],["pagesPluginContent/15",[]],["name/15",[11,26.74]],["parent/15",[]],["pagesPluginContent/16",[]],["name/16",[12,32.165]],["parent/16",[11,1.385]],["pagesPluginContent/17",[]],["name/17",[13,26.74]],["parent/17",[]],["pagesPluginContent/18",[]],["name/18",[14,32.165]],["parent/18",[]],["pagesPluginContent/19",[]],["name/19",[15,26.74]],["parent/19",[]],["pagesPluginContent/20",[]],["name/20",[16,32.165]],["parent/20",[15,1.385]],["pagesPluginContent/21",[]],["name/21",[17,32.165]],["parent/21",[]],["pagesPluginContent/22",[]],["name/22",[18,32.165]],["parent/22",[]],["pagesPluginContent/23",[]],["name/23",[19,20.497]],["parent/23",[]],["pagesPluginContent/24",[]],["name/24",[20,32.165]],["parent/24",[19,1.061]],["pagesPluginContent/25",[]],["name/25",[21,32.165]],["parent/25",[]],["pagesPluginContent/26",[1,24.559,3,24.162,8,19.493,22,48.904,23,19.493,24,30.59,25,13.006,26,18.058,27,19.493,28,18.058,29,18.058,30,18.058,31,15.013,32,30.59,33,40.648,34,18.058,35,18.058,36,18.058,37,25.43,38,13.006,39,15.013,40,22.031,41,18.058,42,13.006,43,18.058,44,25.43,45,15.013,46,18.058,47,15.013,48,40.998,49,56.923,50,56.923,51,18.058,52,13.006,53,13.006,54,18.058,55,37.748,56,25.359,57,33.737,58,18.058,59,22.031,60,15.013,61,15.013,62,25.359,63,22.722,64,15.013,65,18.058,66,18.058,67,28.661,68,28.661,69,13.006,70,18.058,71,22.031,72,15.013,73,18.058,74,18.058,75,18.058,76,30.59,77,15.013,78,30.59,79,13.006,80,25.43,81,18.058,82,33.737,83,18.058,84,30.59,85,18.058,86,18.058,87,13.006,88,18.058,89,18.058,90,18.058,91,18.058,92,15.013,93,15.013,94,18.058,95,15.013,96,13.006,97,15.013,98,18.058,99,18.058,100,18.058,101,18.058,102,13.006,103,15.013,104,15.013,105,18.058,106,18.058,107,13.006,108,13.006,109,15.013,110,15.013,111,13.006]],["name/26",[112,23.437,113,23.437]],["parent/26",[]],["pagesPluginContent/27",[1,11.681,3,6.049,4,9.749,13,9.749,19,7.473,22,44.15,23,15.886,25,24.987,27,32.823,33,44.15,37,5.178,38,8.446,39,5.178,40,24.987,42,17.954,45,13.813,47,9.749,48,28.74,52,4.486,53,8.446,55,26.942,56,13.376,57,8.446,59,24.987,61,13.813,62,31.795,63,9.487,64,5.178,67,37.097,68,20.521,69,8.446,71,20.521,79,15.118,80,17.45,82,15.118,87,8.446,92,20.724,93,9.749,95,5.178,96,11.967,97,5.178,102,4.486,103,13.813,104,17.45,107,8.446,108,4.486,109,5.178,110,9.749,111,20.521,114,6.229,115,6.229,116,6.229,117,11.726,118,16.615,119,6.229,120,6.229,121,24.929,122,6.229,123,6.229,124,6.229,125,11.726,126,26.942,127,6.229,128,6.229,129,11.726,130,9.749,131,6.229,132,17.45,133,11.726,134,39.904,135,6.229,136,11.726,137,24.929,138,16.615,139,16.615,140,6.229,141,13.813,142,6.229,143,6.229,144,16.615,145,6.229,146,16.615,147,11.726,148,6.229,149,6.229,150,20.99,151,6.229,152,6.229,153,6.229,154,13.813,155,6.229,156,6.229,157,6.229,158,6.229,159,6.229,160,6.229,161,6.229,162,28.842,163,11.726,164,4.486,165,48.172,166,6.229,167,6.229,168,31.734,169,31.734,170,31.734,171,11.726,172,24.929,173,11.726,174,16.615,175,6.229,176,6.229,177,6.229,178,11.726,179,6.229,180,17.45,181,6.229,182,6.229,183,6.229,184,6.229,185,6.229,186,6.229,187,20.724,188,6.229,189,6.229,190,6.229,191,6.229,192,6.229,193,9.749,194,6.229,195,11.726,196,6.229,197,6.229,198,6.229,199,11.726,200,11.726,201,9.749,202,11.726,203,11.726,204,11.726,205,6.229,206,11.726,207,11.726,208,6.229,209,6.229,210,6.229,211,11.726,212,11.726,213,6.229,214,11.726,215,6.229,216,6.229,217,6.229,218,6.229,219,6.229,220,11.726,221,6.229,222,6.229,223,6.229,224,5.178,225,13.813,226,6.229,227,11.726,228,6.229,229,6.229,230,16.615,231,6.229,232,6.229,233,11.726,234,6.229,235,11.726,236,6.229,237,6.229,238,6.229,239,6.229,240,11.726,241,11.726,242,6.229,243,6.229,244,6.229,245,6.229,246,6.229,247,6.229,248,6.229,249,5.178,250,8.446,251,6.229,252,11.726,253,11.726,254,11.726,255,6.229,256,11.726,257,11.726,258,6.229,259,6.229,260,6.229,261,11.726,262,6.229,263,6.229,264,6.229,265,6.229,266,16.615,267,6.229,268,6.229,269,6.229,270,6.229,271,11.726,272,6.229,273,6.229,274,5.178,275,11.726,276,6.229,277,6.229,278,6.229,279,6.229,280,6.229,281,6.229,282,6.229,283,6.229,284,6.229,285,6.229,286,6.229,287,6.229,288,6.229,289,6.229,290,6.229,291,6.229,292,6.229,293,6.229,294,6.229,295,6.229,296,6.229,297,5.178,298,5.178]],["name/27",[27,11.747,63,10.526,111,13.277]],["parent/27",[]],["pagesPluginContent/28",[19,29.252,22,43.299,23,24.785,25,12.609,27,18.986,33,29.252,38,12.609,40,12.609,42,21.459,44,42.789,48,40.33,52,12.609,53,21.459,55,21.459,56,18.986,57,43.033,59,12.609,60,24.769,62,38.075,63,17.012,67,33.061,68,28.013,69,21.459,71,12.609,72,24.769,79,12.609,82,12.609,96,12.609,102,12.609,107,12.609,108,12.609,126,12.609,130,24.769,132,14.554,141,14.554,154,14.554,164,12.609,187,24.769,193,24.769,201,14.554,224,14.554,225,24.769,249,14.554,250,40.33,274,24.769,299,17.507,300,17.507,301,45.904,302,17.507,303,17.507,304,29.795,305,17.507,306,38.894,307,38.894,308,38.894,309,17.507,310,17.507,311,17.507,312,17.507,313,29.795,314,55.996,315,17.507,316,17.507,317,38.894,318,17.507,319,17.507,320,17.507,321,17.507,322,17.507,323,17.507,324,17.507,325,17.507,326,17.507,327,17.507,328,17.507,329,17.507,330,17.507,331,17.507,332,17.507,333,17.507,334,17.507,335,17.507,336,17.507,337,17.507,338,14.554,339,17.507,340,17.507,341,17.507,342,17.507,343,29.795,344,17.507,345,17.507,346,17.507,347,17.507,348,17.507,349,17.507]],["name/28",[250,13.277,297,15.325,298,15.325]],["parent/28",[]],["pagesPluginContent/29",[1,9.534,22,51.176,23,21.546,31,16.916,33,12.967,56,21.546,62,12.967,63,11.618,77,16.916,87,14.655,126,14.655,162,16.916,164,14.655,180,16.916,338,16.916,350,16.916,351,20.348,352,20.348,353,20.348,354,20.348,355,20.348,356,20.348,357,20.348,358,20.348,359,20.348,360,20.348,361,20.348,362,20.348,363,67.122,364,20.348,365,71.84,366,20.348,367,60.499,368,67.122,369,20.348,370,20.348,371,20.348,372,69.664,373,43.38,374,20.348,375,20.348,376,20.348,377,20.348,378,20.348,379,20.348,380,20.348,381,20.348,382,20.348,383,20.348,384,20.348,385,20.348,386,20.348,387,20.348,388,20.348,389,20.348,390,20.348,391,20.348,392,20.348,393,20.348,394,20.348,395,20.348,396,20.348,397,20.348,398,20.348,399,20.348,400,20.348,401,20.348,402,20.348,403,20.348,404,20.348,405,20.348,406,20.348,407,20.348,408,20.348,409,20.348,410,20.348,411,20.348,412,20.348,413,20.348,414,20.348,415,20.348,416,20.348,417,20.348,418,20.348,419,20.348,420,20.348,421,20.348,422,20.348,423,20.348,424,20.348]],["name/29",[350,26.74]],["parent/29",[]]],"invertedIndex":[["",{"_index":22,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["0.0.1](https://github.com/scitizen/nest",{"_index":421,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["0.0.2",{"_index":368,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["0.0.2](https://github.com/scitizen/nest",{"_index":362,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["06",{"_index":367,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["07",{"_index":383,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["08",{"_index":373,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["1",{"_index":234,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["10",{"_index":372,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["11",{"_index":366,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["2",{"_index":233,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["2021",{"_index":365,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["467354a](https://github.com/scitizen/nest",{"_index":402,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["9594542](https://github.com/scitizen/nest",{"_index":395,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["__type",{"_index":6,"pagesPluginContent":{},"name":{"9":{}},"parent":{}}],["a",{"_index":40,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["abilities",{"_index":125,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["ability",{"_index":44,"pagesPluginContent":{"26":{},"28":{}},"name":{},"parent":{}}],["abilityfactory",{"_index":12,"pagesPluginContent":{},"name":{"16":{}},"parent":{}}],["able",{"_index":303,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["about",{"_index":230,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["above",{"_index":163,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["access",{"_index":202,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["action`s",{"_index":307,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["actually",{"_index":309,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["add",{"_index":399,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["admin",{"_index":287,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["all",{"_index":77,"pagesPluginContent":{"26":{},"29":{}},"name":{},"parent":{}}],["allow",{"_index":392,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["allowed",{"_index":176,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["also",{"_index":86,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["an",{"_index":165,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["and",{"_index":59,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["any",{"_index":147,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["anything",{"_index":318,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["app",{"_index":244,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["apply",{"_index":245,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["appmodule",{"_index":58,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["approach",{"_index":137,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["approach](#the",{"_index":145,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["are",{"_index":225,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["array",{"_index":263,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["as",{"_index":154,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["assume",{"_index":131,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["assuming",{"_index":160,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["async",{"_index":393,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["at",{"_index":98,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["authenticated",{"_index":279,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["authentication",{"_index":242,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["authorization",{"_index":169,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["aware",{"_index":183,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["bash",{"_index":34,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["basic",{"_index":74,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["be",{"_index":87,"pagesPluginContent":{"26":{},"27":{},"29":{}},"name":{},"parent":{}}],["before",{"_index":118,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["behavior",{"_index":223,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["below",{"_index":238,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["better",{"_index":297,"pagesPluginContent":{"27":{}},"name":{"28":{}},"parent":{}}],["bind",{"_index":290,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["bindpolicydecorators",{"_index":4,"pagesPluginContent":{"27":{}},"name":{"7":{}},"parent":{}}],["boring",{"_index":335,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["both",{"_index":275,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["bound",{"_index":271,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["bound.controller.ts",{"_index":274,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["boundpolicydecorators",{"_index":5,"pagesPluginContent":{},"name":{"8":{}},"parent":{"9":{}}}],["boundpolicydecorators.__type",{"_index":7,"pagesPluginContent":{},"name":{},"parent":{"10":{},"11":{}}}],["bug",{"_index":397,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["but",{"_index":193,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["by",{"_index":294,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["calls",{"_index":257,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["can",{"_index":68,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["can't",{"_index":304,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["canactivate",{"_index":407,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["cannot",{"_index":319,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["care",{"_index":191,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["care.controller.ts",{"_index":91,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["casl",{"_index":37,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["casl/commit/467354a0434a6518f52697c7ab46642ed9384f8e",{"_index":403,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["casl/commit/95945423b9d78ecb1353fe6c1a2228d5c9571cec",{"_index":396,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["casl/commit/f92f45e023c36a7fdfebe01851315d839a2f5a9f",{"_index":414,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["casl/compare/78f16a2f9e103be41b9d6a872f547eb54bc0d80e...v0.0.1",{"_index":422,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["casl/compare/v0.0.1...v0.0.2",{"_index":419,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["casl/compare/v0.0.2",{"_index":363,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["caslabilityfactory",{"_index":19,"pagesPluginContent":{"27":{},"28":{}},"name":{"23":{}},"parent":{"24":{}}}],["caslmodule",{"_index":8,"pagesPluginContent":{"26":{}},"name":{"12":{}},"parent":{"13":{},"14":{}}}],["chances",{"_index":326,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["changelog",{"_index":350,"pagesPluginContent":{"29":{}},"name":{"29":{}},"parent":{}}],["changelog/standard",{"_index":358,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["changes",{"_index":352,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["check",{"_index":102,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["checking",{"_index":119,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["checks",{"_index":410,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["class",{"_index":81,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["close",{"_index":155,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["codeblock",{"_index":48,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["commit",{"_index":360,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["compatible",{"_index":26,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["condition",{"_index":261,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["configuration",{"_index":30,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["configure",{"_index":60,"pagesPluginContent":{"26":{},"28":{}},"name":{},"parent":{}}],["constrain",{"_index":339,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["constrained",{"_index":320,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["constraint",{"_index":332,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["constraints",{"_index":298,"pagesPluginContent":{"27":{}},"name":{"28":{}},"parent":{}}],["constructor",{"_index":10,"pagesPluginContent":{},"name":{"14":{}},"parent":{}}],["context",{"_index":248,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["continue",{"_index":177,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["contraints",{"_index":347,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["controller",{"_index":80,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["controllers",{"_index":73,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["correct",{"_index":401,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["course",{"_index":292,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["createfromrequest",{"_index":20,"pagesPluginContent":{},"name":{"24":{}},"parent":{}}],["cumulative",{"_index":258,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["current",{"_index":46,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["declare",{"_index":39,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["declared",{"_index":311,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["decorator",{"_index":82,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["decorators",{"_index":72,"pagesPluginContent":{"26":{},"28":{}},"name":{},"parent":{}}],["define",{"_index":312,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["delegate",{"_index":208,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["dependencies",{"_index":149,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["dependency",{"_index":153,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["depending",{"_index":247,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["directly",{"_index":143,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["do",{"_index":129,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["documented",{"_index":354,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["does",{"_index":150,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["each",{"_index":246,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["either",{"_index":282,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["enjoy",{"_index":346,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["evaluated",{"_index":265,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["even",{"_index":269,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["every",{"_index":337,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["example",{"_index":166,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["exception",{"_index":172,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["execute",{"_index":116,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["external",{"_index":152,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["extract",{"_index":120,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["extraguard1",{"_index":283,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["extraguard2",{"_index":284,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["f92f45e](https://github.com/scitizen/nest",{"_index":413,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["fact",{"_index":194,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["factory",{"_index":64,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["factory.service.ts",{"_index":53,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["far",{"_index":300,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["features",{"_index":390,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["file",{"_index":355,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["first",{"_index":31,"pagesPluginContent":{"26":{},"29":{}},"name":{},"parent":{}}],["fixes",{"_index":398,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["folded",{"_index":104,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["following",{"_index":133,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["for",{"_index":164,"pagesPluginContent":{"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["forbidden",{"_index":174,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["from",{"_index":45,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["further",{"_index":409,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["generate",{"_index":43,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["generating",{"_index":123,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["getting",{"_index":112,"pagesPluginContent":{},"name":{"26":{}},"parent":{}}],["give",{"_index":200,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["great",{"_index":323,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["greatly",{"_index":324,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["group",{"_index":94,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["guard",{"_index":161,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guard](https://github.com/nestjs/passport/blob/6aef921c7566766d0eb9e79d2c8235177c539863/lib/auth.guard.ts#l58",{"_index":196,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards",{"_index":111,"pagesPluginContent":{"26":{},"27":{}},"name":{"27":{}},"parent":{}}],["guards/ability",{"_index":135,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/jwt",{"_index":213,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/naive",{"_index":226,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/naive.controller.ts",{"_index":197,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/naive.guard.ts",{"_index":158,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/passport",{"_index":219,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/recommended",{"_index":296,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guards/recommended.controller.ts#recommended",{"_index":266,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["guardslist",{"_index":18,"pagesPluginContent":{},"name":{"22":{}},"parent":{}}],["guidelines",{"_index":361,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["handle",{"_index":16,"pagesPluginContent":{},"name":{"20":{}},"parent":{}}],["handlers",{"_index":394,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["has",{"_index":286,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["have",{"_index":132,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["he",{"_index":285,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["header",{"_index":170,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["here",{"_index":224,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["hopefully",{"_index":340,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["i'm",{"_index":182,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["icaslrootconfig",{"_index":11,"pagesPluginContent":{},"name":{"15":{}},"parent":{"16":{}}}],["ide",{"_index":328,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["ideal",{"_index":184,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["if",{"_index":92,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["implementation",{"_index":167,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["import",{"_index":54,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["in",{"_index":56,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["individual",{"_index":89,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["informations",{"_index":122,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["initial",{"_index":423,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["injectability",{"_index":0,"pagesPluginContent":{},"name":{"0":{}},"parent":{}}],["install",{"_index":32,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["interceptor`](https://docs.nestjs.com/interceptors",{"_index":188,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["invalid",{"_index":173,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["ipolicy",{"_index":15,"pagesPluginContent":{},"name":{"19":{}},"parent":{"20":{}}}],["is",{"_index":25,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["it",{"_index":61,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["its",{"_index":124,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["join",{"_index":260,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["just",{"_index":293,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["jwt",{"_index":211,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["let's",{"_index":130,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["level",{"_index":99,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["like",{"_index":218,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["link",{"_index":55,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["matching",{"_index":310,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["maybeasyncvalue",{"_index":21,"pagesPluginContent":{},"name":{"25":{}},"parent":{}}],["metadata",{"_index":400,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["method",{"_index":138,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["method1",{"_index":276,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["method2",{"_index":277,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["methods",{"_index":78,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["middleware`](https://docs.nestjs.com/middleware",{"_index":186,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["might",{"_index":141,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["module",{"_index":24,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["more",{"_index":148,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["moreover",{"_index":249,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["most",{"_index":114,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["multiple",{"_index":241,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["myability",{"_index":316,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["naive",{"_index":217,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["naive.controller.ts",{"_index":220,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["naiveguard",{"_index":199,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["naïve",{"_index":136,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["nestjs",{"_index":156,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["nestjs/passport`](https://www.npmjs.com/package/@nestjs/passport",{"_index":195,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["nestjs@^8.0.0",{"_index":28,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["next",{"_index":109,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["next.0",{"_index":420,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.0...v0.0.2",{"_index":416,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.0](https://github.com/scitizen/nest",{"_index":418,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.1",{"_index":417,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.1...v0.0.2",{"_index":388,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.1](https://github.com/scitizen/nest",{"_index":415,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.2",{"_index":389,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.2...v0.0.2",{"_index":385,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.2](https://github.com/scitizen/nest",{"_index":387,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.3",{"_index":386,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.3...v0.0.2",{"_index":381,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.3](https://github.com/scitizen/nest",{"_index":384,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.4",{"_index":382,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.4...v0.0.2",{"_index":378,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.4](https://github.com/scitizen/nest",{"_index":380,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.5",{"_index":379,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.5...v0.0.2",{"_index":375,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.5](https://github.com/scitizen/nest",{"_index":377,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.6",{"_index":376,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.6...v0.0.2",{"_index":370,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.6](https://github.com/scitizen/nest",{"_index":374,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.7",{"_index":371,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.7...v0.0.2",{"_index":364,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["next.7](https://github.com/scitizen/nest",{"_index":369,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["not",{"_index":139,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["notable",{"_index":351,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["note",{"_index":289,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["now",{"_index":69,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["npm",{"_index":35,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["of",{"_index":79,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["on",{"_index":180,"pagesPluginContent":{"27":{},"29":{}},"name":{},"parent":{}}],["or",{"_index":187,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["or.guard",{"_index":404,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["order",{"_index":338,"pagesPluginContent":{"28":{},"29":{}},"name":{},"parent":{}}],["our",{"_index":306,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["owner.controller.ts",{"_index":85,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["page",{"_index":110,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["parameter",{"_index":331,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["part",{"_index":336,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["pass",{"_index":317,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["passes",{"_index":281,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["passport",{"_index":207,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["passport.strategy.ts",{"_index":214,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["placed",{"_index":237,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["policies",{"_index":96,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["policies.guard",{"_index":391,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["policies.ts",{"_index":343,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["policiesguard",{"_index":204,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["policiesmask",{"_index":3,"pagesPluginContent":{"26":{},"27":{}},"name":{"4":{},"5":{},"11":{}},"parent":{"6":{}}}],["policiesmask.usingguard",{"_index":254,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["policy",{"_index":1,"pagesPluginContent":{"26":{},"27":{},"29":{}},"name":{"1":{},"2":{},"10":{}},"parent":{"3":{}}}],["policy.usingguard",{"_index":253,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["policydescriptor",{"_index":13,"pagesPluginContent":{"27":{}},"name":{"17":{}},"parent":{}}],["policydescriptormask",{"_index":14,"pagesPluginContent":{},"name":{"18":{}},"parent":{}}],["possible",{"_index":157,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["prefer",{"_index":251,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["prepare",{"_index":270,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["prepended",{"_index":255,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["presets",{"_index":252,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["problem",{"_index":229,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["project",{"_index":353,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["promises",{"_index":412,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["properly",{"_index":405,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["property",{"_index":178,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["protect",{"_index":76,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["provide",{"_index":262,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["provider",{"_index":41,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["ran",{"_index":239,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["readability",{"_index":235,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["recommanded",{"_index":140,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["recommended",{"_index":144,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["reduce",{"_index":325,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["release",{"_index":424,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["request",{"_index":47,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["require",{"_index":151,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["ressource",{"_index":203,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["retrieval",{"_index":209,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["reusability",{"_index":240,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["role",{"_index":288,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["run",{"_index":278,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["same",{"_index":97,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["say",{"_index":210,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["scitizen/nest",{"_index":36,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["see",{"_index":162,"pagesPluginContent":{"27":{},"29":{}},"name":{},"parent":{}}],["set",{"_index":179,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["setting",{"_index":192,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["setup",{"_index":29,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["should",{"_index":189,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["show",{"_index":127,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["simple",{"_index":267,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["simplepolicy",{"_index":17,"pagesPluginContent":{},"name":{"21":{}},"parent":{}}],["simply",{"_index":345,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["skip",{"_index":142,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["so",{"_index":299,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["solve",{"_index":341,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["some",{"_index":117,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["spec.ts",{"_index":107,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["spec.ts#abilityfactory",{"_index":51,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["spec.ts#appmodule",{"_index":65,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["spec.ts#catcarecontroller",{"_index":90,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["spec.ts#catcontroller",{"_index":100,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["spec.ts#catownercontroller",{"_index":83,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["spec.ts#test",{"_index":105,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["src/ability",{"_index":52,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["src/app.module.ts",{"_index":66,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["src/cat",{"_index":84,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["src/cat.controller.ts",{"_index":101,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["src/controllers/naive.controller.ts",{"_index":198,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/controllers/passport",{"_index":221,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/controllers/recommended.controller.ts",{"_index":268,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/guards/naive.guard.ts",{"_index":159,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/my",{"_index":344,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["src/policies.ts",{"_index":272,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/recommended",{"_index":273,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/strategies/jwt",{"_index":215,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["src/test",{"_index":349,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["src/test.controller.ts",{"_index":334,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["standard",{"_index":356,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["start",{"_index":70,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["started",{"_index":113,"pagesPluginContent":{},"name":{"26":{}},"parent":{}}],["still",{"_index":216,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["stop",{"_index":408,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["strategies",{"_index":243,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["strategy",{"_index":212,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["subject`s",{"_index":308,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["subsequent",{"_index":259,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["succeed",{"_index":205,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["success",{"_index":411,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["suggest",{"_index":329,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["take",{"_index":190,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["test.e2e",{"_index":227,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["test/basic",{"_index":49,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["test/better",{"_index":314,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["test/cats.e2e",{"_index":106,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["test/use",{"_index":134,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["tested",{"_index":291,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["tests",{"_index":103,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["that",{"_index":42,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["that's",{"_index":322,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["the",{"_index":33,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["them",{"_index":201,"pagesPluginContent":{"27":{},"28":{}},"name":{},"parent":{}}],["then",{"_index":38,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["there",{"_index":232,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["they",{"_index":264,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["this",{"_index":23,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["those",{"_index":256,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["through",{"_index":280,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["times",{"_index":115,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["to",{"_index":62,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["type",{"_index":250,"pagesPluginContent":{"27":{},"28":{}},"name":{"28":{}},"parent":{}}],["types",{"_index":313,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/ability",{"_index":330,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/ability.ts",{"_index":315,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/ability.typecheck.e2e",{"_index":321,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/my",{"_index":342,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/test",{"_index":348,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["types/test.controller.ts",{"_index":333,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["typos",{"_index":327,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["unauthorized",{"_index":171,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["usage",{"_index":75,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["use",{"_index":63,"pagesPluginContent":{"26":{},"27":{},"28":{},"29":{}},"name":{"27":{}},"parent":{}}],["use.e2e",{"_index":50,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["used",{"_index":88,"pagesPluginContent":{"26":{}},"name":{},"parent":{}}],["useguards",{"_index":236,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["user",{"_index":121,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["users",{"_index":168,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["using",{"_index":71,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["usingguard",{"_index":2,"pagesPluginContent":{},"name":{"3":{},"6":{}},"parent":{}}],["valid",{"_index":175,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["various",{"_index":95,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["version",{"_index":359,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["version](https://github.com/conventional",{"_index":357,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["wanna",{"_index":222,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["want",{"_index":93,"pagesPluginContent":{"26":{},"27":{}},"name":{},"parent":{}}],["waterfall",{"_index":406,"pagesPluginContent":{"29":{}},"name":{},"parent":{}}],["way",{"_index":128,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["we",{"_index":301,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["well",{"_index":231,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["were",{"_index":302,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["what",{"_index":108,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["what's",{"_index":228,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["will",{"_index":126,"pagesPluginContent":{"27":{},"28":{},"29":{}},"name":{},"parent":{}}],["with",{"_index":27,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{"27":{}},"parent":{}}],["withconfig",{"_index":9,"pagesPluginContent":{},"name":{"13":{}},"parent":{}}],["without",{"_index":146,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["world",{"_index":185,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["yeah",{"_index":181,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["yet",{"_index":305,"pagesPluginContent":{"28":{}},"name":{},"parent":{}}],["you",{"_index":67,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["you're",{"_index":206,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}],["your",{"_index":57,"pagesPluginContent":{"26":{},"27":{},"28":{}},"name":{},"parent":{}}],["yourself",{"_index":295,"pagesPluginContent":{"27":{}},"name":{},"parent":{}}]],"pipeline":[]}} \ No newline at end of file diff --git a/docs/assets/main.js b/docs/assets/main.js new file mode 100644 index 00000000..99f331b2 --- /dev/null +++ b/docs/assets/main.js @@ -0,0 +1,52 @@ +(()=>{var Ce=Object.create;var J=Object.defineProperty;var Pe=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var Re=Object.getPrototypeOf,_e=Object.prototype.hasOwnProperty;var Me=t=>J(t,"__esModule",{value:!0});var Fe=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var De=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Oe(e))!_e.call(t,i)&&(r||i!=="default")&&J(t,i,{get:()=>e[i],enumerable:!(n=Pe(e,i))||n.enumerable});return t},Ae=(t,e)=>De(Me(J(t!=null?Ce(Re(t)):{},"default",!e&&t&&t.__esModule?{get:()=>t.default,enumerable:!0}:{value:t,enumerable:!0})),t);var de=Fe((ce,he)=>{(function(){var t=function(e){var r=new t.Builder;return r.pipeline.add(t.trimmer,t.stopWordFilter,t.stemmer),r.searchPipeline.add(t.stemmer),e.call(r,r),r.build()};t.version="2.3.9";t.utils={},t.utils.warn=function(e){return function(r){e.console&&console.warn&&console.warn(r)}}(this),t.utils.asString=function(e){return e==null?"":e.toString()},t.utils.clone=function(e){if(e==null)return e;for(var r=Object.create(null),n=Object.keys(e),i=0;i0){var h=t.utils.clone(r)||{};h.position=[a,l],h.index=s.length,s.push(new t.Token(n.slice(a,o),h))}a=o+1}}return s},t.tokenizer.separator=/[\s\-]+/;t.Pipeline=function(){this._stack=[]},t.Pipeline.registeredFunctions=Object.create(null),t.Pipeline.registerFunction=function(e,r){r in this.registeredFunctions&&t.utils.warn("Overwriting existing registered function: "+r),e.label=r,t.Pipeline.registeredFunctions[e.label]=e},t.Pipeline.warnIfFunctionNotRegistered=function(e){var r=e.label&&e.label in this.registeredFunctions;r||t.utils.warn(`Function is not registered with pipeline. This may cause problems when serialising the index. +`,e)},t.Pipeline.load=function(e){var r=new t.Pipeline;return e.forEach(function(n){var i=t.Pipeline.registeredFunctions[n];if(i)r.add(i);else throw new Error("Cannot load unregistered function: "+n)}),r},t.Pipeline.prototype.add=function(){var e=Array.prototype.slice.call(arguments);e.forEach(function(r){t.Pipeline.warnIfFunctionNotRegistered(r),this._stack.push(r)},this)},t.Pipeline.prototype.after=function(e,r){t.Pipeline.warnIfFunctionNotRegistered(r);var n=this._stack.indexOf(e);if(n==-1)throw new Error("Cannot find existingFn");n=n+1,this._stack.splice(n,0,r)},t.Pipeline.prototype.before=function(e,r){t.Pipeline.warnIfFunctionNotRegistered(r);var n=this._stack.indexOf(e);if(n==-1)throw new Error("Cannot find existingFn");this._stack.splice(n,0,r)},t.Pipeline.prototype.remove=function(e){var r=this._stack.indexOf(e);r!=-1&&this._stack.splice(r,1)},t.Pipeline.prototype.run=function(e){for(var r=this._stack.length,n=0;n1&&(oe&&(n=s),o!=e);)i=n-r,s=r+Math.floor(i/2),o=this.elements[s*2];if(o==e||o>e)return s*2;if(ou?h+=2:a==u&&(r+=n[l+1]*i[h+1],l+=2,h+=2);return r},t.Vector.prototype.similarity=function(e){return this.dot(e)/this.magnitude()||0},t.Vector.prototype.toArray=function(){for(var e=new Array(this.elements.length/2),r=1,n=0;r0){var o=s.str.charAt(0),a;o in s.node.edges?a=s.node.edges[o]:(a=new t.TokenSet,s.node.edges[o]=a),s.str.length==1&&(a.final=!0),i.push({node:a,editsRemaining:s.editsRemaining,str:s.str.slice(1)})}if(s.editsRemaining!=0){if("*"in s.node.edges)var u=s.node.edges["*"];else{var u=new t.TokenSet;s.node.edges["*"]=u}if(s.str.length==0&&(u.final=!0),i.push({node:u,editsRemaining:s.editsRemaining-1,str:s.str}),s.str.length>1&&i.push({node:s.node,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)}),s.str.length==1&&(s.node.final=!0),s.str.length>=1){if("*"in s.node.edges)var l=s.node.edges["*"];else{var l=new t.TokenSet;s.node.edges["*"]=l}s.str.length==1&&(l.final=!0),i.push({node:l,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)})}if(s.str.length>1){var h=s.str.charAt(0),p=s.str.charAt(1),v;p in s.node.edges?v=s.node.edges[p]:(v=new t.TokenSet,s.node.edges[p]=v),s.str.length==1&&(v.final=!0),i.push({node:v,editsRemaining:s.editsRemaining-1,str:h+s.str.slice(2)})}}}return n},t.TokenSet.fromString=function(e){for(var r=new t.TokenSet,n=r,i=0,s=e.length;i=e;r--){var n=this.uncheckedNodes[r],i=n.child.toString();i in this.minimizedNodes?n.parent.edges[n.char]=this.minimizedNodes[i]:(n.child._str=i,this.minimizedNodes[i]=n.child),this.uncheckedNodes.pop()}};t.Index=function(e){this.invertedIndex=e.invertedIndex,this.fieldVectors=e.fieldVectors,this.tokenSet=e.tokenSet,this.fields=e.fields,this.pipeline=e.pipeline},t.Index.prototype.search=function(e){return this.query(function(r){var n=new t.QueryParser(e,r);n.parse()})},t.Index.prototype.query=function(e){for(var r=new t.Query(this.fields),n=Object.create(null),i=Object.create(null),s=Object.create(null),o=Object.create(null),a=Object.create(null),u=0;u1?this._b=1:this._b=e},t.Builder.prototype.k1=function(e){this._k1=e},t.Builder.prototype.add=function(e,r){var n=e[this._ref],i=Object.keys(this._fields);this._documents[n]=r||{},this.documentCount+=1;for(var s=0;s=this.length)return t.QueryLexer.EOS;var e=this.str.charAt(this.pos);return this.pos+=1,e},t.QueryLexer.prototype.width=function(){return this.pos-this.start},t.QueryLexer.prototype.ignore=function(){this.start==this.pos&&(this.pos+=1),this.start=this.pos},t.QueryLexer.prototype.backup=function(){this.pos-=1},t.QueryLexer.prototype.acceptDigitRun=function(){var e,r;do e=this.next(),r=e.charCodeAt(0);while(r>47&&r<58);e!=t.QueryLexer.EOS&&this.backup()},t.QueryLexer.prototype.more=function(){return this.pos1&&(e.backup(),e.emit(t.QueryLexer.TERM)),e.ignore(),e.more())return t.QueryLexer.lexText},t.QueryLexer.lexEditDistance=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.EDIT_DISTANCE),t.QueryLexer.lexText},t.QueryLexer.lexBoost=function(e){return e.ignore(),e.acceptDigitRun(),e.emit(t.QueryLexer.BOOST),t.QueryLexer.lexText},t.QueryLexer.lexEOS=function(e){e.width()>0&&e.emit(t.QueryLexer.TERM)},t.QueryLexer.termSeparator=t.tokenizer.separator,t.QueryLexer.lexText=function(e){for(;;){var r=e.next();if(r==t.QueryLexer.EOS)return t.QueryLexer.lexEOS;if(r.charCodeAt(0)==92){e.escapeCharacter();continue}if(r==":")return t.QueryLexer.lexField;if(r=="~")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexEditDistance;if(r=="^")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexBoost;if(r=="+"&&e.width()===1||r=="-"&&e.width()===1)return e.emit(t.QueryLexer.PRESENCE),t.QueryLexer.lexText;if(r.match(t.QueryLexer.termSeparator))return t.QueryLexer.lexTerm}},t.QueryParser=function(e,r){this.lexer=new t.QueryLexer(e),this.query=r,this.currentClause={},this.lexemeIdx=0},t.QueryParser.prototype.parse=function(){this.lexer.run(),this.lexemes=this.lexer.lexemes;for(var e=t.QueryParser.parseClause;e;)e=e(this);return this.query},t.QueryParser.prototype.peekLexeme=function(){return this.lexemes[this.lexemeIdx]},t.QueryParser.prototype.consumeLexeme=function(){var e=this.peekLexeme();return this.lexemeIdx+=1,e},t.QueryParser.prototype.nextClause=function(){var e=this.currentClause;this.query.clause(e),this.currentClause={}},t.QueryParser.parseClause=function(e){var r=e.peekLexeme();if(r!=null)switch(r.type){case t.QueryLexer.PRESENCE:return t.QueryParser.parsePresence;case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var n="expected either a field or a term, found "+r.type;throw r.str.length>=1&&(n+=" with value '"+r.str+"'"),new t.QueryParseError(n,r.start,r.end)}},t.QueryParser.parsePresence=function(e){var r=e.consumeLexeme();if(r!=null){switch(r.str){case"-":e.currentClause.presence=t.Query.presence.PROHIBITED;break;case"+":e.currentClause.presence=t.Query.presence.REQUIRED;break;default:var n="unrecognised presence operator'"+r.str+"'";throw new t.QueryParseError(n,r.start,r.end)}var i=e.peekLexeme();if(i==null){var n="expecting term or field, found nothing";throw new t.QueryParseError(n,r.start,r.end)}switch(i.type){case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var n="expecting term or field, found '"+i.type+"'";throw new t.QueryParseError(n,i.start,i.end)}}},t.QueryParser.parseField=function(e){var r=e.consumeLexeme();if(r!=null){if(e.query.allFields.indexOf(r.str)==-1){var n=e.query.allFields.map(function(o){return"'"+o+"'"}).join(", "),i="unrecognised field '"+r.str+"', possible fields: "+n;throw new t.QueryParseError(i,r.start,r.end)}e.currentClause.fields=[r.str];var s=e.peekLexeme();if(s==null){var i="expecting term, found nothing";throw new t.QueryParseError(i,r.start,r.end)}switch(s.type){case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var i="expecting term, found '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseTerm=function(e){var r=e.consumeLexeme();if(r!=null){e.currentClause.term=r.str.toLowerCase(),r.str.indexOf("*")!=-1&&(e.currentClause.usePipeline=!1);var n=e.peekLexeme();if(n==null){e.nextClause();return}switch(n.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+n.type+"'";throw new t.QueryParseError(i,n.start,n.end)}}},t.QueryParser.parseEditDistance=function(e){var r=e.consumeLexeme();if(r!=null){var n=parseInt(r.str,10);if(isNaN(n)){var i="edit distance must be numeric";throw new t.QueryParseError(i,r.start,r.end)}e.currentClause.editDistance=n;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},t.QueryParser.parseBoost=function(e){var r=e.consumeLexeme();if(r!=null){var n=parseInt(r.str,10);if(isNaN(n)){var i="boost must be numeric";throw new t.QueryParseError(i,r.start,r.end)}e.currentClause.boost=n;var s=e.peekLexeme();if(s==null){e.nextClause();return}switch(s.type){case t.QueryLexer.TERM:return e.nextClause(),t.QueryParser.parseTerm;case t.QueryLexer.FIELD:return e.nextClause(),t.QueryParser.parseField;case t.QueryLexer.EDIT_DISTANCE:return t.QueryParser.parseEditDistance;case t.QueryLexer.BOOST:return t.QueryParser.parseBoost;case t.QueryLexer.PRESENCE:return e.nextClause(),t.QueryParser.parsePresence;default:var i="Unexpected lexeme type '"+s.type+"'";throw new t.QueryParseError(i,s.start,s.end)}}},function(e,r){typeof define=="function"&&define.amd?define(r):typeof ce=="object"?he.exports=r():e.lunr=r()}(this,function(){return t})})()});var le=[];function N(t,e){le.push({selector:e,constructor:t})}var X=class{constructor(){this.createComponents(document.body)}createComponents(e){le.forEach(r=>{e.querySelectorAll(r.selector).forEach(n=>{n.dataset.hasInstance||(new r.constructor({el:n}),n.dataset.hasInstance=String(!0))})})}};var Q=class{constructor(e){this.el=e.el}};var Z=class{constructor(){this.listeners={}}addEventListener(e,r){e in this.listeners||(this.listeners[e]=[]),this.listeners[e].push(r)}removeEventListener(e,r){if(!(e in this.listeners))return;let n=this.listeners[e];for(let i=0,s=n.length;i{let r=Date.now();return(...n)=>{r+e-Date.now()<0&&(t(...n),r=Date.now())}};var ee=class extends Z{constructor(){super();this.scrollTop=0;this.lastY=0;this.width=0;this.height=0;this.showToolbar=!0;this.toolbar=document.querySelector(".tsd-page-toolbar"),this.secondaryNav=document.querySelector(".tsd-navigation.secondary"),window.addEventListener("scroll",K(()=>this.onScroll(),10)),window.addEventListener("resize",K(()=>this.onResize(),10)),this.onResize(),this.onScroll()}triggerResize(){let e=new CustomEvent("resize",{detail:{width:this.width,height:this.height}});this.dispatchEvent(e)}onResize(){this.width=window.innerWidth||0,this.height=window.innerHeight||0;let e=new CustomEvent("resize",{detail:{width:this.width,height:this.height}});this.dispatchEvent(e)}onScroll(){this.scrollTop=window.scrollY||0;let e=new CustomEvent("scroll",{detail:{scrollTop:this.scrollTop}});this.dispatchEvent(e),this.hideShowToolbar()}hideShowToolbar(){var r;let e=this.showToolbar;this.showToolbar=this.lastY>=this.scrollTop||this.scrollTop<=0,e!==this.showToolbar&&(this.toolbar.classList.toggle("tsd-page-toolbar--hide"),(r=this.secondaryNav)==null||r.classList.toggle("tsd-navigation--toolbar-hide")),this.lastY=this.scrollTop}},I=ee;I.instance=new ee;var te=class extends Q{constructor(e){super(e);this.anchors=[];this.index=-1;I.instance.addEventListener("resize",()=>this.onResize()),I.instance.addEventListener("scroll",r=>this.onScroll(r)),this.createAnchors()}createAnchors(){let e=window.location.href;e.indexOf("#")!=-1&&(e=e.substr(0,e.indexOf("#"))),this.el.querySelectorAll("a").forEach(r=>{let n=r.href;if(n.indexOf("#")==-1||n.substr(0,e.length)!=e)return;let i=n.substr(n.indexOf("#")+1),s=document.querySelector("a.tsd-anchor[name="+i+"]"),o=r.parentNode;!s||!o||this.anchors.push({link:o,anchor:s,position:0})}),this.onResize()}onResize(){let e;for(let n=0,i=this.anchors.length;nn.position-i.position);let r=new CustomEvent("scroll",{detail:{scrollTop:I.instance.scrollTop}});this.onScroll(r)}onScroll(e){let r=e.detail.scrollTop+5,n=this.anchors,i=n.length-1,s=this.index;for(;s>-1&&n[s].position>r;)s-=1;for(;s-1&&this.anchors[this.index].link.classList.remove("focus"),this.index=s,this.index>-1&&this.anchors[this.index].link.classList.add("focus"))}};var ue=(t,e=100)=>{let r;return(...n)=>{clearTimeout(r),r=setTimeout(()=>t(n),e)}};var fe=Ae(de());function pe(){let t=document.getElementById("tsd-search");if(!t)return;let e=document.getElementById("search-script");t.classList.add("loading"),e&&(e.addEventListener("error",()=>{t.classList.remove("loading"),t.classList.add("failure")}),e.addEventListener("load",()=>{t.classList.remove("loading"),t.classList.add("ready")}),window.searchData&&t.classList.remove("loading"));let r=document.querySelector("#tsd-search input"),n=document.querySelector("#tsd-search .results");if(!r||!n)throw new Error("The input field or the result list wrapper was not found");let i=!1;n.addEventListener("mousedown",()=>i=!0),n.addEventListener("mouseup",()=>{i=!1,t.classList.remove("has-focus")}),r.addEventListener("focus",()=>t.classList.add("has-focus")),r.addEventListener("blur",()=>{i||(i=!1,t.classList.remove("has-focus"))});let s={base:t.dataset.base+"/"};Ve(t,n,r,s)}function Ve(t,e,r,n){r.addEventListener("input",ue(()=>{ze(t,e,r,n)},200));let i=!1;r.addEventListener("keydown",s=>{i=!0,s.key=="Enter"?Ne(e,r):s.key=="Escape"?r.blur():s.key=="ArrowUp"?me(e,-1):s.key==="ArrowDown"?me(e,1):i=!1}),r.addEventListener("keypress",s=>{i&&s.preventDefault()}),document.body.addEventListener("keydown",s=>{s.altKey||s.ctrlKey||s.metaKey||!r.matches(":focus")&&s.key==="/"&&(r.focus(),s.preventDefault())})}function He(t,e){t.index||window.searchData&&(e.classList.remove("loading"),e.classList.add("ready"),t.data=window.searchData,t.index=fe.Index.load(window.searchData.index))}function ze(t,e,r,n){if(He(n,t),!n.index||!n.data)return;e.textContent="";let i=r.value.trim(),s=n.index.search(`*${i}*`);for(let o=0,a=Math.min(10,s.length);o${ve(u.parent,i)}.${l}`);let h=document.createElement("li");h.classList.value=u.classes;let p=document.createElement("a");p.href=n.base+u.url,p.classList.add("tsd-kind-icon"),p.innerHTML=l,h.append(p),e.appendChild(h)}}function me(t,e){let r=t.querySelector(".current");if(!r)r=t.querySelector(e==1?"li:first-child":"li:last-child"),r&&r.classList.add("current");else{let n=r;if(e===1)do n=n.nextElementSibling;while(n instanceof HTMLElement&&n.offsetParent==null);else do n=n.previousElementSibling;while(n instanceof HTMLElement&&n.offsetParent==null);n&&(r.classList.remove("current"),n.classList.add("current"))}}function Ne(t,e){let r=t.querySelector(".current");if(r||(r=t.querySelector("li:first-child")),r){let n=r.querySelector("a");n&&(window.location.href=n.href),e.blur()}}function ve(t,e){if(e==="")return t;let r=t.toLocaleLowerCase(),n=e.toLocaleLowerCase(),i=[],s=0,o=r.indexOf(n);for(;o!=-1;)i.push(re(t.substring(s,o)),`${re(t.substring(o,o+n.length))}`),s=o+n.length,o=r.indexOf(n,s);return i.push(re(t.substring(s))),i.join("")}var je={"&":"&","<":"<",">":">","'":"'",'"':"""};function re(t){return t.replace(/[&<>"'"]/g,e=>je[e])}var ge=class{constructor(e,r){this.signature=e,this.description=r}addClass(e){return this.signature.classList.add(e),this.description.classList.add(e),this}removeClass(e){return this.signature.classList.remove(e),this.description.classList.remove(e),this}},ne=class extends Q{constructor(e){super(e);this.groups=[];this.index=-1;this.createGroups(),this.container&&(this.el.classList.add("active"),Array.from(this.el.children).forEach(r=>{r.addEventListener("touchstart",n=>this.onClick(n)),r.addEventListener("click",n=>this.onClick(n))}),this.container.classList.add("active"),this.setIndex(0))}setIndex(e){if(e<0&&(e=0),e>this.groups.length-1&&(e=this.groups.length-1),this.index==e)return;let r=this.groups[e];if(this.index>-1){let n=this.groups[this.index];n.removeClass("current").addClass("fade-out"),r.addClass("current"),r.addClass("fade-in"),I.instance.triggerResize(),setTimeout(()=>{n.removeClass("fade-out"),r.removeClass("fade-in")},300)}else r.addClass("current"),I.instance.triggerResize();this.index=e}createGroups(){let e=this.el.children;if(e.length<2)return;this.container=this.el.nextElementSibling;let r=this.container.children;this.groups=[];for(let n=0;n{r.signature===e.currentTarget&&this.setIndex(n)})}};var C="mousedown",ye="mousemove",_="mouseup",G={x:0,y:0},xe=!1,ie=!1,Be=!1,A=!1,Le=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);document.documentElement.classList.add(Le?"is-mobile":"not-mobile");Le&&"ontouchstart"in document.documentElement&&(Be=!0,C="touchstart",ye="touchmove",_="touchend");document.addEventListener(C,t=>{ie=!0,A=!1;let e=C=="touchstart"?t.targetTouches[0]:t;G.y=e.pageY||0,G.x=e.pageX||0});document.addEventListener(ye,t=>{if(!!ie&&!A){let e=C=="touchstart"?t.targetTouches[0]:t,r=G.x-(e.pageX||0),n=G.y-(e.pageY||0);A=Math.sqrt(r*r+n*n)>10}});document.addEventListener(_,()=>{ie=!1});document.addEventListener("click",t=>{xe&&(t.preventDefault(),t.stopImmediatePropagation(),xe=!1)});var se=class extends Q{constructor(e){super(e);this.className=this.el.dataset.toggle||"",this.el.addEventListener(_,r=>this.onPointerUp(r)),this.el.addEventListener("click",r=>r.preventDefault()),document.addEventListener(C,r=>this.onDocumentPointerDown(r)),document.addEventListener(_,r=>this.onDocumentPointerUp(r))}setActive(e){if(this.active==e)return;this.active=e,document.documentElement.classList.toggle("has-"+this.className,e),this.el.classList.toggle("active",e);let r=(this.active?"to-has-":"from-has-")+this.className;document.documentElement.classList.add(r),setTimeout(()=>document.documentElement.classList.remove(r),500)}onPointerUp(e){A||(this.setActive(!0),e.preventDefault())}onDocumentPointerDown(e){if(this.active){if(e.target.closest(".col-menu, .tsd-filter-group"))return;this.setActive(!1)}}onDocumentPointerUp(e){if(!A&&this.active&&e.target.closest(".col-menu")){let r=e.target.closest("a");if(r){let n=window.location.href;n.indexOf("#")!=-1&&(n=n.substr(0,n.indexOf("#"))),r.href.substr(0,n.length)==n&&setTimeout(()=>this.setActive(!1),250)}}}};var oe=class{constructor(e,r){this.key=e,this.value=r,this.defaultValue=r,this.initialize(),window.localStorage[this.key]&&this.setValue(this.fromLocalStorage(window.localStorage[this.key]))}initialize(){}setValue(e){if(this.value==e)return;let r=this.value;this.value=e,window.localStorage[this.key]=this.toLocalStorage(e),this.handleValueChange(r,e)}},ae=class extends oe{initialize(){let e=document.querySelector("#tsd-filter-"+this.key);!e||(this.checkbox=e,this.checkbox.addEventListener("change",()=>{this.setValue(this.checkbox.checked)}))}handleValueChange(e,r){!this.checkbox||(this.checkbox.checked=this.value,document.documentElement.classList.toggle("toggle-"+this.key,this.value!=this.defaultValue))}fromLocalStorage(e){return e=="true"}toLocalStorage(e){return e?"true":"false"}},Ee=class extends oe{initialize(){document.documentElement.classList.add("toggle-"+this.key+this.value);let e=document.querySelector("#tsd-filter-"+this.key);if(!e)return;this.select=e;let r=()=>{this.select.classList.add("active")},n=()=>{this.select.classList.remove("active")};this.select.addEventListener(C,r),this.select.addEventListener("mouseover",r),this.select.addEventListener("mouseleave",n),this.select.querySelectorAll("li").forEach(i=>{i.addEventListener(_,s=>{e.classList.remove("active"),this.setValue(s.target.dataset.value||"")})}),document.addEventListener(C,i=>{this.select.contains(i.target)||this.select.classList.remove("active")})}handleValueChange(e,r){this.select.querySelectorAll("li.selected").forEach(s=>{s.classList.remove("selected")});let n=this.select.querySelector('li[data-value="'+r+'"]'),i=this.select.querySelector(".tsd-select-label");n&&i&&(n.classList.add("selected"),i.textContent=n.textContent),document.documentElement.classList.remove("toggle-"+e),document.documentElement.classList.add("toggle-"+r)}fromLocalStorage(e){return e}toLocalStorage(e){return e}},Y=class extends Q{constructor(e){super(e);this.optionVisibility=new Ee("visibility","private"),this.optionInherited=new ae("inherited",!0),this.optionExternals=new ae("externals",!0)}static isSupported(){try{return typeof window.localStorage!="undefined"}catch{return!1}}};function be(t){let e=localStorage.getItem("tsd-theme")||"os";t.value=e,we(e),t.addEventListener("change",()=>{localStorage.setItem("tsd-theme",t.value),we(t.value)})}function we(t){switch(t){case"os":document.body.classList.remove("light","dark");break;case"light":document.body.classList.remove("dark"),document.body.classList.add("light");break;case"dark":document.body.classList.remove("light"),document.body.classList.add("dark");break}}pe();N(te,".menu-highlight");N(ne,".tsd-signatures");N(se,"a[data-toggle]");Y.isSupported()?N(Y,"#tsd-filter"):document.documentElement.classList.add("no-filter");var Te=document.getElementById("theme");Te&&be(Te);var qe=new X;Object.defineProperty(window,"app",{value:qe});})(); +/*! + * lunr.Builder + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.Index + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.Pipeline + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.Set + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.TokenSet + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.Vector + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.stemmer + * Copyright (C) 2020 Oliver Nightingale + * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt + */ +/*! + * lunr.stopWordFilter + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.tokenizer + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.trimmer + * Copyright (C) 2020 Oliver Nightingale + */ +/*! + * lunr.utils + * Copyright (C) 2020 Oliver Nightingale + */ +/** + * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9 + * Copyright (C) 2020 Oliver Nightingale + * @license MIT + */ diff --git a/docs/assets/pages.css b/docs/assets/pages.css new file mode 100755 index 00000000..3c339a1d --- /dev/null +++ b/docs/assets/pages.css @@ -0,0 +1,30 @@ +.tsd-typography li > ul { + margin: 0; +} +.tsd-navigation li.pages-entry { + border-left: 2px solid var(--color-text-aside); +} +.tsd-navigation li.pages-entry a { + padding-left: 0!important; +} +.tsd-navigation li.pages-entry.pages-entry-page > a { + color: var(--color-link); +} +li.pages-entry-depth-0 { + padding-left: 10px; +} +li.pages-entry-depth-1 { + padding-left: 20px; +} +li.pages-entry-depth-2 { + padding-left: 30px; +} +li.pages-entry-depth-3 { + padding-left: 40px; +} +li.pages-entry-depth-4 { + padding-left: 50px; +} +.tsd-page-toolbar .table-cell .pages-entry { + white-space: normal; +} \ No newline at end of file diff --git a/docs/assets/search.js b/docs/assets/search.js new file mode 100644 index 00000000..cc6eb311 --- /dev/null +++ b/docs/assets/search.js @@ -0,0 +1 @@ +window.searchData = JSON.parse("{\"kinds\":{\"4\":\"Namespace\",\"64\":\"Function\",\"128\":\"Class\",\"256\":\"Interface\",\"512\":\"Constructor\",\"1024\":\"Property\",\"2048\":\"Method\",\"65536\":\"Type literal\",\"4194304\":\"Type alias\"},\"rows\":[{\"id\":0,\"kind\":64,\"name\":\"InjectAbility\",\"url\":\"modules.html#InjectAbility\",\"classes\":\"tsd-kind-function\",\"isPage\":false},{\"id\":1,\"kind\":64,\"name\":\"Policy\",\"url\":\"modules.html#Policy\",\"classes\":\"tsd-kind-function tsd-has-type-parameter\",\"isPage\":false},{\"id\":2,\"kind\":4,\"name\":\"Policy\",\"url\":\"modules/Policy.html\",\"classes\":\"tsd-kind-namespace\",\"isPage\":false},{\"id\":3,\"kind\":64,\"name\":\"usingGuard\",\"url\":\"modules/Policy.html#usingGuard\",\"classes\":\"tsd-kind-function tsd-parent-kind-namespace\",\"isPage\":false,\"parent\":\"Policy\"},{\"id\":4,\"kind\":64,\"name\":\"PoliciesMask\",\"url\":\"modules.html#PoliciesMask\",\"classes\":\"tsd-kind-function tsd-has-type-parameter\",\"isPage\":false},{\"id\":5,\"kind\":4,\"name\":\"PoliciesMask\",\"url\":\"modules/PoliciesMask.html\",\"classes\":\"tsd-kind-namespace\",\"isPage\":false},{\"id\":6,\"kind\":64,\"name\":\"usingGuard\",\"url\":\"modules/PoliciesMask.html#usingGuard\",\"classes\":\"tsd-kind-function tsd-parent-kind-namespace\",\"isPage\":false,\"parent\":\"PoliciesMask\"},{\"id\":7,\"kind\":64,\"name\":\"bindPolicyDecorators\",\"url\":\"modules.html#bindPolicyDecorators\",\"classes\":\"tsd-kind-function tsd-has-type-parameter\",\"isPage\":false},{\"id\":8,\"kind\":4194304,\"name\":\"BoundPolicyDecorators\",\"url\":\"modules.html#BoundPolicyDecorators\",\"classes\":\"tsd-kind-type-alias tsd-has-type-parameter\",\"isPage\":false},{\"id\":9,\"kind\":65536,\"name\":\"__type\",\"url\":\"modules.html#BoundPolicyDecorators.__type\",\"classes\":\"tsd-kind-type-literal tsd-parent-kind-type-alias\",\"isPage\":false,\"parent\":\"BoundPolicyDecorators\"},{\"id\":10,\"kind\":1024,\"name\":\"Policy\",\"url\":\"modules.html#BoundPolicyDecorators.__type.Policy\",\"classes\":\"tsd-kind-property tsd-parent-kind-type-literal\",\"isPage\":false,\"parent\":\"BoundPolicyDecorators.__type\"},{\"id\":11,\"kind\":1024,\"name\":\"PoliciesMask\",\"url\":\"modules.html#BoundPolicyDecorators.__type.PoliciesMask\",\"classes\":\"tsd-kind-property tsd-parent-kind-type-literal\",\"isPage\":false,\"parent\":\"BoundPolicyDecorators.__type\"},{\"id\":12,\"kind\":128,\"name\":\"CaslModule\",\"url\":\"classes/CaslModule.html\",\"classes\":\"tsd-kind-class\",\"isPage\":false},{\"id\":13,\"kind\":2048,\"name\":\"withConfig\",\"url\":\"classes/CaslModule.html#withConfig\",\"classes\":\"tsd-kind-method tsd-parent-kind-class tsd-is-static\",\"isPage\":false,\"parent\":\"CaslModule\"},{\"id\":14,\"kind\":512,\"name\":\"constructor\",\"url\":\"classes/CaslModule.html#constructor\",\"classes\":\"tsd-kind-constructor tsd-parent-kind-class\",\"isPage\":false,\"parent\":\"CaslModule\"},{\"id\":15,\"kind\":256,\"name\":\"ICaslRootConfig\",\"url\":\"interfaces/ICaslRootConfig.html\",\"classes\":\"tsd-kind-interface tsd-has-type-parameter\",\"isPage\":false},{\"id\":16,\"kind\":1024,\"name\":\"abilityFactory\",\"url\":\"interfaces/ICaslRootConfig.html#abilityFactory\",\"classes\":\"tsd-kind-property tsd-parent-kind-interface\",\"isPage\":false,\"parent\":\"ICaslRootConfig\"},{\"id\":17,\"kind\":4194304,\"name\":\"PolicyDescriptor\",\"url\":\"modules.html#PolicyDescriptor\",\"classes\":\"tsd-kind-type-alias tsd-has-type-parameter\",\"isPage\":false},{\"id\":18,\"kind\":4194304,\"name\":\"PolicyDescriptorMask\",\"url\":\"modules.html#PolicyDescriptorMask\",\"classes\":\"tsd-kind-type-alias tsd-has-type-parameter\",\"isPage\":false},{\"id\":19,\"kind\":256,\"name\":\"IPolicy\",\"url\":\"interfaces/IPolicy.html\",\"classes\":\"tsd-kind-interface tsd-has-type-parameter\",\"isPage\":false},{\"id\":20,\"kind\":2048,\"name\":\"handle\",\"url\":\"interfaces/IPolicy.html#handle\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface\",\"isPage\":false,\"parent\":\"IPolicy\"},{\"id\":21,\"kind\":4194304,\"name\":\"SimplePolicy\",\"url\":\"modules.html#SimplePolicy\",\"classes\":\"tsd-kind-type-alias tsd-has-type-parameter\",\"isPage\":false},{\"id\":22,\"kind\":4194304,\"name\":\"GuardsList\",\"url\":\"modules.html#GuardsList\",\"classes\":\"tsd-kind-type-alias\",\"isPage\":false},{\"id\":23,\"kind\":256,\"name\":\"CaslAbilityFactory\",\"url\":\"interfaces/CaslAbilityFactory.html\",\"classes\":\"tsd-kind-interface tsd-has-type-parameter\",\"isPage\":false},{\"id\":24,\"kind\":2048,\"name\":\"createFromRequest\",\"url\":\"interfaces/CaslAbilityFactory.html#createFromRequest\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface\",\"isPage\":false,\"parent\":\"CaslAbilityFactory\"},{\"id\":25,\"kind\":4194304,\"name\":\"MaybeAsyncValue\",\"url\":\"modules.html#MaybeAsyncValue\",\"classes\":\"tsd-kind-type-alias tsd-has-type-parameter\",\"isPage\":false},{\"id\":26,\"kind\":2048,\"name\":\"Page: Getting started\",\"url\":\"pages/guide/getting-started.html\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface tsd-is-inherited tsd-is-external pages-entry\",\"isPage\":true},{\"id\":27,\"kind\":2048,\"name\":\"Page: Use with guards\",\"url\":\"pages/guide/use-with-guards.html\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface tsd-is-inherited tsd-is-external pages-entry\",\"isPage\":true},{\"id\":28,\"kind\":2048,\"name\":\"Page: Better type constraints\",\"url\":\"pages/guide/better-type-constraints.html\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface tsd-is-inherited tsd-is-external pages-entry\",\"isPage\":true},{\"id\":29,\"kind\":2048,\"name\":\"Page: Changelog\",\"url\":\"CHANGELOG.html\",\"classes\":\"tsd-kind-method tsd-parent-kind-interface tsd-is-inherited tsd-is-external pages-entry\",\"isPage\":true}],\"index\":{\"version\":\"2.3.9\",\"fields\":[\"name\",\"parent\"],\"fieldVectors\":[[\"name/0\",[0,33.442]],[\"parent/0\",[]],[\"name/1\",[1,21.311]],[\"parent/1\",[]],[\"name/2\",[1,21.311]],[\"parent/2\",[]],[\"name/3\",[2,27.802]],[\"parent/3\",[1,1.061]],[\"name/4\",[3,21.311]],[\"parent/4\",[]],[\"name/5\",[3,21.311]],[\"parent/5\",[]],[\"name/6\",[2,27.802]],[\"parent/6\",[3,1.061]],[\"name/7\",[4,33.442]],[\"parent/7\",[]],[\"name/8\",[5,27.802]],[\"parent/8\",[]],[\"name/9\",[6,33.442]],[\"parent/9\",[5,1.385]],[\"name/10\",[1,21.311]],[\"parent/10\",[7,1.385]],[\"name/11\",[3,21.311]],[\"parent/11\",[7,1.385]],[\"name/12\",[8,24.086]],[\"parent/12\",[]],[\"name/13\",[9,33.442]],[\"parent/13\",[8,1.2]],[\"name/14\",[10,33.442]],[\"parent/14\",[8,1.2]],[\"name/15\",[11,27.802]],[\"parent/15\",[]],[\"name/16\",[12,33.442]],[\"parent/16\",[11,1.385]],[\"name/17\",[13,33.442]],[\"parent/17\",[]],[\"name/18\",[14,33.442]],[\"parent/18\",[]],[\"name/19\",[15,27.802]],[\"parent/19\",[]],[\"name/20\",[16,33.442]],[\"parent/20\",[15,1.385]],[\"name/21\",[17,33.442]],[\"parent/21\",[]],[\"name/22\",[18,33.442]],[\"parent/22\",[]],[\"name/23\",[19,27.802]],[\"parent/23\",[]],[\"name/24\",[20,33.442]],[\"parent/24\",[19,1.385]],[\"name/25\",[21,33.442]],[\"parent/25\",[]],[\"name/26\",[22,125.73,23,197.302,24,197.302]],[\"parent/26\",[]],[\"name/27\",[22,104.339,25,163.735,26,163.735,27,163.735]],[\"parent/27\",[]],[\"name/28\",[22,104.339,28,163.735,29,163.735,30,163.735]],[\"parent/28\",[]],[\"name/29\",[22,158.153,31,248.183]],[\"parent/29\",[]]],\"invertedIndex\":[[\"__type\",{\"_index\":6,\"name\":{\"9\":{}},\"parent\":{}}],[\"abilityfactory\",{\"_index\":12,\"name\":{\"16\":{}},\"parent\":{}}],[\"better\",{\"_index\":28,\"name\":{\"28\":{}},\"parent\":{}}],[\"bindpolicydecorators\",{\"_index\":4,\"name\":{\"7\":{}},\"parent\":{}}],[\"boundpolicydecorators\",{\"_index\":5,\"name\":{\"8\":{}},\"parent\":{\"9\":{}}}],[\"boundpolicydecorators.__type\",{\"_index\":7,\"name\":{},\"parent\":{\"10\":{},\"11\":{}}}],[\"caslabilityfactory\",{\"_index\":19,\"name\":{\"23\":{}},\"parent\":{\"24\":{}}}],[\"caslmodule\",{\"_index\":8,\"name\":{\"12\":{}},\"parent\":{\"13\":{},\"14\":{}}}],[\"changelog\",{\"_index\":31,\"name\":{\"29\":{}},\"parent\":{}}],[\"constraints\",{\"_index\":30,\"name\":{\"28\":{}},\"parent\":{}}],[\"constructor\",{\"_index\":10,\"name\":{\"14\":{}},\"parent\":{}}],[\"createfromrequest\",{\"_index\":20,\"name\":{\"24\":{}},\"parent\":{}}],[\"getting\",{\"_index\":23,\"name\":{\"26\":{}},\"parent\":{}}],[\"guards\",{\"_index\":27,\"name\":{\"27\":{}},\"parent\":{}}],[\"guardslist\",{\"_index\":18,\"name\":{\"22\":{}},\"parent\":{}}],[\"handle\",{\"_index\":16,\"name\":{\"20\":{}},\"parent\":{}}],[\"icaslrootconfig\",{\"_index\":11,\"name\":{\"15\":{}},\"parent\":{\"16\":{}}}],[\"injectability\",{\"_index\":0,\"name\":{\"0\":{}},\"parent\":{}}],[\"ipolicy\",{\"_index\":15,\"name\":{\"19\":{}},\"parent\":{\"20\":{}}}],[\"maybeasyncvalue\",{\"_index\":21,\"name\":{\"25\":{}},\"parent\":{}}],[\"page\",{\"_index\":22,\"name\":{\"26\":{},\"27\":{},\"28\":{},\"29\":{}},\"parent\":{}}],[\"policiesmask\",{\"_index\":3,\"name\":{\"4\":{},\"5\":{},\"11\":{}},\"parent\":{\"6\":{}}}],[\"policy\",{\"_index\":1,\"name\":{\"1\":{},\"2\":{},\"10\":{}},\"parent\":{\"3\":{}}}],[\"policydescriptor\",{\"_index\":13,\"name\":{\"17\":{}},\"parent\":{}}],[\"policydescriptormask\",{\"_index\":14,\"name\":{\"18\":{}},\"parent\":{}}],[\"simplepolicy\",{\"_index\":17,\"name\":{\"21\":{}},\"parent\":{}}],[\"started\",{\"_index\":24,\"name\":{\"26\":{}},\"parent\":{}}],[\"type\",{\"_index\":29,\"name\":{\"28\":{}},\"parent\":{}}],[\"use\",{\"_index\":25,\"name\":{\"27\":{}},\"parent\":{}}],[\"usingguard\",{\"_index\":2,\"name\":{\"3\":{},\"6\":{}},\"parent\":{}}],[\"with\",{\"_index\":26,\"name\":{\"27\":{}},\"parent\":{}}],[\"withconfig\",{\"_index\":9,\"name\":{\"13\":{}},\"parent\":{}}]],\"pipeline\":[]}}"); \ No newline at end of file diff --git a/docs/assets/style.css b/docs/assets/style.css new file mode 100644 index 00000000..a16ed029 --- /dev/null +++ b/docs/assets/style.css @@ -0,0 +1,1413 @@ +@import url("./icons.css"); + +:root { + /* Light */ + --light-color-background: #fcfcfc; + --light-color-secondary-background: #fff; + --light-color-text: #222; + --light-color-text-aside: #707070; + --light-color-link: #4da6ff; + --light-color-menu-divider: #eee; + --light-color-menu-divider-focus: #000; + --light-color-menu-label: #707070; + --light-color-panel: var(--light-color-secondary-background); + --light-color-panel-divider: #eee; + --light-color-comment-tag: #707070; + --light-color-comment-tag-text: #fff; + --light-color-ts: #9600ff; + --light-color-ts-interface: #647f1b; + --light-color-ts-enum: #937210; + --light-color-ts-class: #0672de; + --light-color-ts-private: #707070; + --light-color-toolbar: #fff; + --light-color-toolbar-text: #333; + --light-icon-filter: invert(0); + --light-external-icon: url("data:image/svg+xml;utf8,"); + + /* Dark */ + --dark-color-background: #36393f; + --dark-color-secondary-background: #2f3136; + --dark-color-text: #ffffff; + --dark-color-text-aside: #e6e4e4; + --dark-color-link: #00aff4; + --dark-color-menu-divider: #eee; + --dark-color-menu-divider-focus: #000; + --dark-color-menu-label: #707070; + --dark-color-panel: var(--dark-color-secondary-background); + --dark-color-panel-divider: #818181; + --dark-color-comment-tag: #dcddde; + --dark-color-comment-tag-text: #2f3136; + --dark-color-ts: #c97dff; + --dark-color-ts-interface: #9cbe3c; + --dark-color-ts-enum: #d6ab29; + --dark-color-ts-class: #3695f3; + --dark-color-ts-private: #e2e2e2; + --dark-color-toolbar: #34373c; + --dark-color-toolbar-text: #ffffff; + --dark-icon-filter: invert(1); + --dark-external-icon: url("data:image/svg+xml;utf8,"); +} + +@media (prefers-color-scheme: light) { + :root { + --color-background: var(--light-color-background); + --color-secondary-background: var(--light-color-secondary-background); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + --color-link: var(--light-color-link); + --color-menu-divider: var(--light-color-menu-divider); + --color-menu-divider-focus: var(--light-color-menu-divider-focus); + --color-menu-label: var(--light-color-menu-label); + --color-panel: var(--light-color-panel); + --color-panel-divider: var(--light-color-panel-divider); + --color-comment-tag: var(--light-color-comment-tag); + --color-comment-tag-text: var(--light-color-comment-tag-text); + --color-ts: var(--light-color-ts); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-class: var(--light-color-ts-class); + --color-ts-private: var(--light-color-ts-private); + --color-toolbar: var(--light-color-toolbar); + --color-toolbar-text: var(--light-color-toolbar-text); + --icon-filter: var(--light-icon-filter); + --external-icon: var(--light-external-icon); + } +} + +@media (prefers-color-scheme: dark) { + :root { + --color-background: var(--dark-color-background); + --color-secondary-background: var(--dark-color-secondary-background); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + --color-link: var(--dark-color-link); + --color-menu-divider: var(--dark-color-menu-divider); + --color-menu-divider-focus: var(--dark-color-menu-divider-focus); + --color-menu-label: var(--dark-color-menu-label); + --color-panel: var(--dark-color-panel); + --color-panel-divider: var(--dark-color-panel-divider); + --color-comment-tag: var(--dark-color-comment-tag); + --color-comment-tag-text: var(--dark-color-comment-tag-text); + --color-ts: var(--dark-color-ts); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-private: var(--dark-color-ts-private); + --color-toolbar: var(--dark-color-toolbar); + --color-toolbar-text: var(--dark-color-toolbar-text); + --icon-filter: var(--dark-icon-filter); + --external-icon: var(--dark-external-icon); + } +} + +body { + margin: 0; +} + +body.light { + --color-background: var(--light-color-background); + --color-secondary-background: var(--light-color-secondary-background); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + --color-link: var(--light-color-link); + --color-menu-divider: var(--light-color-menu-divider); + --color-menu-divider-focus: var(--light-color-menu-divider-focus); + --color-menu-label: var(--light-color-menu-label); + --color-panel: var(--light-color-panel); + --color-panel-divider: var(--light-color-panel-divider); + --color-comment-tag: var(--light-color-comment-tag); + --color-comment-tag-text: var(--light-color-comment-tag-text); + --color-ts: var(--light-color-ts); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-class: var(--light-color-ts-class); + --color-ts-private: var(--light-color-ts-private); + --color-toolbar: var(--light-color-toolbar); + --color-toolbar-text: var(--light-color-toolbar-text); + --icon-filter: var(--light-icon-filter); + --external-icon: var(--light-external-icon); +} + +body.dark { + --color-background: var(--dark-color-background); + --color-secondary-background: var(--dark-color-secondary-background); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + --color-link: var(--dark-color-link); + --color-menu-divider: var(--dark-color-menu-divider); + --color-menu-divider-focus: var(--dark-color-menu-divider-focus); + --color-menu-label: var(--dark-color-menu-label); + --color-panel: var(--dark-color-panel); + --color-panel-divider: var(--dark-color-panel-divider); + --color-comment-tag: var(--dark-color-comment-tag); + --color-comment-tag-text: var(--dark-color-comment-tag-text); + --color-ts: var(--dark-color-ts); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-private: var(--dark-color-ts-private); + --color-toolbar: var(--dark-color-toolbar); + --color-toolbar-text: var(--dark-color-toolbar-text); + --icon-filter: var(--dark-icon-filter); + --external-icon: var(--dark-external-icon); +} + +h1, +h2, +h3, +h4, +h5, +h6 { + line-height: 1.2; +} + +h1 { + font-size: 2em; + margin: 0.67em 0; +} + +h2 { + font-size: 1.5em; + margin: 0.83em 0; +} + +h3 { + font-size: 1.17em; + margin: 1em 0; +} + +h4, +.tsd-index-panel h3 { + font-size: 1em; + margin: 1.33em 0; +} + +h5 { + font-size: 0.83em; + margin: 1.67em 0; +} + +h6 { + font-size: 0.67em; + margin: 2.33em 0; +} + +pre { + white-space: pre; + white-space: pre-wrap; + word-wrap: break-word; +} + +dl, +menu, +ol, +ul { + margin: 1em 0; +} + +dd { + margin: 0 0 0 40px; +} + +.container { + max-width: 1200px; + margin: 0 auto; + padding: 0 40px; +} +@media (max-width: 640px) { + .container { + padding: 0 20px; + } +} + +.container-main { + padding-bottom: 200px; +} + +.row { + display: flex; + position: relative; + margin: 0 -10px; +} +.row:after { + visibility: hidden; + display: block; + content: ""; + clear: both; + height: 0; +} + +.col-4, +.col-8 { + box-sizing: border-box; + float: left; + padding: 0 10px; +} + +.col-4 { + width: 33.3333333333%; +} +.col-8 { + width: 66.6666666667%; +} + +ul.tsd-descriptions > li > :first-child, +.tsd-panel > :first-child, +.col-8 > :first-child, +.col-4 > :first-child, +ul.tsd-descriptions > li > :first-child > :first-child, +.tsd-panel > :first-child > :first-child, +.col-8 > :first-child > :first-child, +.col-4 > :first-child > :first-child, +ul.tsd-descriptions > li > :first-child > :first-child > :first-child, +.tsd-panel > :first-child > :first-child > :first-child, +.col-8 > :first-child > :first-child > :first-child, +.col-4 > :first-child > :first-child > :first-child { + margin-top: 0; +} +ul.tsd-descriptions > li > :last-child, +.tsd-panel > :last-child, +.col-8 > :last-child, +.col-4 > :last-child, +ul.tsd-descriptions > li > :last-child > :last-child, +.tsd-panel > :last-child > :last-child, +.col-8 > :last-child > :last-child, +.col-4 > :last-child > :last-child, +ul.tsd-descriptions > li > :last-child > :last-child > :last-child, +.tsd-panel > :last-child > :last-child > :last-child, +.col-8 > :last-child > :last-child > :last-child, +.col-4 > :last-child > :last-child > :last-child { + margin-bottom: 0; +} + +@keyframes fade-in { + from { + opacity: 0; + } + to { + opacity: 1; + } +} +@keyframes fade-out { + from { + opacity: 1; + visibility: visible; + } + to { + opacity: 0; + } +} +@keyframes fade-in-delayed { + 0% { + opacity: 0; + } + 33% { + opacity: 0; + } + 100% { + opacity: 1; + } +} +@keyframes fade-out-delayed { + 0% { + opacity: 1; + visibility: visible; + } + 66% { + opacity: 0; + } + 100% { + opacity: 0; + } +} +@keyframes shift-to-left { + from { + transform: translate(0, 0); + } + to { + transform: translate(-25%, 0); + } +} +@keyframes unshift-to-left { + from { + transform: translate(-25%, 0); + } + to { + transform: translate(0, 0); + } +} +@keyframes pop-in-from-right { + from { + transform: translate(100%, 0); + } + to { + transform: translate(0, 0); + } +} +@keyframes pop-out-to-right { + from { + transform: translate(0, 0); + visibility: visible; + } + to { + transform: translate(100%, 0); + } +} +body { + background: var(--color-background); + font-family: "Segoe UI", sans-serif; + font-size: 16px; + color: var(--color-text); +} + +a { + color: var(--color-link); + text-decoration: none; +} +a:hover { + text-decoration: underline; +} +a.external[target="_blank"] { + background-image: var(--external-icon); + background-position: top 3px right; + background-repeat: no-repeat; + padding-right: 13px; +} + +code, +pre { + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + padding: 0.2em; + margin: 0; + font-size: 14px; +} + +pre { + padding: 10px; +} +pre code { + padding: 0; + font-size: 100%; +} + +blockquote { + margin: 1em 0; + padding-left: 1em; + border-left: 4px solid gray; +} + +.tsd-typography { + line-height: 1.333em; +} +.tsd-typography ul { + list-style: square; + padding: 0 0 0 20px; + margin: 0; +} +.tsd-typography h4, +.tsd-typography .tsd-index-panel h3, +.tsd-index-panel .tsd-typography h3, +.tsd-typography h5, +.tsd-typography h6 { + font-size: 1em; + margin: 0; +} +.tsd-typography h5, +.tsd-typography h6 { + font-weight: normal; +} +.tsd-typography p, +.tsd-typography ul, +.tsd-typography ol { + margin: 1em 0; +} + +@media (min-width: 901px) and (max-width: 1024px) { + html .col-content { + width: 72%; + } + html .col-menu { + width: 28%; + } + html .tsd-navigation { + padding-left: 10px; + } +} +@media (max-width: 900px) { + html .col-content { + float: none; + width: 100%; + } + html .col-menu { + position: fixed !important; + overflow: auto; + -webkit-overflow-scrolling: touch; + z-index: 1024; + top: 0 !important; + bottom: 0 !important; + left: auto !important; + right: 0 !important; + width: 100%; + padding: 20px 20px 0 0; + max-width: 450px; + visibility: hidden; + background-color: var(--color-panel); + transform: translate(100%, 0); + } + html .col-menu > *:last-child { + padding-bottom: 20px; + } + html .overlay { + content: ""; + display: block; + position: fixed; + z-index: 1023; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: rgba(0, 0, 0, 0.75); + visibility: hidden; + } + + .to-has-menu .overlay { + animation: fade-in 0.4s; + } + + .to-has-menu :is(header, footer, .col-content) { + animation: shift-to-left 0.4s; + } + + .to-has-menu .col-menu { + animation: pop-in-from-right 0.4s; + } + + .from-has-menu .overlay { + animation: fade-out 0.4s; + } + + .from-has-menu :is(header, footer, .col-content) { + animation: unshift-to-left 0.4s; + } + + .from-has-menu .col-menu { + animation: pop-out-to-right 0.4s; + } + + .has-menu body { + overflow: hidden; + } + .has-menu .overlay { + visibility: visible; + } + .has-menu :is(header, footer, .col-content) { + transform: translate(-25%, 0); + } + .has-menu .col-menu { + visibility: visible; + transform: translate(0, 0); + display: grid; + grid-template-rows: auto 1fr; + max-height: 100vh; + } + .has-menu .tsd-navigation { + max-height: 100%; + } +} + +.tsd-page-title { + padding: 70px 0 20px 0; + margin: 0 0 40px 0; + background: var(--color-panel); + box-shadow: 0 0 5px rgba(0, 0, 0, 0.35); +} +.tsd-page-title h1 { + margin: 0; +} + +.tsd-breadcrumb { + margin: 0; + padding: 0; + color: var(--color-text-aside); +} +.tsd-breadcrumb a { + color: var(--color-text-aside); + text-decoration: none; +} +.tsd-breadcrumb a:hover { + text-decoration: underline; +} +.tsd-breadcrumb li { + display: inline; +} +.tsd-breadcrumb li:after { + content: " / "; +} + +dl.tsd-comment-tags { + overflow: hidden; +} +dl.tsd-comment-tags dt { + float: left; + padding: 1px 5px; + margin: 0 10px 0 0; + border-radius: 4px; + border: 1px solid var(--color-comment-tag); + color: var(--color-comment-tag); + font-size: 0.8em; + font-weight: normal; +} +dl.tsd-comment-tags dd { + margin: 0 0 10px 0; +} +dl.tsd-comment-tags dd:before, +dl.tsd-comment-tags dd:after { + display: table; + content: " "; +} +dl.tsd-comment-tags dd pre, +dl.tsd-comment-tags dd:after { + clear: both; +} +dl.tsd-comment-tags p { + margin: 0; +} + +.tsd-panel.tsd-comment .lead { + font-size: 1.1em; + line-height: 1.333em; + margin-bottom: 2em; +} +.tsd-panel.tsd-comment .lead:last-child { + margin-bottom: 0; +} + +.toggle-protected .tsd-is-private { + display: none; +} + +.toggle-public .tsd-is-private, +.toggle-public .tsd-is-protected, +.toggle-public .tsd-is-private-protected { + display: none; +} + +.toggle-inherited .tsd-is-inherited { + display: none; +} + +.toggle-externals .tsd-is-external { + display: none; +} + +#tsd-filter { + position: relative; + display: inline-block; + height: 40px; + vertical-align: bottom; +} +.no-filter #tsd-filter { + display: none; +} +#tsd-filter .tsd-filter-group { + display: inline-block; + height: 40px; + vertical-align: bottom; + white-space: nowrap; +} +#tsd-filter input { + display: none; +} +@media (max-width: 900px) { + #tsd-filter .tsd-filter-group { + display: block; + position: absolute; + top: 40px; + right: 20px; + height: auto; + background-color: var(--color-panel); + visibility: hidden; + transform: translate(50%, 0); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); + } + .has-options #tsd-filter .tsd-filter-group { + visibility: visible; + } + .to-has-options #tsd-filter .tsd-filter-group { + animation: fade-in 0.2s; + } + .from-has-options #tsd-filter .tsd-filter-group { + animation: fade-out 0.2s; + } + #tsd-filter label, + #tsd-filter .tsd-select { + display: block; + padding-right: 20px; + } +} + +footer { + border-top: 1px solid var(--color-panel-divider); + background-color: var(--color-panel); +} +footer:after { + content: ""; + display: table; +} +footer.with-border-bottom { + border-bottom: 1px solid var(--color-panel-divider); +} +footer .tsd-legend-group { + font-size: 0; +} +footer .tsd-legend { + display: inline-block; + width: 25%; + padding: 0; + font-size: 16px; + list-style: none; + line-height: 1.333em; + vertical-align: top; +} +@media (max-width: 900px) { + footer .tsd-legend { + width: 50%; + } +} + +.tsd-hierarchy { + list-style: square; + padding: 0 0 0 20px; + margin: 0; +} +.tsd-hierarchy .target { + font-weight: bold; +} + +.tsd-index-panel .tsd-index-content { + margin-bottom: -30px !important; +} +.tsd-index-panel .tsd-index-section { + margin-bottom: 30px !important; +} +.tsd-index-panel h3 { + margin: 0 -20px 10px -20px; + padding: 0 20px 10px 20px; + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 3; + -moz-column-count: 3; + -ms-column-count: 3; + -o-column-count: 3; + column-count: 3; + -webkit-column-gap: 20px; + -moz-column-gap: 20px; + -ms-column-gap: 20px; + -o-column-gap: 20px; + column-gap: 20px; + padding: 0; + list-style: none; + line-height: 1.333em; +} +@media (max-width: 900px) { + .tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 1; + -moz-column-count: 1; + -ms-column-count: 1; + -o-column-count: 1; + column-count: 1; + } +} +@media (min-width: 901px) and (max-width: 1024px) { + .tsd-index-panel ul.tsd-index-list { + -webkit-column-count: 2; + -moz-column-count: 2; + -ms-column-count: 2; + -o-column-count: 2; + column-count: 2; + } +} +.tsd-index-panel ul.tsd-index-list li { + -webkit-page-break-inside: avoid; + -moz-page-break-inside: avoid; + -ms-page-break-inside: avoid; + -o-page-break-inside: avoid; + page-break-inside: avoid; +} +.tsd-index-panel a, +.tsd-index-panel .tsd-parent-kind-module a { + color: var(--color-ts); +} +.tsd-index-panel .tsd-parent-kind-interface a { + color: var(--color-ts-interface); +} +.tsd-index-panel .tsd-parent-kind-enum a { + color: var(--color-ts-enum); +} +.tsd-index-panel .tsd-parent-kind-class a { + color: var(--color-ts-class); +} +.tsd-index-panel .tsd-kind-module a { + color: var(--color-ts); +} +.tsd-index-panel .tsd-kind-interface a { + color: var(--color-ts-interface); +} +.tsd-index-panel .tsd-kind-enum a { + color: var(--color-ts-enum); +} +.tsd-index-panel .tsd-kind-class a { + color: var(--color-ts-class); +} +.tsd-index-panel .tsd-is-private a { + color: var(--color-ts-private); +} + +.tsd-flag { + display: inline-block; + padding: 1px 5px; + border-radius: 4px; + color: var(--color-comment-tag-text); + background-color: var(--color-comment-tag); + text-indent: 0; + font-size: 14px; + font-weight: normal; +} + +.tsd-anchor { + position: absolute; + top: -100px; +} + +.tsd-member { + position: relative; +} +.tsd-member .tsd-anchor + h3 { + margin-top: 0; + margin-bottom: 0; + border-bottom: none; +} +.tsd-member [data-tsd-kind] { + color: var(--color-ts); +} +.tsd-member [data-tsd-kind="Interface"] { + color: var(--color-ts-interface); +} +.tsd-member [data-tsd-kind="Enum"] { + color: var(--color-ts-enum); +} +.tsd-member [data-tsd-kind="Class"] { + color: var(--color-ts-class); +} +.tsd-member [data-tsd-kind="Private"] { + color: var(--color-ts-private); +} + +.tsd-navigation { + margin: 0 0 0 40px; +} +.tsd-navigation a { + display: block; + padding-top: 2px; + padding-bottom: 2px; + border-left: 2px solid transparent; + color: var(--color-text); + text-decoration: none; + transition: border-left-color 0.1s; +} +.tsd-navigation a:hover { + text-decoration: underline; +} +.tsd-navigation ul { + margin: 0; + padding: 0; + list-style: none; +} +.tsd-navigation li { + padding: 0; +} + +.tsd-navigation.primary { + padding-bottom: 40px; +} +.tsd-navigation.primary a { + display: block; + padding-top: 6px; + padding-bottom: 6px; +} +.tsd-navigation.primary ul li a { + padding-left: 5px; +} +.tsd-navigation.primary ul li li a { + padding-left: 25px; +} +.tsd-navigation.primary ul li li li a { + padding-left: 45px; +} +.tsd-navigation.primary ul li li li li a { + padding-left: 65px; +} +.tsd-navigation.primary ul li li li li li a { + padding-left: 85px; +} +.tsd-navigation.primary ul li li li li li li a { + padding-left: 105px; +} +.tsd-navigation.primary > ul { + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-navigation.primary li { + border-top: 1px solid var(--color-panel-divider); +} +.tsd-navigation.primary li.current > a { + font-weight: bold; +} +.tsd-navigation.primary li.label span { + display: block; + padding: 20px 0 6px 5px; + color: var(--color-menu-label); +} +.tsd-navigation.primary li.globals + li > span, +.tsd-navigation.primary li.globals + li > a { + padding-top: 20px; +} + +.tsd-navigation.secondary { + max-height: calc(100vh - 1rem - 40px); + overflow: auto; + position: sticky; + top: calc(0.5rem + 40px); + transition: 0.3s; +} +.tsd-navigation.secondary.tsd-navigation--toolbar-hide { + max-height: calc(100vh - 1rem); + top: 0.5rem; +} +.tsd-navigation.secondary ul { + transition: opacity 0.2s; +} +.tsd-navigation.secondary ul li a { + padding-left: 25px; +} +.tsd-navigation.secondary ul li li a { + padding-left: 45px; +} +.tsd-navigation.secondary ul li li li a { + padding-left: 65px; +} +.tsd-navigation.secondary ul li li li li a { + padding-left: 85px; +} +.tsd-navigation.secondary ul li li li li li a { + padding-left: 105px; +} +.tsd-navigation.secondary ul li li li li li li a { + padding-left: 125px; +} +.tsd-navigation.secondary ul.current a { + border-left-color: var(--color-panel-divider); +} +.tsd-navigation.secondary li.focus > a, +.tsd-navigation.secondary ul.current li.focus > a { + border-left-color: var(--color-menu-divider-focus); +} +.tsd-navigation.secondary li.current { + margin-top: 20px; + margin-bottom: 20px; + border-left-color: var(--color-panel-divider); +} +.tsd-navigation.secondary li.current > a { + font-weight: bold; +} + +@media (min-width: 901px) { + .menu-sticky-wrap { + position: static; + } +} + +.tsd-panel { + margin: 20px 0; + padding: 20px; + background-color: var(--color-panel); + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); +} +.tsd-panel:empty { + display: none; +} +.tsd-panel > h1, +.tsd-panel > h2, +.tsd-panel > h3 { + margin: 1.5em -20px 10px -20px; + padding: 0 20px 10px 20px; + border-bottom: 1px solid var(--color-panel-divider); +} +.tsd-panel > h1.tsd-before-signature, +.tsd-panel > h2.tsd-before-signature, +.tsd-panel > h3.tsd-before-signature { + margin-bottom: 0; + border-bottom: 0; +} +.tsd-panel table { + display: block; + width: 100%; + overflow: auto; + margin-top: 10px; + word-break: normal; + word-break: keep-all; + border-collapse: collapse; +} +.tsd-panel table th { + font-weight: bold; +} +.tsd-panel table th, +.tsd-panel table td { + padding: 6px 13px; + border: 1px solid var(--color-panel-divider); +} +.tsd-panel table tr { + background: var(--color-background); +} +.tsd-panel table tr:nth-child(even) { + background: var(--color-secondary-background); +} + +.tsd-panel-group { + margin: 60px 0; +} +.tsd-panel-group > h1, +.tsd-panel-group > h2, +.tsd-panel-group > h3 { + padding-left: 20px; + padding-right: 20px; +} + +#tsd-search { + transition: background-color 0.2s; +} +#tsd-search .title { + position: relative; + z-index: 2; +} +#tsd-search .field { + position: absolute; + left: 0; + top: 0; + right: 40px; + height: 40px; +} +#tsd-search .field input { + box-sizing: border-box; + position: relative; + top: -50px; + z-index: 1; + width: 100%; + padding: 0 10px; + opacity: 0; + outline: 0; + border: 0; + background: transparent; + color: var(--color-text); +} +#tsd-search .field label { + position: absolute; + overflow: hidden; + right: -40px; +} +#tsd-search .field input, +#tsd-search .title { + transition: opacity 0.2s; +} +#tsd-search .results { + position: absolute; + visibility: hidden; + top: 40px; + width: 100%; + margin: 0; + padding: 0; + list-style: none; + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); +} +#tsd-search .results li { + padding: 0 10px; + background-color: var(--color-background); +} +#tsd-search .results li:nth-child(even) { + background-color: var(--color-panel); +} +#tsd-search .results li.state { + display: none; +} +#tsd-search .results li.current, +#tsd-search .results li:hover { + background-color: var(--color-panel-divider); +} +#tsd-search .results a { + display: block; +} +#tsd-search .results a:before { + top: 10px; +} +#tsd-search .results span.parent { + color: var(--color-text-aside); + font-weight: normal; +} +#tsd-search.has-focus { + background-color: var(--color-panel-divider); +} +#tsd-search.has-focus .field input { + top: 0; + opacity: 1; +} +#tsd-search.has-focus .title { + z-index: 0; + opacity: 0; +} +#tsd-search.has-focus .results { + visibility: visible; +} +#tsd-search.loading .results li.state.loading { + display: block; +} +#tsd-search.failure .results li.state.failure { + display: block; +} + +.tsd-signature { + margin: 0 0 1em 0; + padding: 10px; + border: 1px solid var(--color-panel-divider); + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + font-size: 14px; + overflow-x: auto; +} +.tsd-signature.tsd-kind-icon { + padding-left: 30px; +} +.tsd-signature.tsd-kind-icon:before { + top: 10px; + left: 10px; +} +.tsd-panel > .tsd-signature { + margin-left: -20px; + margin-right: -20px; + border-width: 1px 0; +} +.tsd-panel > .tsd-signature.tsd-kind-icon { + padding-left: 40px; +} +.tsd-panel > .tsd-signature.tsd-kind-icon:before { + left: 20px; +} + +.tsd-signature-symbol { + color: var(--color-text-aside); + font-weight: normal; +} + +.tsd-signature-type { + font-style: italic; + font-weight: normal; +} + +.tsd-signatures { + padding: 0; + margin: 0 0 1em 0; + border: 1px solid var(--color-panel-divider); +} +.tsd-signatures .tsd-signature { + margin: 0; + border-width: 1px 0 0 0; + transition: background-color 0.1s; +} +.tsd-signatures .tsd-signature:first-child { + border-top-width: 0; +} +.tsd-signatures .tsd-signature.current { + background-color: var(--color-panel-divider); +} +.tsd-signatures.active > .tsd-signature { + cursor: pointer; +} +.tsd-panel > .tsd-signatures { + margin-left: -20px; + margin-right: -20px; + border-width: 1px 0; +} +.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon { + padding-left: 40px; +} +.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before { + left: 20px; +} +.tsd-panel > a.anchor + .tsd-signatures { + border-top-width: 0; + margin-top: -20px; +} + +ul.tsd-descriptions { + position: relative; + overflow: hidden; + padding: 0; + list-style: none; +} +ul.tsd-descriptions.active > .tsd-description { + display: none; +} +ul.tsd-descriptions.active > .tsd-description.current { + display: block; +} +ul.tsd-descriptions.active > .tsd-description.fade-in { + animation: fade-in-delayed 0.3s; +} +ul.tsd-descriptions.active > .tsd-description.fade-out { + animation: fade-out-delayed 0.3s; + position: absolute; + display: block; + top: 0; + left: 0; + right: 0; + opacity: 0; + visibility: hidden; +} +ul.tsd-descriptions h4, +ul.tsd-descriptions .tsd-index-panel h3, +.tsd-index-panel ul.tsd-descriptions h3 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} + +ul.tsd-parameters, +ul.tsd-type-parameters { + list-style: square; + margin: 0; + padding-left: 20px; +} +ul.tsd-parameters > li.tsd-parameter-signature, +ul.tsd-type-parameters > li.tsd-parameter-signature { + list-style: none; + margin-left: -20px; +} +ul.tsd-parameters h5, +ul.tsd-type-parameters h5 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} +ul.tsd-parameters .tsd-comment, +ul.tsd-type-parameters .tsd-comment { + margin-top: -0.5em; +} + +.tsd-sources { + font-size: 14px; + color: var(--color-text-aside); + margin: 0 0 1em 0; +} +.tsd-sources a { + color: var(--color-text-aside); + text-decoration: underline; +} +.tsd-sources ul, +.tsd-sources p { + margin: 0 !important; +} +.tsd-sources ul { + list-style: none; + padding: 0; +} + +.tsd-page-toolbar { + position: fixed; + z-index: 1; + top: 0; + left: 0; + width: 100%; + height: 40px; + color: var(--color-toolbar-text); + background: var(--color-toolbar); + border-bottom: 1px solid var(--color-panel-divider); + transition: transform 0.3s linear; +} +.tsd-page-toolbar a { + color: var(--color-toolbar-text); + text-decoration: none; +} +.tsd-page-toolbar a.title { + font-weight: bold; +} +.tsd-page-toolbar a.title:hover { + text-decoration: underline; +} +.tsd-page-toolbar .table-wrap { + display: table; + width: 100%; + height: 40px; +} +.tsd-page-toolbar .table-cell { + display: table-cell; + position: relative; + white-space: nowrap; + line-height: 40px; +} +.tsd-page-toolbar .table-cell:first-child { + width: 100%; +} + +.tsd-page-toolbar--hide { + transform: translateY(-100%); +} + +.tsd-select .tsd-select-list li:before, +.tsd-select .tsd-select-label:before, +.tsd-widget:before { + content: ""; + display: inline-block; + width: 40px; + height: 40px; + margin: 0 -8px 0 0; + background-image: url(./widgets.png); + background-repeat: no-repeat; + text-indent: -1024px; + vertical-align: bottom; + filter: var(--icon-filter); +} +@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) { + .tsd-select .tsd-select-list li:before, + .tsd-select .tsd-select-label:before, + .tsd-widget:before { + background-image: url(./widgets@2x.png); + background-size: 320px 40px; + } +} + +.tsd-widget { + display: inline-block; + overflow: hidden; + opacity: 0.8; + height: 40px; + transition: opacity 0.1s, background-color 0.2s; + vertical-align: bottom; + cursor: pointer; +} +.tsd-widget:hover { + opacity: 0.9; +} +.tsd-widget.active { + opacity: 1; + background-color: var(--color-panel-divider); +} +.tsd-widget.no-caption { + width: 40px; +} +.tsd-widget.no-caption:before { + margin: 0; +} +.tsd-widget.search:before { + background-position: 0 0; +} +.tsd-widget.menu:before { + background-position: -40px 0; +} +.tsd-widget.options:before { + background-position: -80px 0; +} +.tsd-widget.options, +.tsd-widget.menu { + display: none; +} +@media (max-width: 900px) { + .tsd-widget.options, + .tsd-widget.menu { + display: inline-block; + } +} +input[type="checkbox"] + .tsd-widget:before { + background-position: -120px 0; +} +input[type="checkbox"]:checked + .tsd-widget:before { + background-position: -160px 0; +} + +.tsd-select { + position: relative; + display: inline-block; + height: 40px; + transition: opacity 0.1s, background-color 0.2s; + vertical-align: bottom; + cursor: pointer; +} +.tsd-select .tsd-select-label { + opacity: 0.6; + transition: opacity 0.2s; +} +.tsd-select .tsd-select-label:before { + background-position: -240px 0; +} +.tsd-select.active .tsd-select-label { + opacity: 0.8; +} +.tsd-select.active .tsd-select-list { + visibility: visible; + opacity: 1; + transition-delay: 0s; +} +.tsd-select .tsd-select-list { + position: absolute; + visibility: hidden; + top: 40px; + left: 0; + margin: 0; + padding: 0; + opacity: 0; + list-style: none; + box-shadow: 0 0 4px rgba(0, 0, 0, 0.25); + transition: visibility 0s 0.2s, opacity 0.2s; +} +.tsd-select .tsd-select-list li { + padding: 0 20px 0 0; + background-color: var(--color-background); +} +.tsd-select .tsd-select-list li:before { + background-position: 40px 0; +} +.tsd-select .tsd-select-list li:nth-child(even) { + background-color: var(--color-panel); +} +.tsd-select .tsd-select-list li:hover { + background-color: var(--color-panel-divider); +} +.tsd-select .tsd-select-list li.selected:before { + background-position: -200px 0; +} +@media (max-width: 900px) { + .tsd-select .tsd-select-list { + top: 0; + left: auto; + right: 100%; + margin-right: -5px; + } + .tsd-select .tsd-select-label:before { + background-position: -280px 0; + } +} + +img { + max-width: 100%; +} + +.tsd-anchor-icon { + margin-left: 10px; + vertical-align: middle; + color: var(--color-text); +} + +.tsd-anchor-icon svg { + width: 1em; + height: 1em; + visibility: hidden; +} + +.tsd-anchor-link:hover > .tsd-anchor-icon svg { + visibility: visible; +} diff --git a/docs/assets/images/widgets.png b/docs/assets/widgets.png similarity index 100% rename from docs/assets/images/widgets.png rename to docs/assets/widgets.png diff --git a/docs/assets/images/widgets@2x.png b/docs/assets/widgets@2x.png similarity index 100% rename from docs/assets/images/widgets@2x.png rename to docs/assets/widgets@2x.png diff --git a/docs/classes/CaslModule.html b/docs/classes/CaslModule.html index f9652782..10235f4d 100644 --- a/docs/classes/CaslModule.html +++ b/docs/classes/CaslModule.html @@ -1,261 +1,6 @@ - - - - - - CaslModule | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Class CaslModule

-
-
-
-
-
-
-
-

Hierarchy

-
    -
  • - CaslModule -
  • -
-
-
-

Index

-
-
-
-

Constructors

- -
-
-

Methods

- -
-
-
-
-
-

Constructors

-
- -

constructor

- - -
-
-
-

Methods

-
- -

Static withConfig

- -
    -
  • - -
    -
    -

    Configure the CaslModule using the provided configuration.

    -
    -
    -

    Parameters

    -
      -
    • -
      config: ICaslRootConfig<any>
      -
      -

      The module configuration to use.

      -
      -
    • -
    -

    Returns DynamicModule

    -

    the configured CaslModule

    -
  • -
-
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +CaslModule | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Hierarchy

  • CaslModule

Index

Constructors

Methods

Constructors

Methods

  • +

    Configure the CaslModule using the provided configuration.

    +

    Parameters

    Returns DynamicModule

    the configured CaslModule

    +

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/index.html b/docs/index.html index abf52e36..7afa730b 100644 --- a/docs/index.html +++ b/docs/index.html @@ -1,290 +1,71 @@ - - - - - - @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Project @scitizen/nest-casl

-
-
-
-
-
-
-
- -

@scitizen/nest-casl

-
-

- Nest Logo -  +  - CASL Logo -

-

A simple decorator-based way to check CASL abilities on NestJS controllers.

-

- GitHub issues - NPM version - NPM downloads - License - CircleCI - CodeClimate maintainability - CodeClimate test coverage -

- -

Description

-
-

Use decorators everywhere to protect your controller methods.

- - -

Installation

-
-
npm install --save @scitizen/nest-casl
-
-

Additionally, please make sure you have correct peer dependencies installed:

- - -
npm install @casl/ability@^5.0.0 @nestjs/common@^8.0.0 @nestjs/core@^8.0.0 lodash@^4.17.0 reflect-metadata@^0.1.13 rxjs@^7.0.0
-
- - -

In a nutshell

-
-

Declare a new service that converts the user of your request to a CASL ability:

-
import { Injectable } from '@nestjs/common';
-import { AbilityBuilder, PureAbility } from '@casl/ability';
-import { CaslAbilityFactory } from '@scitizen/nest-casl';
+@knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

@knodes/nest-casl

+ +

@knodes/nest-casl

+
+

+ Nest Logo +  +  + CASL Logo +

-@Injectable() -export class AbilityFactory implements CaslAbilityFactory { - // Here, `request` is the express or fastify request. You might get infos from it. - public createFromRequest( _request: unknown ): PureAbility { - const abilityBuilder = new AbilityBuilder( PureAbility ); - abilityBuilder.can( 'feed', 'cat' ); - abilityBuilder.can( 'hug', 'cat' ); - abilityBuilder.can( 'pet', 'cat' ); - abilityBuilder.cannot( 'rename', 'cat' ); - return abilityBuilder.build(); - } -} -
-

Import the module:

-
import { Module } from '@nestjs/common';
-import { CaslModule } from '@scitizen/nest-casl';
+

A simple decorator-based way to check CASL abilities on NestJS controllers.

-@Module( { - imports: [ - CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ), - // .... - ], -} ) -export class AppModule {} -
-

Use decorators in your controller:

-
import { AbilityBuilder, PureAbility } from '@casl/ability';
-import { Controller, Get } from '@nestjs/common';
-import { InjectAbility, PoliciesMask, Policy } from '@scitizen/nest-casl';
+

+ GitHub issues + NPM version + NPM downloads + License + CircleCI + CodeClimate maintainability + CodeClimate test coverage +

-@Controller( '/cat/care' ) -@PoliciesMask({ - 'pet': { action: 'pet', subject: 'cat' } -}) -export class CatCareController { - // Okay, you can feed. - @Get( 'feed' ) - @Policy( { action: 'feed', subject: 'cat' } ) - public feed(){ - // ... - } - // Well, I guess he won't bite. - @Get( 'hug' ) - @Policy( { action: 'hug', subject: 'cat' } ) - public hug(){ - // ... - } + +

Description

+
+

Use decorators everywhere to protect your controller methods.

+ - @Get( 'pet' ) - public pet( @InjectAbility() ability: PureAbility ){ - // ... - } -} + +

Installation

+
+
npm install --save @knodes/nest-casl
+
+

Additionally, please make sure you have correct peer dependencies installed:

+ + +
npm install @casl/ability@^5.0.0 @nestjs/common@^8.0.0 @nestjs/core@^8.0.0 lodash@^4.17.0 reflect-metadata@^0.1.13 rxjs@^7.0.0
 
-

For more details and usage with guards, please refer to the guide.

- -

License

-
-

@scitizen/nest-casl is MIT licensed.

-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file + + + + +

In a nutshell

+
+

Declare a new service that converts the user of your request to a CASL ability:

+
import { Injectable } from '@nestjs/common';
import { AbilityBuilder, PureAbility } from '@casl/ability';
import { CaslAbilityFactory } from '@knodes/nest-casl';

@Injectable()
export class AbilityFactory implements CaslAbilityFactory {
// Here, `request` is the express or fastify request. You might get infos from it.
public createFromRequest( _request: unknown ): PureAbility {
const abilityBuilder = new AbilityBuilder( PureAbility );
abilityBuilder.can( 'feed', 'cat' );
abilityBuilder.can( 'hug', 'cat' );
abilityBuilder.can( 'pet', 'cat' );
abilityBuilder.cannot( 'rename', 'cat' );
return abilityBuilder.build();
}
} +
+

Import the module:

+
import { Module } from '@nestjs/common';
import { CaslModule } from '@knodes/nest-casl';

@Module( {
imports: [
CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
// ....
],
} )
export class AppModule {} +
+

Use decorators in your controller:

+
import { AbilityBuilder, PureAbility } from '@casl/ability';
import { Controller, Get } from '@nestjs/common';
import { InjectAbility, PoliciesMask, Policy } from '@knodes/nest-casl';

@Controller( '/cat/care' )
@PoliciesMask({
'pet': { action: 'pet', subject: 'cat' }
})
export class CatCareController {
// Okay, you can feed.
@Get( 'feed' )
@Policy( { action: 'feed', subject: 'cat' } )
public feed(){
// ...
}

// Well, I guess he won't bite.
@Get( 'hug' )
@Policy( { action: 'hug', subject: 'cat' } )
public hug(){
// ...
}

@Get( 'pet' )
public pet( @InjectAbility() ability: PureAbility ){
// ...
}
} +
+

For more details and usage with guards, please refer to the guide.

+ + +

License

+
+

@knodes/nest-casl is MIT licensed.

+

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/interfaces/CaslAbilityFactory.html b/docs/interfaces/CaslAbilityFactory.html index 459cba1d..ef060c87 100644 --- a/docs/interfaces/CaslAbilityFactory.html +++ b/docs/interfaces/CaslAbilityFactory.html @@ -1,250 +1,8 @@ - - - - - - CaslAbilityFactory | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Interface CaslAbilityFactory<TAbility>

-
-
-
-
-
-
-
-
-
-

A class interface that generate the CASL ability from the request.

-
-
-
-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
-

Hierarchy

-
    -
  • - CaslAbilityFactory -
  • -
-
-
-

Index

-
-
-
-

Methods

- -
-
-
-
-
-

Methods

-
- -

createFromRequest

- -
    -
  • - -
    -
    -

    Extract the ability from the HTTP request.

    -
    -
    -

    Parameters

    -
      -
    • -
      request: unknown
      -
      -

      The HTTP request, usually from express or fastify depending on your HTTP adapter.

      -
      -
    • -
    -

    Returns MaybeAsyncValue<TAbility>

    -

    the ability for the user.

    -
  • -
-
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +CaslAbilityFactory | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Interface CaslAbilityFactory<TAbility>

+

A class interface that generate the CASL ability from the request.

+

Type parameters

  • TAbility: AnyAbilityLike = PureAbility<any, any>

Hierarchy

  • CaslAbilityFactory

Index

Methods

  • +

    Extract the ability from the HTTP request.

    +

    Parameters

    • request: unknown
      +

      The HTTP request, usually from express or fastify depending on your HTTP adapter.

      +

    Returns MaybeAsyncValue<TAbility>

    the ability for the user.

    +

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/interfaces/ICaslRootConfig.html b/docs/interfaces/ICaslRootConfig.html index 29713d31..353074ce 100644 --- a/docs/interfaces/ICaslRootConfig.html +++ b/docs/interfaces/ICaslRootConfig.html @@ -1,221 +1 @@ - - - - - - ICaslRootConfig | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Interface ICaslRootConfig<TAbility>

-
-
-
-
-
-
-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
-

Hierarchy

-
    -
  • - ICaslRootConfig -
  • -
-
-
-

Index

-
-
-
-

Properties

- -
-
-
-
-
-

Properties

-
- -

abilityFactory

-
abilityFactory: Type<CaslAbilityFactory<TAbility>>
- -
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +ICaslRootConfig | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Interface ICaslRootConfig<TAbility>

Type parameters

  • TAbility: AnyAbilityLike = PureAbility<any, any>

Hierarchy

  • ICaslRootConfig

Index

Properties

Properties

abilityFactory: Type<CaslAbilityFactory<TAbility>>

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/interfaces/IPolicy.html b/docs/interfaces/IPolicy.html index 7bf2867a..05c84fbd 100644 --- a/docs/interfaces/IPolicy.html +++ b/docs/interfaces/IPolicy.html @@ -1,250 +1,8 @@ - - - - - - IPolicy | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Interface IPolicy<TAbility>

-
-
-
-
-
-
-
-
-
-

This interface specify a class or object that can do dynamic and complex checks about the current user abilities.

-
-
-
-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
-

Hierarchy

-
    -
  • - IPolicy -
  • -
-
-
-

Index

-
-
-
-

Methods

- -
-
-
-
-
-

Methods

-
- -

handle

- -
    -
  • - -
    -
    -

    Check if the ability is allowed.

    -
    -
    -

    Parameters

    -
      -
    • -
      ability: TAbility
      -
      -

      The request's ability.

      -
      -
    • -
    -

    Returns MaybeAsyncValue<boolean>

    -

    true if allowed, false otherwise.

    -
  • -
-
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +IPolicy | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Interface IPolicy<TAbility>

+

This interface specify a class or object that can do dynamic and complex checks about the current user abilities.

+

Type parameters

  • TAbility: AnyAbilityLike = AnyAbilityLike

Hierarchy

  • IPolicy

Index

Methods

Methods

  • +

    Check if the ability is allowed.

    +

    Parameters

    • ability: TAbility
      +

      The request's ability.

      +

    Returns MaybeAsyncValue<boolean>

    true if allowed, false otherwise.

    +

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/modules.html b/docs/modules.html index 7e4599c8..5b372bff 100644 --- a/docs/modules.html +++ b/docs/modules.html @@ -1,597 +1,58 @@ - - - - - - @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Project @scitizen/nest-casl

-
-
-
-
-
-
-
-

Index

-
-
-
-

Namespaces

- -
-
-

Classes

- -
-
-

Interfaces

- -
-
-

Type aliases

- -
-
-

Decorators Functions

- -

Other Functions

- -
-
-
-
-
-

Type aliases

-
- -

BoundPolicyDecorators

-
BoundPolicyDecorators<TAbility>: { PoliciesMask: PoliciesMask<TAbility>; Policy: Policy<TAbility> }
- -

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-

Type declaration

- -
-
-
- -

GuardsList

-
GuardsList: ((CanActivate | Type<CanActivate>)[] | Type<CanActivate>)[]
- -
-
-

A list of guards or guard classes. - When called in a usingGuard method, they might be joined by a or condition.

-
-
-
example
-
@Policy( () => true )
-    //          (Guard1 || Guard2)
-    .usingGuard([Guard1,   Guard2])
-class Foo {}
-
-@PoliciesMask( { '*': () => true } )
-    //          (Guard3 || Guard4) && Guard5 && (Guard6)
-    .usingGuard([Guard3,   Guard4],   Guard5,   [Guard6])
-class Bar {}
+@knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

@knodes/nest-casl

Index

Type aliases

BoundPolicyDecorators<TAbility>: { PoliciesMask: PoliciesMask<TAbility>; Policy: Policy<TAbility> }

Type parameters

  • TAbility: AnyAbilityLike = AnyAbilityLike

Type declaration

GuardsList: ((CanActivate | Type<CanActivate>)[] | Type<CanActivate>)[]
+

A list of guards or guard classes. +When called in a usingGuard method, they might be joined by a or condition.

+
example
@Policy( () => true )
// (Guard1 || Guard2)
.usingGuard([Guard1, Guard2])
class Foo {}

@PoliciesMask( { '*': () => true } )
// (Guard3 || Guard4) && Guard5 && (Guard6)
.usingGuard([Guard3, Guard4], Guard5, [Guard6])
class Bar {}
-
-
-
-
-
- -

MaybeAsyncValue

-
MaybeAsyncValue<T>: T | Promise<T> | Observable<T>
- -
-
-

An observable, promise, or sync value.

-
-
-

Type parameters

-
    -
  • -

    T

    -
  • -
-
-
- -

PolicyDescriptor

-
PolicyDescriptor<TAbility>: Type<IPolicy<TAbility>> | IPolicy<TAbility> | ((ability: TAbility) => MaybeAsyncValue<boolean>) | SimplePolicy<TAbility> | boolean
- -
-
-

Any type of policy that can be handled. It can either be

-
    -
  • an object or an injectable class implementing IPolicy
  • -
  • a simple function that takes the ability and return a boolean
  • -
  • a SimplePolicy defining the action and subject
  • -
  • or a static boolean.
  • -
-
-

Booleans are handled in a special ways:

-
    -
  • If true, the policy guards are never ran. This could be used to expose a single anonymously accessible endpoint on a masked controller.
  • -
  • If false, only the {@link PoliciesGuard} is ran, and throws a ForbiddenException: Endpoint statically forbidden.
  • -
-

In all other cases, all guards are ran.

-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
- -

PolicyDescriptorMask

-
PolicyDescriptorMask<TAbility>: Record<string, PolicyDescriptor<TAbility>>
- -
-
-

A dictionary of policies to apply on a class. All properties must be methods of the class it is applied on, except *.

-
-

The * key is a fallback policy used when no more specific key matches. We strongly recommend to use it with false, to explicitly allow endpoints.

-
-
see
-

PolicyDescriptor

-
-
example
-
@PoliciesMask({
-    '*': false, // Disallow by default
-    'create': { action: 'create', subject: 'Cat', },
-    'read': true, // Allow everybody to read. Don't even check any guard.
-    'update': { action: 'update', subject: 'Cat', },
-    'delete': { action: 'delete', subject: 'Cat', },
-})
-class CatsController {
-    public create(){}
-    public read(){}
-    public update(){}
-    public delete(){}
-    public admin(){} // Not specified in the mask, thus applying the `false` policy who always forbid access.
-}
+
MaybeAsyncValue<T>: T | Promise<T> | Observable<T>
+

An observable, promise, or sync value.

+

Type parameters

  • T

PolicyDescriptor<TAbility>: Type<IPolicy<TAbility>> | IPolicy<TAbility> | ((ability: TAbility) => MaybeAsyncValue<boolean>) | SimplePolicy<TAbility> | boolean
+

Any type of policy that can be handled. It can either be

+
    +
  • an object or an injectable class implementing IPolicy
  • +
  • a simple function that takes the ability and return a boolean
  • +
  • a SimplePolicy defining the action and subject
  • +
  • or a static boolean.
  • +
+

Booleans are handled in a special ways:

+
    +
  • If true, the policy guards are never ran. This could be used to expose a single anonymously accessible endpoint on a masked controller.
  • +
  • If false, only the {@link PoliciesGuard} is ran, and throws a ForbiddenException: Endpoint statically forbidden.
  • +
+

In all other cases, all guards are ran.

+

Type parameters

  • TAbility: AnyAbilityLike

PolicyDescriptorMask<TAbility>: Record<string, PolicyDescriptor<TAbility>>
+

A dictionary of policies to apply on a class. All properties must be methods of the class it is applied on, except *.

+

The * key is a fallback policy used when no more specific key matches. We strongly recommend to use it with false, to explicitly allow endpoints.

+
see

PolicyDescriptor

+
example
@PoliciesMask({
'*': false, // Disallow by default
'create': { action: 'create', subject: 'Cat', },
'read': true, // Allow everybody to read. Don't even check any guard.
'update': { action: 'update', subject: 'Cat', },
'delete': { action: 'delete', subject: 'Cat', },
})
class CatsController {
public create(){}
public read(){}
public update(){}
public delete(){}
public admin(){} // Not specified in the mask, thus applying the `false` policy who always forbid access.
}
-
-
-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
- -

SimplePolicy

-
SimplePolicy<TAbility>: TAbility extends Ability<infer TAbilityTuple> ? TAbilityTuple extends any ? { action: TAbilityTuple[0]; subject: TAbilityTuple[1] } : never : { action: string; subject: string }
- -
-
-

A simple policy defined by an action and a subject.

-
-
-
see
-

https://casl.js.org/v5/en/guide/intro#basics

-
-
-
-

Type parameters

-
    -
  • -

    TAbility: AnyAbilityLike

    -
  • -
-
-
-
-

Decorators Functions

-
- -

Const InjectAbility

-
    -
  • InjectAbility(required?: boolean): ParameterDecorator
  • -
-
    -
  • - -
    -
    -

    A parameter decorator factory that retrieve the ability of the current request.

    -
    -
    -

    Parameters

    -
      -
    • -
      Optional required: boolean
      -
      -

      Set to false to not throw if no ability was found for the request. Defaults to true.

      -
      -
    • -
    -

    Returns ParameterDecorator

    -

    a parameter decorator that will set the parameter value to the ability. If not {@link required} and none is found, a new empty ability will be created.

    -
  • -
-
-
- -

PoliciesMask

-
    -
  • PoliciesMask<TMask, TAbility>(mask: TMask): BoundPoliciesMask<TMask, TAbility>
  • -
- -
-
- -

Policy

-
    -
  • Policy<TAbility>(policy: PolicyDescriptor<TAbility>): BoundPolicy<TAbility>
  • -
- -
-
-
-

Other Functions

-
- -

Const bindPolicyDecorators

- -
    -
  • - -
    -
    -

    Prepare a new couple of Policy & PoliciesMask decorators bound to use the given {@link guards}.

    -
    -
    -
    example
    -
    const ViaJwt = bindPolicyDecorators( AuthGuard( 'jwt' ));
    -const ViaStrongJwt = ViaJwt( AuthenticatedStrongly );
    +

    Type parameters

    • TAbility: AnyAbilityLike

SimplePolicy<TAbility>: TAbility extends Ability<infer TAbilityTuple> ? TAbilityTuple extends any ? { action: TAbilityTuple[0]; subject: TAbilityTuple[1] } : never : { action: string; subject: string }
+

A simple policy defined by an action and a subject.

+
see

https://casl.js.org/v5/en/guide/intro#basics

+

Type parameters

  • TAbility: AnyAbilityLike

Decorators Functions

  • InjectAbility(required?: boolean): ParameterDecorator
  • +

    A parameter decorator factory that retrieve the ability of the current request.

    +

    Parameters

    • Optional required: boolean
      +

      Set to false to not throw if no ability was found for the request. Defaults to true.

      +

    Returns ParameterDecorator

    a parameter decorator that will set the parameter value to the ability. If not {@link required} and none is found, a new empty ability will be created.

    +
  • PoliciesMask<TMask, TAbility>(mask: TMask): BoundPoliciesMask<TMask, TAbility>

Other Functions

  • +

    Prepare a new couple of Policy & PoliciesMask decorators bound to use the given {@link guards}.

    +
    example
    const ViaJwt = bindPolicyDecorators( AuthGuard( 'jwt' ));
    const ViaStrongJwt = ViaJwt( AuthenticatedStrongly );
    -
    -
    -
    -

    Type parameters

    -
      -
    • -

      TAbility: AnyAbilityLike

      -
    • -
    -

    Parameters

    -
      -
    • -
      Rest ...guards: GuardsList
      -
      -

      A list of guards to use.

      -
      -
    • -
    -

    Returns BoundPolicyDecorators<TAbility>

    -

    an function with properties containing the new decorators. You may call again this function to add more guards.

    -
  • -
-
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +

Type parameters

  • TAbility: AnyAbilityLike = AnyAbilityLike

Parameters

  • Rest ...guards: GuardsList
    +

    A list of guards to use.

    +

Returns BoundPolicyDecorators<TAbility>

an function with properties containing the new decorators. You may call again this function to add more guards.

+

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/modules/PoliciesMask.html b/docs/modules/PoliciesMask.html index af5b7639..1e9df289 100644 --- a/docs/modules/PoliciesMask.html +++ b/docs/modules/PoliciesMask.html @@ -1,188 +1,6 @@ - - - - - - PoliciesMask | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Namespace PoliciesMask

-
-
-
-
-
-
-
-

Index

-
-
-
-

Functions

- -
-
-
-
-
-

Functions

-
- -

usingGuard

-
    -
  • usingGuard(...guards: GuardsList): PoliciesMask<AnyAbilityLike>
  • -
- -
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +PoliciesMask | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Namespace PoliciesMask

Index

Functions

Functions

  • usingGuard(...guards: GuardsList): PoliciesMask<AnyAbilityLike>

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/modules/Policy.html b/docs/modules/Policy.html index 66647d74..e0ce7ca5 100644 --- a/docs/modules/Policy.html +++ b/docs/modules/Policy.html @@ -1,188 +1,6 @@ - - - - - - Policy | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Namespace Policy

-
-
-
-
-
-
-
-

Index

-
-
-
-

Functions

- -
-
-
-
-
-

Functions

-
- -

usingGuard

-
    -
  • usingGuard(...guards: GuardsList): typeof Policy
  • -
- -
-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file +Policy | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Namespace Policy

Index

Functions

Functions

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/pages/Changelog/CHANGELOG.html b/docs/pages/Changelog/CHANGELOG.html deleted file mode 100644 index 45e1fab7..00000000 --- a/docs/pages/Changelog/CHANGELOG.html +++ /dev/null @@ -1,190 +0,0 @@ - - - - - - Changelog | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Changelog

-
-
-
-
-
-
-
- -

Changelog

-
-

All notable changes to this project will be documented in this file. See standard-version for commit guidelines.

- -

0.0.2 (2021-11-06)

- - -

0.0.2-next.7 (2021-10-08)

- - -

0.0.2-next.6 (2021-10-08)

- - -

0.0.2-next.5 (2021-10-08)

- - -

0.0.2-next.4 (2021-10-07)

- - -

0.0.2-next.3 (2021-10-06)

- - -

0.0.2-next.2 (2021-10-06)

- - -

Features

-
-
    -
  • policies.guard: allow async handlers (9594542)
  • -
- -

Bug Fixes

-
-
    -
  • add policy metadata in the correct order (467354a)
  • -
  • or.guard: properly waterfall canActivate, stop further checks on first success, use promises (f92f45e)
  • -
- -

0.0.2-next.1 (2021-10-06)

- - -

0.0.2-next.0 (2021-10-06)

- - -

0.0.1 (2021-10-06)

- -

Initial release

-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file diff --git a/docs/pages/Guides/better-type-constraints.html b/docs/pages/Guides/better-type-constraints.html deleted file mode 100644 index f522f6b1..00000000 --- a/docs/pages/Guides/better-type-constraints.html +++ /dev/null @@ -1,292 +0,0 @@ - - - - - - Better type constraints | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Better type constraints

-
-
-
-
-
-
-
-

So far, we were able to configure your policies. But we can't yet check that our actions or subjects are actually matching what we declared.

- -

Define the ability type

-
-

Let's configure our ability types:

-

From ./test/demo/better-types/ability.ts#1~6

-
import { Ability } from '@casl/ability';
-
-export type MyAbilities =
-	| ['admin', 'ImportantData']
-	| ['create' | 'read' | 'update' | 'delete', 'PublicData' ];
-export type MyAbility = Ability<MyAbilities>;
-
-

-

Using MyAbility, we can't pass anything to can or cannot: types are constrained.

-

From ./test/demo/better-types/ability.typecheck.e2e-spec.ts#1~12

-
import { expectTypeOf } from 'expect-type';
-
-import { MyAbility } from './ability';
-
-it( 'ability should have correct typings', () => {
-	expectTypeOf<['read', 'PublicData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();
-	expectTypeOf<['create', 'PublicData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();
-	expectTypeOf<['admin', 'ImportantData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();
-
-	expectTypeOf<['admin', 'PublicData']>().not.toMatchTypeOf<Parameters<MyAbility['can']>>();
-	expectTypeOf<['read', 'ImportantData']>().not.toMatchTypeOf<Parameters<MyAbility['can']>>();
-} );
-
-

-

That's great. This will greatly reduce our chances of typos. Moreover, your IDE might now suggest actions & subjects for you.

- -

Use the ability type

-
- -

With the CaslAbilityFactory

- -

Let's now use this type in your CaslAbilityFactory:

-

From ./src/ability-factory.service.ts

-
import { AbilityBuilder, PureAbility } from '@casl/ability';
-import { Injectable } from '@nestjs/common';
-
-import { CaslAbilityFactory } from '@scitizen/nest-casl';
-
-import { MyAbility } from './ability';
-
-@Injectable()
-export class AbilityFactory implements CaslAbilityFactory<MyAbility> {
-	// Here, `request` is the express or fastify request. You might get infos from it.
-	public createFromRequest( _request: unknown ): MyAbility {
-		const { user } = ( _request as any );
-		const abilityBuilder = new AbilityBuilder<MyAbility>( PureAbility );
-		if( user?.role === 'admin' ) {
-			abilityBuilder.can( 'admin', 'ImportantData' );
-		}
-		return abilityBuilder.build();
-	}
-}
-
-

- -

With decorators

-
-

You can pass your ability as a type parameter to your decorators to constraint your actions and subjects:

-

From ./src/test.controller.ts

-
import { Controller, Get } from '@nestjs/common';
-
-import { Policy } from '@scitizen/nest-casl';
-
-import { MyAbility } from './ability';
-
-@Controller()
-// @ts-expect-error -- `something` is not a valid subject
-@Policy<MyAbility>( { action: 'admin', subject: 'something' } )
-// @ts-expect-error -- `rick-roll` is not a valid action
-@Policy<MyAbility>( { action: 'rick-roll', subject: 'ImportantData' } )
-// @ts-expect-error -- `read` is not a valid action on `ImportantData`
-@Policy<MyAbility>( { action: 'read', subject: 'ImportantData' } )
-@Policy<MyAbility>( { action: 'read', subject: 'PublicData' } )
-// ...
-export class TestController {
-	@Get()
-	public method(){
-		// ...
-	}
-}
-
-

-

But the boring part here is that you have to pass your ability type to every decorator in order to constrain them. Hopefully, you can solve this:

-

From ./src/my-policies.ts

-
import { bindPolicyDecorators } from '@scitizen/nest-casl';
-
-import { MyAbility } from './ability';
-
-export const MyPolicies = bindPolicyDecorators<MyAbility>( /* you can even pass some guards here ! */ );
-
-

-

Then, simply enjoy type contraints !

-

From ./src/test-bound.controller.ts

-
import { Controller, Get } from '@nestjs/common';
-
-import { MyPolicies } from './my-policies';
-
-@Controller()
-@MyPolicies.PoliciesMask( {
-	'*': { action: 'admin', subject: 'ImportantData' },
-	'read': { action: 'read', subject: 'PublicData' },
-	'create': { action: 'create', subject: 'PublicData' },
-} )
-export class TestController {
-	@Get()
-	@MyPolicies.Policy( { handle: ability => ability.can( 'read', 'PublicData' ) } )
-	public create(){
-		// ...
-	}
-	@Get()
-	public read(){
-		// ...
-	}
-
-	@Get()
-	public admin(){
-		// ...
-	}
-}
-
-

-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file diff --git a/docs/pages/Guides/getting-started.html b/docs/pages/Guides/getting-started.html deleted file mode 100644 index 8480aa0a..00000000 --- a/docs/pages/Guides/getting-started.html +++ /dev/null @@ -1,311 +0,0 @@ - - - - - - Getting started | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Getting started

-
-
-
-
-
-
-
-
-

This module is compatible with nestjs@^8.0.0.

-
- -

Setup & configuration

-
-

First, install the module:

-
npm install @scitizen/nest-casl
-
-

Then, declare a provider that generate a CASL Ability from the current request.

-

From ./src/ability-factory.service.ts

-
@Injectable()
-export class AbilityFactory implements CaslAbilityFactory {
-	// Here, `request` is the express or fastify request. You might get infos from it.
-	public createFromRequest( _request: unknown ): PureAbility {
-		const abilityBuilder = new AbilityBuilder( PureAbility );
-		abilityBuilder.can( 'feed', 'cat' );
-		abilityBuilder.can( 'hug', 'cat' );
-		abilityBuilder.cannot( 'rename', 'cat' );
-		return abilityBuilder.build();
-	}
-}
-
-

-

Import the CaslModule in your AppModule, and configure it to use your ability factory.

-

From ./src/app.module.ts

-
@Module( {
-	imports: [
-		CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
-		// ....
-	],
-} )
-export class AppModule {}
-
-

-

You can now start using policy decorators (Policy and PoliciesMask) in your controllers !

- -

Basic usage

-
-

You can protect all methods of your controller using the Policy class decorator.

-

From ./src/cat-owner.controller.ts

-
@Controller( '/cat/owner' )
-@Policy( { action: 'rename', subject: 'cat' } )
-export class CatOwnerController {
-	// Given the ability builder above, this method will always reject.
-	@Post( 'rename' )
-	public rename( @Body() _name: string ){
-		// ...
-	}
-}
-
-

-

This decorator can also be used to protect individual methods.

-

From ./src/cat-care.controller.ts

-
@Controller( '/cat/care' )
-export class CatCareController {
-	// Okay, you can feed.
-	@Get( 'feed' )
-	@Policy( { action: 'feed', subject: 'cat' } )
-	public feed(){
-		// ...
-	}
-
-	// Well, I guess he won't bite.
-	@Get( 'hug' )
-	@Policy( { action: 'hug', subject: 'cat' } )
-	public hug(){
-		// ...
-	}
-}
-
-

-

If you want to group various policies in the same decorator at the controller level, use the PoliciesMask decorator.

-

From ./src/cat.controller.ts

-
@Controller( '/cat' )
-@PoliciesMask( {
-	feed: { action: 'feed', subject: 'cat' },
-	hug: { action: 'hug', subject: 'cat' },
-	rename: { action: 'rename', subject: 'cat' },
-} )
-export class CatController {
-	@Get( 'feed' )
-	public feed(){
-		// ...
-	}
-
-	@Get( 'hug' )
-	public hug(){
-		// ...
-	}
-
-	@Post( 'rename' )
-	public rename( @Body() _name: string ){
-		// ...
-	}
-}
-
-

-

Check the tests !

-

From ./test/cats.e2e-spec.ts

-
describe( 'Basic usage', () => {
-	let app: INestApplication;
-
-	beforeAll( async () => {
-		const moduleRef = await Test.createTestingModule( {
-			imports: [ CaslModule.withConfig( { abilityFactory: AbilityFactory } ) ],
-			controllers: [
-				CatOwnerController, CatCareController, CatController,
-			],
-		} ).compile();
-
-		app = moduleRef.createNestApplication();
-		await app.init();
-	} );
-
-	describe( 'CatOwnerController', () => {
-		it( 'should not be able to rename a cat', () => request( app.getHttpServer() )
-			.post( '/cat/owner/rename' )
-			.expect( HttpStatus.FORBIDDEN ) );
-	} );
-	describe( 'CatCareController', () => {
-		it( 'should be able to feed the cat', () => request( app.getHttpServer() )
-			.get( '/cat/care/feed' )
-			.expect( HttpStatus.OK ) );
-		it( 'should be able to hug the cat', () => request( app.getHttpServer() )
-			.get( '/cat/care/hug' )
-			.expect( HttpStatus.OK ) );
-	} );
-	describe( 'PoliciesMask', () => {
-		it( 'should not be able to rename a cat', () => request( app.getHttpServer() )
-			.post( '/cat/rename' )
-			.expect( HttpStatus.FORBIDDEN ) );
-		it( 'should be able to feed the cat', () => request( app.getHttpServer() )
-			.get( '/cat/feed' )
-			.expect( HttpStatus.OK ) );
-		it( 'should be able to hug the cat', () => request( app.getHttpServer() )
-			.get( '/cat/hug' )
-			.expect( HttpStatus.OK ) );
-	} );
-} );
-
-

- -

What next ?

-
-

Use with guards

-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file diff --git a/docs/pages/Guides/use-with-guards.html b/docs/pages/Guides/use-with-guards.html deleted file mode 100644 index 53ecc0ac..00000000 --- a/docs/pages/Guides/use-with-guards.html +++ /dev/null @@ -1,572 +0,0 @@ - - - - - - Use with guards | @scitizen/nest-casl - - - - - - -
-
-
-
- -
-
- Options -
-
- All -
    -
  • Public
  • -
  • Public/Protected
  • -
  • All
  • -
-
- - - - - - -
-
- Menu -
-
-
-
-
-
- -

Use with guards

-
-
-
-
-
-
-
-

Most of the times, you want to execute some guards before checking CASL policies, to extract some user informations before generating its abilities.

-

This page will show you the various way to do.

-

Let's assume you have the following CaslAbilityFactory:

-

From ./src/ability-factory.service.ts

-
import { AbilityBuilder, PureAbility } from '@casl/ability';
-import { Injectable } from '@nestjs/common';
-
-import { CaslAbilityFactory } from '@scitizen/nest-casl';
-
-@Injectable()
-export class AbilityFactory implements CaslAbilityFactory {
-	// Here, `request` is the express or fastify request. You might get infos from it.
-	public createFromRequest( _request: unknown ): PureAbility {
-		const { user } = ( _request as any );
-		const abilityBuilder = new AbilityBuilder( PureAbility );
-		if( user?.role === 'admin' ) {
-			abilityBuilder.can( 'admin', 'something' );
-		}
-		return abilityBuilder.build();
-	}
-}
-
-

- -

The naïve approach

-
-
-

This method is not recommanded. You might skip directly to the recommended approach

-
- -

Without any more dependencies

-
-

This method does not require any external dependency, and is as close to NestJS as possible.

-

From ./src/guards/naive.guard.ts

-
import { CanActivate, ExecutionContext, UnauthorizedException } from '@nestjs/common';
-import { Request } from 'express';
-
-export class NaiveGuard implements CanActivate {
-	public canActivate( context: ExecutionContext ): boolean {
-		const request = context.switchToHttp().getRequest<Request>();
-		const authorization = request.header( 'Authorization' );
-		if( !authorization ){
-			// **BEWARE**: if the guard returns `false`, Nest will throw a `ForbiddenException` which is semantically incorrect here.
-			// The user is not *missing the right to do*, it is *not authenticated at all*.
-			throw new UnauthorizedException( 'Missing authorization header' );
-		}
-		const user = this._getUserFromAuthorization( authorization );
-		if( !user ){
-			return false;
-		}
-		( request as any ).user = user;
-		return true;
-	}
-
-	private _getUserFromAuthorization( authorization?: string ){
-		if( authorization === 'admin' ){
-			return { role: 'admin' };
-		} else if( authorization === 'user' ){
-			return { role: 'user' };
-		} else {
-			return undefined;
-		}
-	}
-}
-
-

-

Assuming the guard does the following (see above for an example implementation):

-
    -
  • Users without an Authorization header will see an Unauthorized exception.
  • -
  • Users with an invalid Authorization header will see a Forbidden exception.
  • -
  • Users with a valid Authorization header will be allowed to continue, and the property user is set on the request.
  • -
-
-

Yeah, I'm aware that in an ideal world, a Middleware or an Interceptor should take care of setting the user property on the Request. But fact is that @nestjs/passport does it in a guard

-
-

From ./src/controllers/naive.controller.ts

-
import { Controller, Get, UseGuards } from '@nestjs/common';
-
-import { Policy } from '@scitizen/nest-casl';
-
-import { NaiveGuard } from './naive.guard';
-
-@Controller( '/naive' )
-@Policy( { action: 'admin', subject: 'something' } ) // **MUST** be above the guard extracting infos from your request.
-@UseGuards( NaiveGuard )
-export class NaiveTestController {
-	@Get()
-	public method(){
-		// ...
-	}
-}
-
-

-

Now,

-
    -
  • Users without an Authorization header will see an Unauthorized exception (from the NaiveGuard).
  • -
  • Users with an invalid Authorization header will see a Forbidden exception (from the NaiveGuard).
  • -
  • Users with an Authorization header that does not give them access to the ressource will see a Forbidden exception (from the {@link PoliciesGuard PoliciesGuard}).
  • -
  • Users with an Authorization header that give them access to the ressource will succeed.
  • -
- -

Using @nestjs/passport

- -

If you're using passport, you can delegate the user retrieval. Let's say you have a JWT passport strategy.

-

From ./src/strategies/jwt-passport.strategy.ts

-
import { Injectable } from '@nestjs/common';
-import { PassportStrategy } from '@nestjs/passport';
-import { ExtractJwt, Strategy, StrategyOptions } from 'passport-jwt';
-
-@Injectable()
-export class JwtPassportStrategy extends PassportStrategy( Strategy, 'jwt' ) {
-	public static readonly KEY = 'this-is-a-secret';
-	public constructor(){
-		super( {
-			jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
-			secretOrKey: JwtPassportStrategy.KEY,
-		} as StrategyOptions );
-	}
-
-	public validate( user: any ){
-		return user;
-	}
-}
-
-

-

Still using the naive approach, you can then declare the controller like this:

-

From ./src/controllers/passport-naive.controller.ts

-
import { Controller, Get, UseGuards } from '@nestjs/common';
-import { AuthGuard } from '@nestjs/passport';
-
-import { Policy } from '@scitizen/nest-casl';
-
-@Controller( '/passport/naive' )
-@Policy( { action: 'admin', subject: 'something' } ) // **MUST** be above the guard extracting infos from your request.
-@UseGuards( AuthGuard( 'jwt' ) )
-export class PassportNaiveTestController {
-	@Get()
-	public method(){
-		// ...
-	}
-}
-
-

- -

The tests

-
-

Wanna see the behavior as tests ? Here you are !

-

From ./test/demo/use-with-guards/naive-test.e2e-spec.ts#1~77

-
import { HttpStatus, INestApplication } from '@nestjs/common';
-import { JwtModule, JwtService } from '@nestjs/jwt';
-import { Test } from '@nestjs/testing';
-import request from 'supertest';
-
-import { CaslModule } from '@scitizen/nest-casl';
-
-import { AbilityFactory } from './ability-factory.service';
-import { JwtPassportStrategy } from './jwt-passport.strategy';
-import { NaiveTestController } from './naive.controller';
-import { PassportNaiveTestController } from './passport-naive.controller';
-
-describe( 'Use with guards (naive)', () => {
-	let app: INestApplication;
-
-	describe( 'NaiveTestController', () => {
-		beforeAll( async () => {
-			const moduleRef = await Test.createTestingModule( {
-				imports: [
-					CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
-				],
-				controllers: [ NaiveTestController ],
-			} ).compile();
-
-			app = moduleRef.createNestApplication();
-			await app.init();
-		} );
-
-		it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
-			.get( '/naive' )
-			.expect( HttpStatus.UNAUTHORIZED )
-			.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Missing authorization header', error: 'Unauthorized' } ) );
-		it( 'should send a FORBIDDEN error if invalid authorization', () => request( app.getHttpServer() )
-			.get( '/naive' )
-			.set( 'Authorization', 'invalid' )
-			.expect( HttpStatus.FORBIDDEN )
-			.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Forbidden resource', error: 'Forbidden' } ) );
-		it( 'should send a FORBIDDEN error if invalid capabilities', () => request( app.getHttpServer() )
-			.get( '/naive' )
-			.set( 'Authorization', 'user' )
-			.expect( HttpStatus.FORBIDDEN )
-			.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\'t "admin" on "something"', error: 'Forbidden' } ) );
-		it( 'should work', () => request( app.getHttpServer() )
-			.get( '/naive' )
-			.set( 'Authorization', 'admin' )
-			.expect( HttpStatus.OK ) );
-	} );
-	describe( 'PassportNaiveTestController', () => {
-		beforeAll( async () => {
-			const moduleRef = await Test.createTestingModule( {
-				imports: [
-					CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
-					JwtModule.register( { secret: JwtPassportStrategy.KEY } ),
-				],
-				providers: [ JwtPassportStrategy ],
-				controllers: [ PassportNaiveTestController ],
-			} ).compile();
-
-			app = moduleRef.createNestApplication();
-			await app.init();
-		} );
-
-		it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
-			.get( '/passport/naive' )
-			.expect( HttpStatus.UNAUTHORIZED )
-			.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Unauthorized' } ) );
-		it( 'should send a FORBIDDEN error if invalid capabilities', () => request( app.getHttpServer() )
-			.get( '/passport/naive' )
-			.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'user' } )}` )
-			.expect( HttpStatus.FORBIDDEN )
-			.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\'t "admin" on "something"', error: 'Forbidden' } ) );
-		it( 'should work', () => request( app.getHttpServer() )
-			.get( '/passport/naive' )
-			.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'admin' } )}` )
-			.expect( HttpStatus.OK ) );
-	} );
-} );
-
-

- -

The recommended approach

-
-

What's the problem about the naïve approach above ? Well, there are 2.

-
    -
  1. The readability: The UseGuards decorator is placed below the Policy decorator, but is ran before it.
  2. -
  3. The reusability: If you're using multiple authentication strategies in the same app, you might have to apply guards and the policies on each method depending on the context. Moreover, if you want to type-check your policies, you might prefer to have abilities presets.
  4. -
- -

About readability

-
-

You can use Policy.usingGuard or PoliciesMask.usingGuard to prepended guards to the decorator factory. Those calls are cumulative, and you can do multiple subsequent calls to join guards using an and condition. If you provide an array of guards, they be evaluated using an or condition.

-

From ./src/controllers/recommended.controller.ts

-
@Controller( '/recommended' )
-@Policy( { action: 'admin', subject: 'something' } )
-	.usingGuard( AuthGuard( 'jwt' ) ) // The policy will run the guard before doing its own checks.
-export class RecommendedTestController {
-	@Get()
-	public method(){
-		// ...
-	}
-}
-
-

- -

About reusability

-
-

You can even prepare a policy decorator with guards or PolicyDescriptor:

-

From ./src/policies.ts

-
export const AdminViaJwtPolicy = Policy( { action: 'admin', subject: 'something' } )
-	.usingGuard( AuthGuard( 'jwt' ) );
-export const ViaJwtPolicy = Policy.usingGuard( AuthGuard( 'jwt' ) );
-
-

-

Then, use those presets in your controller:

-

From ./src/recommended-bound.controller.ts

-
@Injectable()
-export class ExtraGuard1 implements CanActivate {
-	public canActivate( context: ExecutionContext ): boolean {
-		if( !context.switchToHttp().getRequest().user.allowed1 ){
-			throw new BadRequestException( 'Not allowed from ExtraGuard1' );
-		}
-		return true;
-	}
-}
-@Injectable()
-export class ExtraGuard2 implements CanActivate {
-	public canActivate( context: ExecutionContext ): boolean {
-		return context.switchToHttp().getRequest().user.allowed2 ?? false;
-	}
-}
-
-@Controller( '/recommended/bound' )
-export class RecommendedBoundTestController {
-	@Get( 'method1' )
-	@AdminViaJwtPolicy
-		.usingGuard( [ ExtraGuard1, ExtraGuard2 ] ) // Add guards. When passed as an array, if either one can activate, it will continue
-	public method1(){
-		// ...
-	}
-
-	@Get( 'method2' )
-	@ViaJwtPolicy( { action: 'admin', subject: 'something' } )
-		.usingGuard( [ ExtraGuard1, ExtraGuard2 ] ) // Add guards. When passed as an array, if either one can activate, it will continue
-	public method2(){
-		// ...
-	}
-}
-
-

-

Now, both method1 and method2 will run if

-
    -
  • the user is authenticated through jwt strategy
  • -
  • it passes either ExtraGuard1 or ExtraGuard2
  • -
  • and he has admin role.
  • -
-
-

Note that you can use bindPolicyDecorators to bind both Policy and PoliciesMask

-
- -

The tests

-
-

This is tested, of course. Just see by yourself.

-

From ./test/demo/use-with-guards/recommended-test.e2e-spec.ts#1~90

-
import { HttpStatus, INestApplication } from '@nestjs/common';
-import { JwtModule, JwtService } from '@nestjs/jwt';
-import { Test } from '@nestjs/testing';
-import request from 'supertest';
-
-import { CaslModule } from '@scitizen/nest-casl';
-
-import { AbilityFactory } from './ability-factory.service';
-import { JwtPassportStrategy } from './jwt-passport.strategy';
-import { ExtraGuard1, ExtraGuard2, RecommendedBoundTestController, RecommendedTestController } from './recommended.controller';
-
-describe( 'Use with guards (recommended)', () => {
-	let app: INestApplication;
-
-	describe( 'RecommendedTestController', () => {
-		beforeAll( async () => {
-			const moduleRef = await Test.createTestingModule( {
-				imports: [
-					CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
-					JwtModule.register( { secret: JwtPassportStrategy.KEY } ),
-				],
-				providers: [ JwtPassportStrategy ],
-				controllers: [ RecommendedTestController ],
-			} ).compile();
-
-			app = moduleRef.createNestApplication();
-			await app.init();
-		} );
-
-		it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
-			.get( '/recommended' )
-			.expect( HttpStatus.UNAUTHORIZED )
-			.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Unauthorized' } ) );
-		it( 'should send a FORBIDDEN error if invalid capabilities', () => request( app.getHttpServer() )
-			.get( '/recommended' )
-			.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'user' } )}` )
-			.expect( HttpStatus.FORBIDDEN )
-			.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\'t "admin" on "something"', error: 'Forbidden' } ) );
-		it( 'should work', () => request( app.getHttpServer() )
-			.get( '/recommended' )
-			.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'admin' } )}` )
-			.expect( HttpStatus.OK ) );
-	} );
-	describe( 'RecommendedBoundTestController', () => {
-		beforeAll( async () => {
-			const moduleRef = await Test.createTestingModule( {
-				imports: [
-					CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
-					JwtModule.register( { secret: JwtPassportStrategy.KEY } ),
-				],
-				providers: [ JwtPassportStrategy, ExtraGuard1, ExtraGuard2 ],
-				controllers: [ RecommendedBoundTestController ],
-			} ).compile();
-
-			app = moduleRef.createNestApplication();
-			await app.init();
-		} );
-
-		describe.each( [ 'method1', 'method2' ] )( 'On method %s', method => {
-			const endpoint = `/recommended/bound/${method}`;
-			it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.expect( HttpStatus.UNAUTHORIZED )
-				.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Unauthorized' } ) );
-			it( 'should send a FORBIDDEN error if passing neither guard 1 nor 2, and throw error from guard 1', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'user', allowed1: false, allowed2: false } )}` )
-				.expect( HttpStatus.BAD_REQUEST )
-				.expect( { statusCode: HttpStatus.BAD_REQUEST, message: 'Not allowed from ExtraGuard1', error: 'Bad Request' } ) );
-			it( 'should send a FORBIDDEN error if passing guard 1 invalid capabilities', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'user', allowed1: true } )}` )
-				.expect( HttpStatus.FORBIDDEN )
-				.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\'t "admin" on "something"', error: 'Forbidden' } ) );
-			it( 'should send a FORBIDDEN error if passing guard 2 invalid capabilities', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'user', allowed2: true } )}` )
-				.expect( HttpStatus.FORBIDDEN )
-				.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\'t "admin" on "something"', error: 'Forbidden' } ) );
-			it( 'should work via guard 1', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'admin', allowed1: true } )}` )
-				.expect( HttpStatus.OK ) );
-			it( 'should work via guard 2', () => request( app.getHttpServer() )
-				.get( endpoint )
-				.set( 'Authorization', `Bearer ${app.get( JwtService ).sign( { role: 'admin', allowed2: true } )}` )
-				.expect( HttpStatus.OK ) );
-		} );
-	} );
-} );
-
-

- -

What next ?

-
-

Better type constraints

-
-
- -
-
-
-
-

Legend

-
-
    -
  • Property
  • -
  • Method
  • -
-
    -
  • Constructor
  • -
-
    -
  • Static method
  • -
-
-
-
-
-

Generated using TypeDoc

-
-
- - - - \ No newline at end of file diff --git a/docs/pages/guide/better-type-constraints.html b/docs/pages/guide/better-type-constraints.html new file mode 100644 index 00000000..9ca2275f --- /dev/null +++ b/docs/pages/guide/better-type-constraints.html @@ -0,0 +1,48 @@ +Better type constraints | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Better type constraints

So far, we were able to configure your policies. But we can't yet check that our actions or subjects are actually matching what we declared.

+ + +

Define the ability type

+
+

Let's configure our ability types:

+

From ./test/demo/better-types/ability.ts

import { Ability } from '@casl/ability';

export type MyAbilities =
| ['admin', 'ImportantData']
| ['create' | 'read' | 'update' | 'delete', 'PublicData' ];
export type MyAbility = Ability<MyAbilities>;
+
+
+ +

Using MyAbility, we can't pass anything to can or cannot: types are constrained.

+

From ./test/demo/better-types/ability.typecheck.e2e-spec.ts

import { expectTypeOf } from 'expect-type';

import { MyAbility } from './ability';

it( 'ability should have correct typings', () => {
expectTypeOf<['read', 'PublicData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();
expectTypeOf<['create', 'PublicData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();
expectTypeOf<['admin', 'ImportantData']>().toMatchTypeOf<Parameters<MyAbility['can']>>();

expectTypeOf<['admin', 'PublicData']>().not.toMatchTypeOf<Parameters<MyAbility['can']>>();
expectTypeOf<['read', 'ImportantData']>().not.toMatchTypeOf<Parameters<MyAbility['can']>>();
} );
+
+
+ +

That's great. This will greatly reduce our chances of typos. Moreover, your IDE might now suggest actions & subjects for you.

+ + +

Use the ability type

+
+ + +

With the CaslAbilityFactory

+ +

Let's now use this type in your CaslAbilityFactory:

+

From src/ability-factory.service.ts

import { AbilityBuilder, PureAbility } from '@casl/ability';
import { Injectable } from '@nestjs/common';

import { CaslAbilityFactory } from '@knodes/nest-casl';

import { MyAbility } from './ability';

@Injectable()
export class AbilityFactory implements CaslAbilityFactory<MyAbility> {
// Here, \`request\` is the express or fastify request. You might get infos from it.
public createFromRequest( _request: unknown ): MyAbility {
const { user } = ( _request as any );
const abilityBuilder = new AbilityBuilder<MyAbility>( PureAbility );
if( user?.role === 'admin' ) {
abilityBuilder.can( 'admin', 'ImportantData' );
}
return abilityBuilder.build();
}
}
+
+
+ + + +

With decorators

+
+

You can pass your ability as a type parameter to your decorators to constraint your actions and subjects:

+

From src/test.controller.ts

import { Controller, Get } from '@nestjs/common';

import { Policy } from '@knodes/nest-casl';

import { MyAbility } from './ability';

@Controller()
// @ts-expect-error -- \`something\` is not a valid subject
@Policy<MyAbility>( { action: 'admin', subject: 'something' } )
// @ts-expect-error -- \`rick-roll\` is not a valid action
@Policy<MyAbility>( { action: 'rick-roll', subject: 'ImportantData' } )
// @ts-expect-error -- \`read\` is not a valid action on \`ImportantData\`
@Policy<MyAbility>( { action: 'read', subject: 'ImportantData' } )
@Policy<MyAbility>( { action: 'read', subject: 'PublicData' } )
// ...
export class TestController {
@Get()
public method(){
// ...
}
}
+
+
+ +

But the boring part here is that you have to pass your ability type to every decorator in order to constrain them. Hopefully, you can solve this:

+

From src/my-policies.ts

import { bindPolicyDecorators } from '@knodes/nest-casl';

import { MyAbility } from './ability';

export const MyPolicies = bindPolicyDecorators<MyAbility>( /* you can even pass some guards here ! */ );
+
+
+ +

Then, simply enjoy type contraints !

+

From src/test-bound.controller.ts

import { Controller, Get } from '@nestjs/common';

import { MyPolicies } from './my-policies';

@Controller()
@MyPolicies.PoliciesMask( {
'*': { action: 'admin', subject: 'ImportantData' },
'read': { action: 'read', subject: 'PublicData' },
'create': { action: 'create', subject: 'PublicData' },
} )
export class TestController {
@Get()
@MyPolicies.Policy( { handle: ability => ability.can( 'read', 'PublicData' ) } )
public create(){
// ...
}
@Get()
public read(){
// ...
}

@Get()
public admin(){
// ...
}
}
+
+
+

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/pages/guide/getting-started.html b/docs/pages/guide/getting-started.html new file mode 100644 index 00000000..13851b16 --- /dev/null +++ b/docs/pages/guide/getting-started.html @@ -0,0 +1,51 @@ +Getting started | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Getting started

+

This module is compatible with nestjs@^8.0.0.

+
+ + +

Setup & configuration

+
+

First, install the module:

+
npm install @knodes/nest-casl
+
+

Then, declare a provider that generate a CASL Ability from the current request.

+

From src/ability-factory.service.ts

@Injectable()
export class AbilityFactory implements CaslAbilityFactory {
// Here, \`request\` is the express or fastify request. You might get infos from it.
public createFromRequest( _request: unknown ): PureAbility {
const abilityBuilder = new AbilityBuilder( PureAbility );
abilityBuilder.can( 'feed', 'cat' );
abilityBuilder.can( 'hug', 'cat' );
abilityBuilder.cannot( 'rename', 'cat' );
return abilityBuilder.build();
}
} +
+
+ +

Import the CaslModule in your AppModule, and configure it to use your ability factory.

+

From src/app.module.ts

@Module( {
imports: [
CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
// ....
],
} )
export class AppModule {} +
+
+ +

You can now start using policy decorators (Policy and PoliciesMask) in your controllers !

+ + +

Basic usage

+
+

You can protect all methods of your controller using the Policy class decorator.

+

From src/cat-owner.controller.ts

@Controller( '/cat/owner' )
@Policy( { action: 'rename', subject: 'cat' } )
export class CatOwnerController {
// Given the ability builder above, this method will always reject.
@Post( 'rename' )
public rename( @Body() _name: string ){
// ...
}
} +
+
+ +

This decorator can also be used to protect individual methods.

+

From src/cat-care.controller.ts

@Controller( '/cat/care' )
export class CatCareController {
// Okay, you can feed.
@Get( 'feed' )
@Policy( { action: 'feed', subject: 'cat' } )
public feed(){
// ...
}

// Well, I guess he won't bite.
@Get( 'hug' )
@Policy( { action: 'hug', subject: 'cat' } )
public hug(){
// ...
}
} +
+
+ +

If you want to group various policies in the same decorator at the controller level, use the PoliciesMask decorator.

+

From src/cat.controller.ts

@Controller( '/cat' )
@PoliciesMask( {
feed: { action: 'feed', subject: 'cat' },
hug: { action: 'hug', subject: 'cat' },
rename: { action: 'rename', subject: 'cat' },
} )
export class CatController {
@Get( 'feed' )
public feed(){
// ...
}

@Get( 'hug' )
public hug(){
// ...
}

@Post( 'rename' )
public rename( @Body() _name: string ){
// ...
}
} +
+
+ +

Check the tests !

+

From test/cats.e2e-spec.ts

describe( 'Basic usage', () => {
let app: INestApplication;

beforeAll( async () => {
const moduleRef = await Test.createTestingModule( {
imports: [ CaslModule.withConfig( { abilityFactory: AbilityFactory } ) ],
controllers: [
CatOwnerController, CatCareController, CatController,
],
} ).compile();

app = moduleRef.createNestApplication();
await app.init();
} );

describe( 'CatOwnerController', () => {
it( 'should not be able to rename a cat', () => request( app.getHttpServer() )
.post( '/cat/owner/rename' )
.expect( HttpStatus.FORBIDDEN ) );
} );
describe( 'CatCareController', () => {
it( 'should be able to feed the cat', () => request( app.getHttpServer() )
.get( '/cat/care/feed' )
.expect( HttpStatus.OK ) );
it( 'should be able to hug the cat', () => request( app.getHttpServer() )
.get( '/cat/care/hug' )
.expect( HttpStatus.OK ) );
} );
describe( 'PoliciesMask', () => {
it( 'should not be able to rename a cat', () => request( app.getHttpServer() )
.post( '/cat/rename' )
.expect( HttpStatus.FORBIDDEN ) );
it( 'should be able to feed the cat', () => request( app.getHttpServer() )
.get( '/cat/feed' )
.expect( HttpStatus.OK ) );
it( 'should be able to hug the cat', () => request( app.getHttpServer() )
.get( '/cat/hug' )
.expect( HttpStatus.OK ) );
} );
} ); +
+
+ + + +

What next ?

+
+

Use with guards

+

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/docs/pages/guide/use-with-guards.html b/docs/pages/guide/use-with-guards.html new file mode 100644 index 00000000..3a1ac52c --- /dev/null +++ b/docs/pages/guide/use-with-guards.html @@ -0,0 +1,119 @@ +Use with guards | @knodes/nest-casl
Options
All
  • Public
  • Public/Protected
  • All
Menu

Use with guards

Most of the times, you want to execute some guards before checking CASL policies, to extract some user informations before generating its abilities.

+

This page will show you the various way to do.

+

Let's assume you have the following CaslAbilityFactory:

+

From src/ability-factory.service.ts

import { AbilityBuilder, PureAbility } from '@casl/ability';
import { Injectable } from '@nestjs/common';

import { CaslAbilityFactory } from '@knodes/nest-casl';

@Injectable()
export class AbilityFactory implements CaslAbilityFactory {
// Here, \`request\` is the express or fastify request. You might get infos from it.
public createFromRequest( _request: unknown ): PureAbility {
const { user } = ( _request as any );
const abilityBuilder = new AbilityBuilder( PureAbility );
if( user?.role === 'admin' ) {
abilityBuilder.can( 'admin', 'something' );
}
return abilityBuilder.build();
}
}
+
+
+ + + +

The naïve approach

+
+
+

This method is not recommanded. You might skip directly to the recommended approach

+
+ + +

Without any more dependencies

+
+

This method does not require any external dependency, and is as close to NestJS as possible.

+

From src/guards/naive.guard.ts

import { CanActivate, ExecutionContext, UnauthorizedException } from '@nestjs/common';
import { Request } from 'express';

export class NaiveGuard implements CanActivate {
public canActivate( context: ExecutionContext ): boolean {
const request = context.switchToHttp().getRequest<Request>();
const authorization = request.header( 'Authorization' );
if( !authorization ){
// **BEWARE**: if the guard returns \`false\`, Nest will throw a \`ForbiddenException\` which is semantically incorrect here.
// The user is not *missing the right to do*, it is *not authenticated at all*.
throw new UnauthorizedException( 'Missing authorization header' );
}
const user = this._getUserFromAuthorization( authorization );
if( !user ){
return false;
}
( request as any ).user = user;
return true;
}

private _getUserFromAuthorization( authorization?: string ){
if( authorization === 'admin' ){
return { role: 'admin' };
} else if( authorization === 'user' ){
return { role: 'user' };
} else {
return undefined;
}
}
}
+
+
+ +

Assuming the guard does the following (see above for an example implementation):

+
    +
  • Users without an Authorization header will see an Unauthorized exception.
  • +
  • Users with an invalid Authorization header will see a Forbidden exception.
  • +
  • Users with a valid Authorization header will be allowed to continue, and the property user is set on the request.
  • +
+
+

Yeah, I'm aware that in an ideal world, a Middleware or an Interceptor should take care of setting the user property on the Request. But fact is that @nestjs/passport does it in a guard

+
+

From src/controllers/naive.controller.ts

import { Controller, Get, UseGuards } from '@nestjs/common';

import { Policy } from '@knodes/nest-casl';

import { NaiveGuard } from './naive.guard';

@Controller( '/naive' )
@Policy( { action: 'admin', subject: 'something' } ) // **MUST** be above the guard extracting infos from your request.
@UseGuards( NaiveGuard )
export class NaiveTestController {
@Get()
public method(){
// ...
}
}
+
+
+ +

Now,

+
    +
  • Users without an Authorization header will see an Unauthorized exception (from the NaiveGuard).
  • +
  • Users with an invalid Authorization header will see a Forbidden exception (from the NaiveGuard).
  • +
  • Users with an Authorization header that does not give them access to the ressource will see a Forbidden exception (from the {@link PoliciesGuard PoliciesGuard}).
  • +
  • Users with an Authorization header that give them access to the ressource will succeed.
  • +
+ + +

Using @nestjs/passport

+ +

If you're using passport, you can delegate the user retrieval. Let's say you have a JWT passport strategy.

+

From src/strategies/jwt-passport.strategy.ts

import { Injectable } from '@nestjs/common';
import { PassportStrategy } from '@nestjs/passport';
import { ExtractJwt, Strategy, StrategyOptions } from 'passport-jwt';

@Injectable()
export class JwtPassportStrategy extends PassportStrategy( Strategy, 'jwt' ) {
public static readonly KEY = 'this-is-a-secret';
public constructor(){
super( {
jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
secretOrKey: JwtPassportStrategy.KEY,
} as StrategyOptions );
}

public validate( user: any ){
return user;
}
}
+
+
+ +

Still using the naive approach, you can then declare the controller like this:

+

From src/controllers/passport-naive.controller.ts

import { Controller, Get, UseGuards } from '@nestjs/common';
import { AuthGuard } from '@nestjs/passport';

import { Policy } from '@knodes/nest-casl';

@Controller( '/passport/naive' )
@Policy( { action: 'admin', subject: 'something' } ) // **MUST** be above the guard extracting infos from your request.
@UseGuards( AuthGuard( 'jwt' ) )
export class PassportNaiveTestController {
@Get()
public method(){
// ...
}
}
+
+
+ + + +

The tests

+
+

Wanna see the behavior as tests ? Here you are !

+

From ./test/demo/use-with-guards/naive-test.e2e-spec.ts

import { HttpStatus, INestApplication } from '@nestjs/common';
import { JwtModule, JwtService } from '@nestjs/jwt';
import { Test } from '@nestjs/testing';
import request from 'supertest';

import { CaslModule } from '@knodes/nest-casl';

import { AbilityFactory } from './ability-factory.service';
import { JwtPassportStrategy } from './jwt-passport.strategy';
import { NaiveTestController } from './naive.controller';
import { PassportNaiveTestController } from './passport-naive.controller';

describe( 'Use with guards (naive)', () => {
let app: INestApplication;

describe( 'NaiveTestController', () => {
beforeAll( async () => {
const moduleRef = await Test.createTestingModule( {
imports: [
CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
],
controllers: [ NaiveTestController ],
} ).compile();

app = moduleRef.createNestApplication();
await app.init();
} );

it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
.get( '/naive' )
.expect( HttpStatus.UNAUTHORIZED )
.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Missing authorization header', error: 'Unauthorized' } ) );
it( 'should send a FORBIDDEN error if invalid authorization', () => request( app.getHttpServer() )
.get( '/naive' )
.set( 'Authorization', 'invalid' )
.expect( HttpStatus.FORBIDDEN )
.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Forbidden resource', error: 'Forbidden' } ) );
it( 'should send a FORBIDDEN error if invalid capabilities', () => request( app.getHttpServer() )
.get( '/naive' )
.set( 'Authorization', 'user' )
.expect( HttpStatus.FORBIDDEN )
.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\\'t "admin" on "something"', error: 'Forbidden' } ) );
it( 'should work', () => request( app.getHttpServer() )
.get( '/naive' )
.set( 'Authorization', 'admin' )
.expect( HttpStatus.OK ) );
} );
describe( 'PassportNaiveTestController', () => {
beforeAll( async () => {
const moduleRef = await Test.createTestingModule( {
imports: [
CaslModule.withConfig( ( { abilityFactory: AbilityFactory } ) ),
JwtModule.register( { secret: JwtPassportStrategy.KEY } ),
],
providers: [ JwtPassportStrategy ],
controllers: [ PassportNaiveTestController ],
} ).compile();

app = moduleRef.createNestApplication();
await app.init();
} );

it( 'should send an UNAUTHORIZED error if no authorization set', () => request( app.getHttpServer() )
.get( '/passport/naive' )
.expect( HttpStatus.UNAUTHORIZED )
.expect( { statusCode: HttpStatus.UNAUTHORIZED, message: 'Unauthorized' } ) );
it( 'should send a FORBIDDEN error if invalid capabilities', () => request( app.getHttpServer() )
.get( '/passport/naive' )
.set( 'Authorization', \`Bearer ${app.get( JwtService ).sign( { role: 'user' } )}\` )
.expect( HttpStatus.FORBIDDEN )
.expect( { statusCode: HttpStatus.FORBIDDEN, message: 'Invalid authorizations: Can\\'t "admin" on "something"', error: 'Forbidden' } ) );
it( 'should work', () => request( app.getHttpServer() )
.get( '/passport/naive' )
.set( 'Authorization', \`Bearer ${app.get( JwtService ).sign( { role: 'admin' } )}\` )
.expect( HttpStatus.OK ) );
} );
} );
+
+
+ + + +

The recommended approach

+
+

What's the problem about the naïve approach above ? Well, there are 2.

+
    +
  1. The readability: The UseGuards decorator is placed below the Policy decorator, but is ran before it.
  2. +
  3. The reusability: If you're using multiple authentication strategies in the same app, you might have to apply guards and the policies on each method depending on the context. Moreover, if you want to type-check your policies, you might prefer to have abilities presets.
  4. +
+ + +

About readability

+
+

You can use Policy.usingGuard or PoliciesMask.usingGuard to prepended guards to the decorator factory. Those calls are cumulative, and you can do multiple subsequent calls to join guards using an and condition. If you provide an array of guards, they be evaluated using an or condition.

+

From src/controllers/recommended.controller.ts

@Controller( '/recommended' )
@Policy( { action: 'admin', subject: 'something' } )
.usingGuard( AuthGuard( 'jwt' ) ) // The policy will run the guard before doing its own checks.
export class RecommendedTestController {
@Get()
public method(){
// ...
}
} +
+
+ + + +

About reusability

+
+

You can even prepare a policy decorator with guards or PolicyDescriptor:

+

From src/policies.ts

export const AdminViaJwtPolicy = Policy( { action: 'admin', subject: 'something' } )
.usingGuard( AuthGuard( 'jwt' ) );
export const ViaJwtPolicy = Policy.usingGuard( AuthGuard( 'jwt' ) ); +
+
+ +

Then, use those presets in your controller:

+

From src/recommended-bound.controller.ts

@Injectable()
export class ExtraGuard1 implements CanActivate {
public canActivate( context: ExecutionContext ): boolean {
if( !context.switchToHttp().getRequest().user.allowed1 ){
throw new BadRequestException( 'Not allowed from ExtraGuard1' );
}
return true;
}
}
@Injectable()
export class ExtraGuard2 implements CanActivate {
public canActivate( context: ExecutionContext ): boolean {
return context.switchToHttp().getRequest().user.allowed2 ?? false;
}
}

@Controller( '/recommended/bound' )
export class RecommendedBoundTestController {
@Get( 'method1' )
@AdminViaJwtPolicy
.usingGuard( [ ExtraGuard1, ExtraGuard2 ] ) // Add guards. When passed as an array, if either one can activate, it will continue
public method1(){
// ...
}

@Get( 'method2' )
@ViaJwtPolicy( { action: 'admin', subject: 'something' } )
.usingGuard( [ ExtraGuard1, ExtraGuard2 ] ) // Add guards. When passed as an array, if either one can activate, it will continue
public method2(){
// ...
}
} +
+
+ +

Now, both method1 and method2 will run if

+
    +
  • the user is authenticated through jwt strategy
  • +
  • it passes either ExtraGuard1 or ExtraGuard2
  • +
  • and he has admin role.
  • +
+
+

Note that you can use bindPolicyDecorators to bind both Policy and PoliciesMask

+
+ + +

The tests

+
+

This is tested, of course. Just see by yourself.

+

{@codeblock folded use-with-guards/recommended-test.e2e-spec.ts}

+ + +

What next ?

+
+

Better type constraints

+

Legend

  • Property
  • Method
  • Constructor
  • Static method

Settings

Theme

Generated using TypeDoc

\ No newline at end of file diff --git a/package-lock.json b/package-lock.json index fea5d2ec..a44b2c21 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "@knodes/nest-casl", - "version": "0.0.2", + "version": "0.0.3-next.0", "lockfileVersion": 1, "requires": true, "dependencies": { diff --git a/package.json b/package.json index d00cd656..a46b6693 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@knodes/nest-casl", - "version": "0.0.2", + "version": "0.0.3-next.0", "description": "A module for managing authorization in your nest application, using casl.", "license": "MIT", "engines": {