This commit is contained in:
Firstyear 2021-07-27 03:24:42 +00:00
parent 65e11367b2
commit 1b016fa4ae
12 changed files with 1417 additions and 100 deletions

View file

@ -108,9 +108,12 @@ function playground_text(playground) {
let text = playground_text(code_block); let text = playground_text(code_block);
let classes = code_block.querySelector('code').classList; let classes = code_block.querySelector('code').classList;
let has_2018 = classes.contains("edition2018"); let edition = "2015";
let edition = has_2018 ? "2018" : "2015"; if(classes.contains("edition2018")) {
edition = "2018";
} else if(classes.contains("edition2021")) {
edition = "2021";
}
var params = { var params = {
version: "stable", version: "stable",
optimize: "0", optimize: "0",
@ -133,7 +136,15 @@ function playground_text(playground) {
body: JSON.stringify(params) body: JSON.stringify(params)
}) })
.then(response => response.json()) .then(response => response.json())
.then(response => result_block.innerText = response.result) .then(response => {
if (response.result.trim() === '') {
result_block.innerText = "No output";
result_block.classList.add("result-no-output");
} else {
result_block.innerText = response.result;
result_block.classList.remove("result-no-output");
}
})
.catch(error => result_block.innerText = "Playground Communication: " + error.message); .catch(error => result_block.innerText = "Playground Communication: " + error.message);
} }
@ -151,15 +162,16 @@ function playground_text(playground) {
if (window.ace) { if (window.ace) {
// language-rust class needs to be removed for editable // language-rust class needs to be removed for editable
// blocks or highlightjs will capture events // blocks or highlightjs will capture events
Array code_nodes
.from(document.querySelectorAll('code.editable')) .filter(function (node) {return node.classList.contains("editable"); })
.forEach(function (block) { block.classList.remove('language-rust'); }); .forEach(function (block) { block.classList.remove('language-rust'); });
Array Array
.from(document.querySelectorAll('code:not(.editable)')) code_nodes
.forEach(function (block) { hljs.highlightBlock(block); }); .filter(function (node) {return !node.classList.contains("editable"); })
.forEach(function (block) { hljs.highlightElement(block); });
} else { } else {
code_nodes.forEach(function (block) { hljs.highlightBlock(block); }); code_nodes.forEach(function (block) { hljs.highlightElement(block); });
} }
// Adding the hljs class gives code blocks the color css // Adding the hljs class gives code blocks the color css

View file

@ -175,3 +175,7 @@ blockquote {
margin: 5px 0px; margin: 5px 0px;
font-weight: bold; font-weight: bold;
} }
.result-no-output {
font-style: italic;
}

File diff suppressed because one or more lines are too long

View file

@ -1,7 +1,7 @@
<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="The backend. This contains the “low level” storage and query code, which is implemented as a json-like kv document database. This has no rules about content of the server, which are all enforced at higher levels. The role of the backend is to persist content safely to disk, load that content, and execute queries utilising indexes in the most effective way possible."><meta name="keywords" content="rust, rustlang, rust-lang, be"><title>kanidm::be - Rust</title><link rel="stylesheet" type="text/css" href="../../normalize.css"><link rel="stylesheet" type="text/css" href="../../rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="../../light.css" id="themeStyle"><link rel="stylesheet" type="text/css" href="../../dark.css" disabled ><link rel="stylesheet" type="text/css" href="../../ayu.css" disabled ><script id="default-settings"></script><script src="../../storage.js"></script><script src="../../crates.js"></script><noscript><link rel="stylesheet" href="../../noscript.css"></noscript><link rel="icon" type="image/svg+xml" href="../../favicon.svg"> <!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="The backend. This contains the “low level” storage and query code, which is implemented as a json-like kv document database. This has no rules about content of the server, which are all enforced at higher levels. The role of the backend is to persist content safely to disk, load that content, and execute queries utilising indexes in the most effective way possible."><meta name="keywords" content="rust, rustlang, rust-lang, be"><title>kanidm::be - Rust</title><link rel="stylesheet" type="text/css" href="../../normalize.css"><link rel="stylesheet" type="text/css" href="../../rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="../../light.css" id="themeStyle"><link rel="stylesheet" type="text/css" href="../../dark.css" disabled ><link rel="stylesheet" type="text/css" href="../../ayu.css" disabled ><script id="default-settings"></script><script src="../../storage.js"></script><script src="../../crates.js"></script><noscript><link rel="stylesheet" href="../../noscript.css"></noscript><link rel="icon" type="image/svg+xml" href="../../favicon.svg">
<link rel="alternate icon" type="image/png" href="../../favicon-16x16.png"> <link rel="alternate icon" type="image/png" href="../../favicon-16x16.png">
<link rel="alternate icon" type="image/png" href="../../favicon-32x32.png"><style type="text/css">#crate-search{background-image:url("../../down-arrow.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu" role="button">&#9776;</div><a href='../../kanidm/index.html'><div class='logo-container rust-logo'><img src='../../rust-logo.png' alt='logo'></div></a><p class="location">Module be</p><div class="sidebar-elems"><div class="block items"><ul><li><a href="#modules">Modules</a></li><li><a href="#structs">Structs</a></li><li><a href="#enums">Enums</a></li><li><a href="#traits">Traits</a></li></ul></div><p class="location"><a href="../index.html">kanidm</a></p><div id="sidebar-vars" data-name="be" data-ty="mod" data-relpath="../"></div><script defer src="../sidebar-items.js"></script></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!" aria-haspopup="menu"><img src="../../brush.svg" width="18" height="18" alt="Pick another theme!"></button><div id="theme-choices" role="menu"></div></div><nav class="sub"><form class="search-form"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" disabled autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"></div><button type="button" class="help-button">?</button> <link rel="alternate icon" type="image/png" href="../../favicon-32x32.png"><style type="text/css">#crate-search{background-image:url("../../down-arrow.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu" role="button">&#9776;</div><a href='../../kanidm/index.html'><div class='logo-container rust-logo'><img src='../../rust-logo.png' alt='logo'></div></a><p class="location">Module be</p><div class="sidebar-elems"><div class="block items"><ul><li><a href="#modules">Modules</a></li><li><a href="#structs">Structs</a></li><li><a href="#enums">Enums</a></li><li><a href="#traits">Traits</a></li></ul></div><p class="location"><a href="../index.html">kanidm</a></p><div id="sidebar-vars" data-name="be" data-ty="mod" data-relpath="../"></div><script defer src="../sidebar-items.js"></script></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!" aria-haspopup="menu"><img src="../../brush.svg" width="18" height="18" alt="Pick another theme!"></button><div id="theme-choices" role="menu"></div></div><nav class="sub"><form class="search-form"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" disabled autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"></div><button type="button" class="help-button">?</button>
<a id="settings-menu" href="../../settings.html"><img src="../../wheel.svg" width="18" height="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class="fqn"><span class="in-band">Module <a href="../index.html">kanidm</a>::<wbr><a class="mod" href="">be</a><button id="copy-path" onclick="copy_path(this)"></button></span><span class="out-of-band"><span id="render-detail"><a id="toggle-all-docs" href="javascript:void(0)" title="collapse all docs">[<span class="inner">&#x2212;</span>]</a></span><a class="srclink" href="../../src/kanidm/be/mod.rs.html#1-3058" title="goto source code">[src]</a></span></h1><div class="docblock"><p>The backend. This contains the “low level” storage and query code, which is <a id="settings-menu" href="../../settings.html"><img src="../../wheel.svg" width="18" height="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class="fqn"><span class="in-band">Module <a href="../index.html">kanidm</a>::<wbr><a class="mod" href="">be</a><button id="copy-path" onclick="copy_path(this)"></button></span><span class="out-of-band"><span id="render-detail"><a id="toggle-all-docs" href="javascript:void(0)" title="collapse all docs">[<span class="inner">&#x2212;</span>]</a></span><a class="srclink" href="../../src/kanidm/be/mod.rs.html#1-3057" title="goto source code">[src]</a></span></h1><div class="docblock"><p>The backend. This contains the “low level” storage and query code, which is
implemented as a json-like kv document database. This has no rules about content implemented as a json-like kv document database. This has no rules about content
of the server, which are all enforced at higher levels. The role of the backend of the server, which are all enforced at higher levels. The role of the backend
is to persist content safely to disk, load that content, and execute queries is to persist content safely to disk, load that content, and execute queries

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View file

@ -1,6 +1,6 @@
<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="Settings of Rustdoc"><meta name="keywords" content="rust, rustlang, rust-lang"><title>Rustdoc settings</title><link rel="stylesheet" type="text/css" href="./normalize.css"><link rel="stylesheet" type="text/css" href="./rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="./light.css" id="themeStyle"><link rel="stylesheet" type="text/css" href="./dark.css" disabled ><link rel="stylesheet" type="text/css" href="./ayu.css" disabled ><link rel="stylesheet" type="text/css" href="./settings.css" ><script id="default-settings"></script><script src="./storage.js"></script><script src="./crates.js"></script><noscript><link rel="stylesheet" href="./noscript.css"></noscript><link rel="icon" type="image/svg+xml" href="./favicon.svg"> <!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="Settings of Rustdoc"><meta name="keywords" content="rust, rustlang, rust-lang"><title>Rustdoc settings</title><link rel="stylesheet" type="text/css" href="./normalize.css"><link rel="stylesheet" type="text/css" href="./rustdoc.css" id="mainThemeStyle"><link rel="stylesheet" type="text/css" href="./light.css" id="themeStyle"><link rel="stylesheet" type="text/css" href="./dark.css" disabled ><link rel="stylesheet" type="text/css" href="./ayu.css" disabled ><link rel="stylesheet" type="text/css" href="./settings.css" ><script id="default-settings"></script><script src="./storage.js"></script><script src="./crates.js"></script><noscript><link rel="stylesheet" href="./noscript.css"></noscript><link rel="icon" type="image/svg+xml" href="./favicon.svg">
<link rel="alternate icon" type="image/png" href="./favicon-16x16.png"> <link rel="alternate icon" type="image/png" href="./favicon-16x16.png">
<link rel="alternate icon" type="image/png" href="./favicon-32x32.png"><style type="text/css">#crate-search{background-image:url("./down-arrow.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu" role="button">&#9776;</div><a href='./kanidm_ssh_authorizedkeys/index.html'><div class='logo-container rust-logo'><img src='./rust-logo.png' alt='logo'></div></a><p class="location">Settings</p><div class="sidebar-elems"></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!" aria-haspopup="menu"><img src="./brush.svg" width="18" height="18" alt="Pick another theme!"></button><div id="theme-choices" role="menu"></div></div><nav class="sub"><form class="search-form"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" disabled autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"></div><button type="button" class="help-button">?</button> <link rel="alternate icon" type="image/png" href="./favicon-32x32.png"><style type="text/css">#crate-search{background-image:url("./down-arrow.svg");}</style></head><body class="rustdoc mod"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="sidebar"><div class="sidebar-menu" role="button">&#9776;</div><a href='./kanidm_cache_invalidate/index.html'><div class='logo-container rust-logo'><img src='./rust-logo.png' alt='logo'></div></a><p class="location">Settings</p><div class="sidebar-elems"></div></nav><div class="theme-picker"><button id="theme-picker" aria-label="Pick another theme!" aria-haspopup="menu"><img src="./brush.svg" width="18" height="18" alt="Pick another theme!"></button><div id="theme-choices" role="menu"></div></div><nav class="sub"><form class="search-form"><div class="search-container"><div><select id="crate-search"><option value="All crates">All crates</option></select><input class="search-input" name="search" disabled autocomplete="off" spellcheck="false" placeholder="Click or press S to search, ? for more options…" type="search"></div><button type="button" class="help-button">?</button>
<a id="settings-menu" href="./settings.html"><img src="./wheel.svg" width="18" height="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class="fqn"><span class="in-band">Rustdoc settings</span></h1><div class="settings"><div class="setting-line"><div class="title">Theme preferences</div><div class="sub-settings"><div class="setting-line"><label class="toggle"><input type="checkbox" id="use-system-theme" checked><span class="slider"></span></label><div>Use system theme</div></div><div class="setting-line"><div>Preferred dark theme</div><label class="select-wrapper"><select id="preferred-dark-theme" autocomplete="off"><option value="light" >light</option><option value="dark" selected>dark</option><option value="ayu" >ayu</option></select><img src="./down-arrow.svg" alt="Select item"></label></div><div class="setting-line"><div>Preferred light theme</div><label class="select-wrapper"><select id="preferred-light-theme" autocomplete="off"><option value="light" selected>light</option><option value="dark" >dark</option><option value="ayu" >ayu</option></select><img src="./down-arrow.svg" alt="Select item"></label></div></div> <a id="settings-menu" href="./settings.html"><img src="./wheel.svg" width="18" height="18" alt="Change settings"></a></div></form></nav><section id="main" class="content"><h1 class="fqn"><span class="in-band">Rustdoc settings</span></h1><div class="settings"><div class="setting-line"><div class="title">Theme preferences</div><div class="sub-settings"><div class="setting-line"><label class="toggle"><input type="checkbox" id="use-system-theme" checked><span class="slider"></span></label><div>Use system theme</div></div><div class="setting-line"><div>Preferred dark theme</div><label class="select-wrapper"><select id="preferred-dark-theme" autocomplete="off"><option value="light" >light</option><option value="dark" selected>dark</option><option value="ayu" >ayu</option></select><img src="./down-arrow.svg" alt="Select item"></label></div><div class="setting-line"><div>Preferred light theme</div><label class="select-wrapper"><select id="preferred-light-theme" autocomplete="off"><option value="light" selected>light</option><option value="dark" >dark</option><option value="ayu" >ayu</option></select><img src="./down-arrow.svg" alt="Select item"></label></div></div>
</div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-large-items" checked><span class="slider"></span></label><div>Auto-hide item contents for large items.</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-method-docs" ><span class="slider"></span></label><div>Auto-hide item methods' documentation</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-trait-implementations" checked><span class="slider"></span></label><div>Auto-hide trait implementation documentation</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-collapse-implementors" checked><span class="slider"></span></label><div>Auto-hide implementors of a trait</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="go-to-only-result" ><span class="slider"></span></label><div>Directly go to item in search if there is only one result</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="line-numbers" ><span class="slider"></span></label><div>Show line numbers on code examples</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="disable-shortcuts" ><span class="slider"></span></label><div>Disable keyboard shortcuts</div></div></div><script src="./settings.js"></script></section><section id="search" class="content hidden"></section><div id="rustdoc-vars" data-root-path="./" data-current-crate="kanidm_ssh_authorizedkeys" data-search-index-js="./search-index.js" data-search-js="./search.js"></div> </div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-large-items" checked><span class="slider"></span></label><div>Auto-hide item contents for large items.</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-method-docs" ><span class="slider"></span></label><div>Auto-hide item methods' documentation</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-hide-trait-implementations" checked><span class="slider"></span></label><div>Auto-hide trait implementation documentation</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="auto-collapse-implementors" checked><span class="slider"></span></label><div>Auto-hide implementors of a trait</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="go-to-only-result" ><span class="slider"></span></label><div>Directly go to item in search if there is only one result</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="line-numbers" ><span class="slider"></span></label><div>Show line numbers on code examples</div></div><div class="setting-line"><label class="toggle"><input type="checkbox" id="disable-shortcuts" ><span class="slider"></span></label><div>Disable keyboard shortcuts</div></div></div><script src="./settings.js"></script></section><section id="search" class="content hidden"></section><div id="rustdoc-vars" data-root-path="./" data-current-crate="kanidm_cache_invalidate" data-search-index-js="./search-index.js" data-search-js="./search.js"></div>
<script src="./main.js"></script></body></html> <script src="./main.js"></script></body></html>

View file

@ -1083,11 +1083,6 @@
<span id="1080">1080</span> <span id="1080">1080</span>
<span id="1081">1081</span> <span id="1081">1081</span>
<span id="1082">1082</span> <span id="1082">1082</span>
<span id="1083">1083</span>
<span id="1084">1084</span>
<span id="1085">1085</span>
<span id="1086">1086</span>
<span id="1087">1087</span>
</pre><div class="example-wrap"><pre class="rust "> </pre><div class="example-wrap"><pre class="rust ">
<span class="kw">use</span> <span class="ident">tokio::sync::mpsc::UnboundedSender</span> <span class="kw">as</span> <span class="ident">Sender</span>; <span class="kw">use</span> <span class="ident">tokio::sync::mpsc::UnboundedSender</span> <span class="kw">as</span> <span class="ident">Sender</span>;
@ -2105,24 +2100,19 @@
<span class="ident">uat</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">String</span><span class="op">&gt;</span>, <span class="ident">uat</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">String</span><span class="op">&gt;</span>,
<span class="ident">eventid</span>: <span class="ident">Uuid</span>, <span class="ident">eventid</span>: <span class="ident">Uuid</span>,
) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span>(), <span class="ident">OperationError</span><span class="op">&gt;</span> { ) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span>(), <span class="ident">OperationError</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">audit</span> <span class="op">=</span> <span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">audit</span> <span class="op">=</span> <span class="ident">AuditScope::new</span>(<span class="string">&quot;auth_valid&quot;</span>, <span class="ident">eventid</span>, <span class="self">self</span>.<span class="ident">log_level</span>);
<span class="ident">AuditScope::new</span>(<span class="string">&quot;auth_valid&quot;</span>, <span class="ident">eventid</span>, <span class="self">self</span>.<span class="ident">log_level</span>);
<span class="kw">let</span> <span class="ident">ct</span> <span class="op">=</span> <span class="ident">duration_from_epoch_now</span>(); <span class="kw">let</span> <span class="ident">ct</span> <span class="op">=</span> <span class="ident">duration_from_epoch_now</span>();
<span class="kw">let</span> <span class="ident">idms_prox_read</span> <span class="op">=</span> <span class="self">self</span>.<span class="ident">idms</span>.<span class="ident">proxy_read_async</span>().<span class="kw">await</span>; <span class="kw">let</span> <span class="ident">idms_prox_read</span> <span class="op">=</span> <span class="self">self</span>.<span class="ident">idms</span>.<span class="ident">proxy_read_async</span>().<span class="kw">await</span>;
<span class="kw">let</span> <span class="ident">res</span> <span class="op">=</span> <span class="macro">lperf_op_segment!</span>( <span class="kw">let</span> <span class="ident">res</span> <span class="op">=</span> <span class="macro">lperf_op_segment!</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">audit</span>, <span class="string">&quot;actors::v1_read::handle&lt;AuthValid&gt;&quot;</span>, <span class="op">|</span><span class="op">|</span> {
<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">audit</span>, <span class="ident">idms_prox_read</span>
<span class="string">&quot;actors::v1_read::handle&lt;AuthValid&gt;&quot;</span>, .<span class="ident">validate_and_parse_uat</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">audit</span>, <span class="ident">uat</span>.<span class="ident">as_deref</span>(), <span class="ident">ct</span>)
<span class="op">|</span><span class="op">|</span> { .<span class="ident">map</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> ())
<span class="ident">idms_prox_read</span> .<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
.<span class="ident">validate_and_parse_uat</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">audit</span>, <span class="ident">uat</span>.<span class="ident">as_deref</span>(), <span class="ident">ct</span>) <span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Invalid token: {:?}&quot;</span>, <span class="ident">e</span>);
.<span class="ident">map</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> ()) <span class="ident">e</span>
.<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { })
<span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Invalid token: {:?}&quot;</span>, <span class="ident">e</span>); });
<span class="ident">e</span>
})
}
);
<span class="self">self</span>.<span class="ident">log</span>.<span class="ident">send</span>(<span class="ident">audit</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> { <span class="self">self</span>.<span class="ident">log</span>.<span class="ident">send</span>(<span class="ident">audit</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> {
<span class="macro">error!</span>(<span class="string">&quot;CRITICAL: UNABLE TO COMMIT LOGS&quot;</span>); <span class="macro">error!</span>(<span class="string">&quot;CRITICAL: UNABLE TO COMMIT LOGS&quot;</span>);
<span class="ident">OperationError::InvalidState</span> <span class="ident">OperationError::InvalidState</span>

View file

@ -1623,13 +1623,6 @@
<span id="1620">1620</span> <span id="1620">1620</span>
<span id="1621">1621</span> <span id="1621">1621</span>
<span id="1622">1622</span> <span id="1622">1622</span>
<span id="1623">1623</span>
<span id="1624">1624</span>
<span id="1625">1625</span>
<span id="1626">1626</span>
<span id="1627">1627</span>
<span id="1628">1628</span>
<span id="1629">1629</span>
</pre><div class="example-wrap"><pre class="rust "> </pre><div class="example-wrap"><pre class="rust ">
<span class="kw">use</span> <span class="kw">crate</span><span class="ident">::audit::AuditScope</span>; <span class="kw">use</span> <span class="kw">crate</span><span class="ident">::audit::AuditScope</span>;
<span class="kw">use</span> <span class="kw">crate</span><span class="ident">::be</span>::{<span class="ident">BackendConfig</span>, <span class="ident">IdList</span>, <span class="ident">IdRawEntry</span>, <span class="ident">IdxKey</span>, <span class="ident">IdxSlope</span>}; <span class="kw">use</span> <span class="kw">crate</span><span class="ident">::be</span>::{<span class="ident">BackendConfig</span>, <span class="ident">IdList</span>, <span class="ident">IdRawEntry</span>, <span class="ident">IdxKey</span>, <span class="ident">IdxSlope</span>};
@ -1903,11 +1896,10 @@
})<span class="question-mark">?</span>; })<span class="question-mark">?</span>;
<span class="kw">let</span> <span class="ident">idl</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">idl_raw</span> { <span class="kw">let</span> <span class="ident">idl</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">idl_raw</span> {
<span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()) <span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
.<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>,
})<span class="question-mark">?</span>,
<span class="comment">// We don&#39;t have this value, it must be empty (or we</span> <span class="comment">// We don&#39;t have this value, it must be empty (or we</span>
<span class="comment">// have a corrupted index .....</span> <span class="comment">// have a corrupted index .....</span>
<span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="ident">IDLBitRange::new</span>(), <span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="ident">IDLBitRange::new</span>(),
@ -1974,11 +1966,10 @@
<span class="kw">let</span> <span class="ident">spn</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">Value</span><span class="op">&gt;</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">spn_raw</span> { <span class="kw">let</span> <span class="ident">spn</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">Value</span><span class="op">&gt;</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">spn_raw</span> {
<span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> { <span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="ident">dbv</span> <span class="op">=</span> <span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()) <span class="kw">let</span> <span class="ident">dbv</span> <span class="op">=</span> <span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
.<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>;
})<span class="question-mark">?</span>;
<span class="kw">let</span> <span class="ident">spn</span> <span class="op">=</span> <span class="ident">Value::from_db_valuev1</span>(<span class="ident">dbv</span>) <span class="kw">let</span> <span class="ident">spn</span> <span class="op">=</span> <span class="ident">Value::from_db_valuev1</span>(<span class="ident">dbv</span>)
.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::CorruptedIndex</span>(<span class="string">&quot;uuid2spn&quot;</span>.<span class="ident">to_string</span>()))<span class="question-mark">?</span>; .<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::CorruptedIndex</span>(<span class="string">&quot;uuid2spn&quot;</span>.<span class="ident">to_string</span>()))<span class="question-mark">?</span>;
<span class="prelude-val">Some</span>(<span class="ident">spn</span>) <span class="prelude-val">Some</span>(<span class="ident">spn</span>)
@ -2039,12 +2030,10 @@
.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>; .<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>;
<span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> { <span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> {
<span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>( <span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>(<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>),
})<span class="question-mark">?</span>,
),
<span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>, <span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>,
}) })
} }
@ -2066,12 +2055,10 @@
.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>; .<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>;
<span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> { <span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> {
<span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>( <span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>(<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>),
})<span class="question-mark">?</span>,
),
<span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>, <span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>,
}) })
} }
@ -2139,7 +2126,10 @@
<span class="kw">let</span> <span class="ident">allids</span> <span class="op">=</span> <span class="self">self</span>.<span class="ident">get_identry_raw</span>(<span class="ident">audit</span>, <span class="kw-2">&amp;</span><span class="ident">IdList::AllIds</span>)<span class="question-mark">?</span>; <span class="kw">let</span> <span class="ident">allids</span> <span class="op">=</span> <span class="self">self</span>.<span class="ident">get_identry_raw</span>(<span class="ident">audit</span>, <span class="kw-2">&amp;</span><span class="ident">IdList::AllIds</span>)<span class="question-mark">?</span>;
<span class="ident">allids</span> <span class="ident">allids</span>
.<span class="ident">into_iter</span>() .<span class="ident">into_iter</span>()
.<span class="ident">map</span>(<span class="op">|</span><span class="ident">data</span><span class="op">|</span> <span class="ident">data</span>.<span class="ident">into_dbentry</span>(<span class="ident">audit</span>).<span class="ident">map</span>(<span class="op">|</span>(<span class="ident">id</span>, <span class="ident">db_e</span>)<span class="op">|</span> (<span class="ident">id</span>, <span class="ident">db_e</span>.<span class="ident">to_string</span>()))) .<span class="ident">map</span>(<span class="op">|</span><span class="ident">data</span><span class="op">|</span> {
<span class="ident">data</span>.<span class="ident">into_dbentry</span>(<span class="ident">audit</span>)
.<span class="ident">map</span>(<span class="op">|</span>(<span class="ident">id</span>, <span class="ident">db_e</span>)<span class="op">|</span> (<span class="ident">id</span>, <span class="ident">db_e</span>.<span class="ident">to_string</span>()))
})
.<span class="ident">collect</span>() .<span class="ident">collect</span>()
} }
@ -2376,11 +2366,10 @@
<span class="ident">entry</span>: <span class="kw-2">&amp;</span><span class="ident">Entry</span><span class="op">&lt;</span><span class="ident">EntrySealed</span>, <span class="ident">EntryCommitted</span><span class="op">&gt;</span>, <span class="ident">entry</span>: <span class="kw-2">&amp;</span><span class="ident">Entry</span><span class="op">&lt;</span><span class="ident">EntrySealed</span>, <span class="ident">EntryCommitted</span><span class="op">&gt;</span>,
) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span>(), <span class="ident">OperationError</span><span class="op">&gt;</span> { ) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span>(), <span class="ident">OperationError</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="ident">dbe</span> <span class="op">=</span> <span class="ident">entry</span>.<span class="ident">to_dbentry</span>(); <span class="kw">let</span> <span class="ident">dbe</span> <span class="op">=</span> <span class="ident">entry</span>.<span class="ident">to_dbentry</span>();
<span class="kw">let</span> <span class="ident">data</span> <span class="op">=</span> <span class="ident">serde_cbor::to_vec</span>(<span class="kw-2">&amp;</span><span class="ident">dbe</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> <span class="kw">let</span> <span class="ident">data</span> <span class="op">=</span> <span class="ident">serde_cbor::to_vec</span>(<span class="kw-2">&amp;</span><span class="ident">dbe</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
{ <span class="macro">ladmin_error!</span>(<span class="ident">au</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">ladmin_error!</span>(<span class="ident">au</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>;
})<span class="question-mark">?</span>;
<span class="kw">let</span> <span class="ident">raw_entries</span> <span class="op">=</span> <span class="ident">std::iter::once</span>(<span class="ident">IdRawEntry</span> { <span class="kw">let</span> <span class="ident">raw_entries</span> <span class="op">=</span> <span class="ident">std::iter::once</span>(<span class="ident">IdRawEntry</span> {
<span class="ident">id</span>: <span class="ident">entry</span>.<span class="ident">get_id</span>(), <span class="ident">id</span>: <span class="ident">entry</span>.<span class="ident">get_id</span>(),
@ -2622,11 +2611,10 @@
<span class="kw">match</span> <span class="ident">k</span> { <span class="kw">match</span> <span class="ident">k</span> {
<span class="prelude-val">Some</span>(<span class="ident">k</span>) <span class="op">=</span><span class="op">&gt;</span> { <span class="prelude-val">Some</span>(<span class="ident">k</span>) <span class="op">=</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="ident">dbv1</span> <span class="op">=</span> <span class="ident">k</span>.<span class="ident">to_db_valuev1</span>(); <span class="kw">let</span> <span class="ident">dbv1</span> <span class="op">=</span> <span class="ident">k</span>.<span class="ident">to_db_valuev1</span>();
<span class="kw">let</span> <span class="ident">data</span> <span class="op">=</span> <span class="kw">let</span> <span class="ident">data</span> <span class="op">=</span> <span class="ident">serde_cbor::to_vec</span>(<span class="kw-2">&amp;</span><span class="ident">dbv1</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
<span class="ident">serde_cbor::to_vec</span>(<span class="kw-2">&amp;</span><span class="ident">dbv1</span>).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>;
})<span class="question-mark">?</span>;
<span class="self">self</span>.<span class="ident">conn</span> <span class="self">self</span>.<span class="ident">conn</span>
.<span class="ident">prepare</span>(<span class="string">&quot;INSERT OR REPLACE INTO idx_uuid2spn (uuid, spn) VALUES(:uuid, :spn)&quot;</span>) .<span class="ident">prepare</span>(<span class="string">&quot;INSERT OR REPLACE INTO idx_uuid2spn (uuid, spn) VALUES(:uuid, :spn)&quot;</span>)
.<span class="ident">and_then</span>(<span class="op">|</span><span class="kw-2">mut</span> <span class="ident">stmt</span><span class="op">|</span> { .<span class="ident">and_then</span>(<span class="op">|</span><span class="kw-2">mut</span> <span class="ident">stmt</span><span class="op">|</span> {
@ -2917,12 +2905,10 @@
.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>; .<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::SqliteError</span>)<span class="question-mark">?</span>;
<span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> { <span class="prelude-val">Ok</span>(<span class="kw">match</span> <span class="ident">data</span> {
<span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>( <span class="prelude-val">Some</span>(<span class="ident">d</span>) <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">Some</span>(<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
<span class="ident">serde_cbor::from_slice</span>(<span class="ident">d</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">eprintln!</span>(<span class="string">&quot;CRITICAL: Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>),
})<span class="question-mark">?</span>,
),
<span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>, <span class="prelude-val">None</span> <span class="op">=</span><span class="op">&gt;</span> <span class="prelude-val">None</span>,
}) })
} }

View file

@ -3058,7 +3058,6 @@
<span id="3055">3055</span> <span id="3055">3055</span>
<span id="3056">3056</span> <span id="3056">3056</span>
<span id="3057">3057</span> <span id="3057">3057</span>
<span id="3058">3058</span>
</pre><div class="example-wrap"><pre class="rust "> </pre><div class="example-wrap"><pre class="rust ">
<span class="doccomment">//! The backend. This contains the &quot;low level&quot; storage and query code, which is</span> <span class="doccomment">//! The backend. This contains the &quot;low level&quot; storage and query code, which is</span>
<span class="doccomment">//! implemented as a json-like kv document database. This has no rules about content</span> <span class="doccomment">//! implemented as a json-like kv document database. This has no rules about content</span>
@ -3197,11 +3196,10 @@
<span class="self">self</span>, <span class="self">self</span>,
<span class="ident">audit</span>: <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">AuditScope</span>, <span class="ident">audit</span>: <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">AuditScope</span>,
) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span><span class="ident">Entry</span><span class="op">&lt;</span><span class="ident">EntrySealed</span>, <span class="ident">EntryCommitted</span><span class="op">&gt;</span>, <span class="ident">OperationError</span><span class="op">&gt;</span> { ) <span class="op">-</span><span class="op">&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span><span class="ident">Entry</span><span class="op">&lt;</span><span class="ident">EntrySealed</span>, <span class="ident">EntryCommitted</span><span class="op">&gt;</span>, <span class="ident">OperationError</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="ident">db_e</span> <span class="op">=</span> <span class="ident">serde_cbor::from_slice</span>(<span class="self">self</span>.<span class="ident">data</span>.<span class="ident">as_slice</span>()) <span class="kw">let</span> <span class="ident">db_e</span> <span class="op">=</span> <span class="ident">serde_cbor::from_slice</span>(<span class="self">self</span>.<span class="ident">data</span>.<span class="ident">as_slice</span>()).<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> {
.<span class="ident">map_err</span>(<span class="op">|</span><span class="ident">e</span><span class="op">|</span> { <span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>);
<span class="macro">ladmin_error!</span>(<span class="ident">audit</span>, <span class="string">&quot;Serde CBOR Error -&gt; {:?}&quot;</span>, <span class="ident">e</span>); <span class="ident">OperationError::SerdeCborError</span>
<span class="ident">OperationError::SerdeCborError</span> })<span class="question-mark">?</span>;
})<span class="question-mark">?</span>;
<span class="comment">// let id = u64::try_from(self.id).map_err(|_| OperationError::InvalidEntryId)?;</span> <span class="comment">// let id = u64::try_from(self.id).map_err(|_| OperationError::InvalidEntryId)?;</span>
<span class="ident">Entry::from_dbentry</span>(<span class="ident">audit</span>, <span class="ident">db_e</span>, <span class="self">self</span>.<span class="ident">id</span>) <span class="ident">Entry::from_dbentry</span>(<span class="ident">audit</span>, <span class="ident">db_e</span>, <span class="self">self</span>.<span class="ident">id</span>)
.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::CorruptedEntry</span>(<span class="self">self</span>.<span class="ident">id</span>)) .<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">OperationError::CorruptedEntry</span>(<span class="self">self</span>.<span class="ident">id</span>))