diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 000000000..e2ac6616a --- /dev/null +++ b/.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/assets/highlight.css b/assets/highlight.css new file mode 100644 index 000000000..5674cf392 --- /dev/null +++ b/assets/highlight.css @@ -0,0 +1,22 @@ +:root { + --light-code-background: #FFFFFF; + --dark-code-background: #1E1E1E; +} + +@media (prefers-color-scheme: light) { :root { + --code-background: var(--light-code-background); +} } + +@media (prefers-color-scheme: dark) { :root { + --code-background: var(--dark-code-background); +} } + +:root[data-theme='light'] { + --code-background: var(--light-code-background); +} + +:root[data-theme='dark'] { + --code-background: var(--dark-code-background); +} + +pre, code { background: var(--code-background); } diff --git a/assets/icons.js b/assets/icons.js new file mode 100644 index 000000000..3dfbd322d --- /dev/null +++ b/assets/icons.js @@ -0,0 +1,18 @@ +(function() { + addIcons(); + function addIcons() { + if (document.readyState === "loading") return document.addEventListener("DOMContentLoaded", addIcons); + const svg = document.body.appendChild(document.createElementNS("http://www.w3.org/2000/svg", "svg")); + svg.innerHTML = `MMNEPVFCICPMFPCPTTAAATR`; + svg.style.display = "none"; + if (location.protocol === "file:") updateUseElements(); + } + + function updateUseElements() { + document.querySelectorAll("use").forEach(el => { + if (el.getAttribute("href").includes("#icon-")) { + el.setAttribute("href", el.getAttribute("href").replace(/.*#/, "#")); + } + }); + } +})() \ No newline at end of file diff --git a/assets/icons.svg b/assets/icons.svg new file mode 100644 index 000000000..a19417dcc --- /dev/null +++ b/assets/icons.svg @@ -0,0 +1 @@ +MMNEPVFCICPMFPCPTTAAATR \ No newline at end of file diff --git a/assets/main.js b/assets/main.js new file mode 100644 index 000000000..99097a053 --- /dev/null +++ b/assets/main.js @@ -0,0 +1,60 @@ +"use strict"; +window.translations={"copy":"Copy","copied":"Copied!","normally_hidden":"This member is normally hidden due to your filter settings."}; +"use strict";(()=>{var Pe=Object.create;var ie=Object.defineProperty;var Oe=Object.getOwnPropertyDescriptor;var _e=Object.getOwnPropertyNames;var Re=Object.getPrototypeOf,Me=Object.prototype.hasOwnProperty;var Fe=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var De=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of _e(e))!Me.call(t,i)&&i!==n&&ie(t,i,{get:()=>e[i],enumerable:!(r=Oe(e,i))||r.enumerable});return t};var Ae=(t,e,n)=>(n=t!=null?Pe(Re(t)):{},De(e||!t||!t.__esModule?ie(n,"default",{value:t,enumerable:!0}):n,t));var ue=Fe((ae,le)=>{(function(){var t=function(e){var n=new t.Builder;return n.pipeline.add(t.trimmer,t.stopWordFilter,t.stemmer),n.searchPipeline.add(t.stemmer),e.call(n,n),n.build()};t.version="2.3.9";t.utils={},t.utils.warn=function(e){return function(n){e.console&&console.warn&&console.warn(n)}}(this),t.utils.asString=function(e){return e==null?"":e.toString()},t.utils.clone=function(e){if(e==null)return e;for(var n=Object.create(null),r=Object.keys(e),i=0;i0){var d=t.utils.clone(n)||{};d.position=[a,u],d.index=s.length,s.push(new t.Token(r.slice(a,o),d))}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,n){n in this.registeredFunctions&&t.utils.warn("Overwriting existing registered function: "+n),e.label=n,t.Pipeline.registeredFunctions[e.label]=e},t.Pipeline.warnIfFunctionNotRegistered=function(e){var n=e.label&&e.label in this.registeredFunctions;n||t.utils.warn(`Function is not registered with pipeline. This may cause problems when serialising the index. +`,e)},t.Pipeline.load=function(e){var n=new t.Pipeline;return e.forEach(function(r){var i=t.Pipeline.registeredFunctions[r];if(i)n.add(i);else throw new Error("Cannot load unregistered function: "+r)}),n},t.Pipeline.prototype.add=function(){var e=Array.prototype.slice.call(arguments);e.forEach(function(n){t.Pipeline.warnIfFunctionNotRegistered(n),this._stack.push(n)},this)},t.Pipeline.prototype.after=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");r=r+1,this._stack.splice(r,0,n)},t.Pipeline.prototype.before=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var r=this._stack.indexOf(e);if(r==-1)throw new Error("Cannot find existingFn");this._stack.splice(r,0,n)},t.Pipeline.prototype.remove=function(e){var n=this._stack.indexOf(e);n!=-1&&this._stack.splice(n,1)},t.Pipeline.prototype.run=function(e){for(var n=this._stack.length,r=0;r1&&(oe&&(r=s),o!=e);)i=r-n,s=n+Math.floor(i/2),o=this.elements[s*2];if(o==e||o>e)return s*2;if(ol?d+=2:a==l&&(n+=r[u+1]*i[d+1],u+=2,d+=2);return n},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),n=1,r=0;n0){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 l=s.node.edges["*"];else{var l=new t.TokenSet;s.node.edges["*"]=l}if(s.str.length==0&&(l.final=!0),i.push({node:l,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 u=s.node.edges["*"];else{var u=new t.TokenSet;s.node.edges["*"]=u}s.str.length==1&&(u.final=!0),i.push({node:u,editsRemaining:s.editsRemaining-1,str:s.str.slice(1)})}if(s.str.length>1){var d=s.str.charAt(0),m=s.str.charAt(1),p;m in s.node.edges?p=s.node.edges[m]:(p=new t.TokenSet,s.node.edges[m]=p),s.str.length==1&&(p.final=!0),i.push({node:p,editsRemaining:s.editsRemaining-1,str:d+s.str.slice(2)})}}}return r},t.TokenSet.fromString=function(e){for(var n=new t.TokenSet,r=n,i=0,s=e.length;i=e;n--){var r=this.uncheckedNodes[n],i=r.child.toString();i in this.minimizedNodes?r.parent.edges[r.char]=this.minimizedNodes[i]:(r.child._str=i,this.minimizedNodes[i]=r.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(n){var r=new t.QueryParser(e,n);r.parse()})},t.Index.prototype.query=function(e){for(var n=new t.Query(this.fields),r=Object.create(null),i=Object.create(null),s=Object.create(null),o=Object.create(null),a=Object.create(null),l=0;l1?this._b=1:this._b=e},t.Builder.prototype.k1=function(e){this._k1=e},t.Builder.prototype.add=function(e,n){var r=e[this._ref],i=Object.keys(this._fields);this._documents[r]=n||{},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,n;do e=this.next(),n=e.charCodeAt(0);while(n>47&&n<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 n=e.next();if(n==t.QueryLexer.EOS)return t.QueryLexer.lexEOS;if(n.charCodeAt(0)==92){e.escapeCharacter();continue}if(n==":")return t.QueryLexer.lexField;if(n=="~")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexEditDistance;if(n=="^")return e.backup(),e.width()>0&&e.emit(t.QueryLexer.TERM),t.QueryLexer.lexBoost;if(n=="+"&&e.width()===1||n=="-"&&e.width()===1)return e.emit(t.QueryLexer.PRESENCE),t.QueryLexer.lexText;if(n.match(t.QueryLexer.termSeparator))return t.QueryLexer.lexTerm}},t.QueryParser=function(e,n){this.lexer=new t.QueryLexer(e),this.query=n,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 n=e.peekLexeme();if(n!=null)switch(n.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 r="expected either a field or a term, found "+n.type;throw n.str.length>=1&&(r+=" with value '"+n.str+"'"),new t.QueryParseError(r,n.start,n.end)}},t.QueryParser.parsePresence=function(e){var n=e.consumeLexeme();if(n!=null){switch(n.str){case"-":e.currentClause.presence=t.Query.presence.PROHIBITED;break;case"+":e.currentClause.presence=t.Query.presence.REQUIRED;break;default:var r="unrecognised presence operator'"+n.str+"'";throw new t.QueryParseError(r,n.start,n.end)}var i=e.peekLexeme();if(i==null){var r="expecting term or field, found nothing";throw new t.QueryParseError(r,n.start,n.end)}switch(i.type){case t.QueryLexer.FIELD:return t.QueryParser.parseField;case t.QueryLexer.TERM:return t.QueryParser.parseTerm;default:var r="expecting term or field, found '"+i.type+"'";throw new t.QueryParseError(r,i.start,i.end)}}},t.QueryParser.parseField=function(e){var n=e.consumeLexeme();if(n!=null){if(e.query.allFields.indexOf(n.str)==-1){var r=e.query.allFields.map(function(o){return"'"+o+"'"}).join(", "),i="unrecognised field '"+n.str+"', possible fields: "+r;throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.fields=[n.str];var s=e.peekLexeme();if(s==null){var i="expecting term, found nothing";throw new t.QueryParseError(i,n.start,n.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 n=e.consumeLexeme();if(n!=null){e.currentClause.term=n.str.toLowerCase(),n.str.indexOf("*")!=-1&&(e.currentClause.usePipeline=!1);var r=e.peekLexeme();if(r==null){e.nextClause();return}switch(r.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 '"+r.type+"'";throw new t.QueryParseError(i,r.start,r.end)}}},t.QueryParser.parseEditDistance=function(e){var n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="edit distance must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.editDistance=r;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 n=e.consumeLexeme();if(n!=null){var r=parseInt(n.str,10);if(isNaN(r)){var i="boost must be numeric";throw new t.QueryParseError(i,n.start,n.end)}e.currentClause.boost=r;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,n){typeof define=="function"&&define.amd?define(n):typeof ae=="object"?le.exports=n():e.lunr=n()}(this,function(){return t})})()});var se=[];function G(t,e){se.push({selector:e,constructor:t})}var U=class{constructor(){this.alwaysVisibleMember=null;this.createComponents(document.body),this.ensureFocusedElementVisible(),this.listenForCodeCopies(),window.addEventListener("hashchange",()=>this.ensureFocusedElementVisible()),document.body.style.display||(this.ensureFocusedElementVisible(),this.updateIndexVisibility(),this.scrollToHash())}createComponents(e){se.forEach(n=>{e.querySelectorAll(n.selector).forEach(r=>{r.dataset.hasInstance||(new n.constructor({el:r,app:this}),r.dataset.hasInstance=String(!0))})})}filterChanged(){this.ensureFocusedElementVisible()}showPage(){document.body.style.display&&(document.body.style.removeProperty("display"),this.ensureFocusedElementVisible(),this.updateIndexVisibility(),this.scrollToHash())}scrollToHash(){if(location.hash){let e=document.getElementById(location.hash.substring(1));if(!e)return;e.scrollIntoView({behavior:"instant",block:"start"})}}ensureActivePageVisible(){let e=document.querySelector(".tsd-navigation .current"),n=e?.parentElement;for(;n&&!n.classList.contains(".tsd-navigation");)n instanceof HTMLDetailsElement&&(n.open=!0),n=n.parentElement;if(e&&!Ve(e)){let r=e.getBoundingClientRect().top-document.documentElement.clientHeight/4;document.querySelector(".site-menu").scrollTop=r,document.querySelector(".col-sidebar").scrollTop=r}}updateIndexVisibility(){let e=document.querySelector(".tsd-index-content"),n=e?.open;e&&(e.open=!0),document.querySelectorAll(".tsd-index-section").forEach(r=>{r.style.display="block";let i=Array.from(r.querySelectorAll(".tsd-index-link")).every(s=>s.offsetParent==null);r.style.display=i?"none":"block"}),e&&(e.open=n)}ensureFocusedElementVisible(){if(this.alwaysVisibleMember&&(this.alwaysVisibleMember.classList.remove("always-visible"),this.alwaysVisibleMember.firstElementChild.remove(),this.alwaysVisibleMember=null),!location.hash)return;let e=document.getElementById(location.hash.substring(1));if(!e)return;let n=e.parentElement;for(;n&&n.tagName!=="SECTION";)n=n.parentElement;if(!n)return;let r=n.offsetParent==null,i=n;for(;i!==document.body;)i instanceof HTMLDetailsElement&&(i.open=!0),i=i.parentElement;if(n.offsetParent==null){this.alwaysVisibleMember=n,n.classList.add("always-visible");let s=document.createElement("p");s.classList.add("warning"),s.textContent=window.translations.normally_hidden,n.prepend(s)}r&&e.scrollIntoView()}listenForCodeCopies(){document.querySelectorAll("pre > button").forEach(e=>{let n;e.addEventListener("click",()=>{e.previousElementSibling instanceof HTMLElement&&navigator.clipboard.writeText(e.previousElementSibling.innerText.trim()),e.textContent=window.translations.copied,e.classList.add("visible"),clearTimeout(n),n=setTimeout(()=>{e.classList.remove("visible"),n=setTimeout(()=>{e.textContent=window.translations.copy},100)},1e3)})})}};function Ve(t){let e=t.getBoundingClientRect(),n=Math.max(document.documentElement.clientHeight,window.innerHeight);return!(e.bottom<0||e.top-n>=0)}var oe=(t,e=100)=>{let n;return()=>{clearTimeout(n),n=setTimeout(()=>t(),e)}};var pe=Ae(ue());async function ce(t,e){if(!window.searchData)return;let n=await fetch(window.searchData),r=new Blob([await n.arrayBuffer()]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();t.data=i,t.index=pe.Index.load(i.index),e.classList.remove("loading"),e.classList.add("ready")}function fe(){let t=document.getElementById("tsd-search");if(!t)return;let e={base:t.dataset.base+"/"},n=document.getElementById("tsd-search-script");t.classList.add("loading"),n&&(n.addEventListener("error",()=>{t.classList.remove("loading"),t.classList.add("failure")}),n.addEventListener("load",()=>{ce(e,t)}),ce(e,t));let r=document.querySelector("#tsd-search input"),i=document.querySelector("#tsd-search .results");if(!r||!i)throw new Error("The input field or the result list wrapper was not found");i.addEventListener("mouseup",()=>{te(t)}),r.addEventListener("focus",()=>t.classList.add("has-focus")),He(t,i,r,e)}function He(t,e,n,r){n.addEventListener("input",oe(()=>{Ne(t,e,n,r)},200)),n.addEventListener("keydown",i=>{i.key=="Enter"?Be(e,t):i.key=="ArrowUp"?(de(e,n,-1),i.preventDefault()):i.key==="ArrowDown"&&(de(e,n,1),i.preventDefault())}),document.body.addEventListener("keypress",i=>{i.altKey||i.ctrlKey||i.metaKey||!n.matches(":focus")&&i.key==="/"&&(i.preventDefault(),n.focus())}),document.body.addEventListener("keyup",i=>{t.classList.contains("has-focus")&&(i.key==="Escape"||!e.matches(":focus-within")&&!n.matches(":focus"))&&(n.blur(),te(t))})}function te(t){t.classList.remove("has-focus")}function Ne(t,e,n,r){if(!r.index||!r.data)return;e.textContent="";let i=n.value.trim(),s;if(i){let o=i.split(" ").map(a=>a.length?`*${a}*`:"").join(" ");s=r.index.search(o)}else s=[];for(let o=0;oa.score-o.score);for(let o=0,a=Math.min(10,s.length);o`,d=he(l.name,i);globalThis.DEBUG_SEARCH_WEIGHTS&&(d+=` (score: ${s[o].score.toFixed(2)})`),l.parent&&(d=` + ${he(l.parent,i)}.${d}`);let m=document.createElement("li");m.classList.value=l.classes??"";let p=document.createElement("a");p.href=r.base+l.url,p.innerHTML=u+d,m.append(p),p.addEventListener("focus",()=>{e.querySelector(".current")?.classList.remove("current"),m.classList.add("current")}),e.appendChild(m)}}function de(t,e,n){let r=t.querySelector(".current");if(!r)r=t.querySelector(n==1?"li:first-child":"li:last-child"),r&&r.classList.add("current");else{let i=r;if(n===1)do i=i.nextElementSibling??void 0;while(i instanceof HTMLElement&&i.offsetParent==null);else do i=i.previousElementSibling??void 0;while(i instanceof HTMLElement&&i.offsetParent==null);i?(r.classList.remove("current"),i.classList.add("current")):n===-1&&(r.classList.remove("current"),e.focus())}}function Be(t,e){let n=t.querySelector(".current");if(n||(n=t.querySelector("li:first-child")),n){let r=n.querySelector("a");r&&(window.location.href=r.href),te(e)}}function he(t,e){if(e==="")return t;let n=t.toLocaleLowerCase(),r=e.toLocaleLowerCase(),i=[],s=0,o=n.indexOf(r);for(;o!=-1;)i.push(ee(t.substring(s,o)),`${ee(t.substring(o,o+r.length))}`),s=o+r.length,o=n.indexOf(r,s);return i.push(ee(t.substring(s))),i.join("")}var je={"&":"&","<":"<",">":">","'":"'",'"':"""};function ee(t){return t.replace(/[&<>"'"]/g,e=>je[e])}var I=class{constructor(e){this.el=e.el,this.app=e.app}};var F="mousedown",ye="mousemove",N="mouseup",J={x:0,y:0},me=!1,ne=!1,qe=!1,D=!1,ve=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);document.documentElement.classList.add(ve?"is-mobile":"not-mobile");ve&&"ontouchstart"in document.documentElement&&(qe=!0,F="touchstart",ye="touchmove",N="touchend");document.addEventListener(F,t=>{ne=!0,D=!1;let e=F=="touchstart"?t.targetTouches[0]:t;J.y=e.pageY||0,J.x=e.pageX||0});document.addEventListener(ye,t=>{if(ne&&!D){let e=F=="touchstart"?t.targetTouches[0]:t,n=J.x-(e.pageX||0),r=J.y-(e.pageY||0);D=Math.sqrt(n*n+r*r)>10}});document.addEventListener(N,()=>{ne=!1});document.addEventListener("click",t=>{me&&(t.preventDefault(),t.stopImmediatePropagation(),me=!1)});var X=class extends I{constructor(e){super(e),this.className=this.el.dataset.toggle||"",this.el.addEventListener(N,n=>this.onPointerUp(n)),this.el.addEventListener("click",n=>n.preventDefault()),document.addEventListener(F,n=>this.onDocumentPointerDown(n)),document.addEventListener(N,n=>this.onDocumentPointerUp(n))}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 n=(this.active?"to-has-":"from-has-")+this.className;document.documentElement.classList.add(n),setTimeout(()=>document.documentElement.classList.remove(n),500)}onPointerUp(e){D||(this.setActive(!0),e.preventDefault())}onDocumentPointerDown(e){if(this.active){if(e.target.closest(".col-sidebar, .tsd-filter-group"))return;this.setActive(!1)}}onDocumentPointerUp(e){if(!D&&this.active&&e.target.closest(".col-sidebar")){let n=e.target.closest("a");if(n){let r=window.location.href;r.indexOf("#")!=-1&&(r=r.substring(0,r.indexOf("#"))),n.href.substring(0,r.length)==r&&setTimeout(()=>this.setActive(!1),250)}}}};var re;try{re=localStorage}catch{re={getItem(){return null},setItem(){}}}var Q=re;var ge=document.head.appendChild(document.createElement("style"));ge.dataset.for="filters";var Y=class extends I{constructor(e){super(e),this.key=`filter-${this.el.name}`,this.value=this.el.checked,this.el.addEventListener("change",()=>{this.setLocalStorage(this.el.checked)}),this.setLocalStorage(this.fromLocalStorage()),ge.innerHTML+=`html:not(.${this.key}) .tsd-is-${this.el.name} { display: none; } +`,this.app.updateIndexVisibility()}fromLocalStorage(){let e=Q.getItem(this.key);return e?e==="true":this.el.checked}setLocalStorage(e){Q.setItem(this.key,e.toString()),this.value=e,this.handleValueChange()}handleValueChange(){this.el.checked=this.value,document.documentElement.classList.toggle(this.key,this.value),this.app.filterChanged(),this.app.updateIndexVisibility()}};var Z=class extends I{constructor(e){super(e),this.summary=this.el.querySelector(".tsd-accordion-summary"),this.icon=this.summary.querySelector("svg"),this.key=`tsd-accordion-${this.summary.dataset.key??this.summary.textContent.trim().replace(/\s+/g,"-").toLowerCase()}`;let n=Q.getItem(this.key);this.el.open=n?n==="true":this.el.open,this.el.addEventListener("toggle",()=>this.update());let r=this.summary.querySelector("a");r&&r.addEventListener("click",()=>{location.assign(r.href)}),this.update()}update(){this.icon.style.transform=`rotate(${this.el.open?0:-90}deg)`,Q.setItem(this.key,this.el.open.toString())}};function Ee(t){let e=Q.getItem("tsd-theme")||"os";t.value=e,xe(e),t.addEventListener("change",()=>{Q.setItem("tsd-theme",t.value),xe(t.value)})}function xe(t){document.documentElement.dataset.theme=t}var K;function we(){let t=document.getElementById("tsd-nav-script");t&&(t.addEventListener("load",Le),Le())}async function Le(){let t=document.getElementById("tsd-nav-container");if(!t||!window.navigationData)return;let n=await(await fetch(window.navigationData)).arrayBuffer(),r=new Blob([n]).stream().pipeThrough(new DecompressionStream("gzip")),i=await new Response(r).json();K=t.dataset.base,K.endsWith("/")||(K+="/"),t.innerHTML="";for(let s of i)Se(s,t,[]);window.app.createComponents(t),window.app.showPage(),window.app.ensureActivePageVisible()}function Se(t,e,n){let r=e.appendChild(document.createElement("li"));if(t.children){let i=[...n,t.text],s=r.appendChild(document.createElement("details"));s.className=t.class?`${t.class} tsd-accordion`:"tsd-accordion";let o=s.appendChild(document.createElement("summary"));o.className="tsd-accordion-summary",o.dataset.key=i.join("$"),o.innerHTML='',be(t,o);let a=s.appendChild(document.createElement("div"));a.className="tsd-accordion-details";let l=a.appendChild(document.createElement("ul"));l.className="tsd-nested-navigation";for(let u of t.children)Se(u,l,i)}else be(t,r,t.class)}function be(t,e,n){if(t.path){let r=e.appendChild(document.createElement("a"));r.href=K+t.path,n&&(r.className=n),location.pathname===r.pathname&&!r.href.includes("#")&&r.classList.add("current"),t.kind&&(r.innerHTML=``),r.appendChild(document.createElement("span")).textContent=t.text}else{let r=e.appendChild(document.createElement("span"));r.innerHTML='',r.appendChild(document.createElement("span")).textContent=t.text}}G(X,"a[data-toggle]");G(Z,".tsd-accordion");G(Y,".tsd-filter-item input[type=checkbox]");var Te=document.getElementById("tsd-theme");Te&&Ee(Te);var $e=new U;Object.defineProperty(window,"app",{value:$e});fe();we();})(); +/*! Bundled license information: + +lunr/lunr.js: + (** + * 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 + *) + (*! + * lunr.utils + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Set + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.tokenizer + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Pipeline + * 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.trimmer + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.TokenSet + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Index + * Copyright (C) 2020 Oliver Nightingale + *) + (*! + * lunr.Builder + * Copyright (C) 2020 Oliver Nightingale + *) +*/ diff --git a/assets/navigation.js b/assets/navigation.js new file mode 100644 index 000000000..bc857e4b3 --- /dev/null +++ b/assets/navigation.js @@ -0,0 +1 @@ +window.navigationData = "data:application/octet-stream;base64,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" \ No newline at end of file diff --git a/assets/search.js b/assets/search.js new file mode 100644 index 000000000..b9dc782ed --- /dev/null +++ b/assets/search.js @@ -0,0 +1 @@ +window.searchData = "data:application/octet-stream;base64,H4sIAAAAAAAAA8S9XZPbOJLv/V3svfTUCO/A3Hnsntme3u72sbtn44mOjQlZostaq6QaiWW3Z2O/+xMESAlM/gGCFH3OVbtLQGaSTLzlLwH8z7PT8cv52Z9++59nn3aH7bM/8ZUzTPEXzw7rh+rZn569/nJ4dTx82N0/e/Hs6bR/9qdn9dfH6vzHy9/vPtYP+2cvnm326/O5Oj/707Nn//uik6aVEvoi6x//aOpmBT2/lInkvXj2uD5Vh7pnzlUJW3F50bHdbd9W5+P+c3UqUXTXLz+i9K61LqG7rg7rQ/3XdV30jHe94rdprj5Xh/pdfarWD0Wq++Vv0/1Qnc/r++pdfTyVPTepcJv27bpel6uOSy/wxv/jmG8WvdcdCt+m9VSdnx7W7/fVL+vzp/LHhtUmW8LVtSl/Rx9/d6ir04f1pjr/sfst2zPwlbQXacfH6jAq6XlbCtt9MSihYrM/nqtxHV2xeUrWj4/VYTuu5VJunpr7qvZFzuOa4qLzlP3zqTp9LVXXLzxP4bbaV3UVhPz566tdwftEVea6SbU+lbhJKDZBSX9YDUV257o6DAaq3m+3Dq9DYWNDbN+0TPMn4w19WeHn8k7g/PT+vDnt3qdbaSTxeVw68xytjQmV1cOuLtLWFpytKNvBxYrG+7i8onw3F2sq6OmGqgYuEL7CY707Zp4vKpR1h95Ql2n3A4HPx1p8z86EwpFXN9BZ8gKx2myzLVR8V9KKe3WDveku6ccwLfMVSScS/3RrhzSQNdYf9ezKz0ELVd1di4+rHJmR7Q67erfe/+dpN5j1J9WTOnNsoB8v/tJvq8f9V2LL4PeRfrkv/a/NULDb/Ajfcv/HW90DSBtzEGJdaqFQhRdwpMNtWuNdr06J8hFnWT/VH4+n3b/Wvf5y1AxabZ4l+Y+KnAaUWPbzXkVO+8bB2MRLPtfr+uk8Te/dpVKx+vEX3JZ+dzwl+tPml4W604uowt7UG5VeUlevTtW6rrZlyu76NUYVjy/pqzdP7/e788dJFsR1brWhHSF+2T1U53r98FhoBqg2w5J4mtUVHJlogWK3TrVSInOTLWTt1OlWUm9+wpVXXTrlyisfm3Sh2mPTrjfr+90BDQjXH27tI4iksS4isij17Z5O58E4irXcXcqOKRtpkftdvFjLquyKTtdIP87/aeIZb6vz077+7lCf6ABJf540qWqd5fyX3b4exAD6Py40SMTSCseJzrrk7LdtOcUK7+IqJapHO+r64zExSiD1l/IL6H48Hevj5rgv1x7VWOTZSwYp/BamjVNJe1JO/bZab/FyAZSY1Wya+mjSOvj9Numo2eNCSzVSILW0sRKr824TR1ZLLbjr1Z1iTJkrzzZoWWsaTDTdlLbWbXakHNIPNfkWFReZ5fTtcJZuU9cCs+S/62K2r1Nr8UzJpZpXSnRpG0MPMXN0HDFlwlCJJN0wbo4ZVjiIzrGqaEQbt2/i8Dbd0g9+QKRhhlIDr7UXsGu0ueW7DVps8YY2JZaXtH1GRK3EkMLYWlLUyDhS3M/NjD6W2zXqJLl+v19oTt8fL4n/fX3Y7lMrHlBwqRBZQnJpxAw8Qfqx4aJumcXchEXcYPE2wND/fFrvoa3RL5O+98+H6ucPUGL0yySJb9eH+wpKjH6ZLvFVQ19Ow16j/+OtHwtIG/toxLrU+HM60lSvtK67tnSJwrEct2O5Vl92ns50lOxVPvYUfl4uYhbJK4+btTZOXX/ltJasvAb185/y83r/NOXB77oKc7XD6NrPvkelE6n4p1s/5kDW2Ifs2ZWiTMdT/eZ0fKxONYwKAn13pM648pEP2Mh7vTtVGzD5yRoRV7rZChSYTWrPh2YnaIUh6KTakSB0Xu+gL2qDeOeQKPl0Sq9nc0Vv7qPGZI/2V7nnmLikLTWmYE2bFTVjUVts2siq9ia7ssvaCRYWrmtvsHVbffD5KUMeVWplT8IS9qUa4OsxU68FlmpsRGJpE4ssncYS8nrHeQKoP8I0EuB9zJBR9j7ZEq93mhVdlYUsONenp039NEiyH7Eirjbfkpud8mpHK/wPbLpB0cOMt8dfMl/M/7ZUK7wKK22AwbTxR3j7tK/eVQPO3P91qceIxZU+SGdgwmX/rTpsTl8fM30iUHr3j16tIgNGms6/rTdoWp814lplEQtOx/2EF3/3j7b8IrrPu39N0t2Wn6n7NpcL2sv7iL4Zd+FZUxOf3SQ37BlyFypPN2ZsMrb+/QabfOXFbfq3en0/qa205f8fOUyjvXsnfPL78LYnW231z6fdqdr+MuOFXEy6+wcRM93A0f5tvz9++fXg57o3WwuFLWFzcunqV7wwqIqKLLZUpTKLl6ixvfNm0Cnd5XPonoQZUQKM4ZLlJoW0+zaOaJqdKNCXgIgRKJF3nj7Kqw71bhPvn/7wdAizgj/GP08y+uWm3n2ufvGbrV99rDafQsIeMTxR6lbPz4kdc/6U4anQzDmuMN2Ou4GASWaNhhXq9Y62zRKrLhVvtYZfd8m9bPrbl/v9L8MN+62WPw6LZF1BsavDbY6HsGqKwoEjYp/36yQedWh1YhdgwhXGjCh1gKwdUe46eL1RqnXhmy15sLTU0meCzxK7TExruvf4arctN31zfHh8qqucnOe9MtjQ5reEhsf16ZyXH5WYLL217fX6/s37V7vtX07Hhz9/raP1fuppUI0ltJPtxyXqR0686OsvbdKRwvE23FcRO9jbanM8bcO4OdAR/1jucv5zj8t63pVLoNrYsNTn8Zt/ClRdCs7X1WXsVK+rfXVfphbVmWaB5kym01XTmlF+an3e/mF3/sPu8LFqCPh2uv7z7j4+NyCt/lJwSe3hbRa/9m/w7OsmIvlm/XV/XA+7O/wWSJUlLdqd3zWvefvnry/9A09wzEzV2yyMW0x9/Nu7n38qsOZS8EbdJN0mKoZpPyhxc+JNQuRo9g0wdh7VG7GgHOYhQSXJqRPtuVRayopmTybY/DpmR1RtKUseU3vsxmzpVVzKGtJ5l1kCOvIb30kXSBqGyUffSr/qYv7S9n3bv56GC9hRr6GVb7AqXsO8HpwvFi02Lj+Wz8lSJ8H0ReXPgbnalJqOpfbWEi35HbWjah6f4BKMKAmlZqq4r0pUhFIzVYTDowq0XArO/iqJs6UGXyV3uBRWQw5t7Mq8eaphtGtY4NbxNiFx9DzHoaWZPVnvhlgtr/cuqlVqwHho91Lnr9XI670UWOz19iUWv96rpTNfL9Q74fVe649OGtb4IMsCS0YOtCywJe7636YPW4wa77DU7YNBQmZ+VADmTh0eUnrz40S54lN135wrBzvBlO6ozq3q70/r91NUt+Vvf+o1PGAj/cTrdISuXG31e504jDKl+FLjVtXpITWlemRsneLbiUE27du50XZEMdnrtD6s76ttrw7diwSK3Ly/KSVzdGcTsjdFlwZ7RUe03uW2iKO6I9mAE97lJR0w1FnOht1DdXwaHOY0asal2mKWnKr69PXV8Wl4Ut+YMb2aN9kTxa5fDwftLsh0/al8WKyPmCwQWc+v5XIDfu64zPr48/v/rjZDRDZUdSk4V9eHJDGhyj6MkpIybYXP1is6V9/26XHv2Xy5LzzHdSZYUIpoqOISUpN4ZLISqE67z9X2zWn3eV1Xf/tCu6jB7zevA6DA0WXAwMxUv3I81j9UX7+nnX1W7V1cq9CA0VCQL7k7Ht5tPlYPk97CHai8tFVv1vXHmTa1VRe06FL+h4qm4xQYRWrPtysaD/59G5vStUL/1/JRIFgHHm0o7zkoix8kWJbX2Gxl2JQpjIrO13exGo8OmcfMDxIFun+ovv563h3u//3T9sO4YlK6TGtpHx1pK+meqZrrk/1QfX2d6j6qw9PD+Y+gRNYtWT8c/Jfj6WEdnYafF/q8XwU/DbIZ6u/y614dD3X1e11qw7DaQnb0OsJCI7I9YLEF/rd18Ve4Fp+lN57sfjkMJxhf8jvMSpIlOhljORKN/pJ40kBunimkpfbDRUNz8xAhLffxdNxU5zNNVh0oGJSbrOnzer9rsGIiH+6iaVButqbW2O8PdXV/2tXDsWSgE9Qo0U4881XTdSaesfst39eRrRKv2wivT/qrtr8c/1x9d9gct9Uw74KqeD5WPfl8l6eYMdWnRhTN9aFK8mq/O52wPv/DItmhPWGllge7El+wedWjarbZRkXlD1/Kq1hJ6Ifjn0rH1pdRhvffvpx/3J2bycaY4OfJavkn8kaP2nHdlvxqt/1xd35Y1xs64OVNSklYwLrd8fDj8VT98nF9+PlQveuSnH461u+eHh+Pp/gA7wJTy8TdYvfloK2fjrXn9E2P8LKfTZYzNF9/rmWvLlm3TZnNpNeXr3u7RT8+7evdx/X540yrUvXnWvbdlivF3PcHP2zFAY+ULajGbO3NZRjfPezqujqF2MxPx/rnx4r0zUlTxqrPtas7J837ZM9RuwbfrJ3J9qSUlROF3Wrz5Wy3nqq/rHf7AkcrFLKYjdG1RL8edg+P++qhOpS0iCmS5lrrL4lY7//25fz36rT7sKtOf63qS4jgp2P9l+PTYdzUYjHL2dk2zkuXP8NGIGK2fQPH93/57vfHZkfnuG1j1Re2q3SeMlp9YbveVp+Pn+a/r2v15ez6vsOxxTOpMhnLWfijPwPoBvMGApaz7Trp+cvxRJay5QZiKd/CyuKpXaGQhdvHT8f6/6vqsDtsbiMhMuZa6IOZr3uIoO1PRw3LVp1rT9evf710578ezt3s8dXp86hVBQLm2vb9YVv93j5iOGjw782xhL/ErCxlVr7ucha9Q4cDlhv1ruScwGl2xSK/P/xYPRxP0yxLCLjJtnbo8/9uEg2mvbJM7Rv8/nXVxEPe7Ne7Q2Di7Zah0vZYJOLW+XBziUDnMQU2JastYccty4Z0/Rst+2tVT38/tNKtb8dvMrjl9WQELPHl2h56c3ysZnw3VHuuVW/afcnT4y+5mrdaMy/2MlZ7tlXV6aHp8Y6H84XmeVDUztb9vhb/OdqOsTjgcIvkxZ/mbfXPp+r8bZ6nSPaCT/TXqvZK2l7llgdIi1rQ3r+3KCqw0l8P1e+P1aZuMgGbFzbH7FGJ38T642PVgu7vmzf1cfe+2bnazg92FWXGE5+kQPq3eqruj8Xr0xkCv5XtpKX9sh6PmMwS+Q3sb0IhgY9Eqpb4BmOCZz/LJUPI7y4//XrwebzH19X2aVO93N8fT7v648O46cVyvo2l/VTEeVaOJCbOsPC6kH06FYQOCgTMty14TW+O+HLTRlBa5l5gYJmUb2Blc4rduTgyPkHQorZ+f9gcT82J+ddUrnm2YkHfxtbLGHWjqbGcb2NpJpdsqrFFKWYz7X3dZas3297fVpvd464qiMBOk7XwGw6hGz/5mvtm+yK+hX1FobsCAYva9mMzBO8O9+0HOp62t3VTWXkLW/57k3FVGrAqk7GshbvD7RZSGQtb6GeWN/ahQMq3sJKeWT7HxquMRS184+vvq/N5wd5+XOiiz9DMgXqHpEwyNqr9Dd5s14e86lIFm0/pe5dXH9fR2dsz3u+46GWfp/3jbb0skLKolc2X7FrMbTOAhKRFrW0Okl5gDoDE3Grn9bTjOQHyUinLWXmZsL1s0nG/P0ztc0skfQNrGy9bxFgqaDlbL4lD/yrvYVO1F7cqLC7bdvrzh/kGDgV9I1t//jBj5V8m6xtZ/Nof/fCfu/rj8al+1d8bM9NwLPIb2f/rYxPKW9R+LHJx+y8Dz88fXvbvEJxsNxK1vL2h+wmzkEmrxiJRi9v7y/p+4ribFbGcfe0CtDo3k7rX1WP98bvfN1W1ndVlZIUtaPNxX70++iDfd7/vzvXL+q+7z9Vh0jKiVNqyVvssh7j/n2kvknOzpcPENp910P3ecZZC1DFT6jd4ipm8bLrAm233b+bXw+WI6gltEFWda09LxfvHEIfTNF8ett9vfTOpDhNyd+dI/AbWT9m4VSzmG9h5TXg9bH/+cqhOl9zJJcwvkv4NnqqZQb7GB7vOeAoo7UarX1f+7rufjl2I9ofq63fhPrwmR7okFjFF0s3WNlPbOYvmAgE32ua7ozBdDbckveluBW2yR0vDvROFLWGzz9layORxWTdaPByaXh0PW39pZ9gl1EXC2syUUutnyP2/8iRv26vcln2OSOriTxGa2Lwp1Eyhiz9DOCH7dNkvt/DTlIpf/Ln6+Vu3P0hS3rexfPKMdrK4b2t3s8Ba2HYi8ubxtX/E0q+Hd9PSfcrl3GhpFzE6bKpzfTz1D7Cp7h9K0MQkUTfa62edSy4spghc3vYZy4pRKctbudyiYq7w5Z9p/pKiVNiNNpPTtui5UpOTC2aLXeg5mh42oa04p32WyCXm9mEqfkGtYdY3IRd8mqwbLW5CfG+r+ul0qMIGkseCvIN83QUsumG1ufwOr273xs1HQkwQtJStC/niBHm3Wh5OzUu01EK4MU3WjRb/Z3NL2cu6bu7U6o4L8OepoaONSk2fKvRbPcO806jmSv1WT9HtYQq7Yos3/c4Wu8hzzO8CM/WXsCyEyLpW1L9arMQyXH85y5pU95eHbfMfvyuyflrv91+/+32zfzqXnLwwR+Ky1r9qVkbb7iTDTt/3h9ueYFzqck9xSes6bHur5gUeZYLoJZ6n++hz+r5h3aUs8l9wrkmk8hI2/bWqvzvUp6/fb389bKsPu0O1LTyKpVTKQlb+VH2pzrX/v4lJ9hMELWTr94ddvVvv/f/ONTMhYwkLv394eKrjczBefVwf7icOUxkhS9g4f5T6FuNTK7Npg98f3pyqz7vjU/EcPCthQeva03JvNzIlaEFbpwYDEnWX9LRJKxRYcwlrrmmULz/UIQJVkCRYImEJ63xU7OVhGw4DmzWOJUUsYV/T6F/2Y3e/Hj4djl8OMwa1AmEL27yIrd/Cxm4X+mUFFa2qZnlBocBvYvtspFcu7tva/dOx/v4Qxrd3qRvub3uUvIZv8nSv1906YaHvggV+E9vbzJ0mf2DmgqNY5DexP/zYTN4npBbOkTjX+jDEtlqOp5fbkKSx3neTzwk7GabJWsjiJo5TEkVMVlvIjvC/xWuSsdoLWfXrofq83j+tr4fj3PBBx4TNtrnaPHKlP7FwtPLfi9K9EpVutOE0xwZaaa4Nv+wempH64bE05Q1UmKv719M+2rf5U3Msxr6os8pUXNaWZkU805q26g32XNrntDeDqy1AA2+Jg2TqT7KsdwfJ5UTon9aDq77oz96avrbsOYkl4p5HhZNP0TcyvyOgSGlc+hat7Zcp0nktO1lj74uFQ7Lx57r+VvqtLptkRoU9j4smHyGyDurzqQDjurpis/W8rdDUn6p5m7stvECLb4fjarpis/Wkgh5U0XhoY0zTBY+PK4uLTtQXXQ4VQmvD65zav2f9uHd72Pv1udLy19P+l8QNyLHE56A0fobOvnGtiRuDU2pHbg0e09sY/cvxz528EbXD0rdofVef4p14OZWXorfoK3qzpOgsfUdfu8iBaNFZ+s7+7RR/RlT8Nr3jz0mLluorvbatp6zk1rahqrg7GdxVM1A4KFHexTw221MKBT7vCuOnGNqZ0Jm48DKhdOT6y6xWzZmMri9M3CyZUPwALpisz9s/7M5/2B0+Vqd208scS8594jViyHlIuRayY90PQo/YsR5Gmxd8HzDCWfBmknHLhWzbnX2MdPvnr/0diKU2ZuovYGvcrurj3979/FOpXZfSS1jhDFM83WP97IOc12453EaeKpbtvbRS4jq3u1x0Xyz3+aVKYX/S2R51zvGNmqQpl1twB5p1iSEjV8C3vdYlHjPHMiBjURs/+DzVSe7QmXatuqhFj5dDmX3Of5SEP8E2JORmK/vrihYXoClH+1P50L+uzlzpV/WprTwm9DmokJzPdIaO6W73SJfrvlaYq7va7KrzJWZb+vCpWstYUfoaUrWmWEGHt+8em7zr03r/Q/W1uSn0VJ3P4Dpnakqm4gRrJsype9oLp9VDhag5pU5AByVKg1AvO38tFPk8rjD2OFd7oe7vek5SasCg1hwr6EzgWvr7w+NTTXpV8uut4z4SNzbcUwMT48N64CGjKu/Wo+fh09r5MWoXAuVt0vjfq147GTcnUX0Jyz5VXycYEkovpJdUoHOKETtA7Zl2Ucf/YSCcWDYscKv7JySOtQBgaeJ1b8lWnUn670DtUoPGJm/dZbiDaduISf2KS1sz05blLEl1WiOWjPdbRZZEE9c4i2Qwssc/3hq3GsgaCVn1DJsWrRqqGglUlev6y+n4UKyvLTxf5/0lrb9A57XwH/hNWnfnmPsWaO5XuFF7eHVROmLx6+7XudUCkn1XbMWw3k3ff+KnGNaYr/2zvzbwu38+rfe7+uvPH+iOgx0I5g8tKpNy0zsKHz6OWmRfUFx8vt4PVb35GPayTOtDn6dr3mhN++XnmIOrLm/Pj4k4f7lZP4LQf4l1ZbxhaAdCDdP1JaL5Q3UgkD9d22jMfqg3G66fbsHxC4IoQ7VduZt1JROxR3QXp1eX2VJMJNAoWgAjbrGot5NikkG05q2+WeQaIzH4Ob7xrlR3otokS/rz/QlD1HqR8SlBnIbqAGyaqqsKK453Xx8eqvq021xXIPFaK23CWP35ljVOVOhrN+tp9/8UqruWXkTrhHaNa/1fX6X8v1yj3LY+6OLb/j77okkwqDJf/2VHx+QhJl1zAWumumGy4kRb+sG93lZHiLZBiVvDeymRY/E9ZGxiADkN7jAqUn13Gr2xCEkYCaPRzcNlpjyO7Rueb0nvaoFp1mTvEZhvUe8asmkWZe8gm27Rub+xusyWc35P9XQr6vV9aUPsbGirLGXBqd0SN70BddUW8xFfdXioYKGbDGovZdd2XU/1k7bKkha82k19I9daS9rRu+aq3JDs/VazLOl20U43Jqq5lD0jOUxjRhWnL81oVd0R7lPbU1Rvya/2ZqY9tO6SPk1uxC736pEbsGeMSig3b3RUKl+IF74TfDZt4XspO4t2ulXrK8gIoYepIycUsJR1VZadj5k2rL1Y+x/JExztB4pTBItsowuTVxckiJclg99vXZRggWNLkqGZ2ekUjuoXGHCH6xcaNX0ikzcmO42Zox12tOM2jHSzUy1JDYl5Q8YHxKl2gMl/3oTs1H+q9pEpS96S4gnLDC9JThFGHaVggjDVHjgg5w0ZGY4nv5HcYDzySsqG4qkWjQ7EeasmDMNTLcsPwnmzSofgyb1NOvQx0uGUBD4KrNHR+/m92jw154U1d8+/fO8v87jY9OHp4O9mPP8RFcunEUepU3/7Mgz9/u1LftymgfMfdsOgeSfj+eV3/EYa/WnJweNej8iPS03WElI70ikyF0XDgpN1batmH+ab/Xp3CJtuU5z3ojRTY7L26vf6tN7U2bfZKzNZQ5w8lHar57TYTXrK1BRqKd0tcNVRsE2APsggkffHdV2ddmsaio5+WSB1tyeqIGf3YlQ6NxqlwyI1d5/GMmAvtUbzsd+sd3R8z2htS8/QO/+ldnpbmX9Ib3UYGnCxOZv7+7cvn2aachcLmGrU6Mjp7566xbhYwu3W0Zb2JmXg9YeRYY/IS3yMy9+LB+FUQln790mD8cvslutr/mA+RauzKDVotkf1/e3cZtuv8wph+VmaL8P96BOOdPzjel6BgZIqyUXsRzRsjg9N0VEtvXLzNIXM4vhKiBGVsMINutPTK6B3fIo1/u1CZmpJu3oOSs/V+vN+O0ErLT1L6+7cGD/SGq6FZupoTB3V0RWaqWPaKQgz0w2LrcgngiSMKEsCKesXfkwFfHKdBKh0U/9+zR70k9zRBpytV2pJ6SScvIDxifhQFToGp3cMGtHlf7x1E9FAVuG5N96waZuIhqoKT7uhuqYddHNVN/eMm7z+keNtrupnnmyT1z5yqM1V+8zzbMafvegom/5buOkUm7xFkw+wuVq22Nk1ubYxcmzN1ZqZJ9YMdOPDappi+XNqohK3LvhTIktPp4mNzROJYabLiO67XsViM+ZE/scsKTwhp9yKwsNxRt5M+bk45ZaVHkCTMm362TN528DA2z/nlDZT/+tSQ+9VWOHYG2ybN/hGygpH34G2acNvpHDu+DtiwcgAHBkwcwQe0T8yBEf6Z47BBc9fNAiTN3HTKDxi0+RhOLJtsXE4205GBuLInpkj8VA7Hop9ufxYHBdZajAeyCwdjXv2zhkAU5pLR8Be/VvOXksaUnru2gRLNk+n8+AEm1FDLrUWs6NwUpC0aPKsYIJtpdOCpHHT5wV562iT/fXQXOYUqr6tHvf01JPB7/kpghocuf+uPkZRjV13nPzl0f3v5fOO42N1KJL2vC2ZfVnBuNS0Y388l1n+vCs6X1mcn5FVlUvGKFF0XxUqCgXnK/pnb7qZVdUVna9s2z+NPqttmz+Rvsw1qvWp1DVC0WnKEu2IjqkJzSXj6mBwi/h4gdjnlyrjDwZG1mh58qbfww2mL+T3W5coSNzIIoVamHiJADRBZZl1eaGm++ZHMD+H6q6Fb9dZFb7Pa+GbdDahbl8AHGcJ9fYr3Ka7ak52fYQwD+vuVbhJ96n651N1rsFeaag5Ln7z+/7u98fdCexXTr7va4Ub33ebnVn6tq/Fb9J73hwfC726K3qTvs3xEO6yK3zFvfKTNcN+9m3wl4z+tsRyfW0ssLi37eyc09/2FBb1uCPa2kYGojIJpXGFG3WX9UU97dN6o1H9422TaC9vnSO6x9pnT29pCx3RWdRGe4ontVKgHbbT8+AC7qEVlzLlk72n065Y4PNQeOyJrpbmW09vC/6o7n6lm23wk5JpFsRVFngHn48bn+wz9TWQejdbsq0++NOEs90JsaJXZ44Fw/FifBwiNpBaN1sRcMFkM2i1hewYW/5AK/J7WWa8i87Xpr+OqObN1lwSXXDyY9KWQb2bLfFHDE78NL06N1vQ5Fo241qzrSUeRJqtkRO6sryUm638uL4UeTcyZBPLQM051pSmNaX9uCDFaaSTjYfxkPT8Q/U1kU9LC2QH8OKHQ0LLnozaW7QvIa83vy+hVOPwGOy81vHzrzOaxw+Gw0qzh8PlnrTnMvTC2KvO9pfyFZk/rr16edh+f/D7mnzSfO/MvDE1z8tEpB65e5Y5Ttwzo8x7h+rgqx1eLjvQeily8/IXSxxb/w5NnZYXkVI7khxRrrf0bLmUIVNPmMtbVpa7kbJlagLHFFsSWRwpUyamckyxJJHPkf9A3+ydZDM7cm9nVnrHFOuKczxSVt6c6FHeChPZHinLJqZ8jNhBd37Rwjj5I1nu1gyQvOCxNJC0+fMyDoqsKU87SIsbOyphsMqfYl/Jgn+mZTCXpsyqkYSa+e8qc6xE6fsqOl5iroVjmSRlRpank0yxE020cLZp/+fFJljF+abEvJkTq/KM0zJ9h+ZEn/3uX9VffJZWkeJhnVssuEzJinTHpadqnThduyHXttSGsWna/GzbUgvGpmfz822nvIOyadkSGbelVk2fji2Zc1vWcsamYfOzbjP6E9OvTN4tLLPYtGty5i02+cbp1u0ZnlhUSULuZJs+TOm2l5hWzc1RnmNJ8WRlgbzXUvuG99kNGm379/Jpye5cco9S1x9NuTgpHdbDFw33VG1H7hUe0XEJuP1QfX19ufURQsue2my9hS359bw73L++nIZ4JjdaTrQvKe1bWN05bPOHBcyG4r6l3e2p4guaTiV+C+sDEVzCT6ikme24ia1fwcBYgx6UnqW1w6MvD5vqXB9PP1RfXx62r6vzpjoMn/b847rejLT5mRJnWX9f1W980dZf/Dl/H4ZH5ENDxyvPsmls6dazoXTNNqJzd35Xr0/1+T939ccStbD8LM3vn3b77S/r+5FLbYLaYeG57fpzdap/Wd+fSx4WFb9F7wSdt+nrWtLrXhzpbfWhaurv1vvvD3V1f9rVI33FJDmzLD1/PD7tt13n/TIZOuiZla40y4Ywff7+sNk/bavz5aTbkpnd89G6C1j06+HxBptg7XlevD68qU4fjqeH137by8v79e7Q3Sk64tUjVW/wnT83XUP/IcMFRCWtrVTEgvYFd51vHKlfalkpMMezl/EbQvPLo9f9PVVEWfj11gjuUFjZjd+tbdPit0BZ2Z3fI9oKr3rr6Z1411vegks8duxmtdgEVGmiDZOuy411Tw3lFlqQvzY0NmBiILdQf/4C3+HL/xbPX3K/LX0Ts4K4hTZNvew2tu3mEG5R68lfghrbMzGAm9YOryMM5XD4FhW5NXqblFl4I2Hf3mTSe+5CtaTu4hvV+hKWuJYqbdPUe6mm2DZ+JWDaril3Ak6xKXf9UtqasvuXpr2bp8OMlxIqLWZFyTVQaXOm3QM1ZtdwsgZPVYx+W2iiVnqmYmzVrEla8YmKBZqKp0f0aMEJk6N5BzoO9M6cGM06znGgfN6kaNZhjokXvvxzl0yHFjjJscieqVOhBc9xLGgl+WnQ7FMcU5rhFCh9huOwwELTn6knOAJLp4DhvNYxKgxqLzHlufm8xMl25aYWM0+TnGxD4V2At5/YON2y0clg0qgJU8Fye0qmPimLpk18ig+1bMu/e3rf7HN/n+xDLwUWmgD15ZXNgq5GzpoKEZVl86FRncWTIqJ+8swIWjJpekQsmDlHKrAjP1EiZsybLRVYkZ8ywc/xjd5FyeQJvJVbZlAFlk2dRhELl5pLjbaw/ISKWDVvVoVtgFOrS9Hs/IqWWmiSBcUWzrQGht801clZMnm+MxA2I1OwxK6yWeFEa3JTsKw1ZfOwidaMT3myNk2Z90y0rGTyk7Vt2gyowLpoGvSu2jxypT+xQTdz+aV84tNlDqB0pL645/2i+IGutqUmWn5D8Q/V11+O8S1fCZWD0nO1XrKoytQOit/0tH/78umX45+/1gATwuftlb/tiSeoBhVm6oZb6Im67N75UQ3h3tBRh+1KzdRyXx2qU/CD3hWJCXXD4svofbv+MlF1qDFbe7vrv6BLIGVv1VjQNEnZco2leRVEX0lmBVIHOuxTssM+Ldthn6Z32KcbO+zTrA47o7W0+zrN7b7SunPd12lC95XWkO++TpO6r7SWwu7rNK/7Sut937z+X45/3t1/Dw5QIlpp4XKdExv0aXqD7j9idDwzOd0nOjq54FifzMk6WNDIkTpTD9JJKBk/QWfCuTkJHflWQ8VHHejxVL/enapNb2N7dXh6OP+x91v+xV8/YMhV3+4O96PSnvfKJkzv2Qc1vixX+HK+vmjQaRa0g7bQ/LF8qDnvq2p4R+JFxvPud2ykNyAh+WF32D2s9+9GFJBi0/U0t8k+nZqC6Tsfr+pw6elaQ7S2ROOw5FxtP3/4cK6KnjJVfrrmbn5RohWVLdJY2s1HD1jQwxMlccNptoT5I+z/o/pcDY9h7f+cbUylpgORRQ9BLE2MABt/lkOp0lD0Fn3v98fNp3PvBpCczl7xiXrTt4TkNGYvCSnT1b8mJPtKs7eElGmL7wnJ6cpdE1KmKb4oJKcpd09ImSZyeUdO2cjdHaVfLL69I//Fcpd3pNtA1IV897k61P9xvMc9SO/XRTqQocSi/qNvZqI5P+1327+sGznDBQvQ2y9+g95dkyRforErOE3XeNcBVGV7jiJNuONA3y/bbxTqQi4PdeU8vkjX+vGxOgx5IVB2KXmDNn93kC85jAsAlf3iN+i9r+pyrXHhG3SG3i9I+vPXV+ACBKAbVZrYFoeXiWYmRYMS5YsMv2MUHmKSF/4cVcTPOLR/ehebMGLCFemzZ2pp1bnJWrHWzHwt9ebHp2zF2nE3n1Cc7+pzOse7+4TK4hvlZnT7qQ9bfLHc5LlcQmPptW/jnXKpxvLb3+bMIhNKJ1wCN3k+nlBZenPfjIE86T2ld8/luvy31fnpYf1+X/2yPn/KdPyJcovManOyC3e84odIQf/300zw5RfRnOj4x15Arvsft2C8S8zqz3aME7Xj7jH/+NlOcqL+U3W/g9c8ZU2Iai1ixf1pPdED2xoLvQOY75d9/nUu/3mS9ur3Gq0fsvovdRaxIDGU5HuA/IAyuRWgbn6kFeQ6+4JeiAYtvnvY1XV1elefqvXw7oVhkeXCF0Ox5TGMvtUpmpFMG0/pj2vcqj0dYgCKx+MMRTozwQb0tscjDkVaq4fdcHqUUtoWnqWTHIhZnc7Hw/XaoPbQwfDXW1NaYzGjx1y2hqRmGTu65wQIv9vmry/05fMpjH2ynNY0cl9Lqa5ehkFWWza5IKlv3kfq9LXy/sAKFV/sTGWuDtKVyk24exzNX8LGjGbTdhkws4yKay9oFT6fFFg0diJp0hFj5l2d6yZA/9eQyoIoIS1RHqjq8mNoR5MX/XxYLUEkB7aP2TF+vc2YSUjC0tbhM+FLLfs/2TjBZKt8NvYrvPNqxKR+1YXsafO/8UmyIwaRugt/t/bKp8tZZLNMHBO2kM3NsY63mAnqL/t9Z7UBUndZi9J7KMusejc6NZ5rWeIEsjKzXucXZJNtasNl8z4grbywTbM/IRKwsG3wZJJCs97mwgqTLeoOncT3m46YRCt/C5vedZsnbzIulnKjlaf1YXt8uAh8V5/irMUR41KVl7FpjimLWoBT0bMG5JPRJ+p/9f54evdxzZVGIDhrB626iD0owTtrRS7Je6LuTNZhzoKCBMRSO0Im5evd9m11Pu6fan+37vlpX/xOcgIW6mte77ZNQv+8NQutPN2m4uzNxAsqSeXMqO/dUnXc79GVP/7P5Rn7j8f9/m1Vn77i5OVI3PNB0cTSNhiW0df47BFAR6rsWq5QUx9rHvf7Xw/1bv/uabOpzuefT6V6U7UKrSi+IzZSW3RB7PBxBzHDy53Y/mL3xo+GsYphmQXiiQmhBdFFYHIq1tjtQp6q/i6uOcGQ0W3VzYTzEV1PWGBRXHc5m869i8tLrTkXXlpebsfmeNju4C1Oo8b0qt5kUbqB+PBHtnlcSizXOPoiy5vG1dgbHBEqn+iGVxn5j38KHwUF7LPWxPWWsqXZpfHd74+7U5X2xMS76dVczJ7RTiz1pcq7sFJb8p0FtqO0qyi1oaCjwIZM6iYy1uRG0c/HjV+PjgykcbElx9KB3CnDac/2m0awlBmTB7GeoAkf4l3WT/2vI+AD3zY4ogGXuvkDZ8SW3jlIDU9mo7b7VqebcBfXnWTM6HGO9cdj6jK9nEGXikta0x26M8OeqOqNFlH37EKHefdMlLrVPXNix9wzZfhE9ywwocA9U1JmuGeJQSPuOc+ahHuW2DPqnsUWJU5jy3snLnSrc2akFh7FdqNrjhtQ4JkJITMcs8CcEb+cZUvCLQusGfXKWfZsBvfnFRu0Kb09b94b6t04Ovktldw7OmqXBROqV93cORw+tAYHUeQL5wOMOuor/vm0O0WLnWLhz6OqYzNL+DjQnjen48fd+109y6Je5RttSk92X40viK5FllttEJnlK43I3mx62Tq7ysDq7/pVy03JNYPX67pqjhwhHtD9udS1Q/LMNnUSSk/cc1AYP8zFuJzO5HkvUGnBiS95rZfrBcueFRa/SW/h8+LyxZoT8xyfQ/PL+v7v6/1TYjrQKzJpJUoEJI60vfy80PypL69w5nS1sfxx/pI5LpYUmv3aXrdBiGNOz7XQkq+QSJ3yIiOr501BMwaUT0GpkPlT0Jw5ZVPQabbkp6A5a0qnoPPsSU/4SmwqmfBNs+vU3Sk63ai46oIWnf3d49PNudRb0JY63+UmLGlrLek9vnZq/ZL1nGvNBe3Zruv1q8HOjgJzrhUXtuZdfDvzJHPeFVzRPNmeqp1bzTIpqrxo71xyeHy+n552dvxEH+9mZzOcPKq68Hd8M98qWn1hj//L8fSwntFt9+reZlNu2tWGD7NXMYCCS06/gOQpUzDyBLnOp79/dIold736U40a/yTfN1O9w3oPZBB7MyVnz72xpqka5n32ud879aHXMLW6SP0drVtszPjsLXP1bNKc0ptnJ1gyEmJNmlIcX51gy/a6dppmTK/iUtas67oZLud4Ta/mUvZUYXfSdHN6FW+whnYY313kvjkdH6tT/ZUYNixwa3eRkDjWWwBLUx99cA51ieK78VOpgYD8594ddvVuvW/7nr9Xm2GzGDEqIWEh+z5VX79LeeSIYbTqfIsSLllt42sHejb5nxZyw6usQgcMdqXGhOOx/gHshk8pu4srjKsd7XtPu8/VdnilxogRoN4ytoT9Qk1soPTt34F6N9sy0iEMjSjuCkq0l3cCQ0PmNP8Sm6rH5t2e1vvJvgJr3mxPu7pt9plVh7qFSq+O22K3yQm4/W1N6JHIgN3VmWNDYnLv93i+rR73X7871CdqEC40aRHRZAB+d9gct/1N1Hg9kS88Z/HiTR8DB6TQQksYJLVwFUOtngcOMgaUgwMqZD44yJlTBg6m2lISJstbNS1MNs2+3A2LOavKLlicZsuWkvJia6KaC9rzuL7fHTIrrZxFvbq32TR2PelYxwIKLtS5pCRPvaf05k5mxJDyjgYJmt/ZjJlV1uHMsWnSxa4LdTzT7Sy63vWmDqjIpkQDy2UTFCQRlDejSFhhy2lNy4YWS3XdgQuxkyqLglMFL60fkxr/jkXaR+AzUF/MnIv055MEgPrS3IBJ2tMpARkLSjIByqzIAy5kQinTKtI/EjgG+otDxkX6c+kGQHlZlkGR5nRyAdBbklOQ0npLx+YVj58niCwINs8iF7jlFzGLMqfP5lMgny9MoyjSPkZvgf5yaFtsQTpjIqG/JFGiWHsyeyShvCBppFR3PjcD6y9NySi2YSSvIGFFcTpBsR2/Pm4nv4trnVk25IDxyyvyerP+uj+uczxxWHhJjJyQPoUog6cZRZb5tKq8UXdUzBwTp32wy9lX45+LFp0dmMtmFcQlZmvwUcuxqOYM6f6IZyjX/7KM+15FlflqMCq/Mi1TdHctPaqwjFj0D7jMKydVZliAP1q7JPUI8d/Xh+0+sVwC5Zb5oCnBZZ8XmV8eqypJ40oUXjpmNT+dK/U0qSVB4QcvMe0OC5tj7vRAY7ajpKXmdJYXGZkOs19mjpbmiMzso0QFFnI6KrHQ0WJL56eRJZRPyyKLhdyWLpUypzxbKmtL5qNnvOry81yHGqOX/TILuhUROsGzIpOzq+pzetTMWHBHKk8wpyhLkR51PNGskbOO59g1OsfImTVhtjHNqu3wLKFxa9pKN1mRaSxjxKpfZsHGMo9TEZPnIaq0+nI6RWTMB1MZY8qY1CRLcpgnY0kZ4Zn4TkrAWPbtTGNiY9YlGknonbKTlF6ROaNWEDDWFGmphRojFFvYHAeGz2uQORPKm+RAyvxGmTWorFlOtqakOYzYNa1BTLQwH9fPWlYa4Z9o0ePp6TDHo7p682z5rxftXb9/+p9nn6tTc/rEsz8943fizj178ezDrtpvz8/+9Fsw8sWzzfHhIYSGtsfNk//nf7XFQsZlUziU/uPq2YvfVi+0ulP8v/7rxW9dXf93/4dOxPUvvh579uI39oLrO73qV2SDiqxXkT978RsHCvmgHu/VE89e/CZe6NWdZP2KYlBR9CrKZy9+k6iiHFSUvYrq2YvfFKqoBhVVr6J+9uI3jSrqQUXdq2ievfjNoIpmUNH0KtpnL36zqKIdVLS9ii6l0Q0quv73b9zBvZDqjpEPyYauw4jveOdZvZDiTknbrwzcp+8/rHELxpDNbOhDrO9ErHENxmHloR+xviOxxj0Y9EE29CXWdybWuAiDfsiG/sT6DsUaN2HqhbR3zMh+5aFPsb5TscZVmAZNjg3divX9itlkMx96Fuu7FnOphseGzsX63sUbh2HmhTJ3K2n6/cTQvXjfvbh3L9gc+NC9OOmeeMqvOeih+t7FRdKv+dC7eN+7uPcuh3rGoXPxvnPxxl346oXid4qT1zV0Lt53Lq7TVg+di/edi5uUg/Chc/G+c/HGXzhDTzx0Lt53Lu6SeofOxfvOJRp34fyF5HdWiP5YMnQu0Xcu0bgLF8gzxdC5RN+5hB/8JHhiMXQuQca/xl24QnXBCNj3LSFTb0sMfUv0fUt439IvlLxTot/3iKFvib5vicZbuIGVh74l+r4lGnfhFj3x0LdE37dEsuMSQ98Sfd8Sjbtw1BLF0LdE37dk4y0CTajk0LVk37Vkck4lh54l+54lG2cRDL1oOXQt2Xct6edWHHUfcuhbkkyvGncR4oVwd8KwfmUww+o7l2zcRaAGIYe+Jfu+JXWy05ND35J935Im2enJoXPJvnPJpHPJoXPJvnPJxl+EQv2HHHqX7HuXWqUUq6F3qb53qcZhhEaK1dC9VN+9lHcvOFFUQ/dSffdS3r1QO1ZD71J971Leu1BbVEPnUmT+rpJvC8zg+86lGneRKzQPUEPnUn3nUo27SAYrD51L9Z1LNf4i+Qtp7laaVB56l+p7l3LJxqiG3qX63qUbh5ECvGs99C7d9y7d+ItEDVkPnUv3nUs37iLRyKaHvqX7vqVF6hvroW/pvm9pvzKELUIPnUv3nUur5CRCD71LkwWi9y44LGqwRux7l/behZqTHjqX7juX9s6FmpMe+pbu+5ZuvEWhoU0PXUv3XcskOy4zdC3Tdy3Dkk3RDH3L9H3L8GRTNEPnMn3nMiLZmszQu0zfu0zjL4oh7zJD7zJ97zI+9oDCJGboXKbvXEYn3/XQtwwJQJjkfM2AGETfuYxNzhTN0LtM37uM9y7U+Zihd5m+d9nGYRTqfOzQu2zfu2xy0mWHzmX7zmUbd1FwWW6HzmX7zmWTPZcd+pbt+5b1voWW9HboWrbvWta7lkF1h65l+65lG29RqOuxQ9eyfdeyjbMo1PXYoWdZEt5KTrgsCHD1Hcs2vqJRt2WHjmX7juUaX9FoheqGjuX6juUaX9GoCbuhY7m+Yzmeel439CvX9ysnkqOaGzqW6zuWa3xFo1boho7l+o7lGl/RqBW6oWO5vmO5ZJ/lho7l+o7lGl/RaPrgho7l+o7lGl/RMFbrhp7lSOzUJSfFDoRPafx0lZyPh9/61aO/tfW9f6F2HH6i1UkUdZV0sfATrU7iqCuRHJTDb7Q+CaWuZHJcDr/R+iSaulLJoTn8RuuTgOrKx+gtfvsgpLoiMdWVdzrUm4WfaHUSVl2l46orEFhdkcjqyiXXCOE3Wp/4no/HG7h0Zih8P4jfN85kUL/IYACf+J4PyhvUNTIUwqcxfJYcORkK4tMovg/MG9THMRTGp3F8llxVMhTIp5F8H5w3qJdkKJRPY/ksGW9lKJpPw/k+RG9g9IGhiD4N6fswvYEsAQX1SVSf+UC9gX0WCOszEtdnPlRv0PSDgcA+I5F9xtNdHojtMxLcZz5eb2CTB9F9RsL7zIfsLZqHMBDgZyTCz3zQ3jLYZEGMn5EgP+PJEZaBKD8jYX7mQ/cWNlkQ6Gck0s989N7CNgdi/YwE+5kP4FvYaEC4n5F4PxPJ1ScDAX9GIv7MB/ETvS2I+TMS9Gc+kG/RBIWBsD8jcX/mY/kWtjkQ+Wck9M98ON/CNgeC/4xE/5kP6FvY5kD4n5H4P/MhfQsbDQAAjBAAJtLdHWAAjEAA5gP7bgW7O8ABGAEBzAf3HRznAApghAUwH993sNEAGsAIDmA+xO/EC2HulCWYHBABRpAA81H+xNMDKMAIFWAymXLBABZghAswH+pPqUe8nHieD/c72OgBHGCEDjAf8Hew1QE8wAgfYD7k72CrA4CAEULAfNTfwVYHGAEjkID5uL+DrQ5QAkYwAfOh/4TnAFLACCpgPvrvYKsFrIARWMB8/J+tVi+kvBOM6geeR4ABUwGk4+UBgAaMUAPmSQBbcRSLYoAcMIIOmEqHdxmgB4zgA6YCVBcvhL1brRQRAPyPIASmAqCS+BUADyQYgXkywFbqhdR3K02WSIAkMIISmKcDbKWxBcALCU5gHhGwlYEWAKTACFNgOuQJwWYAsAIjXIHp9IQPkAVG0ALT6fAvA3SBEbzAPDHA4UEGAAMjhIF5aMBWDvagADIwQhmYBweYNTLAGRgBDUybjBMD2MAIbWCeIDC2eqFWd1ZRC4APEuTAPEZgjL2Q7k5yTQQAHyTcgXmWAOM7DJAHRtAD8zQBZ7kB9sAIfGCGpxPdAH5ghD8wjxQYw90YQBCMMAjmsQJjAgsAPkg4BPNsgTEJPwBgEYzACGYyqWuARzACJJhnDIzBcRwgCUaYBDPpSAuAEoxQCWaCA2q47gJkghE0wTxuYAzOBACdYARPsDSfYABQMEIomOUZ+wGkYIRSsIApGI6UAVLBCKpgHj/AZDwGYAUjtIJ5AoFbIOAVjAALZtPJbQwwC0agBbPB/Ry2H/gfIRcsoAu+wgJQEiXxQI8kGIcgkQGEwQjDYJ5LMI6TXgHHYARkMA8nUn0AgBmM0AwWcAbuAwDQYIRoMBeydmH4ADANRqAGc8n0NwawBiNcg7l0diUDaIMRtsEC3IBpfwzgDUb4BvPMgsHUPwYQByOMg7nggnAtAygHI5iDOZfpAgDpYAR18FXwQNQHcoA6OEEd3LMLBjMBOWAdnLAOHlgHzOjjAHZwAju4hxcMZvVxADs4gR18FRLHYaYrgB2cwA7u4QVeznEAOziBHdzDCybgrgsAOziBHXyVTvIFsIMT2MED7BAwksAB7uAEd3CPL5iQOB0c5PsS3sE9v2ACtSAOeAcnvIOHDQsCtSAOgAcnwIOHPQsCNgBAPDghHjwQD5FIaQceSJgHb7cuwBYAoAcn0IO3uxdgCwDUgxPqwcMGBglbAMAenGAP7jlGogUA7sEJ9+BhH4OELQBwD064B/cgg8HcOA7AB6fbGcJ+Bpgfx9GGBrqjIWxpkApm+KNNDYNdDd4DJfRguLGBeGDY2iChB6O9DXRzQ9jdgCM6HG1woDsceHIeyNEWB7rHIbfJAe1yoNscwj4HmHXH0U4HutWBBweEDRDtdqDbHcJ+B5h9x9GOB4JAeEAgCjZAwEA4YSDcMw0GM9I4YCCcMBDuoUaiAQMIwgkE4Z5qMJgfxgEF4YSCcI81UvqB+xEMwj3XYDDHjAMOwgkH4SIsg+EIBEAIJyCEBxACU744ICGckBAe9kPAtC8OSAgnJISL4H/Q/wEK4QSFcBn8D29vAv5HWAgPeyNgGhcHLIQTFsI922AwlYsDFsIJC+EebjCYzsUBDOEEhnAPNxjMrOIAhnACQ7inGwxmV3FAQzihIdzjDQazpDjAIZzgEB72S2jof4CHcMJDeNgyAdOVOAAinAAR7gkH09D/ABHhhIjwsHMCJuxwQEQ4ISLcIw5moP8BJMIJEuEBicCUGQ6ICCdEhAciAnNmOAAinAARHoAIzHrhgIdwwkN42EsB81Y44CGc8BAeeIiB/gdwCCc4hAccAjNPOKAhnNAQHmgITD3hAIZwAkN4gCEw94QDFsIJC+GBhcDsEQ5QCCcohAcUAtNHOEAhnKAQHlCIhf4HWAgnLISHfRYwAYQDFsIJC+GebTAL/Q+wEE5YCA8sBKaAcIBCOEEh3KMNBpMwOEAhnKAQHlAIzMLggIRwQkJ4ICEwDYMDEMIJCOEBhMA8DA44CCcchIcNGDARgwMQwgkI4Z5sMAf9D5AQTkgIDyQEplJwQEI4ISE8kBCYS8EBCOEEhPAAQhz0P8BBOOEgPHAQmI3AAQbhBIPwgEFgOgIHGIQTDMIDBoH5CBxgEE4wCA8YBCYkcMBBOOEgPHAQmJHAAQbhBIPwgEFgSgEHGIQTDMI91+Ar6H+Ag3DCQbjHGnyFN5sD/yMYhHuqwVfQ/wAF4YSCcI81+Ar6H8AgnGAQbkMMGvof4CCccBBuw2ZZ6H+Ag3DCQbjHGnwF/Q9gEE4wCPdUg6+g/wEKwgkF4R5qcJgKwAEE4QSCcM80+Ar6H2AgnDAQ7pEGZ9D/AALhBIFwjzQ4g/4HEAgnCIR7pMEZ9D+AQDhBINwzDc6g/wEGwgkD4YGBMOh/gIFwwkC4ZxocYlwOGAgnDIR7psHhKSYcMBBOGAh34awJ6H+AgXDCQLhHGpxB/wMIhBMEIjzS4PB4DwEQiCAIRHikwTnyPwEQiCAIRHikweFhGwIgEEEQiPBIg3PkfwIgEEEQiPBIg0OEJwACEQSBiFXIx4JHZwAEIggCER5pcHx8BkAggiAQ4ZkGhwxNAAYiCAMRHmlwiMAEQCCCIBDhiQbHh2EAAiIIAREsnHkC/Q8QEEEIiGDh2BPof4CACEJAhCcaHCIwAQiIIAREeKDBIcISAIAIAkCEBxpcQP8DAEQQACI80ODwpAoBAIggAER4oMEhgRIAgAgCQIQHGhwSKAEAiCAARHigwSGBEgCACAJAhAcaHB7iIAAAEQSACA80OARQAgAQQQCI8DyDQwAlAP8QhH8IHk7egf4H+Icg/EN4nsEhQBKAfwjCP4THGRwCJAHwhyD4Q4QTniBAEoB/CMI/hOcZHB6yIAD/EIR/CM8zOORHAvAPQfiHCGc9QX4kAP8QhH8IzzM45C8C8A9Bj3wKZz5B/iLQoU/01Kdw7BPkLwKd+0QPfgonP0H+ItDZT4PDn8LpT9D/4PlPxP88z+CQnwh0BhQ9BCqcAgX5h0DHQNFzoMJBUJB/CHQSFD0KKpwFBfmHQKdB0eOgPM/gkH8IdCIUPRIqnAkF+YdAp0IR/iE8z+CQfwjAPwThH8LzDA75hwD8QxD+ITzP4JB/CMA/BOEfwvMMDvmHAPxDEP4hPM/gkH8IwD8E4R9ChlPIoP8B/iEI/xDhsCjIPwTgH4LwD+F5Bof8QwD+IQj/EDKcjQH9D/APQfiH8DyDQ/4hAP8QhH8IzzM45B8C8A9B+IfwPIND/iEA/xCEfwjPMzjkHwLwD0H4h/A8g0P+IQD/EIR/CM8zOOQfAvAPQfiHCPtBIP8QgH8Iwj+ECgfhQf8D/EMQ/iFUOJgF+h/gH4LwD+F5Bof8QwD+IQj/EJ5ncMg/BOAfgvAP4XkGh/xDAP4hCP8QnmdwyD8E4B+C8A/heQaH/EMA/iEI/xCeZ3DIPwTgH4LwD+F5Bof8QwD+IQj/EOG4Kcg/BOAfgvAP4XkGh/xDAP4hCP8QOpzFCP0P8A9B+IfwPIND/iEA/xCEfwjPMzjkHwLwD0H4h/A8g0P+IQD/EIR/CM8zOOQfAvAPQfiH8DyDQ/4hAP8QhH8IzzM45B8C8A9B+IfwPIND/iEA/xCEfwjPMzjkHwLwD0H4h/A8g0P+IQD/EIR/iHAwFeQfAvAPQfiHCGdTQf4hAP8QhH8IE84ExYeRAv8j/EN4nsEh/xCAfwjCP4TnGQLyDwH4hyD8Q3ieISD/EIB/CMI/hOcZAvIPAfiHIPxDeJ4hIP8QgH8Iwj+E5xkC8g8B+Icg/EN4niEg/xCAfwjCP4TnGQLyDwH4hyD8Q3ieISD/EIB/CMI/hOcZAvIPAfiHIPxDuHAuLdzHIgAAEQSACA80BIP7WAQgIIIQEOHCCbXQAwEBEYSACE80BCQgAhAQQQiI8ERDMHxyM0AggiAQ4ZFGYiOOAAxEEAYiPNMQkKEIwEAEYSAi7APB+3AEgCCCQBARNoLAU9UFgCCCQBARDryCEEcACCIIBJHhyCsIcSSAIJJAELkKPogakQQQRBIIIlfBBVEjkgCCSAJB5Cq4IOrEJYAgkkAQ6aGGgBBHAggiCQSR4dArCHEkgCCSQBDpoYaAEEcCCCIJBJEeaggIcSSAIJJAEOmhBk7ClQCCSAJBpIcaAkIgCSCIJBBEhm0g+FwCCSiIJBREthdXwCx2CTCIJBhEBgwCjxWQAINIgkFk2AiCd2RLwEEk4SAybATBxwpIAEIkASEy7ATBxwpIQEIkISEybAXBxwpIgEIkQSEyHIGFjxWQgIVIwkKkZxsCskAJWIgkLESy5N0DEqAQSVCIDHtBEt8QsBBJWIj0bCNx4jpgIZKwEOnZBj6ZVgIWIgkLkTwcF6/ROCQBDJEEhkgPN/ApZBLAEElgiOShH4TjAIAhksAQyUM/CMcBAEMkgSGSh34QjgMAhkgCQ6SHGwLfEgBgiCQwRPJwyjccBwAMkQSGSJE+HkYCGCIJDJEiOCAcRwAMkQSGSA83BISxEsAQSWCIFOFgDjgOABgiCQyRIlxZgB0Q0BBJaIgUyTMAJYAhksAQ6eGGaM7+HB6LIQENkYSGSE83hIAzOQlwiCQ4RIrggbAFABwiCQ6RInggbAEAh0h6S0a4JgPiXIkuyqA3ZWSuykB3ZdDLMsJuELyhVKL7MuiFGeFoLIiTJboyY3BnhvdAiJMlvDWDOGC4NyPhQejqDHp3hucbQsI9uRJdn0Hvz2gv0MBzKXSFBr1DI+wIScyl0D0a9CKNcJMGROISXaVBkIhUwQfhDW8SMBFJmIgMN2pIeLqMBFBEEigiw60aEIpLAEUkgSIyXKwBobgEUEQSKCLD5RoQiksARSSBItJDDgGhuARQRBIoIlU4nwi2IgBFJIEi0kMOAaG4BFBEEigiPeQQEIpLAEUkgSIy3LYBobgEUEQSKCIDFMGrAQBFJIEisj0fC0/mARWRhIrIsCskMZkHWEQSLCLDEVkQ60uARSTBItJjDgGxvgRYRBIsItsjsvBiAnARSbiIbI/Igod4SwBGJAEjMndGlgRkRBIyInVwQtiIARmRhIxIHZwQNmJARiQhI9JkTmmTAI1IgkakCRcLwV4AoBFJ0Ij0qENoeLStBGxEEjYiwzUdMDdBAjYiCRuRnnUImJsgARuRhI1IzzpSAwmAI5LAEWl0ZiABdEQSOiI97RAa33IK8IgkeER63CF04hGAFxI+Ij3vEDA/QgI+IgkfkTachg+HQsBHJOEjMn1MlgR4RBI8IgMewefBS8BHJOEj0vMOfEawBHxEEj4iPe9IHPAgASCRBJBIq9JH7UlASCQhJDIQEg1PG5QAkUiCSKRHHviEagkQiSSIRAZEgk+ll4CRSMJIZGAkMMdEAkYiCSORHnngW5kkQCSSIBIZEInh+G434IUEkUiXOaxNAkYiCSORLSPBTwC8kDASGRgJjiwBRCIJIpGeeCS+ICAkkhASGQgJvogQEBJJCIn0wEMYeNyhBIREEkIiAyFJjOYAkUiCSKTLHFgpASORhJGowEgM7MoVgCSKQBIVIAkObihASRShJCpQEhzeUwCTKIJJVMAkMNdJAUyiCCZRq+RxbQpQEkUoiQqUxMDRVAFMoggmUR574H5AAUyiCCZRq4wXKsBJFOEkynMP3IwU4CSKcBLluQfuiRXgJIpwEuWxR+IWQYBJFMEkylMP3IwVoCSKUBIVjsvCrVABTKIIJlEBk+BWqAAmUQSTKE89Uq0QYBJFMIliKtMKASZRBJOogEnweK4AJlEEkygWvBDNqBSgJIpQEhUoCcz4U4CSKEJJFAujMby6E2ASRTCJ8tRDwIw/BSiJIpREBUoCM/4UoCSKUBLlqYeAGX8KUBJFKIkKlMSiVYUCkEQRSKI89BAw408BSKIIJFEBksCMPwUgiSKQRHnogSGBApBEEUiiAiSBGYMKQBJFIIniyYN7FWAkijASFRiJxb04gCSKQBIlgv/BM/cUoCSKUBIlkksSBSCJIpBEBUhi4XxcAUqiCCVRgZLgCxgUwCSKYBIVMElKAHBBgkmUULlHAD5IQIkKu0ZggEwBTqIIJ1GBk8CsSwUwiSKYRAVMArMuFcAkimASFTAJzLpUAJMogklUwCQw61IBTKIIJlGeewiYdakAJ1GEk6hwqzjMulQAkyiCSVTAJDDrUgFMoggmUQGTwKxLBTCJIphEBUwCsy4VoCSKUBLloYeEWZcKQBJFIInyzEPCrEsFGIkijES1jASGNxVgJIowEtXeNo4v7gaQRNELxz3zkDDvU6E7x+ml4x55SJj3qdC14/TecZU+N1Chm8fp1eMeeUiYN6rQ7eP0+vH2IhGIuRS6gnxwB7lKYy4F7yEnPqgyfSC6ipzeRa4yAWqFriOn95G3F4lAyqDQleT0TvL2IhFIGRS6lpxwEtVeJIKbAQAlioAS1YISGONWAJQoAkpUuKIcpg8rwEkU4SQqfU25AphEEUyiMjeVK4BJFMEkqsUk2AcAJlEEk6iASfCKEFASRSiJ0iYTUwCURBFKosLF5TD/WgFKogglUeH8rEQ7BphEEUyiWkyC2zHAJIpgEhV2kOB2DDCJIphEmdyiGGASRTCJCkdoJdox4CSKcBIVztBKtGMAShQBJcpkaJ0CoEQRUKLCKVqJdgxAiSKgRJkwIMMJCeAkinASlb5NRAFKogglUeEUrdQ3BF5IMIkKN53D1D0FMIkimESFbSS4IwGcRBFOogInwf0AwCSKYBJlM6mDCnASRTiJ8thDwn0QCmASRTCJCrefw+kQgCSKQBLlmQc8hVoBRKIIIlHhNhF4CrUCiEQRRKLCZSL4PiAFEIkiiESFy0TwfUAKMBJFGIkK+0jwLgoFIIkikETlLhNRAJIoAklU5jIRBRiJIoxEhfvR4UlgCjASRRiJ8sxDwpPAFGAkijAS5ZmHhPtgFGAkijASFW4TSYxkAJIoAklUOEoLR5cBI1GEkSiPPCTciKMAIlEEkShPPCQ8ikwBQqIIIdEeeEi4jUYDQKIJINGed0gGUasGgEQTQKI975AMAgYNAIkmgESHy9MZXJVpQEg0ISS6vT3domasASPRhJHoVXBChwUMvVATRqIDI2m8CAkYeqEmkER75iHhXhYNGIkmjESHS0VwM9AAkmgCSXQ4UQs2Aw0giSaQRHvoIeFmGg0giSaQRLOcGwJKogkl0YxnnABQEk0oiWYi4wSAkmhCSbSHHiknAJREE0qiPfSQcEORBpBEE0iiWfBC2BUARqIJI9EsOCFa1mnASDRhJNozDwlPhdOAkWjCSLRnHhJuZNCAkWjCSLRnHjhrRQNGogkj0Z55SLgRQgNGogkj0Z55SLgRQgNGogkj0Z55SLgRQgNGogkj0Z55SLgRQgNGogkj0Z55SLiRQQNGogkj0Z55SLiRQQNGogkj0Z55SLiRQQNGogkj0R56SHiqnAaQRBNIoj3zwNE1DRiJJoxEe+Qh4al0GiASTRCJ9swjoR8wEk0YiW4ZCYQ8GjASTRiJbneSwDx6DRiJJoxEB0aCkxc1YCSaMBIdGAnemK0BI9GEkWgRfBD2IYCRaMJItEhfraQBI9GEkWgRfBD2IYCRaMJItMhEZjSAJJpAEi0zkRkNKIkmlEQHSoKTHzXAJJpgEi3Tuzo1wCSaYBItM7s6NeAkmnASLTO7OjUAJZqAEi0zuzo1ICWakBItM7s6NUAlmqASLTO7OjVgJZqwEi2DH8KxCKASTVCJlsldnRqAEk1AiVbpnBkNQIkmoER78JEYygEo0QSUaJUJD2pASjQhJVplcmY0QCWaoBIddpPg2I4GqEQTVKI9+ZBwU5gGpEQTUqJVZmWsASrRBJXoFpXgngSgEk1QifbkQzbbwkBPAlCJJqhEe/Ih4b4wDUiJJqREZ3aUaABKNAElugUl2IsAKNEElOh2RwnuiQAp0YSU6EBKEj0RYCWasBIdbhpJ9EQAlmgCS3QLS3BPBGCJJrBEe/gh4VmvGsASTWCJDltKYE8EUIkmqESHDSW4JwKoRBNUoj35wNfWa0BKNCEl2mT2t2tASjQhJTpsKEl0JACVaIJKdNhRgs+q0QCVaIJKtCcfEm4t1ICUaEJKtAcfEp62qwEo0QSUaBN6QjivBpxEE06iTfBAOCcEmEQTTKIDJoEbCzXAJJpgEm1CPwjHYsBJNOEk2mMPCTcWaoBJNMEkOtw2gu9L1YCTaMJJtOceEu5M1ICTaMJJtOceEu5M1ICTaMJJdNhOkhhIACfRhJPowEng1kYNOIkmnER78CHh1kYNQIkmoER78iHhxkANSIkmpER78iHhxkANSIkmpER78CHheb8agBJNQIm2wQNhCwCcRBNOosNeErgrTwNMogkm0Z56SLipTgNKogkl0Z56SHjerwaURBNKogMlgXvqNKAkmlASHSgJ3FOnASXRhJJoTz0Sq1JASTShJNpDD4l3xGlASTShJNpl9rdrgEk0wSTaZfa3a8BJNOEkOpy2lXoE4IMElJhw7foK0kIDSIkhpMSs0ikLBoASQ0CJWWXWJAaAEkNAiVllUhYMACWGgBKzyqQsGABKDAElZpVJWTAAlBgCSswqk7JgACgxBJSYAErgydUGgBJDQIlZJVMWDMAkhmASE87cwptRDOAkhnASk9lMYgAnMYSTmHDmFt4IYQAnMYSTmNxuEgM4iSGcxAROoiHvM4CTGMJJTDh0Cy+tDeAkhnASEzgJ3B1rACcxhJMYllkZGwBKDAElhmVWxgaQEkNIiQkXsCf6IoBKDEElJlxAgvsigEoMQSUmd+qWAazEEFZieOawBQNgiSGwxPDMYQsG0BJDaIkJd7An+iKASwzBJaa9hB33RYCXGMJLTOAl8BR6A3iJIbzEhFvYYV8EcIkhuMR4/IFXpgbgEkNwieHplbEBuMQQXGJ4Jn3LAF5iCC8xYU8JXtkaAEwMASZG5DpDQEwMISZG8ExXBIiJIcTEiNAZoomtAcDEEGBiRCah2gBgYggwMSKTUG0AMDEEmJhwFXuiKwLExBBiYsJdJLgrAsTEEGJiRGaTsQHIxBBkYlpkgrsigEwMQSamRSa4KwLIxBBkYsL5W4muCCATQ5CJCSdwJboiwEwMYSbGIxAJL6QwAJkYgkyMTG4yNgCYGAJMTHsAF+xKAC8xhJcYjz8SXRnAJYbgEiMzWf0G4BJDcIkJW0sSPQngJYbwEiMzO90NICaGEBMTtpbA4xoMICaGEBMTtpY0V4KAaRlAJoYgE+MJiDTwDDQDkIkhyMSEzSXwUhADiIkhxMR4ACLhRnkDgIkhwMQEYIJ3uhtATAwhJiYcwIXptQHExBBiYjwAkQZmshlATAwhJiYQEwMjdQYQE0OIiQnEBG4zNoCYGEJMjCcgEm4zNoCYGEJMjAcgEm4zNgCYGAJMjE5vcDKAlxjCS4zHHxJuUzYAlxiCS0zYWpJoRQCXGIJLjFaZVgRwiSG4xARckvBiwEsM4SUmbC5JeDEgJoYQExM2lyS8GCATQ5CJ0S7jxYCZGMJMjAleiMJlBiATQ5CJMelEGgOIiSHExOQ2lxhATAwhJiacwYUzcQxAJoYgExMO4cKZOAYwE0OYiQmncCW8AEATQ6CJ8RAkscoH0MQQaGICNIEb9g2AJoZAExOgCdywbwA0MQSamABN4IZ7A6CJIdDE2OCDMMgAmIkhzMQEZgKv6DGAmRjCTExgJvCKHgOYiSHMxARmAq/oMQCZGIJMTEAmcLO4AcjEEGRiAjKBm8UNQCaGIBNj0wcuGIBMDEEmJiATuNncAGRiCDIxNn06vwHIxBBkYgIycfBQXQOYiSHMxARm4mAelgHQxBBoYjwEgbtzDGAmhjATE3aWwN05BjATQ5iJcSK9O8cAaGIINDFOpnfnGEBNDKEmJlxRgjfXGIBNDMEmJmwuwcsSQE0MoSbGBR+EfRCAJoZAE+MyPgiYiSHMxIS9JfDAAQOQiSHIxIa9JQ4O5BYgE0uQiV0lXdACYmIJMbGrtAtaAEwsASY2ABP4/SzgJZbwEht4CcTOFuASS3CJDbgEzgUtoCWW0BIbaAmcjFoASyyBJdbDDwaRmQWwxBJYYj39kPDACAtoiSW0xHr4oeCBERbAEktgiWXpk/ktgCWWwBIbNpXgPtgCWGIJLLFhUwnugy2AJZbAEhtgSaIFAVhiCSyxnn3gFgRQiSWoxLb3k8AWBFCJJajEtuduwT7YAlRiCSqx4dwtvEPSAlRiCSqxAZXgTtwCVGIJKrHhfhI8DlnASixhJTawEtyLAFRiCSqxnnwoeOyJBaTEElJieXpNbAEosQSUWM89FDy0xAJOYgknsWFbSaIVAU5iCSexnntgHwaYxBJMYgMmwT4MOIklnMR67sEY3FNgASixBJTYcPYWhwl0FpASS0iJDaQE35VmASmxhJRYDz4YxyMBICWWkBIrMvuMLSAllpASK9L7jC0AJZaAEiuCE6LpuAWgxBJQYj33SDQCwEks4SQ2cBJ4RYgFmMQSTGJFcqu7BZDEEkhiRXqruwWQxBJIYgMkwcMIYCSWMBIrwkiMVuMWIBJLEIkNiATxAQsAiSWAxMrQBaLFvAV8xBI+YmVmZ5MFfMQSPmLD0Vv4+DoLAIklgMSmAYkFgMQSQGJl5uw3CwiJJYTEhhtK8OlzFiASSxCJzSESCxCJJYjEeuKh4JkzFhASSwiJlcEF0WLEAkBiCSCxHngoeNaFBYDEEkBiVfBBOJkFfMQSPmI97lDwpAML8IgleMR63KHgSQcW4BFL8Ij1uEPBgwYswCOW4BHraYeCBw1YQEcsoSPWww4FDxqwAI5YAkesZx0KXpdpARuxhI1YjzoUvC7TAjRiCRqxHnUoeF2mBWjEEjRidThsBvofQCOWoBHrUYeC12VagEYsQSPWow4Fr8u0AI1YgkasRx0KHjFgARqxBI1YTzoU3OFvARmxhIxYDzoU3N1uARixBIxYzzkU3N1uARexhItYjzkU3N1uARaxBItYTzkU3N1uARWxhIrYsJEE7m63AIpYAkWshxwK7k63AIpYAkWshxwK7k63AIpYAkWsySxDABOxhIlYjzgU3N1uARKxBIlYTzgU3N1uARGxhIhYDzgU3N1uARCxBIhYDzgU3N1uARCxBIhYk95ZbAEQsQSIWA84FNwdbwEQsQSIWJPc0WkBD7GEh9jAQ/D5GhYAEUuAiLWZEz4sICKWEBEbiAg+oMMCJGIJErHtrSTwgA4LmIglTMTa4IKwCwFMxBImYsOtJPATACRiCRKxYRdJ6g0CFyRMxAYmgo/qsQCKWAJFbNhHgo/qsYCKWEJFbKAiKS8CbkioiA1UJOEEgIpYQkVs2EqScALARSzhItZzDgVPebCAi1jCRaxLHn5pARWxhIrY9sAt7ASAilhCRawL/SAchwAUsQSKWBf6QTgOAShiCRSxLrmf0wImYgkTseG8rRVciQMmYgkTse15W7g+cEDCRFxgIvBqIweQiCNIxHnGoeDGfAeYiCNMxAUmgl6fA0jEESTiwmFb8PU5gEQcQSKuPWsL1x96nyNIxIWjthKvb+h9jiAR5xGHgrviHUAijiARt0p6nwNExBEi4lZp73OAiDhCRNwq7X0OEBFHiIhjGe8DRMQRIuI84FASRiIdICKOEBEXto/gm7kcICKOEBHnAYeCe/odACKOABHnCYeC28kdICKOEBHnCYeCm5kdICKOEBHHggOiOYADQMQRIOJY2gEBDnEEhzhPNxTcC+0ADXGEhrhAQ1YwEOUADXGEhjhPNxTcTO0ADXGEhrhAQ+BmagdoiCM0xIXr2uFmagdoiCM0xAUaAjdTO0BDHKEhzsMNBfdCOwBDHIEhztMNBfdCO0BDHKEhLr1pxAEY4ggMce2mEdh8AAtxhIU4jzYU3AntAApxBIU4nlyFOABCHAEhLhyxhftfwEEc4SBOsHT/CzCIIxjECZ7ufwEGcQSDOI81Ut0n4CCOcBDXnrAFT8ZxAIQ4AkJcOGELX2zoAAlxhIQ4jzbwdVoOoBBHUIgTwQMhU3eAhTjCQly4hgRfLOgADHEEhriwYQRfLOgADXGEhrhwEQm8WNABHOIIDnHhiC24XcIBHOIIDnGebuBNqA7QEEdoiAs0BN5I5gAMcQSGuHARCb7SzQEc4ggOcTJ0gnAUAzTEERriZLoTBCzEERbiAgthuBEBFuIIC3GBhcDzFBxgIY6wEBcuIsFJ3g7AEEdgiFNJHucAC3GEhTjPNjjEaQ6wEEdYiAtXtSc8EMAQR2CICzAkMQ8FNMQRGuI83eAaPwHwQEJDXKAh8EQLB2iIIzTEebph4IV2DtAQR2iICzQEnojhAA1xhIY4ldzH7gAMcQSGuHBXO84vd4CGOEJDnA772CFQdwCHOIJDXMAh8EgPB3CIIzjEBRyiYXKeAzzEER7i0peQOIBDHMEhLhysJWBynwM8xBEe4gIPgWeKOMBDHOEhzvMNJmBajgNAxBEg4sJGkYQPACLiCBFx7dFaCR8AXkiQiAtIBB6L4gAScQSJuIBENJyMAiTiCBJxAYkkfAgwEUeYiDPBCeFiEDARR5iIC0wE3hPuABNxhIm4wETgSQgOMBFHmIgzyYC0A0jEESTiwsFaeDYOkIgjSMSFPSJ4Ng6QiCNIxJn0DnYHkIgjSMSZ9NluDjARR5iICwdrJRbTgIk4wkRcuIAEjyIAiTiCRJwN/gdHMUBEHCEizqb7QMBDHOEhrr1+BH4/wEMc4SEu7BHB3x8AEUeAiLPpe5gc4CGO8BBn0ycoOIBDHMEhztMNBXf/O0BDHKEhzqYXw4CFOMJCnFulN747wEIcYSHOow0Fd407gEIcQSHOo43UYhSwEEdYiAvnauHlNIAhjsAQF7aIJJbTAIY4AkNc5op2B2CIIzDEBRiSmMcCGuIIDXHhjvbEchzwEEd4iPN8I7EcBzzEER7iXNoHAQ5xBIewVXtDO3yF7a99EfEfOxksHRJofx3IYFQGT69J218HMjiVIdKBgfbXgQxBZch0dKL9dSBDUhkqGV9ofxyIUFSETi7x2x8HIjQV4XtHeCJB++NAhKEifAdp0By3/XEgwlIRSf9sfxtIoB7qGYgyaJbZ/khFMOqgAZvAow3aHwciqH96DqLg6QbtjwMR1D0DOjFottj+OBBBvTPQE3gNevvjQAR1TpacM7a/DSRQ3/RIBJ8Y0/44EEF902MRDneVtD8ORFDfDCQF3uje/jgQQX2TZXwTsJT4j62EQFPgeQ3tj1QEp74ZTuLCRgCgEv+xk+BdEx760P44EEFdM1AVeO5D++NABHXNAFbg0Q3tjwMR1DUDW7G4pQO4Ev+xE5GMLLa/DSRQ1/TEBMfW2h8HIqhremiCg1vtjwMR1DU9OFFw+33740AE9U3PThTcgd/+SEUI6pvpS9/b3wYSqG+GO00kDLO0vw5kUOdsD+mC+yDbXwcyqHd6jJLqcAB3if/YiQhHg+CvCshL/MdOhJ9uwkMN2h8HIqh7iiR/bn8bSKDeKdI5EO2PAxHUO0U6DaL9cSCCeqdnKnjt1v5IRUjqnRkM0/44EEHdU4auE4+nAMXEf+xEhK4Tj0OAxsR/7EQkN6e0vw0kUN/0gCX1TQGRif/YidCZbwqoTPzHToTJfRDknJI6p7S55QhgM/EfOxkufcJp++tARvjjf714tjt8rk51tf3+sK1+f/an33579o9/1F8fq2cv/ufZP3bhj+yFV/XsT//zjD370//874tnzIb/ctP+14X/Ctn+t/1dtuVl+/9q1f5Xhf9qEf5r2r8bHf5r23q2/d229R1v/9uWYyve/aMtwZjo/qG6f7RGMt4V5l11ser+0ZXRXRnTCexsYa59OL4y3dO1jy1Fq0teH5h1T9zWUrx7B6L7qXt61elq7qUJ/9CmezHtT6azuTnMLrwTuer+0f3FuO51tfY06ZjtP1qBrntjrnsK170f16lw3edsSGT4R/fhGjLTfoFWchNlDf/oPlYT+An/cK77OqvLvy6fZcUuf+Ps8q/LhxWXv12+zSo86P++6Nw7/L3za/9b4+jrTb07Hs6xCxsd+XBQXCTmc1VXh/Wh3nysNp9O1flpX8dirYvECl0mtjpzpTf1KRYkhLhKkoJPk7StNqevjz3LBLeRQD7RtOoABJpYoCoTuL8/nnb1x4f+s+r4WXXXdC59QtcpGNk5XedQoVkUqN0fv6z3+/Dt7td1rztzPPpooRGVSXw6bKsPu0O1rdf3Pe+y0cdjoZ2PS3x8rA7bXjcb97NtK7WrQpc/b6rDdne4jwU2x1FdJBpTaFddV+d63bSgWFbDni+ynCr8/FdZ5939oTr13pow8ipSrbqhgRU+sZdd9VpRExu+GunYJEF921TUsqUu7DCe6o/Vod5tiMNZG/cSha8ukrWtzpvT7rE+nja77cPu/LCuNx97nqOitslF4YeONPz3l/PD7nwm/sOUjsUWtr2r2N3x8HA8VfXH9eF4qBoPWNdPp+pwrM9Pj4/HZtrRV2djdeXv/NhzgoYwXF+3uozVbWcidTf8dkOZMqIbfmU3/PJu+O36om6IMuIyuBX2HN7A3b8GLSruT7tO0HRDsbqOiOWv/aLmcKzvT+tDXW3rI3hBsW/z0g6wld9z7Oaus4skraZ8sd2/qvCPbbWvaA/dXOd4bX3X2VFhg+4UINHN0dGRd8juO3cT0G5ma0pH807Z8cuhSjxMPNyZspf0fn2utHw67evj+6911e+bWCxwVfb9IoHH9/9dbfpjO4vH9lXZa36/P24+nevjqe8SLh5zXDdFZWUzmvdPu/32n0/V6evxcTCHa05muoi2q8IX2Uis1/deRv89NhckXb3XlvXL/mvUx8vr7L/GeM61KnzkVuDufneo+6O3iEfvws8cpIFPzFexbWVjbCvtXJ/IyCBYPDyGTnJU2mZ9eKxOH46nh6aZ1NX6fr07nOtTtTmeegNBc/PR9cO4sve42fVkuHgQkGXfdrOv1qSnjIR0K5Nujcq6xajq/mG6Zantho3mcKV2IVv4FPvjmfRX8cIl1OKt9G6xJLsFkukWr7b9hXdFlO0WlO4ys+z+0a3IbFfYFg71m+O2b2vcoHjhRGdzfHhcnyry+UTcjajCjr8V9VCdz+v7qt49NJPPh8eea8Xdv1JljaqR+1RTE2MLmSwbLa6Smne3Sc6E9CoeocufPsh+eNrXu4/r88e0fBbLL3TNIH+7vn98v9ltP5yOD4OhyZn4nZTNQ4HcplNY99aMLp5Cy7Kuf3M8bHeDUUTGHaFetS6vu+mhvYScCpcPm+Phw66/7Ir7HtMFQ2zXepvzxsoFP/WHV8Ei/xWusOM9Nt3s06YGg2BzRVk0O2l7Ce2KX3GQ/Kn6uq1Ou89++vm4rj/2p4nRhEWb0n4hJfqpWads1/W6GUrW9fm8+Vg9kHmpiRWWts2swsfTsT5ujvvN8VBXv9dIqYuVljp/kdLmD0ijjTWWdtpZjV7LGr1TFbebwmnsRVl/BeLieEkXMmVdjJGv2gGJd5FJLnj3j24V18VFZRfCVZehTrWFdRfG1F0sUYuLf7cqzGWlZ7oFXjd2mi7o3JxT2zbhbjTvIslWXEKv3V/KP0PjRv0hpcnMusYvug6j2UzQLjmLPbkJ6n/Y7Ul8RMYLem2LLW2kNTEvJFHFEgvtO1WDVVkc++qel/Pua3evQl5AQkcQVIcOdBcO1+rykbsP2PmRKZ2TeAMTkTARdy5SFQ6eQWIqFiCcjqc7U2RuYehPxUY6XjjPCQKbcBOSGAcAeeHgGCTutqfqfNw/NY89DKKrOFRtCxc6QXIzWeh/m3g0K50nXESBRacw8US0dKXjJfoQTK+xiLgL5VNkHT98OFc1ntI6Fk83CicXXuqp+udTde7byONRjE/xxFP1+bgZuLYU8WKudO7jBV4ihv2mYuKmMuUlhhh0T1gcIVeFUCMW1vcVGwe0Jz9qdcIPHDc8qaY8cMJfVrG/FMp7Op37Y3gMca7Rym4wtmX9QzOL69kWz9u61W0XRFKrKxws+1KNeLqwNNEEWrpuiO2Atc9uLRVdHZpV3DYEMM5fTru6W3v2urc4/udM2fu+Tm/7xseUsEO66kJyu/i1zxWepqbnyExGenghLm1knUmAmMWhStbhaWZ592k7GC2upLj8BQ2Cj/HsppVXOJxcxN1X9XCEYnF8lNmJIvfV52rfb4FxZK9wGnYR9/gELYyjEYVz0CCSLrVZHMVk3XKYuUtOQLHwqh3++wvYmCJ3btBNcLs5nM8QL9VS/f64O5HQbvzB9CUaZ8sWZdtu8O6bLlkcLy6MuzeyHp/e73fnj+RFxP2Q6F5Et4a5zP27n3zCe6nC8/HU945VnKegu4SNLgHDlXt09fS4pZ+0ybm/Sl+tCv3jfT+2H70OWzg12lZN//u4X+8OIeD9uP66P677r9nGAb/C+QzIp5AyXuiYwkGiSRfY0RmRjtvXJQDFL8uXwqGzRU3EReOIQJd6pC/ZBLZbwNrCPr1TMpjLsl62gu4SobpeQnVpWLpbzJkuwma6xbwpnJ8HWtBXHkf3uwQk1o3m4jIydn8x3XrfdnzPivLXXFfV5+pQn99/JZOJnhmdhlL/T4bLmFDx6FvYNi/ihqGbZtf1VWCXiiW77tfpwp6lUVGtm5Whb2xNr7ZpM4V2x8On6mu/DxZxH1yIU4OO7aN/mOq/v3zqPwePn2OOxE/V177EOMOBlbpEkOifnwhsNshfJ3u6cBDzAj9VX30E7uOn7Ye+k8XBejblqVMPHedZXBpq6SBAJA8YAJMxvGBTXgF8pUzE6QqF2UE4hiHjBZopnSW12Td0XRvPuPSqizBeovyXFNYunmhduekh26eXLRI5apdt2iVGOHWZ9xcmn/UyivpjeRyaXRV3PvV615vixjEJVpjKsyWmrKIXbAshWBdq+txf58f9Rpmcp8d9yL3Cc+R4GstLl4xfDv12EidtlU55vhyGwClqb4Xfy0s513RMV/FTiWJZ1elEM4zi9aMofjQvaEiV4+GwdBz5ctgd6ur0Yb2pfN14SriKM69K1wRfDg9V/fG4HUiLJ0KiMFmh2uyq87naPHKlP7F+cmwcwSx8dX1xKBs4jjzKwk6iLxWmBMdZIIWJatWWK8Xc7vB5vd9t6QgfD5+8MLhXPez6btwb3rrpXuEz+5BOP9AVd/SiEIy2b6vaDuYHMeHp4JMzZb3bdbIVy4wj1Kyb30p+SZ4uazFX2Ymk7d56daq9u8PjE/HIOMWvw2iqG0dV4bzhquHxdHysTnX/bceZjk4VOmgQef768FDVJzLD7UdA40ZV+gkfm9n5ab1PTB9F7B6FvvbPp/V+iOZi1ldIBfwyp2lOTTr0YNBrrsO6SiztmgYiD8f6+FiBQSN+dl641cOL3+/OdUUi+/3A4wRZx97QGo0UXZB1kiwQ+4sMM26CZcMPEo8U7QRwgnXnp/dwYst62cFl8n6vNk919XTYN+Hv94N8I2FiZlP6OX6v6QYJHufuXnJLCycq1e/1ab2pySxTxFmWqnAW9qGqNx8B3otE6cItN16UDxKt9zFI6NkYT6ekKhvJUoIBoRBx3p4sTOP28g/Vl6rL4ER2x2NGYfcLOrJ4HdBlOOpLqn4bzjDdXkRz2bRmLvHN6w6yMl8JRuwOm/3Ttjpf4rftg/YTIGJeWrgnoC/+6ZBVEI8yujApLSjoZ0/HlLjLq+jyWFTh4p/y9ti2wpAizBtk8UySF8IrT+wHic4snuryQpp03wwf6/1/fzl/rk67D7vqdF/VlxH6cKw/HJ9IX6Tj1VthquNQTTsNhuCXxYFiXhgsDSoyqSYqzn+0uuxVQ6nQ6ObGrkj8lNfvE0U+VV8fq9P5eFj3pUb+YQunWp3Uxk9SXVRzwdxVcOG2tk6wHwGGyUwqztm2hQlCnczm+de7fo6VifzAdLuWTOHskAg+rb/0ZbtY9jSR7VBy9hs2+m/AxG9gntRT1Sc5Kp6YWD3NBzqh7aTnPflgcQKSLusKO8nIW+MAg53YcLuUz8sKMu26MTJTZTM1quUMs4ybaysj0RNfSCd66BYxhrSFnKsT276GIQxS8VTfFs6OiFTgwTIWWjaXI0ITvhbPZgrnREQwcIW40y1MEfJCdxswH+RxwGOOsFP1uO+9zjjDr3BzyX1FeGMcmO4mMKrLrjfd4Qy2EJDcV3Vi42+coFD84evhNksRx8BV+VMPdsLESWWF89dGzNPpVB0SKYPxuQXGlo5QdXWoT1+JeTEXl10KtyxM8m9k+rVofzIYs4P2sxbSvmbbT1jzDFcjcX6+LO4v6080gSwSowoX3PdVHZZKaPUV721RhXGP+6o+7rcpgbGFhXvfmvnuunGYNjHdT64/wCx1GS/r9P9f2rUsOY7kyH/p8x6SEXyI+ytrc1BJzEx2KUkNJVVXrtn8+xofCDkiQMpZe5rq6h6AIuMBOBwOfvXM8XSE+OYHzEvoW/1uwmf5AamN9EV+v5366xQmXpth6oMfacpJVyIi8yWJdo/GU9Yp8r8KsjoWLCUABvzmgmR6fwzHH3rLYZuhND4cyELBFAer1GBmT028rChrwjyPDSxs85ZgAeo/ODbAsM13/f27uc8aMNoHUgbYC9z2MTKmf0ZvCMlUjk0eEvOh+GXKRSAH1rHhQuJjrofZDhDKZY/axMFTxuB9hBS7uFyJ+iGOzd02vJhiCVhdcWw8MNnT7VMYvxRkFWmyo58nx9uxqHds0KQrDykFZcZZ+jzeIHXQMmE5lnRK8uz4jCtkGdKGHKkbMFnRjKoFWdHfEk2TmYI24dQBswQ7oSFcepKEf1aSIgWzcVUlwARMWPWHjNuqk5Hl98/E/ZEQahXIMrw8HHn7puZ/HS+PJlGNw0DJkZcx2saHbruv5qsfoofHo5JEsqb/73J1TH8+/rg09qvBQ5IEspbYczlZfjVx46PHxZ1LN2JdirpaSa7JlRDXwRnz1E8L+ndvnjuJw+WhliSGGdIi+dRoW1aotNzV8je1NGrW0qhZi4BCfQi0pWf7BRmuTo/YvaxsFCiMVJMobXtD5TfFasIoKTyz8CgzMnZvb6EI/LP5Htvfh5FnoaM6zZMnj5Hbeu6DkjHSrpOTndHtbUxe9DWEWiwFqX7Q3sacJbKDSTLZWtDe1oCQHPv/SrLXZjwMPrrm/ON7XZEoe8N6sujR5SIKkgunvggNqrKnC6Enl3JPlFK7qqTRuRJFj4qkuT0feV12CJd+Ls1UBYlGtrfb/Tjcb/+090+r6xcrnSS54O9/osZKTHvJ8OPvf25rpH/rvsfarivpx5yKM9+hvPHogojGafilrzis0JA4d8wiQTZuTtKUVLRjEL5Rl8uR7/Zn823ziwqs8tVkkKCspewfvE1yEtRKTeoFhTzhnMyqfzYxnnVAqsJTQSDIBMhNRzZp/2y+v0bktj1qqagDtk+SYIJRG/KoLVjIFXsgmXOXNqLOefXjl2uae5Nfx+74MVYrbo+vMaa6H2+a2ofBSUYql3wdVViM0WpGclO+jr+lM3ES8RzTvB/N0rqpeaa4aUiGm4Weo0JLaOpZQgSRLcilJScP94QP+hXyBwmvSokwSvmPK+HJVdLDVT1VckkEfHl0rdcYk28LlIepyWbKxXIEZCsRGCEnigIyeTgvlifMWL1zzAS4424xNQHGcyoTXx6I85DCs1JmVHsKi2meZEmIofTu9Qrc3WXMgHAW8Gbsj5mzeo3WIcBCRubiLGpBVATkXcvo9gRlE8ihwLdRk8KFq2XrHIO8gszFlDX1ct+P7SU6YvBycX/iwDhvtAjQfpOG6EWOBeyC7JNRRpMKoBJH2vfDYyJAjgKvBQlforGXXwkhP7I5Du2vHSi4m8jWMDRrfXuMw/ftqtGi+elREYMEVdBm+uUxJdu3Q4O9qfCoMxCEGncbXSL8qexjfH+M6kmazSbBxDskWJKgYGLx1bJF0VxHpuSJE7v7TGl//eHjA4n50bVf10sz/vfxb8BLl4QDEk8WEARBGVmbTsxa6kBIlcjJRCsxnGwZTK9JpTUxGkti4G5eYi1S6RYtGjR2pPK87fvho0Xz6MHQhs0QFpsrZHbVTbXvd4PFz2N3vkSkZOQH7Tp5TUaGGv8g5JYQ2ktkL1mEzN7Ipb0pF/pLIRJ1RUB8hDJdCjmjLIMumqQTMpukkiEMtajy1aHJVPpYp7FC8id2h46VQl3GwgBDniKY/WtBk4XALX9TS/N67cPzCYguM0+m4UtiiDwFW91QhWoZZEvAV9u1X8fL7dI0EdUGyZukLFI3SvJc2v9tDOgN31wpZNCSlHGaETNLUxwzqJwUX+m7UZcs5esr8idn6dqoL4AfQFQhw2CeMINIZCJdONmkLiG6DwfJkw9B31X+4wPZSToBrBpYxTOfLAxNVgKiaOmUYLtWTqbD2qpBNMGJCjkZdl9HsfRUoRB/tOyvMlRyuHX9NJ3qiSnhBNYcEJZilhauZzLpnu1FXej4tesnyELmmtfjEOt5I4YlGFsuqzwXLe9CevoLaXApRByolJJaKQddKZBRKZXnSioTFVnzmx40VrjGmgd51IudbX1r5B86ElUSy6/VrbFM58hmgcm6qYeI6TUpe/lELIIG9cxXS7sxcrXsucPEMK9bfTA7qkk48Gk0bWxDenFRc0d6ZC9W+ivwQDmQJaTIZrTlkc+SS0WtEJn7QkaqFSJpVsoWK4P2L9lKiDRBY8XgDU2qASUW0/eFASepLo1WRZszNYz0eVK/YBOSw+t/92K5WUBkjrWDkmwNN2yCLqtw9MfHX+ggJgSKJG5X7X472vPybWnfWJAgi9mGbyG4LrCU7QorpaS6meFqcqCkYOXf3I8fJlMQiU6OzHU3HM/y5Y+u+X1tTqF5RntEGI7EAjY99tcmxCDXof9sf7T3CVAfOUVt1OiIUyMcyb945T1aQ/ejJsWiYK7bfXLYLuUv7W+KIA6JHpttVHjkkQXda3+JM3UsPRzYbdRfLkNzH76ThK5AZs6B3Sr95TLm/b0ugxcoqnFg12J/uTy6e3u5PU6n5jYWWizL2NfIrjNTdc1jOFXIcMYiKN+TOfbTuJF+5kiqrqRIWpHY+1OMLE2BcrzeSvZ+jww+uqmiPVaMH6fG1EfJEBBzJCK07SfhJjjMHRybcyU+nmyWx6C57e5N1VHJ2y44uPdxcwcytCuyUnMd+nFZGyBuhqUuR5ImnieyDpGxrs1GFGZoApsjsBglQRaUKg+zcYXLWwuYV0vqV/tAuKBf1PQ4qi4wz77t+vtCdtCfFwMKEjLa8DI8Ls3Nao53qBTj2ODechR02Ib+MrY/tte2iUr/WKt0pJqX6avtTv0wNCcbUXBYGHPkpIttP7bIt8Nrz5EA2rYjHCOjXeFNTQpRr7iaKdtT+KVd4J5lgZgNFzHN3GHVwJECHKaDKZBpu49lqfXD2Vzb2N3vWKTK9vd7ZCUZxEWHCbdjczLTR9ut+sDD4P9z5Czhp71rsO3FkQqYW16mM6eJyD+4YdiM0/IxHpvj19fWcY+Qgk2m9RleHCWSXm9M7BJ35NifDaeykGES2Me8xE+fR138cKjd4MgGI9v18pf2LsJjgaQYml7G7yVrw7wfUDbCk6rtpqdxAtL6OYedQZ5Fh/VMMR3r4KIm2zrF3oruuKqq7FvIiUY1QowulCGlo6MWemMt+UK9c+9vIkzYHLVzc8TbO1MDNqUymkttqQg4ehYwQvkD2U4SPKcnF4bHGYvTSvudZtfhIhdltJIck7ItBpLj6y5Jgnpq8gV7xSFq6kkFqNSLTV9BraZs594E2xKLHse2rrazriJN/t13qRqextW64ghbvUgB4tTRcpzN4fwsrTJ2fPQPQ9bIqYHlJOXjhcvl4O7ftSPUHyGFH1446t9XUiKlq73zUFzxNY/I2HiPyAcmyWCrLsOd17/P3rUrPBZIMe91V/MynOOGJAxHlM2TSvqrruI5Qg4JdJ6kJ6xaHy/y9AJHXM+TfcepCwO2QDppRs6BTg1bhClkP5c7r6On5SXXaW5jVHhurvfP5vepaaL2CIdYpWcrlamz/tKc+wk2aH6343jFj/ZXk8zAcF61sv7p+Tanckd92mg/uLB24kAGoX4iP6sOeQshd1j89Hsv/tTrS0jeIQrqSQHWdSGvHNu3SlJ5QZtLaUNIj87Ijldt09p7SGEgtay0UWvfKdo1DVKj1YTyiZ0BGcvZUCYfnayJeOPivU1yVEMt6fuqkXo1H4Lel49Oh5RI862ywG8km1NXuRQ4aI/9oZYokUd+SiG4bCFzNw4kkzTYNisecARUZCOPKXrkEYLOyR70YClW80LaFNlFGGwZ+D8SmYXsVJG9D+bYNFT4yQJrKihvBLWBMNyIxYPE2co4XewzIqeIBZMrA3WRVF+TNNOojzZTWmlCFC6ek6ulW5XUKUtOeo/4nQ8s46C9TV4lk11D6U3NAV9MktHd2uGsGhZ3mJpnKiaNJl7111LmhmN3NjSOC4xhD+StMds6/eiH2+fRFWU8rgdTpQPZ/TXbbDVMVmAidCCporOlJwH1PsRrHPPhA8lqXawaxrCmTR4iszGTc19gQnsg21qGY/fRnEbdiSG+fpREMW/MIFArOVrOUtQjlyGckolKpg9j8Mj4ykRUPepS54eA9An2R9Yr5rQjaeUtKg3WkGtmMhZzgLHnNJyJoYWgCP0GUpTN3sgkytBp9wgkeiGglyRlbDGoBUjmqYvjwL3zlCs1na3n5vCQ8uRRv+FxJNmabhBNICHpDTdP1bXurJnspnfMOTxJxN3wPuJB6+MtHQZCnrzwg0TxJFLR9VJQfApXjEp2cSUEwzdPhgGrYsg5Xn9lHVp2yNRH2X2F2GIW5Ek1BuVgpdfwoOajkkGoMmw1AKoE641U71BWrUwQey4rEj4MRvUgxU1iDnYEejI9XPxYk4EwmiUpE4u1FHywKO426cZhguZJ/s4uvyPBNtYcdThnz5PqEKte56XwGuFBqpLnb1vb6RzrDqFhlHCPRzXJelt1rymupj/MZTypnbLtbxPOQpFuT0KqnLsRiLRd4jG97ziV6kB3mnpftXhT8/EVRUAOe0s9WcNbXCk5MDp+KJTgOxtxrjlcCx+ww82TeujrXnZGD9iU6Mki5rrzF8EDBvCeJC4vzrbq3hgB1WRdTMxqpkEsHrZJ4cHExpPaLZHbcVet+LRIlQ4Vxzypibc2ygGJuRmpCY225grefIsGSGdiXRukKmRteLdr607OVkIiLGDXJOcczc5PH2gy8yVpdyg4nFDp98VJayh8oUZUvpHFNTRqxF4ZMgszUlkEbU4tf+x3xROSHO2GvlKJB2S8Z29kPS0xmeBVBUak9b7sMxHawWVXkcUxsPUqgcCBj54ErsH8WvqgXuy+22xW73lqqFrUNY+kWc8iPU/7ZnKipm7vOzfWhHwQpan2m0xXrCrQve2LadeVfApVHn/bF6vOZu+PoWvmvuBrRN7ErnK/L5WcKQK3lWvLIBBgUcuT7dJbo4JyTNOqfSHnKz0fXBw12egRm2YEfRziEZ6sm8WOdt1eeFCTrUmxP3OHZmrx/9nHWAwbu7VQmiNv+8C1LYWiHEHQaucOWBcoQnH07G0f+PNCWKdS8A9Zxl0dQZorYZ0nHrZryU9m53FRYbrGx9DeIVxbS3pwo3myvv3KqzTyzioilni9w6PDk3NWXrn96ofm/nns+q4xRz86DBf8PiQ9dmoopBSVWnMkAVHZfxGP4Fbx+zKFyf6cKYxdPcfuPP7PpFZxfxwvl+/m9+nyuEWzZBz+JM+WF02PpxFfOIvSrXidRsymXjHuIqkHqVe5CJOWS4faK54cYZPaDxz87qzAme2fhtcNSUxC1/LVrK2MSYwnJ8HEtqePYxrH4IGcKqSM2/c8Qkn1PuxzMvsc+vbopq6C5pzOyHFYsvPkXJXIy6uo2+EF6Umty8jHPIJt+qeN/i68fzyp6Y6O2q+vxx2nipw+xzKvdoJK1n5f7ro6xRuXUBHaS//gztkIUxDDq/eFc7Pp+dAYt0LbXYfmV9s/dACHkYUn1bUMD4vA95YjPAVZakLqyMSvMFXyLFMhtW0kGZgteZZEYlhOT22McD2pqYqWnwT74/t9Bkwj4jtm5p4lq4AHS4ATY46cbLtXNkdw99id52Ev5tGMlUPPMmPAxRQsaRT50f3s+n864yjF4qdnOSm2sw0neJaS8luJkxUhu0I1Nb2RnQBofaTn60MHNbL2IRnBoFEFxZpqva8aKWZ/jYOvtNEMje4/VURlJUTdEBSbqxPVOTwpdrbpcLvQh3pIfh+8+MJd19/bbj6XttaXQ1UkT8q5bD7B+A9LIG3/ZLwo9oHvtsPnFJO1UBM1ijypC7PpUvhRqyRx1CXypF7M0HyMVUU9LxHbbbPDorl2oLfXJJAVSbggibAku5gWS9EICuzlLkUZ7kBjuJPJdI4iapGThFiLqFAgVlHTxLfZUHxoKoCGfvswuyVRkkZS4mwgI5U9UruJnnSByjMHmt11H75P/SMaC4pM1oxsYAfBsuTzVvh5yRs56jJWnEYW3Ov7e0LQz7AvygW2Oxm+pvGkR6AoF/3cWjodalLvYMHK1ZMi2ceRDLrZznJ69cPxPDN8jhfJpVa6OFFxzJOKY5GvEQ+KAS1UTvOkclpkdv5HM9FE6TtPSt9F1h/deNQ/jk+9udU3hCEfGSenE17xcC8lxSzDkHbhAh9IGZZbc7q6ovyZacQaJ4KT2GWw9LMZ30BSwPUoneVJ6azF6KAfD0/WikxQg6XVx8OwiqzH3D77x+X849Fezo/u2b8y3e+GcDhWW0tSjcF2EVjhlhe8q0lVmdlLrLmhVx5SakpSRmgMI/Vhh91NIjdfCnG9CmNNRSq2IkOvKV7VsmDIBi/Yt/3M3fRjY4MXGfEaSae2iXURMqjdCsszlMfKRAktz8KMZGmik6kGRSXquzJzoJSxBpXI/Vci+l6RtKMU1shQiiyTL5zJF87l7Mqd9JKFfyWzbIssPLtICIdxn7KIikqkuPOgLhyGtoVegDC9TX6WWK7EeyUTBysZL1vlYTHK6UrWluMmelVYI0MsY54BckLYi6Qf7ud2FDyKJWkQTpQfTGYfazOtNQGGM3U/3iN0UOmpkEbGhqV7/+N4a8r8Meh5j5jD5CR3L1hMpzXg7iVp57PwUxTiqJoaycsyyQpKNWpZzF4+6YEksb4qDav5j29sTAlGk0K20pXg7CWZFjIDwkx4yXyL58QSCa7JlCQdoInAGil7NMOayekPP3o5EElmwH2RJv9oRtg0mRKFPYRkAXhszdMHDPaGk2GxoYCbYVqekQdB6BM0OIAe1TM9qZ5579XRhOAgd3Qauz9zaq+xdv6+6bM3Q+HMTCaL5jItPpfbqpD7q5DB7aVcSaXcg9WbhE5Orm6SOXrv55k0+geiOByp15QqFeC+JGHox6U9v0/yTtHwQrz0SLW6RzdCtnMpLR2Kh+TVgsRRHkOrkQk1WY87EB7DBXT5ZNDQCM7otY7nIqlBapuO5tpjOObp330JafSaWYQvyZ5ZAUmhL2OkUEzN+nfVpDFiQilKmyPWX5I5pTjV3QND895Ms2eOlwDZalcIQpEdW+Jq3PgG8oM4ekF2RIjJSIIir9R4PRHII1EpMbrsFfMFZNhg5EjuqR4KoB4YxYxKsqQUzEG/expR5bjCC5JFJKbn61rDaChvSzI4gjmr7T3HD1+RezspdGH+SKa389BNvW7wXA1z4Mga62yv+ffjeGnv3/17TLyIqKEel1BOcoOWQaEW3c1j4FeQ+VRKUETxWs9Edf/6r7+u7bW5tF3z13//z7/+85//A9JrrBMG8wMA"; \ No newline at end of file diff --git a/assets/style.css b/assets/style.css new file mode 100644 index 000000000..178bfb023 --- /dev/null +++ b/assets/style.css @@ -0,0 +1,1493 @@ +:root { + /* Light */ + --light-color-background: #f2f4f8; + --light-color-background-secondary: #eff0f1; + --light-color-warning-text: #222; + --light-color-background-warning: #e6e600; + --light-color-accent: #c5c7c9; + --light-color-active-menu-item: var(--light-color-accent); + --light-color-text: #222; + --light-color-text-aside: #6e6e6e; + + --light-color-icon-background: var(--light-color-background); + --light-color-icon-text: var(--light-color-text); + + --light-color-comment-tag-text: var(--light-color-text); + --light-color-comment-tag: var(--light-color-background); + + --light-color-link: #1f70c2; + --light-color-focus-outline: #3584e4; + + --light-color-ts-keyword: #056bd6; + --light-color-ts-project: #b111c9; + --light-color-ts-module: var(--light-color-ts-project); + --light-color-ts-namespace: var(--light-color-ts-project); + --light-color-ts-enum: #7e6f15; + --light-color-ts-enum-member: var(--light-color-ts-enum); + --light-color-ts-variable: #4760ec; + --light-color-ts-function: #572be7; + --light-color-ts-class: #1f70c2; + --light-color-ts-interface: #108024; + --light-color-ts-constructor: #4d7fff; + --light-color-ts-property: #ff984d; + --light-color-ts-method: #ff4db8; + --light-color-ts-reference: #ff4d82; + --light-color-ts-call-signature: var(--light-color-ts-method); + --light-color-ts-index-signature: var(--light-color-ts-property); + --light-color-ts-constructor-signature: var(--light-color-ts-constructor); + --light-color-ts-parameter: var(--light-color-ts-variable); + /* type literal not included as links will never be generated to it */ + --light-color-ts-type-parameter: #a55c0e; + --light-color-ts-accessor: #ff4d4d; + --light-color-ts-get-signature: var(--light-color-ts-accessor); + --light-color-ts-set-signature: var(--light-color-ts-accessor); + --light-color-ts-type-alias: #d51270; + /* reference not included as links will be colored with the kind that it points to */ + --light-color-document: #000000; + + --light-external-icon: url("data:image/svg+xml;utf8,"); + --light-color-scheme: light; + + /* Dark */ + --dark-color-background: #2b2e33; + --dark-color-background-secondary: #1e2024; + --dark-color-background-warning: #bebe00; + --dark-color-warning-text: #222; + --dark-color-accent: #9096a2; + --dark-color-active-menu-item: #5d5d6a; + --dark-color-text: #f5f5f5; + --dark-color-text-aside: #dddddd; + + --dark-color-icon-background: var(--dark-color-background-secondary); + --dark-color-icon-text: var(--dark-color-text); + + --dark-color-comment-tag-text: var(--dark-color-text); + --dark-color-comment-tag: var(--dark-color-background); + + --dark-color-link: #00aff4; + --dark-color-focus-outline: #4c97f2; + + --dark-color-ts-keyword: #3399ff; + --dark-color-ts-project: #e358ff; + --dark-color-ts-module: var(--dark-color-ts-project); + --dark-color-ts-namespace: var(--dark-color-ts-project); + --dark-color-ts-enum: #f4d93e; + --dark-color-ts-enum-member: var(--dark-color-ts-enum); + --dark-color-ts-variable: #798dff; + --dark-color-ts-function: #a280ff; + --dark-color-ts-class: #8ac4ff; + --dark-color-ts-interface: #6cff87; + --dark-color-ts-constructor: #4d7fff; + --dark-color-ts-property: #ff984d; + --dark-color-ts-method: #ff4db8; + --dark-color-ts-reference: #ff4d82; + --dark-color-ts-call-signature: var(--dark-color-ts-method); + --dark-color-ts-index-signature: var(--dark-color-ts-property); + --dark-color-ts-constructor-signature: var(--dark-color-ts-constructor); + --dark-color-ts-parameter: var(--dark-color-ts-variable); + /* type literal not included as links will never be generated to it */ + --dark-color-ts-type-parameter: #e07d13; + --dark-color-ts-accessor: #ff4d4d; + --dark-color-ts-get-signature: var(--dark-color-ts-accessor); + --dark-color-ts-set-signature: var(--dark-color-ts-accessor); + --dark-color-ts-type-alias: #ff6492; + /* reference not included as links will be colored with the kind that it points to */ + --dark-color-document: #ffffff; + + --dark-external-icon: url("data:image/svg+xml;utf8,"); + --dark-color-scheme: dark; +} + +@media (prefers-color-scheme: light) { + :root { + --color-background: var(--light-color-background); + --color-background-secondary: var(--light-color-background-secondary); + --color-background-warning: var(--light-color-background-warning); + --color-warning-text: var(--light-color-warning-text); + --color-accent: var(--light-color-accent); + --color-active-menu-item: var(--light-color-active-menu-item); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + + --color-icon-background: var(--light-color-icon-background); + --color-icon-text: var(--light-color-icon-text); + + --color-comment-tag-text: var(--light-color-text); + --color-comment-tag: var(--light-color-background); + + --color-link: var(--light-color-link); + --color-focus-outline: var(--light-color-focus-outline); + + --color-ts-keyword: var(--light-color-ts-keyword); + --color-ts-project: var(--light-color-ts-project); + --color-ts-module: var(--light-color-ts-module); + --color-ts-namespace: var(--light-color-ts-namespace); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-enum-member: var(--light-color-ts-enum-member); + --color-ts-variable: var(--light-color-ts-variable); + --color-ts-function: var(--light-color-ts-function); + --color-ts-class: var(--light-color-ts-class); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-constructor: var(--light-color-ts-constructor); + --color-ts-property: var(--light-color-ts-property); + --color-ts-method: var(--light-color-ts-method); + --color-ts-reference: var(--light-color-ts-reference); + --color-ts-call-signature: var(--light-color-ts-call-signature); + --color-ts-index-signature: var(--light-color-ts-index-signature); + --color-ts-constructor-signature: var( + --light-color-ts-constructor-signature + ); + --color-ts-parameter: var(--light-color-ts-parameter); + --color-ts-type-parameter: var(--light-color-ts-type-parameter); + --color-ts-accessor: var(--light-color-ts-accessor); + --color-ts-get-signature: var(--light-color-ts-get-signature); + --color-ts-set-signature: var(--light-color-ts-set-signature); + --color-ts-type-alias: var(--light-color-ts-type-alias); + --color-document: var(--light-color-document); + + --external-icon: var(--light-external-icon); + --color-scheme: var(--light-color-scheme); + } +} + +@media (prefers-color-scheme: dark) { + :root { + --color-background: var(--dark-color-background); + --color-background-secondary: var(--dark-color-background-secondary); + --color-background-warning: var(--dark-color-background-warning); + --color-warning-text: var(--dark-color-warning-text); + --color-accent: var(--dark-color-accent); + --color-active-menu-item: var(--dark-color-active-menu-item); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + + --color-icon-background: var(--dark-color-icon-background); + --color-icon-text: var(--dark-color-icon-text); + + --color-comment-tag-text: var(--dark-color-text); + --color-comment-tag: var(--dark-color-background); + + --color-link: var(--dark-color-link); + --color-focus-outline: var(--dark-color-focus-outline); + + --color-ts-keyword: var(--dark-color-ts-keyword); + --color-ts-project: var(--dark-color-ts-project); + --color-ts-module: var(--dark-color-ts-module); + --color-ts-namespace: var(--dark-color-ts-namespace); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-enum-member: var(--dark-color-ts-enum-member); + --color-ts-variable: var(--dark-color-ts-variable); + --color-ts-function: var(--dark-color-ts-function); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-constructor: var(--dark-color-ts-constructor); + --color-ts-property: var(--dark-color-ts-property); + --color-ts-method: var(--dark-color-ts-method); + --color-ts-reference: var(--dark-color-ts-reference); + --color-ts-call-signature: var(--dark-color-ts-call-signature); + --color-ts-index-signature: var(--dark-color-ts-index-signature); + --color-ts-constructor-signature: var( + --dark-color-ts-constructor-signature + ); + --color-ts-parameter: var(--dark-color-ts-parameter); + --color-ts-type-parameter: var(--dark-color-ts-type-parameter); + --color-ts-accessor: var(--dark-color-ts-accessor); + --color-ts-get-signature: var(--dark-color-ts-get-signature); + --color-ts-set-signature: var(--dark-color-ts-set-signature); + --color-ts-type-alias: var(--dark-color-ts-type-alias); + --color-document: var(--dark-color-document); + + --external-icon: var(--dark-external-icon); + --color-scheme: var(--dark-color-scheme); + } +} + +html { + color-scheme: var(--color-scheme); +} + +body { + margin: 0; +} + +:root[data-theme="light"] { + --color-background: var(--light-color-background); + --color-background-secondary: var(--light-color-background-secondary); + --color-background-warning: var(--light-color-background-warning); + --color-warning-text: var(--light-color-warning-text); + --color-icon-background: var(--light-color-icon-background); + --color-accent: var(--light-color-accent); + --color-active-menu-item: var(--light-color-active-menu-item); + --color-text: var(--light-color-text); + --color-text-aside: var(--light-color-text-aside); + --color-icon-text: var(--light-color-icon-text); + + --color-comment-tag-text: var(--light-color-text); + --color-comment-tag: var(--light-color-background); + + --color-link: var(--light-color-link); + --color-focus-outline: var(--light-color-focus-outline); + + --color-ts-keyword: var(--light-color-ts-keyword); + --color-ts-project: var(--light-color-ts-project); + --color-ts-module: var(--light-color-ts-module); + --color-ts-namespace: var(--light-color-ts-namespace); + --color-ts-enum: var(--light-color-ts-enum); + --color-ts-enum-member: var(--light-color-ts-enum-member); + --color-ts-variable: var(--light-color-ts-variable); + --color-ts-function: var(--light-color-ts-function); + --color-ts-class: var(--light-color-ts-class); + --color-ts-interface: var(--light-color-ts-interface); + --color-ts-constructor: var(--light-color-ts-constructor); + --color-ts-property: var(--light-color-ts-property); + --color-ts-method: var(--light-color-ts-method); + --color-ts-reference: var(--light-color-ts-reference); + --color-ts-call-signature: var(--light-color-ts-call-signature); + --color-ts-index-signature: var(--light-color-ts-index-signature); + --color-ts-constructor-signature: var( + --light-color-ts-constructor-signature + ); + --color-ts-parameter: var(--light-color-ts-parameter); + --color-ts-type-parameter: var(--light-color-ts-type-parameter); + --color-ts-accessor: var(--light-color-ts-accessor); + --color-ts-get-signature: var(--light-color-ts-get-signature); + --color-ts-set-signature: var(--light-color-ts-set-signature); + --color-ts-type-alias: var(--light-color-ts-type-alias); + --color-document: var(--light-color-document); + + --external-icon: var(--light-external-icon); + --color-scheme: var(--light-color-scheme); +} + +:root[data-theme="dark"] { + --color-background: var(--dark-color-background); + --color-background-secondary: var(--dark-color-background-secondary); + --color-background-warning: var(--dark-color-background-warning); + --color-warning-text: var(--dark-color-warning-text); + --color-icon-background: var(--dark-color-icon-background); + --color-accent: var(--dark-color-accent); + --color-active-menu-item: var(--dark-color-active-menu-item); + --color-text: var(--dark-color-text); + --color-text-aside: var(--dark-color-text-aside); + --color-icon-text: var(--dark-color-icon-text); + + --color-comment-tag-text: var(--dark-color-text); + --color-comment-tag: var(--dark-color-background); + + --color-link: var(--dark-color-link); + --color-focus-outline: var(--dark-color-focus-outline); + + --color-ts-keyword: var(--dark-color-ts-keyword); + --color-ts-project: var(--dark-color-ts-project); + --color-ts-module: var(--dark-color-ts-module); + --color-ts-namespace: var(--dark-color-ts-namespace); + --color-ts-enum: var(--dark-color-ts-enum); + --color-ts-enum-member: var(--dark-color-ts-enum-member); + --color-ts-variable: var(--dark-color-ts-variable); + --color-ts-function: var(--dark-color-ts-function); + --color-ts-class: var(--dark-color-ts-class); + --color-ts-interface: var(--dark-color-ts-interface); + --color-ts-constructor: var(--dark-color-ts-constructor); + --color-ts-property: var(--dark-color-ts-property); + --color-ts-method: var(--dark-color-ts-method); + --color-ts-reference: var(--dark-color-ts-reference); + --color-ts-call-signature: var(--dark-color-ts-call-signature); + --color-ts-index-signature: var(--dark-color-ts-index-signature); + --color-ts-constructor-signature: var( + --dark-color-ts-constructor-signature + ); + --color-ts-parameter: var(--dark-color-ts-parameter); + --color-ts-type-parameter: var(--dark-color-ts-type-parameter); + --color-ts-accessor: var(--dark-color-ts-accessor); + --color-ts-get-signature: var(--dark-color-ts-get-signature); + --color-ts-set-signature: var(--dark-color-ts-set-signature); + --color-ts-type-alias: var(--dark-color-ts-type-alias); + --color-document: var(--dark-color-document); + + --external-icon: var(--dark-external-icon); + --color-scheme: var(--dark-color-scheme); +} + +*:focus-visible, +.tsd-accordion-summary:focus-visible svg { + outline: 2px solid var(--color-focus-outline); +} + +.always-visible, +.always-visible .tsd-signatures { + display: inherit !important; +} + +h1, +h2, +h3, +h4, +h5, +h6 { + line-height: 1.2; +} + +h1 { + font-size: 1.875rem; + margin: 0.67rem 0; +} + +h2 { + font-size: 1.5rem; + margin: 0.83rem 0; +} + +h3 { + font-size: 1.25rem; + margin: 1rem 0; +} + +h4 { + font-size: 1.05rem; + margin: 1.33rem 0; +} + +h5 { + font-size: 1rem; + margin: 1.5rem 0; +} + +h6 { + font-size: 0.875rem; + margin: 2.33rem 0; +} + +dl, +menu, +ol, +ul { + margin: 1em 0; +} + +dd { + margin: 0 0 0 40px; +} + +.container { + max-width: 1700px; + padding: 0 2rem; +} + +/* Footer */ +footer { + border-top: 1px solid var(--color-accent); + padding-top: 1rem; + padding-bottom: 1rem; + max-height: 3.5rem; +} +footer > p { + margin: 0 1em; +} + +.container-main { + margin: 0 auto; + /* toolbar, footer, margin */ + min-height: calc(100vh - 41px - 56px - 4rem); +} + +@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 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: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", + Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"; + 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; +} +a.tsd-anchor-link { + color: var(--color-text); +} + +code, +pre { + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + padding: 0.2em; + margin: 0; + font-size: 0.875rem; + border-radius: 0.8em; +} + +pre { + position: relative; + white-space: pre-wrap; + word-wrap: break-word; + padding: 10px; + border: 1px solid var(--color-accent); +} +pre code { + padding: 0; + font-size: 100%; +} +pre > button { + position: absolute; + top: 10px; + right: 10px; + opacity: 0; + transition: opacity 0.1s; + box-sizing: border-box; +} +pre:hover > button, +pre > button.visible { + opacity: 1; +} + +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 .tsd-index-panel h3, +.tsd-index-panel .tsd-typography h3, +.tsd-typography h4, +.tsd-typography h5, +.tsd-typography h6 { + font-size: 1em; +} +.tsd-typography h5, +.tsd-typography h6 { + font-weight: normal; +} +.tsd-typography p, +.tsd-typography ul, +.tsd-typography ol { + margin: 1em 0; +} +.tsd-typography table { + border-collapse: collapse; + border: none; +} +.tsd-typography td, +.tsd-typography th { + padding: 6px 13px; + border: 1px solid var(--color-accent); +} +.tsd-typography thead, +.tsd-typography tr:nth-child(even) { + background-color: var(--color-background-secondary); +} + +.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: " / "; +} + +.tsd-comment-tags { + display: flex; + flex-direction: column; +} +dl.tsd-comment-tag-group { + display: flex; + align-items: center; + overflow: hidden; + margin: 0.5em 0; +} +dl.tsd-comment-tag-group dt { + display: flex; + margin-right: 0.5em; + font-size: 0.875em; + font-weight: normal; +} +dl.tsd-comment-tag-group dd { + margin: 0; +} +code.tsd-tag { + padding: 0.25em 0.4em; + border: 0.1em solid var(--color-accent); + margin-right: 0.25em; + font-size: 70%; +} +h1 code.tsd-tag:first-of-type { + margin-left: 0.25em; +} + +dl.tsd-comment-tag-group dd:before, +dl.tsd-comment-tag-group dd:after { + content: " "; +} +dl.tsd-comment-tag-group dd pre, +dl.tsd-comment-tag-group dd:after { + clear: both; +} +dl.tsd-comment-tag-group 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; +} + +.tsd-filter-visibility h4 { + font-size: 1rem; + padding-top: 0.75rem; + padding-bottom: 0.5rem; + margin: 0; +} +.tsd-filter-item:not(:last-child) { + margin-bottom: 0.5rem; +} +.tsd-filter-input { + display: flex; + width: -moz-fit-content; + width: fit-content; + align-items: center; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: pointer; +} +.tsd-filter-input input[type="checkbox"] { + cursor: pointer; + position: absolute; + width: 1.5em; + height: 1.5em; + opacity: 0; +} +.tsd-filter-input input[type="checkbox"]:disabled { + pointer-events: none; +} +.tsd-filter-input svg { + cursor: pointer; + width: 1.5em; + height: 1.5em; + margin-right: 0.5em; + border-radius: 0.33em; + /* Leaving this at full opacity breaks event listeners on Firefox. + Don't remove unless you know what you're doing. */ + opacity: 0.99; +} +.tsd-filter-input input[type="checkbox"]:focus-visible + svg { + outline: 2px solid var(--color-focus-outline); +} +.tsd-checkbox-background { + fill: var(--color-accent); +} +input[type="checkbox"]:checked ~ svg .tsd-checkbox-checkmark { + stroke: var(--color-text); +} +.tsd-filter-input input:disabled ~ svg > .tsd-checkbox-background { + fill: var(--color-background); + stroke: var(--color-accent); + stroke-width: 0.25rem; +} +.tsd-filter-input input:disabled ~ svg > .tsd-checkbox-checkmark { + stroke: var(--color-accent); +} + +.settings-label { + font-weight: bold; + text-transform: uppercase; + display: inline-block; +} + +.tsd-filter-visibility .settings-label { + margin: 0.75rem 0 0.5rem 0; +} + +.tsd-theme-toggle .settings-label { + margin: 0.75rem 0.75rem 0 0; +} + +.tsd-hierarchy { + list-style: square; + margin: 0; +} +.tsd-hierarchy .target { + font-weight: bold; +} + +.tsd-full-hierarchy:not(:last-child) { + margin-bottom: 1em; + padding-bottom: 1em; + border-bottom: 1px solid var(--color-accent); +} +.tsd-full-hierarchy, +.tsd-full-hierarchy ul { + list-style: none; + margin: 0; + padding: 0; +} +.tsd-full-hierarchy ul { + padding-left: 1.5rem; +} +.tsd-full-hierarchy a { + padding: 0.25rem 0 !important; + font-size: 1rem; + display: inline-flex; + align-items: center; + color: var(--color-text); +} + +.tsd-panel-group.tsd-index-group { + margin-bottom: 0; +} +.tsd-index-panel .tsd-index-list { + list-style: none; + line-height: 1.333em; + margin: 0; + padding: 0.25rem 0 0 0; + overflow: hidden; + display: grid; + grid-template-columns: repeat(3, 1fr); + column-gap: 1rem; + grid-template-rows: auto; +} +@media (max-width: 1024px) { + .tsd-index-panel .tsd-index-list { + grid-template-columns: repeat(2, 1fr); + } +} +@media (max-width: 768px) { + .tsd-index-panel .tsd-index-list { + grid-template-columns: repeat(1, 1fr); + } +} +.tsd-index-panel .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-flag { + display: inline-block; + padding: 0.25em 0.4em; + border-radius: 4px; + color: var(--color-comment-tag-text); + background-color: var(--color-comment-tag); + text-indent: 0; + font-size: 75%; + line-height: 1; + font-weight: normal; +} + +.tsd-anchor { + position: relative; + top: -100px; +} + +.tsd-member { + position: relative; +} +.tsd-member .tsd-anchor + h3 { + display: flex; + align-items: center; + margin-top: 0; + margin-bottom: 0; + border-bottom: none; +} + +.tsd-navigation.settings { + margin: 1rem 0; +} +.tsd-navigation > a, +.tsd-navigation .tsd-accordion-summary { + width: calc(100% - 0.25rem); + display: flex; + align-items: center; +} +.tsd-navigation a, +.tsd-navigation summary > span, +.tsd-page-navigation a { + display: flex; + width: calc(100% - 0.25rem); + align-items: center; + padding: 0.25rem; + color: var(--color-text); + text-decoration: none; + box-sizing: border-box; +} +.tsd-navigation a.current, +.tsd-page-navigation a.current { + background: var(--color-active-menu-item); +} +.tsd-navigation a:hover, +.tsd-page-navigation a:hover { + text-decoration: underline; +} +.tsd-navigation ul, +.tsd-page-navigation ul { + margin-top: 0; + margin-bottom: 0; + padding: 0; + list-style: none; +} +.tsd-navigation li, +.tsd-page-navigation li { + padding: 0; + max-width: 100%; +} +.tsd-navigation .tsd-nav-link { + display: none; +} +.tsd-nested-navigation { + margin-left: 3rem; +} +.tsd-nested-navigation > li > details { + margin-left: -1.5rem; +} +.tsd-small-nested-navigation { + margin-left: 1.5rem; +} +.tsd-small-nested-navigation > li > details { + margin-left: -1.5rem; +} + +.tsd-page-navigation-section { + margin-left: 10px; +} +.tsd-page-navigation-section > summary { + padding: 0.25rem; +} +.tsd-page-navigation-section > div { + margin-left: 20px; +} +.tsd-page-navigation ul { + padding-left: 1.75rem; +} + +#tsd-sidebar-links a { + margin-top: 0; + margin-bottom: 0.5rem; + line-height: 1.25rem; +} +#tsd-sidebar-links a:last-of-type { + margin-bottom: 0; +} + +a.tsd-index-link { + padding: 0.25rem 0 !important; + font-size: 1rem; + line-height: 1.25rem; + display: inline-flex; + align-items: center; + color: var(--color-text); +} +.tsd-accordion-summary { + list-style-type: none; /* hide marker on non-safari */ + outline: none; /* broken on safari, so just hide it */ +} +.tsd-accordion-summary::-webkit-details-marker { + display: none; /* hide marker on safari */ +} +.tsd-accordion-summary, +.tsd-accordion-summary a { + -moz-user-select: none; + -webkit-user-select: none; + -ms-user-select: none; + user-select: none; + + cursor: pointer; +} +.tsd-accordion-summary a { + width: calc(100% - 1.5rem); +} +.tsd-accordion-summary > * { + margin-top: 0; + margin-bottom: 0; + padding-top: 0; + padding-bottom: 0; +} +.tsd-accordion .tsd-accordion-summary > svg { + margin-left: 0.25rem; + vertical-align: text-top; +} +.tsd-index-content > :not(:first-child) { + margin-top: 0.75rem; +} +.tsd-index-heading { + margin-top: 1.5rem; + margin-bottom: 0.75rem; +} + +.tsd-no-select { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.tsd-kind-icon { + margin-right: 0.5rem; + width: 1.25rem; + height: 1.25rem; + min-width: 1.25rem; + min-height: 1.25rem; +} +.tsd-signature > .tsd-kind-icon { + margin-right: 0.8rem; +} + +.tsd-panel { + margin-bottom: 2.5rem; +} +.tsd-panel.tsd-member { + margin-bottom: 4rem; +} +.tsd-panel:empty { + display: none; +} +.tsd-panel > h1, +.tsd-panel > h2, +.tsd-panel > h3 { + margin: 1.5rem -1.5rem 0.75rem -1.5rem; + padding: 0 1.5rem 0.75rem 1.5rem; +} +.tsd-panel > h1.tsd-before-signature, +.tsd-panel > h2.tsd-before-signature, +.tsd-panel > h3.tsd-before-signature { + margin-bottom: 0; + border-bottom: none; +} + +.tsd-panel-group { + margin: 2rem 0; +} +.tsd-panel-group.tsd-index-group { + margin: 2rem 0; +} +.tsd-panel-group.tsd-index-group details { + margin: 2rem 0; +} +.tsd-panel-group > .tsd-accordion-summary { + margin-bottom: 1rem; +} + +#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: 2.5rem; + height: 100%; +} +#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, +#tsd-toolbar-links a { + 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 { + background-color: var(--color-background); + line-height: initial; + padding: 4px; +} +#tsd-search .results li:nth-child(even) { + background-color: var(--color-background-secondary); +} +#tsd-search .results li.state { + display: none; +} +#tsd-search .results li.current:not(.no-results), +#tsd-search .results li:hover:not(.no-results) { + background-color: var(--color-accent); +} +#tsd-search .results a { + display: flex; + align-items: center; + padding: 0.25rem; + box-sizing: border-box; +} +#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-accent); +} +#tsd-search.has-focus .field input { + top: 0; + opacity: 1; +} +#tsd-search.has-focus .title, +#tsd-search.has-focus #tsd-toolbar-links a { + 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-toolbar-links { + position: absolute; + top: 0; + right: 2rem; + height: 100%; + display: flex; + align-items: center; + justify-content: flex-end; +} +#tsd-toolbar-links a { + margin-left: 1.5rem; +} +#tsd-toolbar-links a:hover { + text-decoration: underline; +} + +.tsd-signature { + margin: 0 0 1rem 0; + padding: 1rem 0.5rem; + border: 1px solid var(--color-accent); + font-family: Menlo, Monaco, Consolas, "Courier New", monospace; + font-size: 14px; + overflow-x: auto; +} + +.tsd-signature-keyword { + color: var(--color-ts-keyword); + font-weight: normal; +} + +.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; + list-style-type: none; +} +.tsd-signatures .tsd-signature { + margin: 0; + border-color: var(--color-accent); + border-width: 1px 0; + transition: background-color 0.1s; +} +.tsd-signatures .tsd-index-signature:not(:last-child) { + margin-bottom: 1em; +} +.tsd-signatures .tsd-index-signature .tsd-signature { + border-width: 1px; +} +.tsd-description .tsd-signatures .tsd-signature { + border-width: 1px; +} + +ul.tsd-parameter-list, +ul.tsd-type-parameter-list { + list-style: square; + margin: 0; + padding-left: 20px; +} +ul.tsd-parameter-list > li.tsd-parameter-signature, +ul.tsd-type-parameter-list > li.tsd-parameter-signature { + list-style: none; + margin-left: -20px; +} +ul.tsd-parameter-list h5, +ul.tsd-type-parameter-list h5 { + font-size: 16px; + margin: 1em 0 0.5em 0; +} +.tsd-sources { + margin-top: 1rem; + font-size: 0.875em; +} +.tsd-sources a { + color: var(--color-text-aside); + text-decoration: underline; +} +.tsd-sources ul { + list-style: none; + padding: 0; +} + +.tsd-page-toolbar { + position: sticky; + z-index: 1; + top: 0; + left: 0; + width: 100%; + color: var(--color-text); + background: var(--color-background-secondary); + border-bottom: 1px var(--color-accent) solid; + transition: transform 0.3s ease-in-out; +} +.tsd-page-toolbar a { + color: var(--color-text); + text-decoration: none; +} +.tsd-page-toolbar a.title { + font-weight: bold; +} +.tsd-page-toolbar a.title:hover { + text-decoration: underline; +} +.tsd-page-toolbar .tsd-toolbar-contents { + display: flex; + justify-content: space-between; + height: 2.5rem; + margin: 0 auto; +} +.tsd-page-toolbar .table-cell { + position: relative; + white-space: nowrap; + line-height: 40px; +} +.tsd-page-toolbar .table-cell:first-child { + width: 100%; +} +.tsd-page-toolbar .tsd-toolbar-icon { + box-sizing: border-box; + line-height: 0; + padding: 12px 0; +} + +.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-accent); +} +.tsd-widget.no-caption { + width: 40px; +} +.tsd-widget.no-caption:before { + margin: 0; +} + +.tsd-widget.options, +.tsd-widget.menu { + display: none; +} +input[type="checkbox"] + .tsd-widget:before { + background-position: -120px 0; +} +input[type="checkbox"]:checked + .tsd-widget:before { + background-position: -160px 0; +} + +img { + max-width: 100%; +} + +.tsd-anchor-icon { + display: inline-flex; + align-items: center; + margin-left: 0.5rem; + 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; +} + +.deprecated { + text-decoration: line-through !important; +} + +.warning { + padding: 1rem; + color: var(--color-warning-text); + background: var(--color-background-warning); +} + +.tsd-kind-project { + color: var(--color-ts-project); +} +.tsd-kind-module { + color: var(--color-ts-module); +} +.tsd-kind-namespace { + color: var(--color-ts-namespace); +} +.tsd-kind-enum { + color: var(--color-ts-enum); +} +.tsd-kind-enum-member { + color: var(--color-ts-enum-member); +} +.tsd-kind-variable { + color: var(--color-ts-variable); +} +.tsd-kind-function { + color: var(--color-ts-function); +} +.tsd-kind-class { + color: var(--color-ts-class); +} +.tsd-kind-interface { + color: var(--color-ts-interface); +} +.tsd-kind-constructor { + color: var(--color-ts-constructor); +} +.tsd-kind-property { + color: var(--color-ts-property); +} +.tsd-kind-method { + color: var(--color-ts-method); +} +.tsd-kind-reference { + color: var(--color-ts-reference); +} +.tsd-kind-call-signature { + color: var(--color-ts-call-signature); +} +.tsd-kind-index-signature { + color: var(--color-ts-index-signature); +} +.tsd-kind-constructor-signature { + color: var(--color-ts-constructor-signature); +} +.tsd-kind-parameter { + color: var(--color-ts-parameter); +} +.tsd-kind-type-parameter { + color: var(--color-ts-type-parameter); +} +.tsd-kind-accessor { + color: var(--color-ts-accessor); +} +.tsd-kind-get-signature { + color: var(--color-ts-get-signature); +} +.tsd-kind-set-signature { + color: var(--color-ts-set-signature); +} +.tsd-kind-type-alias { + color: var(--color-ts-type-alias); +} + +/* if we have a kind icon, don't color the text by kind */ +.tsd-kind-icon ~ span { + color: var(--color-text); +} + +* { + scrollbar-width: thin; + scrollbar-color: var(--color-accent) var(--color-icon-background); +} + +*::-webkit-scrollbar { + width: 0.75rem; +} + +*::-webkit-scrollbar-track { + background: var(--color-icon-background); +} + +*::-webkit-scrollbar-thumb { + background-color: var(--color-accent); + border-radius: 999rem; + border: 0.25rem solid var(--color-icon-background); +} + +/* mobile */ +@media (max-width: 769px) { + .tsd-widget.options, + .tsd-widget.menu { + display: inline-block; + } + + .container-main { + display: flex; + } + html .col-content { + float: none; + max-width: 100%; + width: 100%; + } + html .col-sidebar { + position: fixed !important; + overflow-y: auto; + -webkit-overflow-scrolling: touch; + z-index: 1024; + top: 0 !important; + bottom: 0 !important; + left: auto !important; + right: 0 !important; + padding: 1.5rem 1.5rem 0 0; + width: 75vw; + visibility: hidden; + background-color: var(--color-background); + transform: translate(100%, 0); + } + html .col-sidebar > *: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 .col-sidebar { + animation: pop-in-from-right 0.4s; + } + + .from-has-menu .overlay { + animation: fade-out 0.4s; + } + + .from-has-menu .col-sidebar { + animation: pop-out-to-right 0.4s; + } + + .has-menu body { + overflow: hidden; + } + .has-menu .overlay { + visibility: visible; + } + .has-menu .col-sidebar { + visibility: visible; + transform: translate(0, 0); + display: flex; + flex-direction: column; + gap: 1.5rem; + max-height: 100vh; + padding: 1rem 2rem; + } + .has-menu .tsd-navigation { + max-height: 100%; + } + #tsd-toolbar-links { + display: none; + } + .tsd-navigation .tsd-nav-link { + display: flex; + } +} + +/* one sidebar */ +@media (min-width: 770px) { + .container-main { + display: grid; + grid-template-columns: minmax(0, 1fr) minmax(0, 2fr); + grid-template-areas: "sidebar content"; + margin: 2rem auto; + } + + .col-sidebar { + grid-area: sidebar; + } + .col-content { + grid-area: content; + padding: 0 1rem; + } +} +@media (min-width: 770px) and (max-width: 1399px) { + .col-sidebar { + max-height: calc(100vh - 2rem - 42px); + overflow: auto; + position: sticky; + top: 42px; + padding-top: 1rem; + } + .site-menu { + margin-top: 1rem; + } +} + +/* two sidebars */ +@media (min-width: 1200px) { + .container-main { + grid-template-columns: minmax(0, 1fr) minmax(0, 2.5fr) minmax(0, 20rem); + grid-template-areas: "sidebar content toc"; + } + + .col-sidebar { + display: contents; + } + + .page-menu { + grid-area: toc; + padding-left: 1rem; + } + .site-menu { + grid-area: sidebar; + } + + .site-menu { + margin-top: 1rem; + } + + .page-menu, + .site-menu { + max-height: calc(100vh - 2rem - 42px); + overflow: auto; + position: sticky; + top: 42px; + } +} diff --git a/classes/AllowAllTenantGate.html b/classes/AllowAllTenantGate.html new file mode 100644 index 000000000..572f302c3 --- /dev/null +++ b/classes/AllowAllTenantGate.html @@ -0,0 +1,5 @@ +AllowAllTenantGate | DWN-SDK Documentation - v0.5.1

A tenant gate that treats every DID as an active tenant.

+

Implements

Constructors

Methods

Constructors

Methods

diff --git a/classes/Cid.html b/classes/Cid.html new file mode 100644 index 000000000..5e184ade0 --- /dev/null +++ b/classes/Cid.html @@ -0,0 +1,17 @@ +Cid | DWN-SDK Documentation - v0.5.1

Utility class for creating CIDs. Exported for the convenience of developers.

+

Constructors

Methods

  • Computes a V1 CID for the provided payload

    +

    Parameters

    • payload: any
    • codecCode: number = cbor.code

      the codec to use. Defaults to cbor

      +
    • multihashCode: number = sha256.code

      the multihasher to use. Defaults to sha256

      +

    Returns Promise<string>

    payload CID

    +

    codec is not supported

    +

    encoding fails

    +

    if hasher is not supported

    +
  • Parameters

    • content: Uint8Array

    Returns Promise<string>

    V1 CID of the DAG comprised by chunking data into unixfs DAG-PB encoded blocks

    +
  • Parameters

    • dataStream: Readable

    Returns Promise<string>

    V1 CID of the DAG comprised by chunking data into unixfs DAG-PB encoded blocks

    +
  • Parses the given CID string into a {CID}.

    +

    Parameters

    • str: string

    Returns CID<unknown, number, number, Version>

diff --git a/classes/DataStoreLevel.html b/classes/DataStoreLevel.html new file mode 100644 index 000000000..031d3a19c --- /dev/null +++ b/classes/DataStoreLevel.html @@ -0,0 +1,27 @@ +DataStoreLevel | DWN-SDK Documentation - v0.5.1

A simple implementation of DataStore that works in both the browser and server-side. +Leverages LevelDB under the hood.

+

It has the following structure (+ represents an additional sublevel/partition): +'data' + + + ->

+

Implements

Constructors

Properties

Methods

Constructors

Properties

blockstore: BlockstoreLevel
config: DataStoreLevelConfig

Methods

  • Deletes the specified data. No-op if the data does not exist.

    +

    Parameters

    • tenant: string
    • recordId: string

      The logical ID of the record that references the data.

      +
    • dataCid: string

      The IPFS CID of the data.

      +

    Returns Promise<void>

  • Fetches the specified data.

    +

    Parameters

    • tenant: string
    • recordId: string

      The logical ID of the record that references the data.

      +
    • dataCid: string

      The IPFS CID of the data.

      +

    Returns Promise<undefined | DataStoreGetResult>

    the data size and data stream if found, otherwise undefined.

    +
diff --git a/classes/DataStream.html b/classes/DataStream.html new file mode 100644 index 000000000..ce2689af4 --- /dev/null +++ b/classes/DataStream.html @@ -0,0 +1,13 @@ +DataStream | DWN-SDK Documentation - v0.5.1

Utility class for readable data stream, intentionally named to disambiguate from ReadableStream, readable-stream, Readable etc.

+

Constructors

Methods

  • Duplicates the given data stream into the number of streams specified so that multiple handlers can consume the same data stream.

    +

    Parameters

    • dataStream: Readable
    • count: number

    Returns Readable[]

  • Creates a readable stream from the bytes given.

    +

    Parameters

    • bytes: Uint8Array

    Returns Readable

  • Creates a readable stream from the object given.

    +

    Parameters

    • object: Record<string, any>

    Returns Readable

  • Reads the entire readable stream given into array of bytes.

    +

    Parameters

    • readableStream: Readable

    Returns Promise<Uint8Array>

  • Reads the entire readable stream and JSON parses it into an object.

    +

    Parameters

    • readableStream: Readable

    Returns Promise<object>

diff --git a/classes/Dwn.html b/classes/Dwn.html new file mode 100644 index 000000000..5e6e65514 --- /dev/null +++ b/classes/Dwn.html @@ -0,0 +1,16 @@ +Dwn | DWN-SDK Documentation - v0.5.1

Methods

  • Initializes the DWN instance and opens the connection to it.

    +

    Returns Promise<void>

  • Validates structure of DWN message

    +

    Parameters

    • rawMessage: any

    Returns Promise<undefined | GenericMessageReply>

    GenericMessageReply if the message has an integrity error, otherwise undefined.

    +
  • Checks tenant gate to see if tenant is allowed.

    +

    Parameters

    • tenant: string

      The tenant DID to route the given message to.

      +

    Returns Promise<undefined | GenericMessageReply>

    GenericMessageReply if the message has an integrity error, otherwise undefined.

    +
diff --git a/classes/DwnConstant.html b/classes/DwnConstant.html new file mode 100644 index 000000000..c3a8750d7 --- /dev/null +++ b/classes/DwnConstant.html @@ -0,0 +1,6 @@ +DwnConstant | DWN-SDK Documentation - v0.5.1

Constructors

Properties

maxDataSizeAllowedToBeEncoded: 30000 = 30_000

The maximum size of raw data that will be returned as encodedData.

+

We chose 30k, as after encoding it would give plenty of headroom up to the 65k limit in most SQL variants. +We currently encode using base64url which is a 33% increase in size.

+
diff --git a/classes/DwnError.html b/classes/DwnError.html new file mode 100644 index 000000000..ebd984c5a --- /dev/null +++ b/classes/DwnError.html @@ -0,0 +1,4 @@ +DwnError | DWN-SDK Documentation - v0.5.1

A class that represents a DWN error.

+

Hierarchy

  • Error
    • DwnError

Constructors

Properties

Constructors

Properties

code: string
diff --git a/classes/Encoder.html b/classes/Encoder.html new file mode 100644 index 000000000..e0782acd4 --- /dev/null +++ b/classes/Encoder.html @@ -0,0 +1,11 @@ +Encoder | DWN-SDK Documentation - v0.5.1

Utility class for encoding/converting data into various formats.

+

Constructors

Methods

  • Parameters

    • base64urlString: string

    Returns Uint8Array

  • Parameters

    • base64urlString: string

    Returns any

  • Parameters

    • obj: Record<string, any>

    Returns Uint8Array

diff --git a/classes/Encryption.html b/classes/Encryption.html new file mode 100644 index 000000000..084c24bf3 --- /dev/null +++ b/classes/Encryption.html @@ -0,0 +1,17 @@ +Encryption | DWN-SDK Documentation - v0.5.1

Utility class for performing common, non-DWN specific encryption operations.

+

Constructors

Accessors

Methods

  • Decrypts the given cipher stream using AES-256-CTR algorithm.

    +

    Parameters

    • key: Uint8Array
    • initializationVector: Uint8Array
    • cipherStream: Readable

    Returns Promise<Readable>

  • Encrypts the given plaintext stream using AES-256-CTR algorithm.

    +

    Parameters

    • key: Uint8Array
    • initializationVector: Uint8Array
    • plaintextStream: Readable

    Returns Promise<Readable>

  • Decrypt the given plaintext using ECIES (Elliptic Curve Integrated Encryption Scheme) +with SECP256K1 for the asymmetric calculations, HKDF as the key-derivation function, +and AES-GCM for the symmetric encryption and MAC algorithms.

    +

    Parameters

    • input: EciesEncryptionInput

    Returns Promise<Uint8Array>

  • Encrypts the given plaintext using ECIES (Elliptic Curve Integrated Encryption Scheme) +with SECP256K1 for the asymmetric calculations, HKDF as the key-derivation function, +and AES-GCM for the symmetric encryption and MAC algorithms.

    +

    Parameters

    • publicKeyBytes: Uint8Array
    • plaintext: Uint8Array

    Returns Promise<EciesEncryptionOutput>

diff --git a/classes/EventEmitterStream.html b/classes/EventEmitterStream.html new file mode 100644 index 000000000..534671a84 --- /dev/null +++ b/classes/EventEmitterStream.html @@ -0,0 +1,7 @@ +EventEmitterStream | DWN-SDK Documentation - v0.5.1

The EventStream interface implements a pub/sub system based on Message filters.

+

Implements

Constructors

Methods

Constructors

Methods

diff --git a/classes/EventLogLevel.html b/classes/EventLogLevel.html new file mode 100644 index 000000000..d2e73475c --- /dev/null +++ b/classes/EventLogLevel.html @@ -0,0 +1,28 @@ +EventLogLevel | DWN-SDK Documentation - v0.5.1

Implements

Constructors

Properties

index: IndexLevel
ulidFactory: ULIDFactory

Methods

  • adds an event to a tenant's event log

    +

    Parameters

    • tenant: string

      the tenant's DID

      +
    • messageCid: string

      the CID of the message

      +
    • indexes: KeyValues

      (key-value pairs) to be included as part of indexing this event.

      +

    Returns Promise<void>

  • deletes any events that have any of the messageCids provided

    +

    Parameters

    • tenant: string
    • messageCids: string[]

    Returns Promise<void>

    the number of events deleted

    +
  • Retrieves all of a tenant's events that occurred after the cursor provided. +If no cursor is provided, all events for a given tenant will be returned.

    +

    The cursor is a messageCid.

    +

    Returns an array of messageCids that represent the events.

    +

    Parameters

    Returns Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>

  • retrieves a filtered set of events that occurred after a the cursor provided, accepts multiple filters.

    +

    If no cursor is provided, all events for a given tenant and filter combo will be returned. +The cursor is a messageCid.

    +

    Returns an array of messageCids that represent the events.

    +

    Parameters

    Returns Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>

diff --git a/classes/HdKey.html b/classes/HdKey.html new file mode 100644 index 000000000..ccb47830f --- /dev/null +++ b/classes/HdKey.html @@ -0,0 +1,14 @@ +HdKey | DWN-SDK Documentation - v0.5.1

Class containing hierarchical deterministic key related utility methods used by the DWN.

+

Constructors

Methods

  • Derives a key using HMAC-based Extract-and-Expand Key Derivation Function (HKDF) as defined in RFC 5869. +TODO: Consolidate HKDF implementation and usage with web5-js - https://github.com/TBD54566975/dwn-sdk-js/issues/742

    +

    Parameters

    • params: {
          hashAlgorithm: "SHA-256" | "SHA-384" | "SHA-512";
          info: Uint8Array;
          initialKeyMaterial: Uint8Array;
          keyLengthInBytes: number;
      }
      • hashAlgorithm: "SHA-256" | "SHA-384" | "SHA-512"
      • info: Uint8Array
      • initialKeyMaterial: Uint8Array
      • keyLengthInBytes: number

    Returns Promise<Uint8Array>

  • Derives a hardened hierarchical deterministic private key.

    +

    Parameters

    • privateKey: Uint8Array
    • relativePath: string[]

    Returns Promise<Uint8Array>

  • Derives a descendant public key from an ancestor private key. +NOTE: currently only supports SECP256K1 keys.

    +

    Parameters

    Returns Promise<PublicJwk>

diff --git a/classes/Jws.html b/classes/Jws.html new file mode 100644 index 000000000..55ddfe57c --- /dev/null +++ b/classes/Jws.html @@ -0,0 +1,18 @@ +Jws | DWN-SDK Documentation - v0.5.1

Utility class for JWS related operations.

+

Constructors

Methods

  • Decodes the payload of the given JWS object as a plain object.

    +

    Parameters

    • jws: GeneralJws

    Returns any

  • Extracts the DID from the given kid string.

    +

    Parameters

    • kid: string

    Returns string

  • Gets the kid from a general JWS signature entry.

    +

    Parameters

    • signatureEntry: SignatureEntry

    Returns string

  • Gets the signer DID from a general JWS signature entry.

    +

    Parameters

    • signatureEntry: SignatureEntry

    Returns string

  • Verifies the signature against the given payload.

    +

    Parameters

    • base64UrlPayload: string
    • signatureEntry: SignatureEntry
    • jwkPublic: PublicJwk

    Returns Promise<boolean>

    true if signature is valid; false otherwise

    +
diff --git a/classes/Message.html b/classes/Message.html new file mode 100644 index 000000000..6dc5fe188 --- /dev/null +++ b/classes/Message.html @@ -0,0 +1,48 @@ +Message | DWN-SDK Documentation - v0.5.1

A class containing utility methods for working with DWN messages.

+

Constructors

Methods

  • Compares message CID in lexicographical order according to the spec.

    +

    Returns Promise<number>

    1 if a is larger than b; -1 if a is smaller/older than b; 0 otherwise (same message)

    +
  • Compares the messageTimestamp of the given messages with a fallback to message CID according to the spec.

    +

    Returns Promise<number>

    1 if a is larger/newer than b; -1 if a is smaller/older than b; 0 otherwise (same age)

    +
  • Creates the authorization property to be included in a DWN message.

    +

    Parameters

    Returns Promise<AuthorizationModel>

    used as an authorization property.

    +
  • Creates a generic signature from the given DWN message descriptor by including descriptorCid as the required property in the signature payload. +NOTE: there is an opportunity to consolidate RecordsWrite.createSignerSignature() wth this method

    +

    Parameters

    • descriptor: Descriptor
    • signer: Signer
    • OptionaladditionalPayloadProperties: {
          delegatedGrantId?: string;
          permissionGrantId?: string;
          protocolRole?: string;
      }
      • OptionaldelegatedGrantId?: string
      • OptionalpermissionGrantId?: string
      • OptionalprotocolRole?: string

    Returns Promise<GeneralJws>

  • Gets the DID of the author of the given message.

    +

    Parameters

    Returns undefined | string

  • Gets the DID of the signer of the given message, returns undefined if message is not signed.

    +

    Parameters

    Returns undefined | string

  • Validates the given message against the corresponding JSON schema.

    +

    Parameters

    • rawMessage: any

    Returns void

    if fails validation.

    +
  • Validates the structural integrity of the message signature given:

    +
      +
    1. The message signature must contain exactly 1 signature
    2. +
    3. Passes JSON schema validation
    4. +
    5. The descriptorCid property matches the CID of the message descriptor +NOTE: signature is NOT verified.
    6. +
    +

    Parameters

    • messageSignature: GeneralJws
    • messageDescriptor: Descriptor
    • payloadJsonSchemaKey: string = 'GenericSignaturePayload'

      The key to look up the JSON schema referenced in compile-validators.js and perform payload schema validation on.

      +

    Returns Promise<GenericSignaturePayload>

    the parsed JSON payload object if validation succeeds.

    +
diff --git a/classes/MessageStoreLevel.html b/classes/MessageStoreLevel.html new file mode 100644 index 000000000..5eb4f6142 --- /dev/null +++ b/classes/MessageStoreLevel.html @@ -0,0 +1,26 @@ +MessageStoreLevel | DWN-SDK Documentation - v0.5.1

A simple implementation of MessageStore that works in both the browser and server-side. +Leverages LevelDB under the hood.

+

Implements

Constructors

Properties

blockstore: BlockstoreLevel
config: MessageStoreLevelConfig
index: IndexLevel

Methods

diff --git a/classes/MessagesQuery.html b/classes/MessagesQuery.html new file mode 100644 index 000000000..bcc4ea7ff --- /dev/null +++ b/classes/MessagesQuery.html @@ -0,0 +1,19 @@ +MessagesQuery | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/MessagesRead.html b/classes/MessagesRead.html new file mode 100644 index 000000000..48cd77bfc --- /dev/null +++ b/classes/MessagesRead.html @@ -0,0 +1,19 @@ +MessagesRead | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/MessagesSubscribe.html b/classes/MessagesSubscribe.html new file mode 100644 index 000000000..d31e690b8 --- /dev/null +++ b/classes/MessagesSubscribe.html @@ -0,0 +1,21 @@ +MessagesSubscribe | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/PermissionGrant.html b/classes/PermissionGrant.html new file mode 100644 index 000000000..6709b86a3 --- /dev/null +++ b/classes/PermissionGrant.html @@ -0,0 +1,23 @@ +PermissionGrant | DWN-SDK Documentation - v0.5.1

A class representing a Permission Grant for a more convenient abstraction.

+

Properties

Optional conditions that must be met when the grant is used.

+
dateExpires: string

Timestamp at which this grant will no longer be active.

+
dateGranted: string

The date at which the grant was given.

+
delegated?: boolean

Whether this grant is delegated or not. If true, the grantedTo will be able to act as the grantedTo within the scope of this grant.

+
description?: string

Optional string that communicates what the grant would be used for

+
grantee: string

The grantee of the permission.

+
grantor: string

The grantor of the permission.

+
id: string

The ID of the permission grant, which is the record ID DWN message.

+
requestId?: string

Optional CID of a permission request. This is optional because grants may be given without being officially requested

+

The scope of the allowed access.

+

Methods

diff --git a/classes/PermissionRequest.html b/classes/PermissionRequest.html new file mode 100644 index 000000000..03daedada --- /dev/null +++ b/classes/PermissionRequest.html @@ -0,0 +1,16 @@ +PermissionRequest | DWN-SDK Documentation - v0.5.1

A class representing a Permission Request for a more convenient abstraction.

+

Properties

Optional conditions that must be met when the requested grant is used.

+
delegated?: boolean

Whether the requested grant is delegated or not. +If true, the requestor will be able to act as the grantor of the permission within the scope of the requested grant.

+
description?: string

Optional string that communicates what the requested grant would be used for.

+
id: string

The ID of the permission request, which is the record ID DWN message.

+
requester: string

The requester for of the permission.

+

The scope of the allowed access.

+

Methods

diff --git a/classes/PermissionsProtocol.html b/classes/PermissionsProtocol.html new file mode 100644 index 000000000..56661f260 --- /dev/null +++ b/classes/PermissionsProtocol.html @@ -0,0 +1,32 @@ +PermissionsProtocol | DWN-SDK Documentation - v0.5.1

This is a first-class DWN protocol for managing permission grants of a given DWN.

+

Constructors

Properties

definition: ProtocolDefinition = ...

The definition of the Permissions protocol.

+
grantPath: "grant" = 'grant'

The protocol path of the grant record.

+
requestPath: "request" = 'request'

The protocol path of the request record.

+
revocationPath: "grant/revocation" = 'grant/revocation'

The protocol path of the revocation record.

+
uri: "https://tbd.website/dwn/permissions" = 'https://tbd.website/dwn/permissions'

The URI of the DWN Permissions protocol.

+

Methods

  • Fetches PermissionGrant with the specified recordID.

    +

    Parameters

    • tenant: string
    • messageStore: MessageStore
    • permissionGrantId: string

    Returns Promise<PermissionGrant>

    the PermissionGrant matching the recordId specified.

    +

    if PermissionGrant does not exist

    +
  • Validates the given Permissions protocol RecordsWrite. It can be a request, grant, or revocation.

    +

    Parameters

    Returns void

diff --git a/classes/Poller.html b/classes/Poller.html new file mode 100644 index 000000000..00bf3af85 --- /dev/null +++ b/classes/Poller.html @@ -0,0 +1,12 @@ +Poller | DWN-SDK Documentation - v0.5.1

Constructors

Properties

pollRetrySleep: number = 20

The interval in milliseconds to wait before retrying the delegate function.

+
pollTimeout: number = 2000

The maximum time in milliseconds to wait before timing out the delegate function.

+

Methods

  • Polls the delegate function until it succeeds or the timeout is exceeded.

    +

    Type Parameters

    • T

    Parameters

    • delegate: (() => Promise<T>)

      a function that returns a promise and may throw.

      +
        • (): Promise<T>
        • Returns Promise<T>

    • retrySleep: number = Poller.pollRetrySleep

      the interval in milliseconds to wait before retrying the delegate function.

      +
    • timeout: number = Poller.pollTimeout

      the maximum time in milliseconds to wait before timing out the delegate function.

      +

    Returns Promise<T>

    Operation timed out if the timeout is exceeded.

    +
diff --git a/classes/PrivateKeySigner.html b/classes/PrivateKeySigner.html new file mode 100644 index 000000000..b837cf759 --- /dev/null +++ b/classes/PrivateKeySigner.html @@ -0,0 +1,17 @@ +PrivateKeySigner | DWN-SDK Documentation - v0.5.1

A signer that signs using a private key.

+

Implements

Constructors

Properties

Methods

Constructors

Properties

algorithm: string

The name of the signature algorithm used by this signer. +This value will be used as the "alg" parameter in JWS produced. +This parameter is not used by the DWN but is unfortunately a required header property for a JWS as per: +https://datatracker.ietf.org/doc/html/rfc7515#section-4.1.1 +Valid signature algorithm values can be found at https://www.iana.org/assignments/jose/jose.xhtml

+
keyId: string

The ID of the key used by this signer. +This needs to be a fully-qualified ID (ie. prefixed with DID) so that author can be parsed out for processing such as recordId computation. +Example: did:example:alice#key1 +This value will be used as the "kid" parameter in JWS produced. +While this property is not a required property per JWS specification, it is required for DWN authentication.

+

Methods

  • Signs the given content and returns the signature as bytes.

    +

    Parameters

    • content: Uint8Array

    Returns Promise<Uint8Array>

diff --git a/classes/Protocols.html b/classes/Protocols.html new file mode 100644 index 000000000..bd7426596 --- /dev/null +++ b/classes/Protocols.html @@ -0,0 +1,7 @@ +Protocols | DWN-SDK Documentation - v0.5.1

Class containing Protocol related utility methods.

+

Constructors

Methods

  • Derives public encryptions keys and inject it in the $encryption property for each protocol path segment of the given Protocol definition, +then returns the final encryption-enabled protocol definition. +NOTE: The original definition passed in is unmodified.

    +

    Parameters

    Returns Promise<ProtocolDefinition>

diff --git a/classes/ProtocolsConfigure.html b/classes/ProtocolsConfigure.html new file mode 100644 index 000000000..88d4f3c8b --- /dev/null +++ b/classes/ProtocolsConfigure.html @@ -0,0 +1,22 @@ +ProtocolsConfigure | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

  • Authorizes the author-delegate who signed this message.

    +

    Parameters

    • messageStore: MessageStore

      Used to check if the grant has been revoked.

      +

    Returns Promise<void>

diff --git a/classes/ProtocolsQuery.html b/classes/ProtocolsQuery.html new file mode 100644 index 000000000..b130a7597 --- /dev/null +++ b/classes/ProtocolsQuery.html @@ -0,0 +1,21 @@ +ProtocolsQuery | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/Records.html b/classes/Records.html new file mode 100644 index 000000000..91509aa9e --- /dev/null +++ b/classes/Records.html @@ -0,0 +1,64 @@ +Records | DWN-SDK Documentation - v0.5.1

Class containing useful utilities related to the Records interface.

+

Constructors

Methods

  • This will create individual keys for each of the tags that look like tag.tag_property

    +

    Parameters

    Returns KeyValues

  • Checks if the given RecordsDelete message can be performed against a record with the given newest existing state.

    +

    Parameters

    Returns boolean

  • Constructs the full key derivation path using dataFormats scheme.

    +

    Parameters

    • schema: undefined | string
    • dataFormat: string

    Returns string[]

  • Constructs the full key derivation path using protocolContext scheme.

    +

    Parameters

    • contextId: undefined | string

    Returns string[]

  • Constructs the full key derivation path using protocolPath scheme.

    +

    Parameters

    Returns string[]

  • Constructs the full key derivation path using schemas scheme.

    +

    Parameters

    • schema: undefined | string

    Returns string[]

  • Converts an incoming RecordsFilter into a Filter usable by MessageStore.

    +

    Parameters

    Returns Filter

    a generic Filter able to be used with MessageStore.

    +
  • Decrypts the encrypted data in a message reply using the given ancestor private key.

    +

    Parameters

    Returns Promise<Readable>

  • Derives a descendant private key given an ancestor private key and the full absolute derivation path. +NOTE: right now only ECIES-ES256K algorithm is supported for asymmetric encryption, +so we will only derive SECP256K1 key without additional conditional checks

    +

    Parameters

    Returns Promise<Uint8Array>

  • Checks if the filter supports returning published records.

    +

    Parameters

    Returns boolean

  • Checks if the filter supports returning unpublished records.

    +

    Parameters

    Returns boolean

  • Extracts the parent context ID from the given context ID.

    +

    Parameters

    • contextId: undefined | string

    Returns undefined | string

  • Parameters

    • filter:
          | string
          | number
          | boolean
          | {
              gt: RangeValue;
          } & {
              gte?: undefined;
          } & Partial<{
              gt: RangeValue;
          } & {
              gte?: undefined;
          }> & Partial<{
              lt: RangeValue;
          } & {
              lte?: undefined;
          }>
          | {
              gt: RangeValue;
          } & {
              gte?: undefined;
          } & Partial<{
              gt: RangeValue;
          } & {
              gte?: undefined;
          }> & Partial<{
              lt?: undefined;
          } & {
              lte: RangeValue;
          }>
          | never
          | never
          | never
          | never
          | {
              gt?: undefined;
          } & {
              gte: RangeValue;
          } & Partial<{
              gt?: undefined;
          } & {
              gte: RangeValue;
          }> & Partial<{
              lt: RangeValue;
          } & {
              lte?: undefined;
          }>
          | {
              gt?: undefined;
          } & {
              gte: RangeValue;
          } & Partial<{
              gt?: undefined;
          } & {
              gte: RangeValue;
          }> & Partial<{
              lt?: undefined;
          } & {
              lte: RangeValue;
          }>
          | {
              lt: RangeValue;
          } & {
              lte?: undefined;
          } & Partial<{
              gt: RangeValue;
          } & {
              gte?: undefined;
          }> & Partial<{
              lt: RangeValue;
          } & {
              lte?: undefined;
          }>
          | never
          | {
              lt: RangeValue;
          } & {
              lte?: undefined;
          } & Partial<{
              gt?: undefined;
          } & {
              gte: RangeValue;
          }> & Partial<{
              lt: RangeValue;
          } & {
              lte?: undefined;
          }>
          | never
          | never
          | {
              lt?: undefined;
          } & {
              lte: RangeValue;
          } & Partial<{
              gt: RangeValue;
          } & {
              gte?: undefined;
          }> & Partial<{
              lt?: undefined;
          } & {
              lte: RangeValue;
          }>
          | never
          | {
              lt?: undefined;
          } & {
              lte: RangeValue;
          } & Partial<{
              gt?: undefined;
          } & {
              gte: RangeValue;
          }> & Partial<{
              lt?: undefined;
          } & {
              lte: RangeValue;
          }>
          | StartsWithFilter

    Returns filter is StartsWithFilter

  • Normalizes the protocol and schema URLs within a provided RecordsFilter and returns a copy of RecordsFilter with the modified values.

    +

    Parameters

    Returns RecordsFilter

    a copy of the incoming RecordsFilter with the normalized properties.

    +
  • Checks whether or not the incoming records query filter should build an unpublished author MessageStore filter.

    +

    Parameters

    • filter: RecordsFilter

      The incoming RecordsFilter to evaluate against.

      +
    • author: string

      The author to check against the filter, typically the query/subscribe message author.

      +

    Returns boolean

    True if the filter contains the author, or if the author filter is undefined/empty.

    +
  • Checks whether or not the incoming records query filter should build an unpublished recipient MessageStore filter.

    +

    Parameters

    • filter: RecordsFilter

      The incoming RecordsFilter to evaluate against.

      +
    • recipient: string

      The recipient to check against the filter, typically the query/subscribe message author.

      +

    Returns boolean

    True if the filter contains the recipient, or if the recipient filter is undefined/empty.

    +
  • Determines if signature payload contains a protocolRole and should be authorized as such.

    +

    Parameters

    • signaturePayload: GenericSignaturePayload

    Returns boolean

  • Validates that ancestor derivation path matches the descendant derivation path completely.

    +

    Parameters

    • ancestorKeyDerivationPath: string[]
    • descendantKeyDerivationPath: string[]

    Returns void

    with DwnErrorCode.RecordsInvalidAncestorKeyDerivationSegment if fails validation.

    +
  • Validates the referential integrity of both author-delegated grant and owner-delegated grant.

    +

    Parameters

    • message:
          | RecordsWriteMessage
          | RecordsQueryMessage
          | RecordsDeleteMessage
          | RecordsSubscribeMessage
          | RecordsReadMessage
    • authorSignaturePayload: undefined | GenericSignaturePayload

      Decoded payload of the author signature of the message. Pass undefined if message is not signed. +Passed purely as a performance optimization so we don't have to decode the signature payload again.

      +
    • OptionalownerSignaturePayload: GenericSignaturePayload

      Decoded payload of the owner signature of the message. Pass undefined if no owner signature is present. +Passed purely as a performance optimization so we don't have to decode the owner signature payload again.

      +

    Returns Promise<void>

diff --git a/classes/RecordsDelete.html b/classes/RecordsDelete.html new file mode 100644 index 000000000..fa81e5118 --- /dev/null +++ b/classes/RecordsDelete.html @@ -0,0 +1,23 @@ +RecordsDelete | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/RecordsQuery.html b/classes/RecordsQuery.html new file mode 100644 index 000000000..67ccf6ed3 --- /dev/null +++ b/classes/RecordsQuery.html @@ -0,0 +1,23 @@ +RecordsQuery | DWN-SDK Documentation - v0.5.1

A class representing a RecordsQuery DWN message.

+

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

  • Authorizes the delegate who signed this message.

    +

    Parameters

    • messageStore: MessageStore

      Used to check if the grant has been revoked.

      +

    Returns Promise<void>

diff --git a/classes/RecordsRead.html b/classes/RecordsRead.html new file mode 100644 index 000000000..2dae55707 --- /dev/null +++ b/classes/RecordsRead.html @@ -0,0 +1,24 @@ +RecordsRead | DWN-SDK Documentation - v0.5.1

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/RecordsSubscribe.html b/classes/RecordsSubscribe.html new file mode 100644 index 000000000..61fa12a8d --- /dev/null +++ b/classes/RecordsSubscribe.html @@ -0,0 +1,23 @@ +RecordsSubscribe | DWN-SDK Documentation - v0.5.1

A class representing a RecordsSubscribe DWN message.

+

Hierarchy

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get isSignedByAuthorDelegate(): boolean
  • If this message is signed by an author-delegate.

    +

    Returns boolean

  • get message(): M
  • Valid JSON message representing this DWN message.

    +

    Returns M

  • get signaturePayload(): undefined | GenericSignaturePayload
  • Decoded payload of the signature of this message.

    +

    Returns undefined | GenericSignaturePayload

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

diff --git a/classes/RecordsWrite.html b/classes/RecordsWrite.html new file mode 100644 index 000000000..112d0d4e3 --- /dev/null +++ b/classes/RecordsWrite.html @@ -0,0 +1,90 @@ +RecordsWrite | DWN-SDK Documentation - v0.5.1

A class representing a RecordsWrite DWN message. +NOTE: Unable to extend AbstractMessage directly because the incompatible _message type, which is not just a generic <M> type.

+

Implements

Properties

attesters: string[]

Accessors

  • get author(): undefined | string
  • DID of the logical author of this message. +NOTE: we say "logical" author because a message can be signed by a delegate of the actual author, +in which case the author DID would not be the same as the signer/delegate DID, +but be the DID of the grantor (grantedBy) of the delegated grant presented.

    +

    Returns undefined | string

  • get owner(): undefined | string
  • The owner DID of the message if owner signature is present in the message; undefined otherwise. +This is the logical owner of the message, not to be confused with the actual signer of the owner signature, +this is because the signer of the owner signature may not be the actual DWN owner, but a delegate authorized by the owner.

    +

    Returns undefined | string

  • get ownerSignaturePayload(): undefined | GenericSignaturePayload
  • Decoded owner signature payload.

    +

    Returns undefined | GenericSignaturePayload

  • get ownerSignatureSigner(): undefined | string
  • Gets the signer of owner signature; undefined if owner signature is not present in the message. +This is not to be confused with the logical owner #owner of the message, +this is because the signer of the owner signature may not be the actual DWN owner, but a delegate authorized by the owner. +In the case that the owner signature is signed by the actual DWN owner, this value will be the same as #owner.

    +

    Returns undefined | string

  • get signer(): undefined | string
  • Gets the signer of this message. +This is not to be confused with the logical author of the message.

    +

    Returns undefined | string

Methods

  • Authorizes the author-delegate who signed this message.

    +

    Parameters

    • messageStore: MessageStore

      Used to check if the grant has been revoked.

      +

    Returns Promise<void>

  • Authorizes the owner-delegate who signed this message.

    +

    Parameters

    • messageStore: MessageStore

      Used to check if the grant has been revoked.

      +

    Returns Promise<void>

  • Encrypts the symmetric encryption key using the public keys given and attach the resulting encryption property to the RecordsWrite.

    +

    Parameters

    Returns Promise<void>

  • Signs the RecordsWrite as the DWN owner. +This is used when the DWN owner wants to retain a copy of a message that the owner did not author. +NOTE: requires the RecordsWrite to already have the author's signature.

    +

    Parameters

    Returns Promise<void>

  • Signs the RecordsWrite as the DWN owner-delegate. +This is used when a DWN owner-delegate wants to retain a copy of a message that the owner did not author. +NOTE: requires the RecordsWrite to already have the author's signature.

    +

    Parameters

    Returns Promise<void>

  • Creates the attestation property of a RecordsWrite message if given signature inputs; returns undefined otherwise.

    +

    Parameters

    • descriptorCid: string
    • Optionalsigners: Signer[]

    Returns Promise<undefined | GeneralJws>

  • Convenience method that creates a message by:

    +
      +
    1. Copying over immutable properties from the given source message
    2. +
    3. Copying over mutable properties that are not overwritten from the given source message
    4. +
    5. Replace the mutable properties that are given new value
    6. +
    +

    Parameters

    Returns Promise<RecordsWrite>

  • Creates the signature property in the authorization of a RecordsWrite message.

    +

    Parameters

    • input: {
          attestation: undefined | GeneralJws;
          contextId: undefined | string;
          delegatedGrantId?: string;
          descriptorCid: string;
          encryption: undefined | EncryptionProperty;
          permissionGrantId?: string;
          protocolRole?: string;
          recordId: string;
          signer: Signer;
      }
      • attestation: undefined | GeneralJws
      • contextId: undefined | string
      • OptionaldelegatedGrantId?: string
      • descriptorCid: string
      • encryption: undefined | EncryptionProperty
      • OptionalpermissionGrantId?: string
      • OptionalprotocolRole?: string
      • recordId: string
      • signer: Signer

    Returns Promise<GeneralJws>

diff --git a/classes/ResumableTaskStoreLevel.html b/classes/ResumableTaskStoreLevel.html new file mode 100644 index 000000000..737aba471 --- /dev/null +++ b/classes/ResumableTaskStoreLevel.html @@ -0,0 +1,41 @@ +ResumableTaskStoreLevel | DWN-SDK Documentation - v0.5.1

A simple single-instance implementation of ResumableTaskStore that works in both browsers and node.js. +Leverages LevelDB under the hood.

+

Implements

Constructors

Properties

Methods

Constructors

Properties

config: ResumableTaskStoreLevelConfig
db: LevelWrapper<string>

Methods

  • Deletes the task associated with the task ID provided. +No-op if the task is not found, as this implies that the task has already been completed. +Called when the task has been successfully completed.

    +

    Parameters

    • taskId: string

    Returns Promise<void>

  • Extends the timeout of the task associated with the task ID provided. +No-op if the task is not found, as this implies that the task has already been completed. +This allows the client that is executing the task to continue working on it before the task is considered timed out.

    +

    Parameters

    • taskId: string

      ID of the task to extend the timeout for.

      +
    • timeoutInSeconds: number

      Timeout in seconds from the current time.

      +

    Returns Promise<void>

  • Grabs a number of unhandled tasks from the store. +Unhandled tasks are tasks that are not currently in-flight/under processing (ie. tasks that have timed-out). +NOTE: The implementation must make sure that once a task is grabbed by a client, +tis timeout must be updated so that it is considered in-flight/under processing +and cannot be grabbed by another client until it is timed-out.

    +

    Parameters

    • count: number

      Desired number of tasks to grab.

      +

    Returns Promise<ManagedResumableTask[]>

    A list of tasks exclusive for the caller to handle; or empty array if there is no tasks, or if all tasks are already grabbed by others.

    +
  • Registers a new resumable task that is currently in-flight/under processing to the store. +If the task is timed out, a client will be able to grab it through the grab() method and resume the task.

    +

    Parameters

    • task: any

      Task specific data. This is deliberately of type any because this store should not have to be ware of its type.

      +
    • timeoutInSeconds: number

      Timeout in seconds from the current time.

      +

    Returns Promise<ManagedResumableTask>

    A ManagedResumableTask object that can be used to extend or delete the task.

    +

    with code set to ResumableTaskAlreadyExists if the same task is already registered.

    +
diff --git a/classes/Secp256k1.html b/classes/Secp256k1.html new file mode 100644 index 000000000..4e8eb04dc --- /dev/null +++ b/classes/Secp256k1.html @@ -0,0 +1,27 @@ +Secp256k1 | DWN-SDK Documentation - v0.5.1

Class containing SECP256K1 related utility methods.

+

Constructors

Methods

  • Generates key pair in raw bytes, where the publicKey is compressed.

    +

    Returns Promise<{
        privateKey: Uint8Array;
        publicKey: Uint8Array;
    }>

  • Gets the compressed public key of the given private key.

    +

    Parameters

    • privateKey: Uint8Array

    Returns Promise<Uint8Array>

  • Creates a private key in raw bytes from the given SECP256K1 JWK.

    +

    Parameters

    Returns Uint8Array

  • Creates a compressed key in raw bytes from the given SECP256K1 JWK.

    +

    Parameters

    Returns Uint8Array

  • Signs the provided content using the provided JWK.

    +

    Parameters

    Returns Promise<Uint8Array>

  • Verifies a signature against the provided payload hash and public key.

    +

    Parameters

    • content: Uint8Array
    • signature: Uint8Array
    • publicJwk: PublicJwk

    Returns Promise<boolean>

    a boolean indicating whether the signature is valid.

    +
diff --git a/classes/Secp256r1.html b/classes/Secp256r1.html new file mode 100644 index 000000000..aa0f16179 --- /dev/null +++ b/classes/Secp256r1.html @@ -0,0 +1,20 @@ +Secp256r1 | DWN-SDK Documentation - v0.5.1

Class containing SECP256R1 related utility methods.

+

Constructors

Methods

  • Creates a private key in raw bytes from the given SECP256R1 JWK.

    +

    Parameters

    Returns Uint8Array

  • Signs the provided content using the provided JWK. +Signature that is outputted is JWS format, not DER.

    +

    Parameters

    Returns Promise<Uint8Array>

  • Verifies a signature against the provided payload hash and public key.

    +

    Parameters

    • content: Uint8Array
    • signature: Uint8Array

      the signature to verify. Can be in either DER or compact format. If using Oracle Cloud KMS, keys will be DER formatted.

      +
    • publicJwk: PublicJwk

    Returns Promise<boolean>

    a boolean indicating whether the signature is valid.

    +
diff --git a/classes/TestDataGenerator.html b/classes/TestDataGenerator.html new file mode 100644 index 000000000..80a6e0258 --- /dev/null +++ b/classes/TestDataGenerator.html @@ -0,0 +1,60 @@ +TestDataGenerator | DWN-SDK Documentation - v0.5.1

Utility class for generating data for testing.

+

Constructors

Methods

  • Generates a dummy authorization property for a DWN message that only conforms to schema validation.

    +

    Returns AuthorizationModel

  • Generates a dummy authorization property for a DWN message that only conforms to schema validation.

    +

    Returns GeneralJws

  • Generates a valid RecordsWrite that modifies the given an existing write. +Any mutable property is not specified will be automatically mutated. +e.g. if published is not specified, it will be toggled from the state of the given existing write.

    +

    Parameters

    • input: GenerateFromRecordsWriteInput

    Returns Promise<GenerateFromRecordsWriteOut>

  • Parameters

    • Optionalinput: GenerateGrantCreateInput

    Returns Promise<GenerateGrantCreateOutput>

  • Parameters

    • input: GenerateMessagesQueryInput

    Returns Promise<GenerateMessagesQueryOutput>

  • Parameters

    • input: GenerateMessagesReadInput

    Returns Promise<GenerateMessagesReadOutput>

  • Generates a MessagesSubscribe message for testing.

    +

    Parameters

    • Optionalinput: GenerateMessagesSubscribeInput

    Returns Promise<GenerateMessagesSubscribeOutput>

  • Generates a encrypted RecordsWrite message for testing.

    +

    Parameters

    • input: {
          author: Persona;
          encryptSymmetricKeyWithProtocolContextDerivedKey: boolean;
          encryptSymmetricKeyWithProtocolPathDerivedKey: boolean;
          plaintextBytes: Uint8Array;
          protocolContextDerivedPublicJwk?: PublicJwk;
          protocolContextDerivingRootKeyId?: string;
          protocolDefinition: ProtocolDefinition;
          protocolParentContextId?: string;
          protocolPath: string;
          recipient?: string;
      }
      • author: Persona
      • encryptSymmetricKeyWithProtocolContextDerivedKey: boolean

        Set to true to attach the symmetric key encrypted by the protocol context derived public key

        +
      • encryptSymmetricKeyWithProtocolPathDerivedKey: boolean

        Set to true to attach the symmetric key encrypted by the protocol path derived public key

        +
      • plaintextBytes: Uint8Array
      • OptionalprotocolContextDerivedPublicJwk?: PublicJwk
      • OptionalprotocolContextDerivingRootKeyId?: string
      • protocolDefinition: ProtocolDefinition

        Protocol definition used to generate the RecordsWrite. +Must be the RECIPIENT's protocol definition if encryptSymmetricKeyWithProtocolPathDerivedKey is true, +because the recipient's public keys will be needed to encrypt the symmetric key.

        +
      • OptionalprotocolParentContextId?: string
      • protocolPath: string
      • Optionalrecipient?: string

    Returns Promise<{
        dataStream: Readable;
        encryptedDataBytes: Uint8Array;
        encryptionInput: EncryptionInput;
        message: RecordsWriteMessage;
        recordsWrite: RecordsWrite;
    }>

  • Generates a ProtocolsConfigure message for testing. +Optional parameters are generated if not given. +Implementation currently uses ProtocolsConfigure.create().

    +

    Parameters

    • Optionalinput: GenerateProtocolsConfigureInput

    Returns Promise<GenerateProtocolsConfigureOutput>

  • Generates a ProtocolsQuery message for testing.

    +

    Parameters

    • Optionalinput: GenerateProtocolsQueryInput

    Returns Promise<GenerateProtocolsQueryOutput>

  • Generates a RecordsDelete for testing.

    +

    Parameters

    • Optionalinput: GenerateRecordsDeleteInput

    Returns Promise<GenerateRecordsDeleteOutput>

  • Generates a RecordsQuery message for testing.

    +

    Parameters

    • Optionalinput: GenerateRecordsQueryInput

    Returns Promise<GenerateRecordsQueryOutput>

  • Generates a RecordsSubscribe message for testing.

    +

    Parameters

    • Optionalinput: GenerateRecordsSubscribeInput

    Returns Promise<GenerateRecordsSubscribeOutput>

  • Generates a RecordsWrite message for testing. +dataBytes & dataStream returned will be undefined as long as dataCid or dataSize is given. +Implementation currently uses RecordsWrite.create().

    +

    Parameters

    • Optionalinput: GenerateRecordsWriteInput

    Returns Promise<GenerateRecordsWriteOutput>

  • Generates a random within a range (inclusive).

    +

    Parameters

    • min: number

      lowest potential value.

      +
    • max: number

      greatest potential value.

      +

    Returns number

  • Generates a random timestamp. Optionally allows you to set specific non-randomized values for the timestamp.

    +

    Parameters

    • Optionaloptions: {
          day?: number;
          hour?: number;
          microsecond?: number;
          millisecond?: number;
          minute?: number;
          month?: number;
          second?: number;
          year?: number;
      }
      • Optionalday?: number
      • Optionalhour?: number
      • Optionalmicrosecond?: number
      • Optionalmillisecond?: number
      • Optionalminute?: number
      • Optionalmonth?: number
      • Optionalsecond?: number
      • Optionalyear?: number

    Returns string

    random UTC ISO-8601 timestamp

    +
diff --git a/classes/Time.html b/classes/Time.html new file mode 100644 index 000000000..0615dcade --- /dev/null +++ b/classes/Time.html @@ -0,0 +1,24 @@ +Time | DWN-SDK Documentation - v0.5.1

Time related utilities.

+

Constructors

Methods

  • Creates a UTC ISO-8601 timestamp offset from now or given timestamp accepted by DWN.

    +

    Parameters

    • offset: {
          seconds: number;
      }

      Negative number means offset into the past.

      +
      • seconds: number
    • Optionaltimestamp: string

    Returns string

  • Creates a UTC ISO-8601 timestamp in microsecond precision accepted by DWN.

    +

    Parameters

    • options: {
          day?: number;
          hour?: number;
          microsecond?: number;
          millisecond?: number;
          minute?: number;
          month?: number;
          second?: number;
          year?: number;
      }

      Options for creating the timestamp.

      +
      • Optionalday?: number
      • Optionalhour?: number
      • Optionalmicrosecond?: number
      • Optionalmillisecond?: number
      • Optionalminute?: number
      • Optionalmonth?: number
      • Optionalsecond?: number
      • Optionalyear?: number

    Returns string

    string

    +
  • Returns an UTC ISO-8601 timestamp with microsecond precision accepted by DWN. +using @js-temporal/polyfill

    +

    Returns string

  • sleeps for the desired duration

    +

    Parameters

    • durationInMillisecond: number

      the desired amount of sleep time

      +

    Returns Promise<void>

    when the provided duration has passed

    +
  • Validates that the provided timestamp is a valid number

    +

    Parameters

    • timestamp: string

      the timestamp to validate

      +

    Returns void

    DwnError if timestamp is not a valid number

    +
diff --git a/enums/DateSort.html b/enums/DateSort.html new file mode 100644 index 000000000..c98c3519f --- /dev/null +++ b/enums/DateSort.html @@ -0,0 +1,5 @@ +DateSort | DWN-SDK Documentation - v0.5.1

Enumeration DateSort

Enumeration Members

CreatedAscending
CreatedDescending
PublishedAscending
PublishedDescending
diff --git a/enums/DwnErrorCode.html b/enums/DwnErrorCode.html new file mode 100644 index 000000000..8dd1f8c43 --- /dev/null +++ b/enums/DwnErrorCode.html @@ -0,0 +1,153 @@ +DwnErrorCode | DWN-SDK Documentation - v0.5.1

Enumeration DwnErrorCode

DWN SDK error codes.

+

Enumeration Members

AuthenticateDescriptorCidMismatch +AuthenticateJwsMissing +AuthenticationMoreThanOneSignatureNotSupported +AuthorizationNotGrantedToAuthor +ComputeCidCodecNotSupported +ComputeCidMultihashNotSupported +Ed25519InvalidJwk +EventEmitterStreamNotOpenError +GeneralJwsVerifierGetPublicKeyNotFound +GeneralJwsVerifierInvalidSignature +GrantAuthorizationGrantExpired +GrantAuthorizationGrantMissing +GrantAuthorizationGrantNotYetActive +GrantAuthorizationGrantRevoked +GrantAuthorizationInterfaceMismatch +GrantAuthorizationMethodMismatch +GrantAuthorizationNotGrantedForTenant +GrantAuthorizationNotGrantedToAuthor +HdKeyDerivationPathInvalid +IndexInvalidCursorSortProperty +IndexInvalidCursorValueType +IndexInvalidSortPropertyInMemory +IndexMissingIndexableProperty +JwsDecodePlainObjectPayloadInvalid +JwsVerifySignatureUnsupportedCrv +MessageGetInvalidCid +MessagesGrantAuthorizationMismatchedProtocol +MessagesQueryAuthorizationFailed +MessagesReadAuthorizationFailed +MessagesReadInvalidCid +MessagesReadVerifyScopeFailed +MessagesSubscribeAuthorizationFailed +MessagesSubscribeEventStreamUnimplemented +ParseCidCodecNotSupported +ParseCidMultihashNotSupported +PermissionsProtocolCreateGrantRecordsScopeMissingProtocol +PermissionsProtocolCreateRequestRecordsScopeMissingProtocol +PermissionsProtocolGetScopeInvalidProtocol +PermissionsProtocolValidateRevocationProtocolTagMismatch +PermissionsProtocolValidateSchemaUnexpectedRecord +PermissionsProtocolValidateScopeContextIdProhibitedProperties +PermissionsProtocolValidateScopeMissingProtocolTag +PermissionsProtocolValidateScopeProtocolMismatch +PrivateKeySignerUnableToDeduceAlgorithm +PrivateKeySignerUnableToDeduceKeyId +PrivateKeySignerUnsupportedCurve +ProtocolAuthorizationActionNotAllowed +ProtocolAuthorizationActionRulesNotFound +ProtocolAuthorizationDuplicateRoleRecipient +ProtocolAuthorizationIncorrectContextId +ProtocolAuthorizationIncorrectDataFormat +ProtocolAuthorizationIncorrectProtocolPath +ProtocolAuthorizationInvalidSchema +ProtocolAuthorizationInvalidType +ProtocolAuthorizationMatchingRoleRecordNotFound +ProtocolAuthorizationMaxSizeInvalid +ProtocolAuthorizationMinSizeInvalid +ProtocolAuthorizationMissingContextId +ProtocolAuthorizationMissingRuleSet +ProtocolAuthorizationNotARole +ProtocolAuthorizationParentlessIncorrectProtocolPath +ProtocolAuthorizationParentNotFoundConstructingRecordChain +ProtocolAuthorizationProtocolNotFound +ProtocolAuthorizationRoleMissingRecipient +ProtocolAuthorizationTagsInvalidSchema +ProtocolsConfigureAuthorizationFailed +ProtocolsConfigureDuplicateActorInRuleSet +ProtocolsConfigureDuplicateRoleInRuleSet +ProtocolsConfigureInvalidActionDeleteWithoutCreate +ProtocolsConfigureInvalidActionMissingOf +ProtocolsConfigureInvalidActionOfNotAllowed +ProtocolsConfigureInvalidActionUpdateWithoutCreate +ProtocolsConfigureInvalidRecipientOfAction +ProtocolsConfigureInvalidRuleSetRecordType +ProtocolsConfigureInvalidSize +ProtocolsConfigureInvalidTagSchema +ProtocolsConfigureRecordNestingDepthExceeded +ProtocolsConfigureRoleDoesNotExistAtGivenPath +ProtocolsConfigureRoleReadActionMissing +ProtocolsGrantAuthorizationQueryProtocolScopeMismatch +ProtocolsGrantAuthorizationScopeProtocolMismatch +ProtocolsQueryUnauthorized +RecordsAuthorDelegatedGrantAndIdExistenceMismatch +RecordsAuthorDelegatedGrantCidMismatch +RecordsAuthorDelegatedGrantGrantedToAndOwnerSignatureMismatch +RecordsAuthorDelegatedGrantNotADelegatedGrant +RecordsDecryptNoMatchingKeyEncryptedFound +RecordsDeleteAuthorizationFailed +RecordsDerivePrivateKeyUnSupportedCurve +RecordsGrantAuthorizationConditionPublicationProhibited +RecordsGrantAuthorizationConditionPublicationRequired +RecordsGrantAuthorizationDeleteProtocolScopeMismatch +RecordsGrantAuthorizationQueryOrSubscribeProtocolScopeMismatch +RecordsGrantAuthorizationScopeContextIdMismatch +RecordsGrantAuthorizationScopeProtocolMismatch +RecordsGrantAuthorizationScopeProtocolPathMismatch +RecordsInvalidAncestorKeyDerivationSegment +RecordsOwnerDelegatedGrantAndIdExistenceMismatch +RecordsOwnerDelegatedGrantCidMismatch +RecordsOwnerDelegatedGrantGrantedToAndOwnerSignatureMismatch +RecordsOwnerDelegatedGrantNotADelegatedGrant +RecordsProtocolContextDerivationSchemeMissingContextId +RecordsProtocolPathDerivationSchemeMissingProtocol +RecordsQueryCreateFilterPublishedSortInvalid +RecordsQueryFilterMissingRequiredProperties +RecordsQueryParseFilterPublishedSortInvalid +RecordsReadAuthorizationFailed +RecordsReadInitialWriteNotFound +RecordsReadReturnedMultiple +RecordsSchemasDerivationSchemeMissingSchema +RecordsSubscribeEventStreamUnimplemented +RecordsSubscribeFilterMissingRequiredProperties +RecordsWriteAttestationIntegrityDescriptorCidMismatch +RecordsWriteAttestationIntegrityInvalidPayloadProperty +RecordsWriteAttestationIntegrityMoreThanOneSignature +RecordsWriteAuthorizationFailed +RecordsWriteCreateDataAndDataCidMutuallyExclusive +RecordsWriteCreateDataCidAndDataSizeMutuallyInclusive +RecordsWriteCreateMissingSigner +RecordsWriteCreateProtocolAndProtocolPathMutuallyInclusive +RecordsWriteDataCidMismatch +RecordsWriteDataSizeMismatch +RecordsWriteGetEntryIdUndefinedAuthor +RecordsWriteGetInitialWriteNotFound +RecordsWriteGetNewestWriteRecordNotFound +RecordsWriteImmutablePropertyChanged +RecordsWriteMissingDataInPrevious +RecordsWriteMissingEncodedDataInPrevious +RecordsWriteMissingProtocol +RecordsWriteMissingSchema +RecordsWriteMissingSigner +RecordsWriteNotAllowedAfterDelete +RecordsWriteOwnerAndTenantMismatch +RecordsWriteSignAsOwnerDelegateUnknownAuthor +RecordsWriteSignAsOwnerUnknownAuthor +RecordsWriteValidateIntegrityAttestationMismatch +RecordsWriteValidateIntegrityContextIdMismatch +RecordsWriteValidateIntegrityContextIdNotInSignerSignaturePayload +RecordsWriteValidateIntegrityDateCreatedMismatch +RecordsWriteValidateIntegrityEncryptionCidMismatch +RecordsWriteValidateIntegrityRecordIdUnauthorized +SchemaValidatorAdditionalPropertyNotAllowed +SchemaValidatorFailure +SchemaValidatorSchemaNotFound +SchemaValidatorUnevaluatedPropertyNotAllowed +Secp256k1KeyNotValid +Secp256r1KeyNotValid +TimestampInvalid +UrlProtocolNotNormalizable +UrlProtocolNotNormalized +UrlSchemaNotNormalized +

Enumeration Members

AuthenticateDescriptorCidMismatch
AuthenticateJwsMissing
AuthenticationMoreThanOneSignatureNotSupported
AuthorizationNotGrantedToAuthor
ComputeCidCodecNotSupported
ComputeCidMultihashNotSupported
Ed25519InvalidJwk
EventEmitterStreamNotOpenError
GeneralJwsVerifierGetPublicKeyNotFound
GeneralJwsVerifierInvalidSignature
GrantAuthorizationGrantExpired
GrantAuthorizationGrantMissing
GrantAuthorizationGrantNotYetActive
GrantAuthorizationGrantRevoked
GrantAuthorizationInterfaceMismatch
GrantAuthorizationMethodMismatch
GrantAuthorizationNotGrantedForTenant
GrantAuthorizationNotGrantedToAuthor
HdKeyDerivationPathInvalid
IndexInvalidCursorSortProperty
IndexInvalidCursorValueType
IndexInvalidSortPropertyInMemory
IndexMissingIndexableProperty
JwsDecodePlainObjectPayloadInvalid
JwsVerifySignatureUnsupportedCrv
MessageGetInvalidCid
MessagesGrantAuthorizationMismatchedProtocol
MessagesQueryAuthorizationFailed
MessagesReadAuthorizationFailed
MessagesReadInvalidCid
MessagesReadVerifyScopeFailed
MessagesSubscribeAuthorizationFailed
MessagesSubscribeEventStreamUnimplemented
ParseCidCodecNotSupported
ParseCidMultihashNotSupported
PermissionsProtocolCreateGrantRecordsScopeMissingProtocol
PermissionsProtocolCreateRequestRecordsScopeMissingProtocol
PermissionsProtocolGetScopeInvalidProtocol
PermissionsProtocolValidateRevocationProtocolTagMismatch
PermissionsProtocolValidateSchemaUnexpectedRecord
PermissionsProtocolValidateScopeContextIdProhibitedProperties
PermissionsProtocolValidateScopeMissingProtocolTag
PermissionsProtocolValidateScopeProtocolMismatch
PrivateKeySignerUnableToDeduceAlgorithm
PrivateKeySignerUnableToDeduceKeyId
PrivateKeySignerUnsupportedCurve
ProtocolAuthorizationActionNotAllowed
ProtocolAuthorizationActionRulesNotFound
ProtocolAuthorizationDuplicateRoleRecipient
ProtocolAuthorizationIncorrectContextId
ProtocolAuthorizationIncorrectDataFormat
ProtocolAuthorizationIncorrectProtocolPath
ProtocolAuthorizationInvalidSchema
ProtocolAuthorizationInvalidType
ProtocolAuthorizationMatchingRoleRecordNotFound
ProtocolAuthorizationMaxSizeInvalid
ProtocolAuthorizationMinSizeInvalid
ProtocolAuthorizationMissingContextId
ProtocolAuthorizationMissingRuleSet
ProtocolAuthorizationNotARole
ProtocolAuthorizationParentlessIncorrectProtocolPath
ProtocolAuthorizationParentNotFoundConstructingRecordChain
ProtocolAuthorizationProtocolNotFound
ProtocolAuthorizationRoleMissingRecipient
ProtocolAuthorizationTagsInvalidSchema
ProtocolsConfigureAuthorizationFailed
ProtocolsConfigureDuplicateActorInRuleSet
ProtocolsConfigureDuplicateRoleInRuleSet
ProtocolsConfigureInvalidActionDeleteWithoutCreate
ProtocolsConfigureInvalidActionMissingOf
ProtocolsConfigureInvalidActionOfNotAllowed
ProtocolsConfigureInvalidActionUpdateWithoutCreate
ProtocolsConfigureInvalidRecipientOfAction
ProtocolsConfigureInvalidRuleSetRecordType
ProtocolsConfigureInvalidSize
ProtocolsConfigureInvalidTagSchema
ProtocolsConfigureRecordNestingDepthExceeded
ProtocolsConfigureRoleDoesNotExistAtGivenPath
ProtocolsConfigureRoleReadActionMissing
ProtocolsGrantAuthorizationQueryProtocolScopeMismatch
ProtocolsGrantAuthorizationScopeProtocolMismatch
ProtocolsQueryUnauthorized
RecordsAuthorDelegatedGrantAndIdExistenceMismatch
RecordsAuthorDelegatedGrantCidMismatch
RecordsAuthorDelegatedGrantGrantedToAndOwnerSignatureMismatch
RecordsAuthorDelegatedGrantNotADelegatedGrant
RecordsDecryptNoMatchingKeyEncryptedFound
RecordsDeleteAuthorizationFailed
RecordsDerivePrivateKeyUnSupportedCurve
RecordsGrantAuthorizationConditionPublicationProhibited
RecordsGrantAuthorizationConditionPublicationRequired
RecordsGrantAuthorizationDeleteProtocolScopeMismatch
RecordsGrantAuthorizationQueryOrSubscribeProtocolScopeMismatch
RecordsGrantAuthorizationScopeContextIdMismatch
RecordsGrantAuthorizationScopeProtocolMismatch
RecordsGrantAuthorizationScopeProtocolPathMismatch
RecordsInvalidAncestorKeyDerivationSegment
RecordsOwnerDelegatedGrantAndIdExistenceMismatch
RecordsOwnerDelegatedGrantCidMismatch
RecordsOwnerDelegatedGrantGrantedToAndOwnerSignatureMismatch
RecordsOwnerDelegatedGrantNotADelegatedGrant
RecordsProtocolContextDerivationSchemeMissingContextId
RecordsProtocolPathDerivationSchemeMissingProtocol
RecordsQueryCreateFilterPublishedSortInvalid
RecordsQueryFilterMissingRequiredProperties
RecordsQueryParseFilterPublishedSortInvalid
RecordsReadAuthorizationFailed
RecordsReadInitialWriteNotFound
RecordsReadReturnedMultiple
RecordsSchemasDerivationSchemeMissingSchema
RecordsSubscribeEventStreamUnimplemented
RecordsSubscribeFilterMissingRequiredProperties
RecordsWriteAttestationIntegrityDescriptorCidMismatch
RecordsWriteAttestationIntegrityInvalidPayloadProperty
RecordsWriteAttestationIntegrityMoreThanOneSignature
RecordsWriteAuthorizationFailed
RecordsWriteCreateDataAndDataCidMutuallyExclusive
RecordsWriteCreateDataCidAndDataSizeMutuallyInclusive
RecordsWriteCreateMissingSigner
RecordsWriteCreateProtocolAndProtocolPathMutuallyInclusive
RecordsWriteDataCidMismatch
RecordsWriteDataSizeMismatch
RecordsWriteGetEntryIdUndefinedAuthor
RecordsWriteGetInitialWriteNotFound
RecordsWriteGetNewestWriteRecordNotFound
RecordsWriteImmutablePropertyChanged
RecordsWriteMissingDataInPrevious
RecordsWriteMissingEncodedDataInPrevious
RecordsWriteMissingProtocol
RecordsWriteMissingSchema
RecordsWriteMissingSigner
RecordsWriteNotAllowedAfterDelete
RecordsWriteOwnerAndTenantMismatch
RecordsWriteSignAsOwnerDelegateUnknownAuthor
RecordsWriteSignAsOwnerUnknownAuthor
RecordsWriteValidateIntegrityAttestationMismatch
RecordsWriteValidateIntegrityContextIdMismatch
RecordsWriteValidateIntegrityContextIdNotInSignerSignaturePayload
RecordsWriteValidateIntegrityDateCreatedMismatch
RecordsWriteValidateIntegrityEncryptionCidMismatch
RecordsWriteValidateIntegrityRecordIdUnauthorized
SchemaValidatorAdditionalPropertyNotAllowed
SchemaValidatorFailure
SchemaValidatorSchemaNotFound
SchemaValidatorUnevaluatedPropertyNotAllowed
Secp256k1KeyNotValid
Secp256r1KeyNotValid
TimestampInvalid
UrlProtocolNotNormalizable
UrlProtocolNotNormalized
UrlSchemaNotNormalized
diff --git a/enums/DwnInterfaceName.html b/enums/DwnInterfaceName.html new file mode 100644 index 000000000..8dc046bdd --- /dev/null +++ b/enums/DwnInterfaceName.html @@ -0,0 +1,4 @@ +DwnInterfaceName | DWN-SDK Documentation - v0.5.1

Enumeration DwnInterfaceName

Enumeration Members

Enumeration Members

Messages
Protocols
Records
diff --git a/enums/DwnMethodName.html b/enums/DwnMethodName.html new file mode 100644 index 000000000..00ea414b8 --- /dev/null +++ b/enums/DwnMethodName.html @@ -0,0 +1,7 @@ +DwnMethodName | DWN-SDK Documentation - v0.5.1

Enumeration DwnMethodName

Enumeration Members

Enumeration Members

Configure
Delete
Query
Read
Subscribe
Write
diff --git a/enums/EncryptionAlgorithm.html b/enums/EncryptionAlgorithm.html new file mode 100644 index 000000000..798feaaa5 --- /dev/null +++ b/enums/EncryptionAlgorithm.html @@ -0,0 +1,3 @@ +EncryptionAlgorithm | DWN-SDK Documentation - v0.5.1

Enumeration EncryptionAlgorithm

Enumeration Members

Enumeration Members

Aes256Ctr
EciesSecp256k1
diff --git a/enums/KeyDerivationScheme.html b/enums/KeyDerivationScheme.html new file mode 100644 index 000000000..a5d8bd880 --- /dev/null +++ b/enums/KeyDerivationScheme.html @@ -0,0 +1,7 @@ +KeyDerivationScheme | DWN-SDK Documentation - v0.5.1

Enumeration KeyDerivationScheme

Enumeration Members

DataFormats

Key derivation using the dataFormat value for Flat-space records.

+
ProtocolContext
ProtocolPath
Schemas

Key derivation using the schema value for Flat-space records.

+
diff --git a/enums/PermissionConditionPublication.html b/enums/PermissionConditionPublication.html new file mode 100644 index 000000000..317e77162 --- /dev/null +++ b/enums/PermissionConditionPublication.html @@ -0,0 +1,3 @@ +PermissionConditionPublication | DWN-SDK Documentation - v0.5.1

Enumeration PermissionConditionPublication

Enumeration Members

Enumeration Members

Prohibited
Required
diff --git a/enums/SortDirection.html b/enums/SortDirection.html new file mode 100644 index 000000000..1d9c684dd --- /dev/null +++ b/enums/SortDirection.html @@ -0,0 +1,3 @@ +SortDirection | DWN-SDK Documentation - v0.5.1

Enumeration SortDirection

Enumeration Members

Enumeration Members

Ascending
Descending
diff --git a/functions/authenticate.html b/functions/authenticate.html new file mode 100644 index 000000000..345ece5d0 --- /dev/null +++ b/functions/authenticate.html @@ -0,0 +1,3 @@ +authenticate | DWN-SDK Documentation - v0.5.1
  • Verifies all the signature(s) within the authorization property.

    +

    Parameters

    • authorizationModel: undefined | AuthorizationModel
    • didResolver: DidResolver

    Returns Promise<void>

    if fails authentication

    +
diff --git a/functions/executeUnlessAborted.html b/functions/executeUnlessAborted.html new file mode 100644 index 000000000..03d7c2782 --- /dev/null +++ b/functions/executeUnlessAborted.html @@ -0,0 +1,2 @@ +executeUnlessAborted | DWN-SDK Documentation - v0.5.1

Function executeUnlessAborted

  • Wraps the given Promise such that it will reject if the AbortSignal is triggered.

    +

    Type Parameters

    • T

    Parameters

    • promise: Promise<T>
    • signal: undefined | AbortSignal

    Returns Promise<T>

diff --git a/hierarchy.html b/hierarchy.html new file mode 100644 index 000000000..cadc3110e --- /dev/null +++ b/hierarchy.html @@ -0,0 +1 @@ +DWN-SDK Documentation - v0.5.1
diff --git a/index.html b/index.html new file mode 100644 index 000000000..aad2566a2 --- /dev/null +++ b/index.html @@ -0,0 +1,152 @@ +DWN-SDK Documentation - v0.5.1

DWN-SDK Documentation - v0.5.1

Index

Enumerations

Classes

Interfaces

Type Aliases

ActiveTenantCheckResult +CreateFromOptions +DataEncodedRecordsWriteMessage +DataStoreGetResult +DataStorePutResult +DerivedPrivateJwk +DwnConfig +EncryptedKey +EncryptionInput +EncryptionProperty +EqualFilter +EventListener +Filter +GenericMessage +GenericMessageReply +InternalRecordsWriteMessage +KeyEncryptionInput +KeyMaterial +ManagedResumableTask +MessageEvent +MessagesFilter +MessageSort +MessagesPermissionScope +MessagesQueryMessage +MessagesQueryOptions +MessagesQueryReply +MessagesReadMessage +MessagesReadOptions +MessagesReadReply +MessagesReadReplyEntry +MessagesSubscribeDescriptor +MessagesSubscribeMessage +MessagesSubscribeOptions +MessagesSubscribeReply +MessageSubscriptionHandler +OneOfFilter +Pagination +PaginationCursor +PermissionConditions +PermissionGrantData +PermissionRequestData +PermissionRevocationData +PermissionScope +Persona +PrivateJwk +ProtocolDefinition +ProtocolPermissionScope +ProtocolRuleSet +ProtocolsConfigureDescriptor +ProtocolsConfigureMessage +ProtocolsConfigureOptions +ProtocolsQueryFilter +ProtocolsQueryMessage +ProtocolsQueryOptions +ProtocolsQueryReply +ProtocolTypes +PublicJwk +QueryOptions +QueryResultEntry +RangeCriterion +RangeFilter +RecordEvent +RecordsDeleteDescriptor +RecordsDeleteMessage +RecordsDeleteOptions +RecordsFilter +RecordsPermissionScope +RecordsQueryDescriptor +RecordsQueryMessage +RecordsQueryOptions +RecordsQueryReply +RecordsQueryReplyEntry +RecordsReadDescriptor +RecordsReadMessage +RecordsReadOptions +RecordsReadReply +RecordsReadReplyEntry +RecordsSubscribeDescriptor +RecordsSubscribeMessage +RecordsSubscribeMessageOptions +RecordsSubscribeOptions +RecordsSubscribeReply +RecordSubscriptionHandler +RecordsWriteAttestationPayload +RecordsWriteDescriptor +RecordsWriteMessage +RecordsWriteMessageOptions +RecordsWriteOptions +RecordsWriteSignaturePayload +RecordsWriteTags +RecordsWriteTagsFilter +RecordsWriteTagValue +SubscriptionReply +UnionMessageReply +

Functions

diff --git a/interfaces/DataStore.html b/interfaces/DataStore.html new file mode 100644 index 000000000..25b76bbe0 --- /dev/null +++ b/interfaces/DataStore.html @@ -0,0 +1,21 @@ +DataStore | DWN-SDK Documentation - v0.5.1

The interface that defines how to store and fetch data associated with a message.

+
interface DataStore {
    clear(): Promise<void>;
    close(): Promise<void>;
    delete(tenant: string, recordId: string, dataCid: string): Promise<void>;
    get(tenant: string, recordId: string, dataCid: string): Promise<undefined | DataStoreGetResult>;
    open(): Promise<void>;
    put(tenant: string, recordId: string, dataCid: string, dataStream: Readable): Promise<DataStorePutResult>;
}

Implemented by

Methods

Methods

  • Clears the entire store. Mainly used for testing to cleaning up in test environments.

    +

    Returns Promise<void>

  • Deletes the specified data. No-op if the data does not exist.

    +

    Parameters

    • tenant: string
    • recordId: string

      The logical ID of the record that references the data.

      +
    • dataCid: string

      The IPFS CID of the data.

      +

    Returns Promise<void>

  • Fetches the specified data.

    +

    Parameters

    • tenant: string
    • recordId: string

      The logical ID of the record that references the data.

      +
    • dataCid: string

      The IPFS CID of the data.

      +

    Returns Promise<undefined | DataStoreGetResult>

    the data size and data stream if found, otherwise undefined.

    +
  • Stores the given data.

    +

    Parameters

    • tenant: string
    • recordId: string

      The logical ID of the record that references the data.

      +
    • dataCid: string

      The IPFS CID of the data.

      +
    • dataStream: Readable

    Returns Promise<DataStorePutResult>

diff --git a/interfaces/EventLog.html b/interfaces/EventLog.html new file mode 100644 index 000000000..a7a1b728c --- /dev/null +++ b/interfaces/EventLog.html @@ -0,0 +1,25 @@ +EventLog | DWN-SDK Documentation - v0.5.1
interface EventLog {
    append(tenant: string, messageCid: string, indexes: KeyValues): Promise<void>;
    clear(): Promise<void>;
    close(): Promise<void>;
    deleteEventsByCid(tenant: string, messageCids: string[]): Promise<void>;
    getEvents(tenant: string, cursor?: PaginationCursor): Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>;
    open(): Promise<void>;
    queryEvents(tenant: string, filters: Filter[], cursor?: PaginationCursor): Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>;
}

Implemented by

Methods

  • adds an event to a tenant's event log

    +

    Parameters

    • tenant: string

      the tenant's DID

      +
    • messageCid: string

      the CID of the message

      +
    • indexes: KeyValues

      (key-value pairs) to be included as part of indexing this event.

      +

    Returns Promise<void>

  • Clears the entire store. Mainly used for cleaning up in test environment.

    +

    Returns Promise<void>

  • closes the connection to the underlying store

    +

    Returns Promise<void>

  • deletes any events that have any of the messageCids provided

    +

    Parameters

    • tenant: string
    • messageCids: string[]

    Returns Promise<void>

    the number of events deleted

    +
  • Retrieves all of a tenant's events that occurred after the cursor provided. +If no cursor is provided, all events for a given tenant will be returned.

    +

    The cursor is a messageCid.

    +

    Returns an array of messageCids that represent the events.

    +

    Parameters

    Returns Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>

  • opens a connection to the underlying store

    +

    Returns Promise<void>

  • retrieves a filtered set of events that occurred after a the cursor provided, accepts multiple filters.

    +

    If no cursor is provided, all events for a given tenant and filter combo will be returned. +The cursor is a messageCid.

    +

    Returns an array of messageCids that represent the events.

    +

    Parameters

    Returns Promise<{
        cursor?: PaginationCursor;
        events: string[];
    }>

diff --git a/interfaces/EventStream.html b/interfaces/EventStream.html new file mode 100644 index 000000000..1c89e603d --- /dev/null +++ b/interfaces/EventStream.html @@ -0,0 +1,6 @@ +EventStream | DWN-SDK Documentation - v0.5.1

The EventStream interface implements a pub/sub system based on Message filters.

+
interface EventStream {
    close(): Promise<void>;
    emit(tenant: string, event: MessageEvent, indexes: KeyValues): void;
    open(): Promise<void>;
    subscribe(tenant: string, id: string, listener: EventListener): Promise<EventSubscription>;
}

Implemented by

Methods

Methods

diff --git a/interfaces/EventSubscription.html b/interfaces/EventSubscription.html new file mode 100644 index 000000000..f82796208 --- /dev/null +++ b/interfaces/EventSubscription.html @@ -0,0 +1,3 @@ +EventSubscription | DWN-SDK Documentation - v0.5.1

Interface EventSubscription

interface EventSubscription {
    close: (() => Promise<void>);
    id: string;
}

Properties

Properties

close: (() => Promise<void>)
id: string
diff --git a/interfaces/MessageStore.html b/interfaces/MessageStore.html new file mode 100644 index 000000000..fff45041b --- /dev/null +++ b/interfaces/MessageStore.html @@ -0,0 +1,18 @@ +MessageStore | DWN-SDK Documentation - v0.5.1

Interface MessageStore

interface MessageStore {
    clear(): Promise<void>;
    close(): Promise<void>;
    delete(tenant: string, cid: string, options?: MessageStoreOptions): Promise<void>;
    get(tenant: string, cid: string, options?: MessageStoreOptions): Promise<undefined | GenericMessage>;
    open(): Promise<void>;
    put(tenant: string, message: GenericMessage, indexes: KeyValues, options?: MessageStoreOptions): Promise<void>;
    query(tenant: string, filters: Filter[], messageSort?: MessageSort, pagination?: Pagination, options?: MessageStoreOptions): Promise<{
        cursor?: PaginationCursor;
        messages: GenericMessage[];
    }>;
}

Implemented by

Methods

Methods

  • Clears the entire store. Mainly used for cleaning up in test environment.

    +

    Returns Promise<void>

  • adds a message to the underlying store. Uses the message's cid as the key

    +

    Parameters

    Returns Promise<void>

diff --git a/interfaces/MessageStoreOptions.html b/interfaces/MessageStoreOptions.html new file mode 100644 index 000000000..58497935e --- /dev/null +++ b/interfaces/MessageStoreOptions.html @@ -0,0 +1,2 @@ +MessageStoreOptions | DWN-SDK Documentation - v0.5.1

Interface MessageStoreOptions

interface MessageStoreOptions {
    signal?: AbortSignal;
}

Properties

Properties

signal?: AbortSignal
diff --git a/interfaces/MessageSubscription.html b/interfaces/MessageSubscription.html new file mode 100644 index 000000000..23648ab58 --- /dev/null +++ b/interfaces/MessageSubscription.html @@ -0,0 +1,3 @@ +MessageSubscription | DWN-SDK Documentation - v0.5.1

Interface MessageSubscription

interface MessageSubscription {
    close: (() => Promise<void>);
    id: string;
}

Properties

Properties

close: (() => Promise<void>)
id: string
diff --git a/interfaces/ResumableTaskStore.html b/interfaces/ResumableTaskStore.html new file mode 100644 index 000000000..528a8dfb8 --- /dev/null +++ b/interfaces/ResumableTaskStore.html @@ -0,0 +1,57 @@ +ResumableTaskStore | DWN-SDK Documentation - v0.5.1

Interface ResumableTaskStore

Interface for interacting with the resumable task store.

+

Implementer's Note: +The store implementation used in a horizontally scalable deployment, such as in a Kubernetes cluster, +must account for concurrent access by multiple ResumableTaskStore instances. +It would be undesirable to have many kubernetes pods all trying to handle the same resumable task. +A minimal viable implementation can use a per tenant exclusive lock on the store when grab() and method is called. +This would prevent issues that occur from concurrent modification to the same task to the store, +but negatively impacts the throughput performance of the DWN. +Requirements for a more performant implementation that allows distributed processing of resumable tasks across multiple clients:

+
    +
  1. The implementation probably requires both: +a. a persistent store for storing the data of each resumable task; and +b. an message streaming queue/service for distributing the each task exclusively to one of multiple handling clients.
  2. +
  3. The grab() and/or open() implementation will need to copy the timed-out tasks from persistent store into the message queue/service +for distributed processing by multiple clients when there is no resumable tasks to grab in the message queue. +During the move, the persistent store should be locked to prevent multiple copies of the same tasks from being copied.
  4. +
  5. Both Google's pub-sub and Amazon's SQS require an Ack ID / Receipt Handle to acknowledge the message, +The value of Ack ID / Receipt Handle is not known until the message is received, +therefore the implementer will likely need to have an in-memory mapping of task ID -> Ack ID / Receipt Handle +so that delete() can be called with task ID.
  6. +
+
interface ResumableTaskStore {
    clear(): Promise<void>;
    close(): Promise<void>;
    delete(taskId: string): Promise<void>;
    extend(taskId: string, timeoutInSeconds: number): Promise<void>;
    grab(count: number): Promise<ManagedResumableTask[]>;
    open(): Promise<void>;
    read(taskId: string): Promise<undefined | ManagedResumableTask>;
    register(task: any, timeoutInSeconds: number): Promise<ManagedResumableTask>;
}

Implemented by

Methods

  • Deletes the task associated with the task ID provided. +No-op if the task is not found, as this implies that the task has already been completed. +Called when the task has been successfully completed.

    +

    Parameters

    • taskId: string

    Returns Promise<void>

  • Extends the timeout of the task associated with the task ID provided. +No-op if the task is not found, as this implies that the task has already been completed. +This allows the client that is executing the task to continue working on it before the task is considered timed out.

    +

    Parameters

    • taskId: string

      ID of the task to extend the timeout for.

      +
    • timeoutInSeconds: number

      Timeout in seconds from the current time.

      +

    Returns Promise<void>

  • Grabs a number of unhandled tasks from the store. +Unhandled tasks are tasks that are not currently in-flight/under processing (ie. tasks that have timed-out). +NOTE: The implementation must make sure that once a task is grabbed by a client, +tis timeout must be updated so that it is considered in-flight/under processing +and cannot be grabbed by another client until it is timed-out.

    +

    Parameters

    • count: number

      Desired number of tasks to grab.

      +

    Returns Promise<ManagedResumableTask[]>

    A list of tasks exclusive for the caller to handle; or empty array if there is no tasks, or if all tasks are already grabbed by others.

    +
  • Reads the task associated with the task ID provided regardless of whether it is in-flight/under processing or not. +This is mainly introduced for testing purposes: ie. to check the status of a task for easy test verification.

    +

    Parameters

    • taskId: string

      ID of the task to read.

      +

    Returns Promise<undefined | ManagedResumableTask>

  • Registers a new resumable task that is currently in-flight/under processing to the store. +If the task is timed out, a client will be able to grab it through the grab() method and resume the task.

    +

    Parameters

    • task: any

      Task specific data. This is deliberately of type any because this store should not have to be ware of its type.

      +
    • timeoutInSeconds: number

      Timeout in seconds from the current time.

      +

    Returns Promise<ManagedResumableTask>

    A ManagedResumableTask object that can be used to extend or delete the task.

    +

    with code set to ResumableTaskAlreadyExists if the same task is already registered.

    +
diff --git a/interfaces/Signer.html b/interfaces/Signer.html new file mode 100644 index 000000000..393cb7629 --- /dev/null +++ b/interfaces/Signer.html @@ -0,0 +1,16 @@ +Signer | DWN-SDK Documentation - v0.5.1

A signer that is capable of generating a digital signature over any given bytes.

+
interface Signer {
    algorithm: string;
    keyId: string;
    sign(content: Uint8Array): Promise<Uint8Array>;
}

Implemented by

Properties

Methods

Properties

algorithm: string

The name of the signature algorithm used by this signer. +This value will be used as the "alg" parameter in JWS produced. +This parameter is not used by the DWN but is unfortunately a required header property for a JWS as per: +https://datatracker.ietf.org/doc/html/rfc7515#section-4.1.1 +Valid signature algorithm values can be found at https://www.iana.org/assignments/jose/jose.xhtml

+
keyId: string

The ID of the key used by this signer. +This needs to be a fully-qualified ID (ie. prefixed with DID) so that author can be parsed out for processing such as recordId computation. +Example: did:example:alice#key1 +This value will be used as the "kid" parameter in JWS produced. +While this property is not a required property per JWS specification, it is required for DWN authentication.

+

Methods

  • Signs the given content and returns the signature as bytes.

    +

    Parameters

    • content: Uint8Array

    Returns Promise<Uint8Array>

diff --git a/interfaces/TenantGate.html b/interfaces/TenantGate.html new file mode 100644 index 000000000..d976cf8ac --- /dev/null +++ b/interfaces/TenantGate.html @@ -0,0 +1,4 @@ +TenantGate | DWN-SDK Documentation - v0.5.1

An interface that gates tenant access to the DWN.

+
interface TenantGate {
    isActiveTenant(did: string): Promise<ActiveTenantCheckResult>;
}

Implemented by

Methods

diff --git a/types/ActiveTenantCheckResult.html b/types/ActiveTenantCheckResult.html new file mode 100644 index 000000000..354ed19e1 --- /dev/null +++ b/types/ActiveTenantCheckResult.html @@ -0,0 +1,4 @@ +ActiveTenantCheckResult | DWN-SDK Documentation - v0.5.1

Type Alias ActiveTenantCheckResult

ActiveTenantCheckResult: {
    detail?: string;
    isActiveTenant: boolean;
}

The result of the isActiveTenant() call.

+

Type declaration

  • Optionaldetail?: string

    An optional detail message if the given DID is not an active tenant of the DWN.

    +
  • isActiveTenant: boolean

    true if the given DID is an active tenant of the DWN; false otherwise.

    +
diff --git a/types/CreateFromOptions.html b/types/CreateFromOptions.html new file mode 100644 index 000000000..417c7779b --- /dev/null +++ b/types/CreateFromOptions.html @@ -0,0 +1,4 @@ +CreateFromOptions | DWN-SDK Documentation - v0.5.1

Type Alias CreateFromOptions

CreateFromOptions: {
    attestationSigners?: Signer[];
    data?: Uint8Array;
    dataFormat?: string;
    datePublished?: string;
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    encryptionInput?: EncryptionInput;
    messageTimestamp?: string;
    protocolRole?: string;
    published?: boolean;
    recordsWriteMessage: RecordsWriteMessage;
    signer?: Signer;
    tags?: RecordsWriteTags;
}

Type declaration

  • OptionalattestationSigners?: Signer[]
  • Optionaldata?: Uint8Array
  • OptionaldataFormat?: string

    The data format of the new data. If not given, the data format from the existing message will be used.

    +
  • OptionaldatePublished?: string
  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant to sign on behalf of the logical author, which is the grantor (grantedBy) of the delegated grant.

    +
  • OptionalencryptionInput?: EncryptionInput
  • OptionalmessageTimestamp?: string
  • OptionalprotocolRole?: string
  • Optionalpublished?: boolean
  • recordsWriteMessage: RecordsWriteMessage
  • Optionalsigner?: Signer

    The signer of the message, which is commonly the author, but can also be a delegate.

    +
  • Optionaltags?: RecordsWriteTags
diff --git a/types/DataEncodedRecordsWriteMessage.html b/types/DataEncodedRecordsWriteMessage.html new file mode 100644 index 000000000..b6349d947 --- /dev/null +++ b/types/DataEncodedRecordsWriteMessage.html @@ -0,0 +1,3 @@ +DataEncodedRecordsWriteMessage | DWN-SDK Documentation - v0.5.1

Type Alias DataEncodedRecordsWriteMessage

DataEncodedRecordsWriteMessage: RecordsWriteMessage & {
    encodedData: string;
}

Represents a RecordsWrite message with encoded data attached.

+

Type declaration

  • encodedData: string

    The encoded data of the record if the data associated with the record is equal or smaller than DwnConstant.maxDataSizeAllowedToBeEncoded.

    +
diff --git a/types/DataStoreGetResult.html b/types/DataStoreGetResult.html new file mode 100644 index 000000000..2de673ed0 --- /dev/null +++ b/types/DataStoreGetResult.html @@ -0,0 +1,3 @@ +DataStoreGetResult | DWN-SDK Documentation - v0.5.1

Type Alias DataStoreGetResult

DataStoreGetResult: {
    dataSize: number;
    dataStream: Readable;
}

Result of a data store get() method call if the data exists.

+

Type declaration

  • dataSize: number

    The number of bytes of the data stored.

    +
  • dataStream: Readable
diff --git a/types/DataStorePutResult.html b/types/DataStorePutResult.html new file mode 100644 index 000000000..30276e4ec --- /dev/null +++ b/types/DataStorePutResult.html @@ -0,0 +1,3 @@ +DataStorePutResult | DWN-SDK Documentation - v0.5.1

Type Alias DataStorePutResult

DataStorePutResult: {
    dataSize: number;
}

Result of a data store put() method call.

+

Type declaration

  • dataSize: number

    The number of bytes of the data stored.

    +
diff --git a/types/DerivedPrivateJwk.html b/types/DerivedPrivateJwk.html new file mode 100644 index 000000000..96488e657 --- /dev/null +++ b/types/DerivedPrivateJwk.html @@ -0,0 +1 @@ +DerivedPrivateJwk | DWN-SDK Documentation - v0.5.1

Type Alias DerivedPrivateJwk

DerivedPrivateJwk: {
    derivationPath?: string[];
    derivationScheme: KeyDerivationScheme;
    derivedPrivateKey: PrivateJwk;
    rootKeyId: string;
}
diff --git a/types/DwnConfig.html b/types/DwnConfig.html new file mode 100644 index 000000000..3d6aa95b7 --- /dev/null +++ b/types/DwnConfig.html @@ -0,0 +1,2 @@ +DwnConfig | DWN-SDK Documentation - v0.5.1

Type Alias DwnConfig

DwnConfig: {
    dataStore: DataStore;
    didResolver?: DidResolver;
    eventLog: EventLog;
    eventStream?: EventStream;
    messageStore: MessageStore;
    resumableTaskStore: ResumableTaskStore;
    tenantGate?: TenantGate;
}

DWN configuration.

+
diff --git a/types/EncryptedKey.html b/types/EncryptedKey.html new file mode 100644 index 000000000..075bb935e --- /dev/null +++ b/types/EncryptedKey.html @@ -0,0 +1,3 @@ +EncryptedKey | DWN-SDK Documentation - v0.5.1

Type Alias EncryptedKey

EncryptedKey: {
    algorithm: EncryptionAlgorithm;
    derivationScheme: KeyDerivationScheme;
    derivedPublicKey?: PublicJwk;
    encryptedKey: string;
    ephemeralPublicKey: PublicJwk;
    initializationVector: string;
    messageAuthenticationCode: string;
    rootKeyId: string;
}

Type declaration

  • algorithm: EncryptionAlgorithm
  • derivationScheme: KeyDerivationScheme
  • OptionalderivedPublicKey?: PublicJwk

    The actual derived public key.

    +
  • encryptedKey: string
  • ephemeralPublicKey: PublicJwk
  • initializationVector: string
  • messageAuthenticationCode: string
  • rootKeyId: string

    The fully qualified key ID (e.g. did:example:abc#encryption-key-id) of the root public key used to encrypt the symmetric encryption key.

    +
diff --git a/types/EncryptionInput.html b/types/EncryptionInput.html new file mode 100644 index 000000000..324cd8f87 --- /dev/null +++ b/types/EncryptionInput.html @@ -0,0 +1,7 @@ +EncryptionInput | DWN-SDK Documentation - v0.5.1

Type Alias EncryptionInput

EncryptionInput: {
    algorithm?: EncryptionAlgorithm;
    initializationVector: Uint8Array;
    key: Uint8Array;
    keyEncryptionInputs: KeyEncryptionInput[];
}

Input that describes how data is encrypted as spec-ed in TP18 (https://github.com/TBD54566975/technical-proposals/pull/6).

+

Type declaration

  • Optionalalgorithm?: EncryptionAlgorithm

    Algorithm used for encrypting the Data. Uses {EncryptionAlgorithm.Aes256Ctr} if not given.

    +
  • initializationVector: Uint8Array

    Initialization vector used for encrypting the data.

    +
  • key: Uint8Array

    Symmetric key used to encrypt the data.

    +
  • keyEncryptionInputs: KeyEncryptionInput[]

    Array of input that specifies how the symmetric key is encrypted. +Each entry in the array will result in a unique ciphertext of the symmetric key.

    +
diff --git a/types/EncryptionProperty.html b/types/EncryptionProperty.html new file mode 100644 index 000000000..a4557af64 --- /dev/null +++ b/types/EncryptionProperty.html @@ -0,0 +1 @@ +EncryptionProperty | DWN-SDK Documentation - v0.5.1

Type Alias EncryptionProperty

EncryptionProperty: {
    algorithm: EncryptionAlgorithm;
    initializationVector: string;
    keyEncryption: EncryptedKey[];
}
diff --git a/types/EqualFilter.html b/types/EqualFilter.html new file mode 100644 index 000000000..e7ecac8cb --- /dev/null +++ b/types/EqualFilter.html @@ -0,0 +1 @@ +EqualFilter | DWN-SDK Documentation - v0.5.1

Type Alias EqualFilter

EqualFilter: string | number | boolean
diff --git a/types/EventListener.html b/types/EventListener.html new file mode 100644 index 000000000..c1349738a --- /dev/null +++ b/types/EventListener.html @@ -0,0 +1 @@ +EventListener | DWN-SDK Documentation - v0.5.1

Type Alias EventListener

EventListener: ((tenant: string, event: MessageEvent, indexes: KeyValues) => void)
diff --git a/types/Filter.html b/types/Filter.html new file mode 100644 index 000000000..fad62eeaf --- /dev/null +++ b/types/Filter.html @@ -0,0 +1 @@ +Filter | DWN-SDK Documentation - v0.5.1
Filter: {
    [property: string]: FilterValue;
}
diff --git a/types/GenericMessage.html b/types/GenericMessage.html new file mode 100644 index 000000000..1e0eb4f27 --- /dev/null +++ b/types/GenericMessage.html @@ -0,0 +1,2 @@ +GenericMessage | DWN-SDK Documentation - v0.5.1

Type Alias GenericMessage

GenericMessage: {
    authorization?: AuthorizationModel;
    descriptor: Descriptor;
}

Intersection type for all concrete message types.

+
diff --git a/types/GenericMessageReply.html b/types/GenericMessageReply.html new file mode 100644 index 000000000..204594ec4 --- /dev/null +++ b/types/GenericMessageReply.html @@ -0,0 +1 @@ +GenericMessageReply | DWN-SDK Documentation - v0.5.1

Type Alias GenericMessageReply

GenericMessageReply: {
    status: Status;
}
diff --git a/types/InternalRecordsWriteMessage.html b/types/InternalRecordsWriteMessage.html new file mode 100644 index 000000000..283a80ac0 --- /dev/null +++ b/types/InternalRecordsWriteMessage.html @@ -0,0 +1,2 @@ +InternalRecordsWriteMessage | DWN-SDK Documentation - v0.5.1

Type Alias InternalRecordsWriteMessage

InternalRecordsWriteMessage: GenericMessage & {
    attestation?: GeneralJws;
    contextId?: string;
    descriptor: RecordsWriteDescriptor;
    encryption?: EncryptionProperty;
    recordId?: string;
}

Internal RecordsWrite message representation that can be in an incomplete state.

+
diff --git a/types/KeyEncryptionInput.html b/types/KeyEncryptionInput.html new file mode 100644 index 000000000..ddc6c77d5 --- /dev/null +++ b/types/KeyEncryptionInput.html @@ -0,0 +1,7 @@ +KeyEncryptionInput | DWN-SDK Documentation - v0.5.1

Type Alias KeyEncryptionInput

KeyEncryptionInput: {
    algorithm?: EncryptionAlgorithm;
    derivationScheme: KeyDerivationScheme;
    publicKey: PublicJwk;
    publicKeyId: string;
}

Input that specifies how a symmetric key is encrypted.

+

Type declaration

  • Optionalalgorithm?: EncryptionAlgorithm

    Algorithm used for encrypting the symmetric key. Uses {EncryptionAlgorithm.EciesSecp256k1} if not given.

    +
  • derivationScheme: KeyDerivationScheme

    Key derivation scheme used to derive the public key to encrypt the symmetric key.

    +
  • publicKey: PublicJwk

    Public key to be used to encrypt the symmetric key.

    +
  • publicKeyId: string

    Fully qualified ID of root public key used derive the public key to be used to to encrypt the symmetric key. +(e.g. did:example:abc#encryption-key-id)

    +
diff --git a/types/KeyMaterial.html b/types/KeyMaterial.html new file mode 100644 index 000000000..eb5512203 --- /dev/null +++ b/types/KeyMaterial.html @@ -0,0 +1,2 @@ +KeyMaterial | DWN-SDK Documentation - v0.5.1

Type Alias KeyMaterial

KeyMaterial: {
    keyId: string;
    keyPair: {
        privateJwk: PrivateJwk;
        publicJwk: PublicJwk;
    };
}

Contains a public-private key pair and the associated key ID.

+
diff --git a/types/ManagedResumableTask.html b/types/ManagedResumableTask.html new file mode 100644 index 000000000..0e1a9d763 --- /dev/null +++ b/types/ManagedResumableTask.html @@ -0,0 +1,6 @@ +ManagedResumableTask | DWN-SDK Documentation - v0.5.1

Type Alias ManagedResumableTask

ManagedResumableTask: {
    id: string;
    retryCount: number;
    task: any;
    timeout: number;
}

An managed resumable task model.

+

Type declaration

  • id: string

    Globally unique ID. Used to extend or delete the task.

    +
  • retryCount: number

    Number of retries

    +
  • task: any

    Task specific data. This is deliberately of type any because this store should not have to be ware of its type.

    +
  • timeout: number

    Task timeout in Epoch Time.

    +
diff --git a/types/MessageEvent.html b/types/MessageEvent.html new file mode 100644 index 000000000..a9277318f --- /dev/null +++ b/types/MessageEvent.html @@ -0,0 +1,3 @@ +MessageEvent | DWN-SDK Documentation - v0.5.1

Type Alias MessageEvent

MessageEvent: {
    initialWrite?: RecordsWriteMessage;
    message: GenericMessage;
}

MessageEvent contains the message being emitted and an optional initial write message.

+

Type declaration

diff --git a/types/MessageSort.html b/types/MessageSort.html new file mode 100644 index 000000000..04f49c9ee --- /dev/null +++ b/types/MessageSort.html @@ -0,0 +1 @@ +MessageSort | DWN-SDK Documentation - v0.5.1

Type Alias MessageSort

MessageSort: {
    dateCreated?: SortDirection;
    datePublished?: SortDirection;
    messageTimestamp?: SortDirection;
}
diff --git a/types/MessageSubscriptionHandler.html b/types/MessageSubscriptionHandler.html new file mode 100644 index 000000000..7090b5007 --- /dev/null +++ b/types/MessageSubscriptionHandler.html @@ -0,0 +1 @@ +MessageSubscriptionHandler | DWN-SDK Documentation - v0.5.1

Type Alias MessageSubscriptionHandler

MessageSubscriptionHandler: ((event: MessageEvent) => void)
diff --git a/types/MessagesFilter.html b/types/MessagesFilter.html new file mode 100644 index 000000000..7a16a7293 --- /dev/null +++ b/types/MessagesFilter.html @@ -0,0 +1,2 @@ +MessagesFilter | DWN-SDK Documentation - v0.5.1

Type Alias MessagesFilter

MessagesFilter: {
    interface?: string;
    messageTimestamp?: RangeCriterion;
    method?: string;
    protocol?: string;
}

filters used when filtering for any type of Message across interfaces

+
diff --git a/types/MessagesPermissionScope.html b/types/MessagesPermissionScope.html new file mode 100644 index 000000000..269bcac56 --- /dev/null +++ b/types/MessagesPermissionScope.html @@ -0,0 +1 @@ +MessagesPermissionScope | DWN-SDK Documentation - v0.5.1

Type Alias MessagesPermissionScope

MessagesPermissionScope: {
    interface: Messages;
    method: Query | Read | Subscribe;
    protocol?: string;
}
diff --git a/types/MessagesQueryMessage.html b/types/MessagesQueryMessage.html new file mode 100644 index 000000000..8ee34e9d4 --- /dev/null +++ b/types/MessagesQueryMessage.html @@ -0,0 +1 @@ +MessagesQueryMessage | DWN-SDK Documentation - v0.5.1

Type Alias MessagesQueryMessage

MessagesQueryMessage: GenericMessage & {
    authorization: AuthorizationModel;
    descriptor: MessagesQueryDescriptor;
}
diff --git a/types/MessagesQueryOptions.html b/types/MessagesQueryOptions.html new file mode 100644 index 000000000..c8bba7e37 --- /dev/null +++ b/types/MessagesQueryOptions.html @@ -0,0 +1 @@ +MessagesQueryOptions | DWN-SDK Documentation - v0.5.1

Type Alias MessagesQueryOptions

MessagesQueryOptions: {
    cursor?: PaginationCursor;
    filters?: MessagesFilter[];
    messageTimestamp?: string;
    permissionGrantId?: string;
    signer: Signer;
}
diff --git a/types/MessagesQueryReply.html b/types/MessagesQueryReply.html new file mode 100644 index 000000000..0a2f32b30 --- /dev/null +++ b/types/MessagesQueryReply.html @@ -0,0 +1 @@ +MessagesQueryReply | DWN-SDK Documentation - v0.5.1

Type Alias MessagesQueryReply

MessagesQueryReply: GenericMessageReply & {
    cursor?: PaginationCursor;
    entries?: string[];
}
diff --git a/types/MessagesReadMessage.html b/types/MessagesReadMessage.html new file mode 100644 index 000000000..21d222ea3 --- /dev/null +++ b/types/MessagesReadMessage.html @@ -0,0 +1 @@ +MessagesReadMessage | DWN-SDK Documentation - v0.5.1

Type Alias MessagesReadMessage

MessagesReadMessage: GenericMessage & {
    authorization: AuthorizationModel;
    descriptor: MessagesReadDescriptor;
}
diff --git a/types/MessagesReadOptions.html b/types/MessagesReadOptions.html new file mode 100644 index 000000000..bd7610ab7 --- /dev/null +++ b/types/MessagesReadOptions.html @@ -0,0 +1 @@ +MessagesReadOptions | DWN-SDK Documentation - v0.5.1

Type Alias MessagesReadOptions

MessagesReadOptions: {
    messageCid: string;
    messageTimestamp?: string;
    permissionGrantId?: string;
    signer: Signer;
}
diff --git a/types/MessagesReadReply.html b/types/MessagesReadReply.html new file mode 100644 index 000000000..a6fc52392 --- /dev/null +++ b/types/MessagesReadReply.html @@ -0,0 +1 @@ +MessagesReadReply | DWN-SDK Documentation - v0.5.1

Type Alias MessagesReadReply

MessagesReadReply: GenericMessageReply & {
    entry?: MessagesReadReplyEntry;
}
diff --git a/types/MessagesReadReplyEntry.html b/types/MessagesReadReplyEntry.html new file mode 100644 index 000000000..0a10598fd --- /dev/null +++ b/types/MessagesReadReplyEntry.html @@ -0,0 +1 @@ +MessagesReadReplyEntry | DWN-SDK Documentation - v0.5.1

Type Alias MessagesReadReplyEntry

MessagesReadReplyEntry: {
    data?: Readable;
    message: GenericMessage;
    messageCid: string;
}
diff --git a/types/MessagesSubscribeDescriptor.html b/types/MessagesSubscribeDescriptor.html new file mode 100644 index 000000000..f67dbe619 --- /dev/null +++ b/types/MessagesSubscribeDescriptor.html @@ -0,0 +1 @@ +MessagesSubscribeDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias MessagesSubscribeDescriptor

MessagesSubscribeDescriptor: {
    filters: MessagesFilter[];
    interface: Messages;
    messageTimestamp: string;
    method: Subscribe;
}
diff --git a/types/MessagesSubscribeMessage.html b/types/MessagesSubscribeMessage.html new file mode 100644 index 000000000..6e8249427 --- /dev/null +++ b/types/MessagesSubscribeMessage.html @@ -0,0 +1 @@ +MessagesSubscribeMessage | DWN-SDK Documentation - v0.5.1

Type Alias MessagesSubscribeMessage

MessagesSubscribeMessage: {
    authorization: AuthorizationModel;
    descriptor: MessagesSubscribeDescriptor;
}
diff --git a/types/MessagesSubscribeOptions.html b/types/MessagesSubscribeOptions.html new file mode 100644 index 000000000..bdca717ba --- /dev/null +++ b/types/MessagesSubscribeOptions.html @@ -0,0 +1 @@ +MessagesSubscribeOptions | DWN-SDK Documentation - v0.5.1

Type Alias MessagesSubscribeOptions

MessagesSubscribeOptions: {
    filters?: MessagesFilter[];
    messageTimestamp?: string;
    permissionGrantId?: string;
    signer: Signer;
}
diff --git a/types/MessagesSubscribeReply.html b/types/MessagesSubscribeReply.html new file mode 100644 index 000000000..aba1df314 --- /dev/null +++ b/types/MessagesSubscribeReply.html @@ -0,0 +1 @@ +MessagesSubscribeReply | DWN-SDK Documentation - v0.5.1

Type Alias MessagesSubscribeReply

MessagesSubscribeReply: GenericMessageReply & {
    subscription?: MessageSubscription;
}
diff --git a/types/OneOfFilter.html b/types/OneOfFilter.html new file mode 100644 index 000000000..028e5aa46 --- /dev/null +++ b/types/OneOfFilter.html @@ -0,0 +1 @@ +OneOfFilter | DWN-SDK Documentation - v0.5.1

Type Alias OneOfFilter

OneOfFilter: EqualFilter[]
diff --git a/types/Pagination.html b/types/Pagination.html new file mode 100644 index 000000000..cca3f6039 --- /dev/null +++ b/types/Pagination.html @@ -0,0 +1,3 @@ +Pagination | DWN-SDK Documentation - v0.5.1

Type Alias Pagination

Pagination: {
    cursor?: PaginationCursor;
    limit?: number;
}

Pagination Options for querying messages.

+

The cursor is the messageCid of the message you would like to pagination from.

+
diff --git a/types/PaginationCursor.html b/types/PaginationCursor.html new file mode 100644 index 000000000..cfcb932b3 --- /dev/null +++ b/types/PaginationCursor.html @@ -0,0 +1 @@ +PaginationCursor | DWN-SDK Documentation - v0.5.1

Type Alias PaginationCursor

PaginationCursor: {
    messageCid: string;
    value: string | number;
}
diff --git a/types/PermissionConditions.html b/types/PermissionConditions.html new file mode 100644 index 000000000..708d63bf3 --- /dev/null +++ b/types/PermissionConditions.html @@ -0,0 +1,4 @@ +PermissionConditions | DWN-SDK Documentation - v0.5.1

Type Alias PermissionConditions

PermissionConditions: {
    publication?: PermissionConditionPublication;
}

Type declaration

  • Optionalpublication?: PermissionConditionPublication

    indicates whether a message written with the invocation of a permission must, may, or must not +be marked as public. +If undefined, it is optional to make the message public.

    +
diff --git a/types/PermissionGrantData.html b/types/PermissionGrantData.html new file mode 100644 index 000000000..b1023e59c --- /dev/null +++ b/types/PermissionGrantData.html @@ -0,0 +1,7 @@ +PermissionGrantData | DWN-SDK Documentation - v0.5.1

Type Alias PermissionGrantData

PermissionGrantData: {
    conditions?: PermissionConditions;
    dateExpires: string;
    delegated?: boolean;
    description?: string;
    requestId?: string;
    scope: PermissionScope;
}

Type for the data payload of a permission grant message.

+

Type declaration

  • Optionalconditions?: PermissionConditions
  • dateExpires: string

    Timestamp at which this grant will no longer be active.

    +
  • Optionaldelegated?: boolean

    Whether this grant is delegated or not. If true, the grantedTo will be able to act as the grantedTo within the scope of this grant.

    +
  • Optionaldescription?: string

    Optional string that communicates what the grant would be used for

    +
  • OptionalrequestId?: string

    Optional CID of a permission request. This is optional because grants may be given without being officially requested

    +
  • scope: PermissionScope

    The scope of the allowed access.

    +
diff --git a/types/PermissionRequestData.html b/types/PermissionRequestData.html new file mode 100644 index 000000000..cbf8c35f6 --- /dev/null +++ b/types/PermissionRequestData.html @@ -0,0 +1,5 @@ +PermissionRequestData | DWN-SDK Documentation - v0.5.1

Type Alias PermissionRequestData

PermissionRequestData: {
    conditions?: PermissionConditions;
    delegated: boolean;
    description?: string;
    scope: PermissionScope;
}

Type for the data payload of a permission request message.

+

Type declaration

  • Optionalconditions?: PermissionConditions
  • delegated: boolean

    If the grant is a delegated grant or not. If true, the grantedTo will be able to act as the grantedBy within the scope of this grant.

    +
  • Optionaldescription?: string

    Optional string that communicates what the grant would be used for.

    +
  • scope: PermissionScope

    The scope of the allowed access.

    +
diff --git a/types/PermissionRevocationData.html b/types/PermissionRevocationData.html new file mode 100644 index 000000000..337656eb0 --- /dev/null +++ b/types/PermissionRevocationData.html @@ -0,0 +1,3 @@ +PermissionRevocationData | DWN-SDK Documentation - v0.5.1

Type Alias PermissionRevocationData

PermissionRevocationData: {
    description?: string;
}

Type for the data payload of a permission revocation message.

+

Type declaration

  • Optionaldescription?: string

    Optional string that communicates the details of the revocation.

    +
diff --git a/types/PermissionScope.html b/types/PermissionScope.html new file mode 100644 index 000000000..0495128f6 --- /dev/null +++ b/types/PermissionScope.html @@ -0,0 +1,2 @@ +PermissionScope | DWN-SDK Documentation - v0.5.1

Type Alias PermissionScope

The data model for a permission scope.

+
diff --git a/types/Persona.html b/types/Persona.html new file mode 100644 index 000000000..ef3b6fdaa --- /dev/null +++ b/types/Persona.html @@ -0,0 +1,2 @@ +Persona | DWN-SDK Documentation - v0.5.1
Persona: {
    did: string;
    keyId: string;
    keyPair: {
        privateJwk: PrivateJwk;
        publicJwk: PublicJwk;
    };
    signer: Signer;
}

A logical grouping of user data used to generate test messages.

+
diff --git a/types/PrivateJwk.html b/types/PrivateJwk.html new file mode 100644 index 000000000..1e27ded4d --- /dev/null +++ b/types/PrivateJwk.html @@ -0,0 +1,4 @@ +PrivateJwk | DWN-SDK Documentation - v0.5.1

Type Alias PrivateJwk

PrivateJwk: PublicJwk & {
    d: string;
}

Type declaration

  • d: string

    the Elliptic Curve private key value. +It is represented as the base64url encoding of the octet string representation of the private key value +MUST be present to represent Elliptic Curve private keys.

    +
diff --git a/types/ProtocolDefinition.html b/types/ProtocolDefinition.html new file mode 100644 index 000000000..f470ac962 --- /dev/null +++ b/types/ProtocolDefinition.html @@ -0,0 +1,2 @@ +ProtocolDefinition | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolDefinition

ProtocolDefinition: {
    protocol: string;
    published: boolean;
    structure: {
        [key: string]: ProtocolRuleSet;
    };
    types: ProtocolTypes;
}

Type declaration

  • protocol: string
  • published: boolean

    Denotes if this Protocol Definition can be returned by unauthenticated or unauthorized ProtocolsQuery.

    +
  • structure: {
        [key: string]: ProtocolRuleSet;
    }
  • types: ProtocolTypes
diff --git a/types/ProtocolPermissionScope.html b/types/ProtocolPermissionScope.html new file mode 100644 index 000000000..657a30068 --- /dev/null +++ b/types/ProtocolPermissionScope.html @@ -0,0 +1 @@ +ProtocolPermissionScope | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolPermissionScope

ProtocolPermissionScope: {
    interface: Protocols;
    method: Configure | Query;
    protocol?: string;
}
diff --git a/types/ProtocolRuleSet.html b/types/ProtocolRuleSet.html new file mode 100644 index 000000000..5f8c5c231 --- /dev/null +++ b/types/ProtocolRuleSet.html @@ -0,0 +1,8 @@ +ProtocolRuleSet | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolRuleSet

ProtocolRuleSet: {
    $actions?: ProtocolActionRule[];
    $encryption?: ProtocolPathEncryption;
    $role?: boolean;
    $size?: {
        max?: number;
        min?: number;
    };
    $tags?: {
        $allowUndefinedTags?: boolean;
        $requiredTags?: string[];
        [key: string]: any;
    };
    [key: string]: any;
}

Type declaration

  • [key: string]: any
  • Optional$actions?: ProtocolActionRule[]
  • Optional$encryption?: ProtocolPathEncryption

    Encryption setting for objects that are in this protocol path.

    +
  • Optional$role?: boolean

    If true, this marks a record as a role that may used within a context. +The recipient of a $role record may invoke their role by setting protocolRole property to the protocol path of the $role record.

    +
  • Optional$size?: {
        max?: number;
        min?: number;
    }

    If $size is set, the record size in bytes must be within the limits.

    +
    • Optionalmax?: number
    • Optionalmin?: number
  • Optional$tags?: {
        $allowUndefinedTags?: boolean;
        $requiredTags?: string[];
        [key: string]: any;
    }

    If $tags is set, the record must conform to the tag rules.

    +
    • [key: string]: any
    • Optional$allowUndefinedTags?: boolean

      allow properties other than those explicitly listed. defaults to false

      +
    • Optional$requiredTags?: string[]

      array of required tags

      +
diff --git a/types/ProtocolTypes.html b/types/ProtocolTypes.html new file mode 100644 index 000000000..37399072f --- /dev/null +++ b/types/ProtocolTypes.html @@ -0,0 +1 @@ +ProtocolTypes | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolTypes

ProtocolTypes: {
    [key: string]: ProtocolType;
}
diff --git a/types/ProtocolsConfigureDescriptor.html b/types/ProtocolsConfigureDescriptor.html new file mode 100644 index 000000000..e7eebbe41 --- /dev/null +++ b/types/ProtocolsConfigureDescriptor.html @@ -0,0 +1 @@ +ProtocolsConfigureDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsConfigureDescriptor

ProtocolsConfigureDescriptor: {
    definition: ProtocolDefinition;
    interface: Protocols;
    messageTimestamp: string;
    method: Configure;
}
diff --git a/types/ProtocolsConfigureMessage.html b/types/ProtocolsConfigureMessage.html new file mode 100644 index 000000000..1110bf2f0 --- /dev/null +++ b/types/ProtocolsConfigureMessage.html @@ -0,0 +1 @@ +ProtocolsConfigureMessage | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsConfigureMessage

ProtocolsConfigureMessage: GenericMessage & {
    authorization: AuthorizationModel;
    descriptor: ProtocolsConfigureDescriptor;
}
diff --git a/types/ProtocolsConfigureOptions.html b/types/ProtocolsConfigureOptions.html new file mode 100644 index 000000000..48c4a320c --- /dev/null +++ b/types/ProtocolsConfigureOptions.html @@ -0,0 +1,2 @@ +ProtocolsConfigureOptions | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsConfigureOptions

ProtocolsConfigureOptions: {
    definition: ProtocolDefinition;
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    messageTimestamp?: string;
    permissionGrantId?: string;
    signer: Signer;
}

Type declaration

  • definition: ProtocolDefinition
  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant invoked to sign on behalf of the logical author, which is the grantor of the delegated grant.

    +
  • OptionalmessageTimestamp?: string
  • OptionalpermissionGrantId?: string
  • signer: Signer
diff --git a/types/ProtocolsQueryFilter.html b/types/ProtocolsQueryFilter.html new file mode 100644 index 000000000..c28b69bf6 --- /dev/null +++ b/types/ProtocolsQueryFilter.html @@ -0,0 +1 @@ +ProtocolsQueryFilter | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsQueryFilter

ProtocolsQueryFilter: {
    protocol: string;
}
diff --git a/types/ProtocolsQueryMessage.html b/types/ProtocolsQueryMessage.html new file mode 100644 index 000000000..a67254ae8 --- /dev/null +++ b/types/ProtocolsQueryMessage.html @@ -0,0 +1 @@ +ProtocolsQueryMessage | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsQueryMessage

ProtocolsQueryMessage: GenericMessage & {
    descriptor: ProtocolsQueryDescriptor;
}
diff --git a/types/ProtocolsQueryOptions.html b/types/ProtocolsQueryOptions.html new file mode 100644 index 000000000..86c882bbf --- /dev/null +++ b/types/ProtocolsQueryOptions.html @@ -0,0 +1 @@ +ProtocolsQueryOptions | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsQueryOptions

ProtocolsQueryOptions: {
    filter?: ProtocolsQueryFilter;
    messageTimestamp?: string;
    permissionGrantId?: string;
    signer?: Signer;
}
diff --git a/types/ProtocolsQueryReply.html b/types/ProtocolsQueryReply.html new file mode 100644 index 000000000..ec09803c7 --- /dev/null +++ b/types/ProtocolsQueryReply.html @@ -0,0 +1 @@ +ProtocolsQueryReply | DWN-SDK Documentation - v0.5.1

Type Alias ProtocolsQueryReply

ProtocolsQueryReply: GenericMessageReply & {
    entries?: ProtocolsConfigureMessage[];
}
diff --git a/types/PublicJwk.html b/types/PublicJwk.html new file mode 100644 index 000000000..9cf639221 --- /dev/null +++ b/types/PublicJwk.html @@ -0,0 +1,8 @@ +PublicJwk | DWN-SDK Documentation - v0.5.1

Type Alias PublicJwk

PublicJwk: Jwk & {
    crv: "Ed25519" | "secp256k1" | "P-256";
    x: string;
    y?: string;
}

Type declaration

  • crv: "Ed25519" | "secp256k1" | "P-256"

    The "crv" (curve) parameter identifies the cryptographic curve used with the key. +MUST be present for all EC public keys

    +
  • x: string

    the x coordinate for the Elliptic Curve point. +Represented as the base64url encoding of the octet string representation of the coordinate. +MUST be present for all EC public keys

    +
  • Optionaly?: string

    the y coordinate for the Elliptic Curve point. +Represented as the base64url encoding of the octet string representation of the coordinate.

    +
diff --git a/types/QueryOptions.html b/types/QueryOptions.html new file mode 100644 index 000000000..bdefc1047 --- /dev/null +++ b/types/QueryOptions.html @@ -0,0 +1 @@ +QueryOptions | DWN-SDK Documentation - v0.5.1

Type Alias QueryOptions

QueryOptions: {
    cursor?: PaginationCursor;
    limit?: number;
    sortDirection?: SortDirection;
    sortProperty: string;
}
diff --git a/types/QueryResultEntry.html b/types/QueryResultEntry.html new file mode 100644 index 000000000..e0ca4bd15 --- /dev/null +++ b/types/QueryResultEntry.html @@ -0,0 +1,6 @@ +QueryResultEntry | DWN-SDK Documentation - v0.5.1

Type Alias QueryResultEntry

QueryResultEntry: GenericMessage & {
    encodedData?: string;
}

Message returned in a query result. +NOTE: the message structure is a modified version of the message received, the most notable differences are:

+
    +
  1. May include encoded data
  2. +
+
diff --git a/types/RangeCriterion.html b/types/RangeCriterion.html new file mode 100644 index 000000000..b7c5ae0bd --- /dev/null +++ b/types/RangeCriterion.html @@ -0,0 +1,3 @@ +RangeCriterion | DWN-SDK Documentation - v0.5.1

Type Alias RangeCriterion

RangeCriterion: {
    from?: string;
    to?: string;
}

Type declaration

  • Optionalfrom?: string

    Inclusive starting date-time.

    +
  • Optionalto?: string

    Inclusive end date-time.

    +
diff --git a/types/RangeFilter.html b/types/RangeFilter.html new file mode 100644 index 000000000..6fb117925 --- /dev/null +++ b/types/RangeFilter.html @@ -0,0 +1,2 @@ +RangeFilter | DWN-SDK Documentation - v0.5.1

Type Alias RangeFilter

RangeFilter: (GT | LT) & Partial<GT> & Partial<LT>

Ranger filter. 1 condition is required.

+
diff --git a/types/RecordEvent.html b/types/RecordEvent.html new file mode 100644 index 000000000..b5f23379a --- /dev/null +++ b/types/RecordEvent.html @@ -0,0 +1 @@ +RecordEvent | DWN-SDK Documentation - v0.5.1

Type Alias RecordEvent

RecordEvent: {
    initialWrite?: RecordsWriteMessage;
    message: RecordsWriteMessage | RecordsDeleteMessage;
}
diff --git a/types/RecordSubscriptionHandler.html b/types/RecordSubscriptionHandler.html new file mode 100644 index 000000000..db98547ed --- /dev/null +++ b/types/RecordSubscriptionHandler.html @@ -0,0 +1 @@ +RecordSubscriptionHandler | DWN-SDK Documentation - v0.5.1

Type Alias RecordSubscriptionHandler

RecordSubscriptionHandler: ((event: RecordEvent) => void)
diff --git a/types/RecordsDeleteDescriptor.html b/types/RecordsDeleteDescriptor.html new file mode 100644 index 000000000..cd2aa7597 --- /dev/null +++ b/types/RecordsDeleteDescriptor.html @@ -0,0 +1,2 @@ +RecordsDeleteDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias RecordsDeleteDescriptor

RecordsDeleteDescriptor: {
    interface: Records;
    messageTimestamp: string;
    method: Delete;
    prune: boolean;
    recordId: string;
}

Type declaration

  • interface: Records
  • messageTimestamp: string
  • method: Delete
  • prune: boolean

    Denotes if all the descendent records should be purged.

    +
  • recordId: string
diff --git a/types/RecordsDeleteMessage.html b/types/RecordsDeleteMessage.html new file mode 100644 index 000000000..abb91c11c --- /dev/null +++ b/types/RecordsDeleteMessage.html @@ -0,0 +1 @@ +RecordsDeleteMessage | DWN-SDK Documentation - v0.5.1

Type Alias RecordsDeleteMessage

RecordsDeleteMessage: GenericMessage & {
    authorization: AuthorizationModel;
    descriptor: RecordsDeleteDescriptor;
}
diff --git a/types/RecordsDeleteOptions.html b/types/RecordsDeleteOptions.html new file mode 100644 index 000000000..8658f9321 --- /dev/null +++ b/types/RecordsDeleteOptions.html @@ -0,0 +1,3 @@ +RecordsDeleteOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsDeleteOptions

RecordsDeleteOptions: {
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    messageTimestamp?: string;
    protocolRole?: string;
    prune?: boolean;
    recordId: string;
    signer: Signer;
}

Type declaration

  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant to sign on behalf of the logical author, which is the grantor (grantedBy) of the delegated grant.

    +
  • OptionalmessageTimestamp?: string
  • OptionalprotocolRole?: string
  • Optionalprune?: boolean

    Denotes if all the descendent records should be purged. Defaults to false.

    +
  • recordId: string
  • signer: Signer
diff --git a/types/RecordsFilter.html b/types/RecordsFilter.html new file mode 100644 index 000000000..b036f168e --- /dev/null +++ b/types/RecordsFilter.html @@ -0,0 +1,3 @@ +RecordsFilter | DWN-SDK Documentation - v0.5.1

Type Alias RecordsFilter

RecordsFilter: {
    attester?: string;
    author?: string | string[];
    contextId?: string;
    dataCid?: string;
    dataFormat?: string;
    dataSize?: RangeFilter;
    dateCreated?: RangeCriterion;
    datePublished?: RangeCriterion;
    dateUpdated?: RangeCriterion;
    parentId?: string;
    protocol?: string;
    protocolPath?: string;
    published?: boolean;
    recipient?: string | string[];
    recordId?: string;
    schema?: string;
    tags?: {
        [property: string]: RecordsWriteTagsFilter;
    };
}

Type declaration

  • Optionalattester?: string
  • Optionalauthor?: string | string[]

    The logical author of the record

    +
  • OptionalcontextId?: string

    When given all Records message under the context of the given contextId will be returned.

    +
  • OptionaldataCid?: string
  • OptionaldataFormat?: string
  • OptionaldataSize?: RangeFilter
  • OptionaldateCreated?: RangeCriterion
  • OptionaldatePublished?: RangeCriterion
  • OptionaldateUpdated?: RangeCriterion
  • OptionalparentId?: string
  • Optionalprotocol?: string
  • OptionalprotocolPath?: string
  • Optionalpublished?: boolean
  • Optionalrecipient?: string | string[]
  • OptionalrecordId?: string
  • Optionalschema?: string
  • Optionaltags?: {
        [property: string]: RecordsWriteTagsFilter;
    }
diff --git a/types/RecordsPermissionScope.html b/types/RecordsPermissionScope.html new file mode 100644 index 000000000..c9c89ebb8 --- /dev/null +++ b/types/RecordsPermissionScope.html @@ -0,0 +1,4 @@ +RecordsPermissionScope | DWN-SDK Documentation - v0.5.1

Type Alias RecordsPermissionScope

RecordsPermissionScope: {
    contextId?: string;
    interface: Records;
    method:
        | Read
        | Write
        | Query
        | Subscribe
        | Delete;
    protocol: string;
    protocolPath?: string;
}

The data model for a permission scope that is specific to the Records interface.

+

Type declaration

  • OptionalcontextId?: string

    May only be present when protocol is defined and protocolPath is undefined

    +
  • interface: Records
  • method:
        | Read
        | Write
        | Query
        | Subscribe
        | Delete
  • protocol: string
  • OptionalprotocolPath?: string

    May only be present when protocol is defined and contextId is undefined

    +
diff --git a/types/RecordsQueryDescriptor.html b/types/RecordsQueryDescriptor.html new file mode 100644 index 000000000..9d4436896 --- /dev/null +++ b/types/RecordsQueryDescriptor.html @@ -0,0 +1 @@ +RecordsQueryDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias RecordsQueryDescriptor

RecordsQueryDescriptor: {
    dateSort?: DateSort;
    filter: RecordsFilter;
    interface: Records;
    messageTimestamp: string;
    method: Query;
    pagination?: Pagination;
}
diff --git a/types/RecordsQueryMessage.html b/types/RecordsQueryMessage.html new file mode 100644 index 000000000..c2e60460e --- /dev/null +++ b/types/RecordsQueryMessage.html @@ -0,0 +1 @@ +RecordsQueryMessage | DWN-SDK Documentation - v0.5.1

Type Alias RecordsQueryMessage

RecordsQueryMessage: GenericMessage & {
    descriptor: RecordsQueryDescriptor;
}
diff --git a/types/RecordsQueryOptions.html b/types/RecordsQueryOptions.html new file mode 100644 index 000000000..7611b25c9 --- /dev/null +++ b/types/RecordsQueryOptions.html @@ -0,0 +1,2 @@ +RecordsQueryOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsQueryOptions

RecordsQueryOptions: {
    dateSort?: DateSort;
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    filter: RecordsFilter;
    messageTimestamp?: string;
    pagination?: Pagination;
    protocolRole?: string;
    signer?: Signer;
}

Type declaration

  • OptionaldateSort?: DateSort
  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant to sign on behalf of the logical author, which is the grantor (grantedBy) of the delegated grant.

    +
  • filter: RecordsFilter
  • OptionalmessageTimestamp?: string
  • Optionalpagination?: Pagination
  • OptionalprotocolRole?: string
  • Optionalsigner?: Signer
diff --git a/types/RecordsQueryReply.html b/types/RecordsQueryReply.html new file mode 100644 index 000000000..c65e6b736 --- /dev/null +++ b/types/RecordsQueryReply.html @@ -0,0 +1 @@ +RecordsQueryReply | DWN-SDK Documentation - v0.5.1

Type Alias RecordsQueryReply

RecordsQueryReply: GenericMessageReply & {
    cursor?: PaginationCursor;
    entries?: RecordsQueryReplyEntry[];
}
diff --git a/types/RecordsQueryReplyEntry.html b/types/RecordsQueryReplyEntry.html new file mode 100644 index 000000000..631e42fc0 --- /dev/null +++ b/types/RecordsQueryReplyEntry.html @@ -0,0 +1,9 @@ +RecordsQueryReplyEntry | DWN-SDK Documentation - v0.5.1

Type Alias RecordsQueryReplyEntry

RecordsQueryReplyEntry: RecordsWriteMessage & {
    encodedData?: string;
    initialWrite?: RecordsWriteMessage;
}

Data structure returned in a RecordsQuery reply entry. +NOTE: the message structure is a modified version of the message received, the most notable differences are:

+
    +
  1. May include an initial RecordsWrite message
  2. +
  3. May include encoded data
  4. +
+

Type declaration

  • OptionalencodedData?: string

    The encoded data of the record if the data associated with the record is equal or smaller than DwnConstant.maxDataSizeAllowedToBeEncoded.

    +
  • OptionalinitialWrite?: RecordsWriteMessage

    The initial write of the record if the returned RecordsWrite message itself is not the initial write.

    +
diff --git a/types/RecordsReadDescriptor.html b/types/RecordsReadDescriptor.html new file mode 100644 index 000000000..63a544905 --- /dev/null +++ b/types/RecordsReadDescriptor.html @@ -0,0 +1 @@ +RecordsReadDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias RecordsReadDescriptor

RecordsReadDescriptor: {
    filter: RecordsFilter;
    interface: Records;
    messageTimestamp: string;
    method: Read;
}
diff --git a/types/RecordsReadMessage.html b/types/RecordsReadMessage.html new file mode 100644 index 000000000..78352c0d4 --- /dev/null +++ b/types/RecordsReadMessage.html @@ -0,0 +1 @@ +RecordsReadMessage | DWN-SDK Documentation - v0.5.1

Type Alias RecordsReadMessage

RecordsReadMessage: {
    authorization?: AuthorizationModel;
    descriptor: RecordsReadDescriptor;
}
diff --git a/types/RecordsReadOptions.html b/types/RecordsReadOptions.html new file mode 100644 index 000000000..73eb29e8e --- /dev/null +++ b/types/RecordsReadOptions.html @@ -0,0 +1,4 @@ +RecordsReadOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsReadOptions

RecordsReadOptions: {
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    filter: RecordsFilter;
    messageTimestamp?: string;
    permissionGrantId?: string;
    protocolRole?: string;
    signer?: Signer;
}

Type declaration

  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant to sign on behalf of the logical author, which is the grantor (grantedBy) of the delegated grant.

    +
  • filter: RecordsFilter
  • OptionalmessageTimestamp?: string
  • OptionalpermissionGrantId?: string
  • OptionalprotocolRole?: string

    Used when authorizing protocol records. +The protocol path to the role record type whose recipient is the author of this RecordsRead

    +
  • Optionalsigner?: Signer
diff --git a/types/RecordsReadReply.html b/types/RecordsReadReply.html new file mode 100644 index 000000000..6e9889be3 --- /dev/null +++ b/types/RecordsReadReply.html @@ -0,0 +1,4 @@ +RecordsReadReply | DWN-SDK Documentation - v0.5.1

Type Alias RecordsReadReply

RecordsReadReply: GenericMessageReply & {
    entry?: RecordsReadReplyEntry;
}

The reply to a RecordsRead message.

+

Type declaration

  • Optionalentry?: RecordsReadReplyEntry

    A container for the data returned from a RecordsRead. +undefined if no data needs to be returned.

    +
diff --git a/types/RecordsReadReplyEntry.html b/types/RecordsReadReplyEntry.html new file mode 100644 index 000000000..85563654d --- /dev/null +++ b/types/RecordsReadReplyEntry.html @@ -0,0 +1,6 @@ +RecordsReadReplyEntry | DWN-SDK Documentation - v0.5.1

Type Alias RecordsReadReplyEntry

RecordsReadReplyEntry: {
    data?: Readable;
    initialWrite?: RecordsWriteMessage;
    recordsDelete?: RecordsDeleteMessage;
    recordsWrite?: RecordsWriteMessage;
}

The structure of the entry container property in RecordsReadReplyEntry.

+

Type declaration

  • Optionaldata?: Readable

    The data stream associated with the record if the records exists (not deleted).

    +
  • OptionalinitialWrite?: RecordsWriteMessage

    The initial write of the record if the returned RecordsWrite message itself is not the initial write or if a RecordsDelete is returned.

    +
  • OptionalrecordsDelete?: RecordsDeleteMessage

    The RecordsDelete if the record is deleted.

    +
  • OptionalrecordsWrite?: RecordsWriteMessage

    The latest RecordsWrite message of the record if record exists (not deleted).

    +
diff --git a/types/RecordsSubscribeDescriptor.html b/types/RecordsSubscribeDescriptor.html new file mode 100644 index 000000000..537a1a8d8 --- /dev/null +++ b/types/RecordsSubscribeDescriptor.html @@ -0,0 +1 @@ +RecordsSubscribeDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias RecordsSubscribeDescriptor

RecordsSubscribeDescriptor: {
    filter: RecordsFilter;
    interface: Records;
    messageTimestamp: string;
    method: Subscribe;
}
diff --git a/types/RecordsSubscribeMessage.html b/types/RecordsSubscribeMessage.html new file mode 100644 index 000000000..820f78b1f --- /dev/null +++ b/types/RecordsSubscribeMessage.html @@ -0,0 +1 @@ +RecordsSubscribeMessage | DWN-SDK Documentation - v0.5.1

Type Alias RecordsSubscribeMessage

RecordsSubscribeMessage: GenericMessage & {
    descriptor: RecordsSubscribeDescriptor;
}
diff --git a/types/RecordsSubscribeMessageOptions.html b/types/RecordsSubscribeMessageOptions.html new file mode 100644 index 000000000..5eebb9385 --- /dev/null +++ b/types/RecordsSubscribeMessageOptions.html @@ -0,0 +1 @@ +RecordsSubscribeMessageOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsSubscribeMessageOptions

RecordsSubscribeMessageOptions: {
    subscriptionHandler: RecordSubscriptionHandler;
}
diff --git a/types/RecordsSubscribeOptions.html b/types/RecordsSubscribeOptions.html new file mode 100644 index 000000000..e82a673dd --- /dev/null +++ b/types/RecordsSubscribeOptions.html @@ -0,0 +1,2 @@ +RecordsSubscribeOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsSubscribeOptions

RecordsSubscribeOptions: {
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    filter: RecordsFilter;
    messageTimestamp?: string;
    protocolRole?: string;
    signer?: Signer;
}

Type declaration

  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant to sign on behalf of the logical author, which is the grantor (grantedBy) of the delegated grant.

    +
  • filter: RecordsFilter
  • OptionalmessageTimestamp?: string
  • OptionalprotocolRole?: string
  • Optionalsigner?: Signer
diff --git a/types/RecordsSubscribeReply.html b/types/RecordsSubscribeReply.html new file mode 100644 index 000000000..1e22666b5 --- /dev/null +++ b/types/RecordsSubscribeReply.html @@ -0,0 +1 @@ +RecordsSubscribeReply | DWN-SDK Documentation - v0.5.1

Type Alias RecordsSubscribeReply

RecordsSubscribeReply: GenericMessageReply & {
    subscription?: MessageSubscription;
}
diff --git a/types/RecordsWriteAttestationPayload.html b/types/RecordsWriteAttestationPayload.html new file mode 100644 index 000000000..e135810a9 --- /dev/null +++ b/types/RecordsWriteAttestationPayload.html @@ -0,0 +1 @@ +RecordsWriteAttestationPayload | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteAttestationPayload

RecordsWriteAttestationPayload: {
    descriptorCid: string;
}
diff --git a/types/RecordsWriteDescriptor.html b/types/RecordsWriteDescriptor.html new file mode 100644 index 000000000..75fef6128 --- /dev/null +++ b/types/RecordsWriteDescriptor.html @@ -0,0 +1 @@ +RecordsWriteDescriptor | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteDescriptor

RecordsWriteDescriptor: {
    dataCid: string;
    dataFormat: string;
    dataSize: number;
    dateCreated: string;
    datePublished?: string;
    interface: Records;
    messageTimestamp: string;
    method: Write;
    parentId?: string;
    protocol?: string;
    protocolPath?: string;
    published?: boolean;
    recipient?: string;
    schema?: string;
    tags?: RecordsWriteTags;
}
diff --git a/types/RecordsWriteMessage.html b/types/RecordsWriteMessage.html new file mode 100644 index 000000000..7ccbd4b91 --- /dev/null +++ b/types/RecordsWriteMessage.html @@ -0,0 +1 @@ +RecordsWriteMessage | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteMessage

RecordsWriteMessage: {
    attestation?: GeneralJws;
    authorization: AuthorizationModel;
    contextId?: string;
    descriptor: RecordsWriteDescriptor;
    encryption?: EncryptionProperty;
    recordId: string;
}
diff --git a/types/RecordsWriteMessageOptions.html b/types/RecordsWriteMessageOptions.html new file mode 100644 index 000000000..336bb831e --- /dev/null +++ b/types/RecordsWriteMessageOptions.html @@ -0,0 +1 @@ +RecordsWriteMessageOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteMessageOptions

RecordsWriteMessageOptions: {
    dataStream?: Readable;
}
diff --git a/types/RecordsWriteOptions.html b/types/RecordsWriteOptions.html new file mode 100644 index 000000000..05b52bd8b --- /dev/null +++ b/types/RecordsWriteOptions.html @@ -0,0 +1,5 @@ +RecordsWriteOptions | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteOptions

RecordsWriteOptions: {
    attestationSigners?: Signer[];
    data?: Uint8Array;
    dataCid?: string;
    dataFormat: string;
    dataSize?: number;
    dateCreated?: string;
    datePublished?: string;
    delegatedGrant?: DataEncodedRecordsWriteMessage;
    encryptionInput?: EncryptionInput;
    messageTimestamp?: string;
    parentContextId?: string;
    permissionGrantId?: string;
    protocol?: string;
    protocolPath?: string;
    protocolRole?: string;
    published?: boolean;
    recipient?: string;
    recordId?: string;
    schema?: string;
    signer?: Signer;
    tags?: RecordsWriteTags;
}

Type declaration

  • OptionalattestationSigners?: Signer[]
  • Optionaldata?: Uint8Array
  • OptionaldataCid?: string
  • dataFormat: string
  • OptionaldataSize?: number
  • OptionaldateCreated?: string
  • OptionaldatePublished?: string
  • OptionaldelegatedGrant?: DataEncodedRecordsWriteMessage

    The delegated grant invoked to sign on behalf of the logical author, which is the grantor of the delegated grant.

    +
  • OptionalencryptionInput?: EncryptionInput
  • OptionalmessageTimestamp?: string
  • OptionalparentContextId?: string

    Must be given if this message is for a non-root protocol record. +If not given, it either means this write is for a root protocol record or a flat-space record.

    +
  • OptionalpermissionGrantId?: string
  • Optionalprotocol?: string
  • OptionalprotocolPath?: string
  • OptionalprotocolRole?: string
  • Optionalpublished?: boolean
  • Optionalrecipient?: string
  • OptionalrecordId?: string
  • Optionalschema?: string
  • Optionalsigner?: Signer

    The signer of the message, which is commonly the author, but can also be a delegate.

    +
  • Optionaltags?: RecordsWriteTags
diff --git a/types/RecordsWriteSignaturePayload.html b/types/RecordsWriteSignaturePayload.html new file mode 100644 index 000000000..c4cc3a06a --- /dev/null +++ b/types/RecordsWriteSignaturePayload.html @@ -0,0 +1 @@ +RecordsWriteSignaturePayload | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteSignaturePayload

RecordsWriteSignaturePayload: GenericSignaturePayload & {
    attestationCid?: string;
    contextId?: string;
    encryptionCid?: string;
    recordId: string;
}
diff --git a/types/RecordsWriteTagValue.html b/types/RecordsWriteTagValue.html new file mode 100644 index 000000000..e6dfa4049 --- /dev/null +++ b/types/RecordsWriteTagValue.html @@ -0,0 +1 @@ +RecordsWriteTagValue | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteTagValue

RecordsWriteTagValue:
    | string
    | number
    | boolean
    | string[]
    | number[]
diff --git a/types/RecordsWriteTags.html b/types/RecordsWriteTags.html new file mode 100644 index 000000000..1a591c8a1 --- /dev/null +++ b/types/RecordsWriteTags.html @@ -0,0 +1 @@ +RecordsWriteTags | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteTags

RecordsWriteTags: {
    [property: string]: RecordsWriteTagValue;
}
diff --git a/types/RecordsWriteTagsFilter.html b/types/RecordsWriteTagsFilter.html new file mode 100644 index 000000000..dddcb9fcd --- /dev/null +++ b/types/RecordsWriteTagsFilter.html @@ -0,0 +1 @@ +RecordsWriteTagsFilter | DWN-SDK Documentation - v0.5.1

Type Alias RecordsWriteTagsFilter

RecordsWriteTagsFilter:
    | StartsWithFilter
    | RangeFilter
    | string
    | number
    | boolean
diff --git a/types/SubscriptionReply.html b/types/SubscriptionReply.html new file mode 100644 index 000000000..5fa258efc --- /dev/null +++ b/types/SubscriptionReply.html @@ -0,0 +1 @@ +SubscriptionReply | DWN-SDK Documentation - v0.5.1

Type Alias SubscriptionReply

SubscriptionReply: GenericMessageReply & {
    subscription?: MessageSubscription;
}
diff --git a/types/UnionMessageReply.html b/types/UnionMessageReply.html new file mode 100644 index 000000000..a5bceb2a9 --- /dev/null +++ b/types/UnionMessageReply.html @@ -0,0 +1,10 @@ +UnionMessageReply | DWN-SDK Documentation - v0.5.1

Type Alias UnionMessageReply

UnionMessageReply: GenericMessageReply & {
    cursor?: PaginationCursor;
    entries?: QueryResultEntry[] | ProtocolsConfigureMessage[] | string[];
    entry?: MessagesReadReplyEntry & RecordsReadReplyEntry;
    subscription?: MessageSubscription;
}

Catch-all message reply type. It is recommended to use GenericMessageReply or a message-specific reply type wherever possible.

+

Type declaration

  • Optionalcursor?: PaginationCursor

    A cursor for pagination if applicable (e.g. RecordsQuery). +Mutually exclusive with record.

    +
  • Optionalentries?: QueryResultEntry[] | ProtocolsConfigureMessage[] | string[]

    Resulting message entries or events returned from the invocation of the corresponding message. +e.g. the resulting messages from a RecordsQuery, or array of messageCid strings for MessagesQuery +Mutually exclusive with record.

    +
  • Optionalentry?: MessagesReadReplyEntry & RecordsReadReplyEntry

    A container for the data returned from a RecordsRead or MessagesRead. +Mutually exclusive with (entries + cursor) and subscription.

    +
  • Optionalsubscription?: MessageSubscription

    A subscription object if a subscription was requested.

    +