1
0
mirror of https://github.com/actix/actix-website synced 2025-06-30 16:54:27 +02:00

update stable docs

This commit is contained in:
Nikolay Kim
2018-07-26 10:53:41 -07:00
parent 0c2153597f
commit 90165ac1cc
2025 changed files with 116162 additions and 2957 deletions

View File

@ -855,6 +855,30 @@
<span id="855">855</span>
<span id="856">856</span>
<span id="857">857</span>
<span id="858">858</span>
<span id="859">859</span>
<span id="860">860</span>
<span id="861">861</span>
<span id="862">862</span>
<span id="863">863</span>
<span id="864">864</span>
<span id="865">865</span>
<span id="866">866</span>
<span id="867">867</span>
<span id="868">868</span>
<span id="869">869</span>
<span id="870">870</span>
<span id="871">871</span>
<span id="872">872</span>
<span id="873">873</span>
<span id="874">874</span>
<span id="875">875</span>
<span id="876">876</span>
<span id="877">877</span>
<span id="878">878</span>
<span id="879">879</span>
<span id="880">880</span>
<span id="881">881</span>
</pre><pre class="rust ">
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">rc</span>::<span class="ident">Rc</span>;
@ -1029,7 +1053,9 @@
<span class="doccomment">/// In the following example only requests with an `/app/` path</span>
<span class="doccomment">/// prefix get handled. Requests with path `/app/test/` would be</span>
<span class="doccomment">/// handled, while requests with the paths `/application` or</span>
<span class="doccomment">/// `/other/...` would return `NOT FOUND`.</span>
<span class="doccomment">/// `/other/...` would return `NOT FOUND`. It is also possible to</span>
<span class="doccomment">/// handle `/app` path, to do this you can register resource for</span>
<span class="doccomment">/// empty string `&quot;&quot;`</span>
<span class="doccomment">///</span>
<span class="doccomment">/// ```rust</span>
<span class="doccomment">/// # extern crate actix_web;</span>
@ -1038,6 +1064,8 @@
<span class="doccomment">/// fn main() {</span>
<span class="doccomment">/// let app = App::new()</span>
<span class="doccomment">/// .prefix(&quot;/app&quot;)</span>
<span class="doccomment">/// .resource(&quot;&quot;, |r| r.f(|_| HttpResponse::Ok())) // &lt;- handle `/app` path</span>
<span class="doccomment">/// .resource(&quot;/&quot;, |r| r.f(|_| HttpResponse::Ok())) // &lt;- handle `/app/` path</span>
<span class="doccomment">/// .resource(&quot;/test&quot;, |r| {</span>
<span class="doccomment">/// r.get().f(|_| HttpResponse::Ok());</span>
<span class="doccomment">/// r.head().f(|_| HttpResponse::MethodNotAllowed());</span>
@ -1489,6 +1517,7 @@
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">NOT_FOUND</span>);
<span class="kw">let</span> <span class="ident">app</span> <span class="op">=</span> <span class="ident">App</span>::<span class="ident">new</span>()
.<span class="ident">resource</span>(<span class="string">&quot;/test&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">HttpResponse</span>::<span class="prelude-val">Ok</span>()))
.<span class="ident">default_resource</span>(<span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">HttpResponse</span>::<span class="ident">MethodNotAllowed</span>()))
.<span class="ident">finish</span>();
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">with_uri</span>(<span class="string">&quot;/blah&quot;</span>).<span class="ident">request</span>();
@ -1679,6 +1708,23 @@
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">NOT_FOUND</span>);
}
<span class="attribute">#[<span class="ident">test</span>]</span>
<span class="kw">fn</span> <span class="ident">test_option_responder</span>() {
<span class="kw">let</span> <span class="ident">app</span> <span class="op">=</span> <span class="ident">App</span>::<span class="ident">new</span>()
.<span class="ident">resource</span>(<span class="string">&quot;/none&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="op">-&gt;</span> <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="kw-2">&amp;</span><span class="lifetime">&#39;static</span> <span class="ident">str</span><span class="op">&gt;</span> { <span class="prelude-val">None</span> }))
.<span class="ident">resource</span>(<span class="string">&quot;/some&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="prelude-val">Some</span>(<span class="string">&quot;some&quot;</span>)))
.<span class="ident">finish</span>();
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">with_uri</span>(<span class="string">&quot;/none&quot;</span>).<span class="ident">request</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">app</span>.<span class="ident">run</span>(<span class="ident">req</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">NOT_FOUND</span>);
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">with_uri</span>(<span class="string">&quot;/some&quot;</span>).<span class="ident">request</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">app</span>.<span class="ident">run</span>(<span class="ident">req</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">OK</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">body</span>(), <span class="kw-2">&amp;</span><span class="ident">Body</span>::<span class="ident">Binary</span>(<span class="ident">Binary</span>::<span class="ident">Slice</span>(<span class="string">b&quot;some&quot;</span>)));
}
<span class="attribute">#[<span class="ident">test</span>]</span>
<span class="kw">fn</span> <span class="ident">test_filter</span>() {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">srv</span> <span class="op">=</span> <span class="ident">TestServer</span>::<span class="ident">with_factory</span>(<span class="op">||</span> {
@ -1697,21 +1743,23 @@
}
<span class="attribute">#[<span class="ident">test</span>]</span>
<span class="kw">fn</span> <span class="ident">test_option_responder</span>() {
<span class="kw">let</span> <span class="ident">app</span> <span class="op">=</span> <span class="ident">App</span>::<span class="ident">new</span>()
.<span class="ident">resource</span>(<span class="string">&quot;/none&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="op">-&gt;</span> <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="kw-2">&amp;</span><span class="lifetime">&#39;static</span> <span class="ident">str</span><span class="op">&gt;</span> { <span class="prelude-val">None</span> }))
.<span class="ident">resource</span>(<span class="string">&quot;/some&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="prelude-val">Some</span>(<span class="string">&quot;some&quot;</span>)))
.<span class="ident">finish</span>();
<span class="kw">fn</span> <span class="ident">test_prefix_root</span>() {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">srv</span> <span class="op">=</span> <span class="ident">TestServer</span>::<span class="ident">with_factory</span>(<span class="op">||</span> {
<span class="ident">App</span>::<span class="ident">new</span>()
.<span class="ident">prefix</span>(<span class="string">&quot;/test&quot;</span>)
.<span class="ident">resource</span>(<span class="string">&quot;/&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">HttpResponse</span>::<span class="prelude-val">Ok</span>()))
.<span class="ident">resource</span>(<span class="string">&quot;&quot;</span>, <span class="op">|</span><span class="ident">r</span><span class="op">|</span> <span class="ident">r</span>.<span class="ident">f</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">HttpResponse</span>::<span class="ident">Created</span>()))
});
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">with_uri</span>(<span class="string">&quot;/none&quot;</span>).<span class="ident">request</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">app</span>.<span class="ident">run</span>(<span class="ident">req</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">NOT_FOUND</span>);
<span class="kw">let</span> <span class="ident">request</span> <span class="op">=</span> <span class="ident">srv</span>.<span class="ident">get</span>().<span class="ident">uri</span>(<span class="ident">srv</span>.<span class="ident">url</span>(<span class="string">&quot;/test/&quot;</span>)).<span class="ident">finish</span>().<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">response</span> <span class="op">=</span> <span class="ident">srv</span>.<span class="ident">execute</span>(<span class="ident">request</span>.<span class="ident">send</span>()).<span class="ident">unwrap</span>();
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">response</span>.<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">OK</span>);
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">with_uri</span>(<span class="string">&quot;/some&quot;</span>).<span class="ident">request</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">app</span>.<span class="ident">run</span>(<span class="ident">req</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">OK</span>);
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">as_msg</span>().<span class="ident">body</span>(), <span class="kw-2">&amp;</span><span class="ident">Body</span>::<span class="ident">Binary</span>(<span class="ident">Binary</span>::<span class="ident">Slice</span>(<span class="string">b&quot;some&quot;</span>)));
<span class="kw">let</span> <span class="ident">request</span> <span class="op">=</span> <span class="ident">srv</span>.<span class="ident">get</span>().<span class="ident">uri</span>(<span class="ident">srv</span>.<span class="ident">url</span>(<span class="string">&quot;/test&quot;</span>)).<span class="ident">finish</span>().<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">response</span> <span class="op">=</span> <span class="ident">srv</span>.<span class="ident">execute</span>(<span class="ident">request</span>.<span class="ident">send</span>()).<span class="ident">unwrap</span>();
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">response</span>.<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">CREATED</span>);
}
}
</pre>
</section><section id="search" class="content hidden"></section><section class="footer"></section><aside id="help" class="hidden"><div><h1 class="hidden">Help</h1><div class="shortcuts"><h2>Keyboard Shortcuts</h2><dl><dt><kbd>?</kbd></dt><dd>Show this help dialog</dd><dt><kbd>S</kbd></dt><dd>Focus the search field</dd><dt><kbd></kbd></dt><dd>Move up in search results</dd><dt><kbd></kbd></dt><dd>Move down in search results</dd><dt><kbd></kbd></dt><dd>Switch tab</dd><dt><kbd>&#9166;</kbd></dt><dd>Go to active search result</dd><dt><kbd>+</kbd></dt><dd>Expand all sections</dd><dt><kbd>-</kbd></dt><dd>Collapse all sections</dd></dl></div><div class="infos"><h2>Search Tricks</h2><p>Prefix searches with a type followed by a colon (e.g. <code>fn:</code>) to restrict the search to a given type.</p><p>Accepted types are: <code>fn</code>, <code>mod</code>, <code>struct</code>, <code>enum</code>, <code>trait</code>, <code>type</code>, <code>macro</code>, and <code>const</code>.</p><p>Search functions by type signature (e.g. <code>vec -> usize</code> or <code>* -> vec</code>)</p><p>Search multiple things at once by splitting your query with comma (e.g. <code>str,u8</code> or <code>String,struct:Vec,test</code>)</p></div></div></aside><script>window.rootPath = "../../";window.currentCrate = "actix_web";</script><script src="../../aliases.js"></script><script src="../../main.js"></script><script defer src="../../search-index.js"></script></body></html>

View File

@ -1147,6 +1147,7 @@
<span id="1147">1147</span>
<span id="1148">1148</span>
<span id="1149">1149</span>
<span id="1150">1150</span>
</pre><pre class="rust ">
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">collections</span>::{<span class="ident">HashMap</span>, <span class="ident">VecDeque</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">net</span>::<span class="ident">Shutdown</span>;
@ -1749,7 +1750,7 @@
}
<span class="ident">Acquire</span>::<span class="ident">Available</span> <span class="op">=&gt;</span> {
<span class="comment">// create new connection</span>
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="ident">key</span>.<span class="ident">clone</span>(), <span class="ident">waiter</span>, <span class="ident">ctx</span>);
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="kw-2">&amp;</span><span class="ident">key</span>, <span class="ident">waiter</span>, <span class="ident">ctx</span>);
}
}
}
@ -1758,7 +1759,8 @@
<span class="self">self</span>.<span class="ident">waiters</span> <span class="op">=</span> <span class="prelude-val">Some</span>(<span class="ident">act_waiters</span>);
}
<span class="kw">fn</span> <span class="ident">connect_waiter</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>, <span class="ident">key</span>: <span class="ident">Key</span>, <span class="ident">waiter</span>: <span class="ident">Waiter</span>, <span class="ident">ctx</span>: <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">Context</span><span class="op">&lt;</span><span class="self">Self</span><span class="op">&gt;</span>) {
<span class="kw">fn</span> <span class="ident">connect_waiter</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>, <span class="ident">key</span>: <span class="kw-2">&amp;</span><span class="ident">Key</span>, <span class="ident">waiter</span>: <span class="ident">Waiter</span>, <span class="ident">ctx</span>: <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">Context</span><span class="op">&lt;</span><span class="self">Self</span><span class="op">&gt;</span>) {
<span class="kw">let</span> <span class="ident">key</span> <span class="op">=</span> <span class="ident">key</span>.<span class="ident">clone</span>();
<span class="kw">let</span> <span class="ident">conn</span> <span class="op">=</span> <span class="ident">AcquiredConn</span>(<span class="ident">key</span>.<span class="ident">clone</span>(), <span class="prelude-val">Some</span>(<span class="self">self</span>.<span class="ident">acq_tx</span>.<span class="ident">clone</span>()));
<span class="kw">let</span> <span class="ident">key2</span> <span class="op">=</span> <span class="ident">key</span>.<span class="ident">clone</span>();
@ -1785,7 +1787,7 @@
<span class="ident">act</span>.<span class="ident">connector</span>
.<span class="ident">connect_async</span>(<span class="kw-2">&amp;</span><span class="ident">key</span>.<span class="ident">host</span>, <span class="ident">stream</span>)
.<span class="ident">into_actor</span>(<span class="ident">act</span>)
.<span class="ident">then</span>(<span class="kw">move</span> <span class="op">|</span><span class="ident">res</span>, <span class="ident">act</span>, <span class="kw">_</span><span class="op">|</span> {
.<span class="ident">then</span>(<span class="kw">move</span> <span class="op">|</span><span class="ident">res</span>, <span class="kw">_</span>, <span class="kw">_</span><span class="op">|</span> {
<span class="kw">match</span> <span class="ident">res</span> {
<span class="prelude-val">Err</span>(<span class="ident">e</span>) <span class="op">=&gt;</span> {
<span class="kw">let</span> <span class="kw">_</span> <span class="op">=</span> <span class="ident">waiter</span>.<span class="ident">tx</span>.<span class="ident">send</span>(<span class="prelude-val">Err</span>(
@ -1978,7 +1980,7 @@
<span class="ident">wait</span>,
<span class="ident">conn_timeout</span>,
};
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="ident">key</span>.<span class="ident">clone</span>(), <span class="ident">waiter</span>, <span class="ident">ctx</span>);
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="kw-2">&amp;</span><span class="ident">key</span>, <span class="ident">waiter</span>, <span class="ident">ctx</span>);
<span class="kw">return</span> <span class="ident">ActorResponse</span>::<span class="ident">async</span>(
<span class="ident">rx</span>.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">ClientConnectorError</span>::<span class="ident">Disconnected</span>)
@ -2035,7 +2037,7 @@
<span class="ident">wait</span>,
<span class="ident">conn_timeout</span>,
};
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="ident">key</span>.<span class="ident">clone</span>(), <span class="ident">waiter</span>, <span class="ident">ctx</span>);
<span class="self">self</span>.<span class="ident">connect_waiter</span>(<span class="kw-2">&amp;</span><span class="ident">key</span>, <span class="ident">waiter</span>, <span class="ident">ctx</span>);
<span class="ident">ActorResponse</span>::<span class="ident">async</span>(
<span class="ident">rx</span>.<span class="ident">map_err</span>(<span class="op">|</span><span class="kw">_</span><span class="op">|</span> <span class="ident">ClientConnectorError</span>::<span class="ident">Disconnected</span>)

View File

@ -769,7 +769,7 @@
<span class="kw">match</span> <span class="ident">pl</span>.<span class="ident">parse</span>() {
<span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">Ready</span>(<span class="kw-2">mut</span> <span class="ident">resp</span>)) <span class="op">=&gt;</span> {
<span class="kw">if</span> <span class="self">self</span>.<span class="ident">req</span>.<span class="ident">method</span>() <span class="op">==</span> <span class="kw-2">&amp;</span><span class="ident">Method</span>::<span class="ident">HEAD</span> {
<span class="kw">if</span> <span class="self">self</span>.<span class="ident">req</span>.<span class="ident">method</span>() <span class="op">==</span> <span class="ident">Method</span>::<span class="ident">HEAD</span> {
<span class="ident">pl</span>.<span class="ident">parser</span>.<span class="ident">take</span>();
}
<span class="ident">resp</span>.<span class="ident">set_pipeline</span>(<span class="ident">pl</span>);

File diff suppressed because it is too large Load Diff

View File

@ -1791,16 +1791,21 @@
<span id="1791">1791</span>
<span id="1792">1792</span>
<span id="1793">1793</span>
<span id="1794">1794</span>
<span id="1795">1795</span>
<span id="1796">1796</span>
<span id="1797">1797</span>
<span id="1798">1798</span>
</pre><pre class="rust ">
<span class="doccomment">//! Static files support</span>
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">fmt</span>::<span class="ident">Write</span>;
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">fs</span>::{<span class="ident">DirEntry</span>, <span class="ident">File</span>, <span class="ident">Metadata</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">io</span>::{<span class="ident">Read</span>, <span class="ident">Seek</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">marker</span>::<span class="ident">PhantomData</span>;
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">ops</span>::{<span class="ident">Deref</span>, <span class="ident">DerefMut</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">path</span>::{<span class="ident">Path</span>, <span class="ident">PathBuf</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">time</span>::{<span class="ident">SystemTime</span>, <span class="ident">UNIX_EPOCH</span>};
<span class="kw">use</span> <span class="ident">std</span>::{<span class="ident">cmp</span>, <span class="ident">io</span>};
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">marker</span>::<span class="ident">PhantomData</span>;
<span class="attribute">#[<span class="ident">cfg</span>(<span class="ident">unix</span>)]</span>
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">os</span>::<span class="ident">unix</span>::<span class="ident">fs</span>::<span class="ident">MetadataExt</span>;
@ -1816,13 +1821,13 @@
<span class="kw">use</span> <span class="ident">error</span>::{<span class="ident">Error</span>, <span class="ident">StaticFileError</span>};
<span class="kw">use</span> <span class="ident">handler</span>::{<span class="ident">AsyncResult</span>, <span class="ident">Handler</span>, <span class="ident">Responder</span>, <span class="ident">RouteHandler</span>, <span class="ident">WrapHandler</span>};
<span class="kw">use</span> <span class="ident">header</span>;
<span class="kw">use</span> <span class="ident">header</span>::{<span class="ident">ContentDisposition</span>, <span class="ident">DispositionParam</span>, <span class="ident">DispositionType</span>};
<span class="kw">use</span> <span class="ident">http</span>::{<span class="ident">ContentEncoding</span>, <span class="ident">Method</span>, <span class="ident">StatusCode</span>};
<span class="kw">use</span> <span class="ident">httpmessage</span>::<span class="ident">HttpMessage</span>;
<span class="kw">use</span> <span class="ident">httprequest</span>::<span class="ident">HttpRequest</span>;
<span class="kw">use</span> <span class="ident">httpresponse</span>::<span class="ident">HttpResponse</span>;
<span class="kw">use</span> <span class="ident">param</span>::<span class="ident">FromParam</span>;
<span class="kw">use</span> <span class="ident">server</span>::<span class="ident">settings</span>::<span class="ident">DEFAULT_CPUPOOL</span>;
<span class="kw">use</span> <span class="ident">header</span>::{<span class="ident">ContentDisposition</span>, <span class="ident">DispositionParam</span>, <span class="ident">DispositionType</span>};
<span class="doccomment">///Describes `StaticFiles` configiration</span>
<span class="doccomment">///</span>
@ -1900,7 +1905,7 @@
<span class="doccomment">/// A file with an associated name.</span>
<span class="attribute">#[<span class="ident">derive</span>(<span class="ident">Debug</span>)]</span>
<span class="kw">pub</span> <span class="kw">struct</span> <span class="ident">NamedFile</span><span class="op">&lt;</span><span class="ident">C</span><span class="op">=</span><span class="ident">DefaultConfig</span><span class="op">&gt;</span> {
<span class="kw">pub</span> <span class="kw">struct</span> <span class="ident">NamedFile</span><span class="op">&lt;</span><span class="ident">C</span> <span class="op">=</span> <span class="ident">DefaultConfig</span><span class="op">&gt;</span> {
<span class="ident">path</span>: <span class="ident">PathBuf</span>,
<span class="ident">file</span>: <span class="ident">File</span>,
<span class="ident">content_type</span>: <span class="ident">mime</span>::<span class="ident">Mime</span>,
@ -1982,7 +1987,7 @@
<span class="ident">cpu_pool</span>,
<span class="ident">encoding</span>,
<span class="ident">status_code</span>: <span class="ident">StatusCode</span>::<span class="ident">OK</span>,
<span class="ident">_cd_map</span>: <span class="ident">PhantomData</span>
<span class="ident">_cd_map</span>: <span class="ident">PhantomData</span>,
})
}
@ -2160,21 +2165,22 @@
<span class="kw">return</span> <span class="prelude-val">Ok</span>(<span class="ident">resp</span>.<span class="ident">streaming</span>(<span class="ident">reader</span>));
}
<span class="kw">if</span> <span class="op">!</span><span class="ident">C</span>::<span class="ident">is_method_allowed</span>(<span class="ident">req</span>.<span class="ident">method</span>())
{
<span class="kw">if</span> <span class="op">!</span><span class="ident">C</span>::<span class="ident">is_method_allowed</span>(<span class="ident">req</span>.<span class="ident">method</span>()) {
<span class="kw">return</span> <span class="prelude-val">Ok</span>(<span class="ident">HttpResponse</span>::<span class="ident">MethodNotAllowed</span>()
.<span class="ident">header</span>(<span class="ident">header</span>::<span class="ident">CONTENT_TYPE</span>, <span class="string">&quot;text/plain&quot;</span>)
.<span class="ident">header</span>(<span class="ident">header</span>::<span class="ident">ALLOW</span>, <span class="string">&quot;GET, HEAD&quot;</span>)
.<span class="ident">body</span>(<span class="string">&quot;This resource only supports GET and HEAD.&quot;</span>));
}
<span class="kw">let</span> <span class="ident">etag</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">C</span>::<span class="ident">is_use_etag</span>() {
<span class="bool-val">true</span> <span class="op">=&gt;</span> <span class="self">self</span>.<span class="ident">etag</span>(),
<span class="bool-val">false</span> <span class="op">=&gt;</span> <span class="prelude-val">None</span>,
<span class="kw">let</span> <span class="ident">etag</span> <span class="op">=</span> <span class="kw">if</span> <span class="ident">C</span>::<span class="ident">is_use_etag</span>() {
<span class="self">self</span>.<span class="ident">etag</span>()
} <span class="kw">else</span> {
<span class="prelude-val">None</span>
};
<span class="kw">let</span> <span class="ident">last_modified</span> <span class="op">=</span> <span class="kw">match</span> <span class="ident">C</span>::<span class="ident">is_use_last_modifier</span>() {
<span class="bool-val">true</span> <span class="op">=&gt;</span> <span class="self">self</span>.<span class="ident">last_modified</span>(),
<span class="bool-val">false</span> <span class="op">=&gt;</span> <span class="prelude-val">None</span>,
<span class="kw">let</span> <span class="ident">last_modified</span> <span class="op">=</span> <span class="kw">if</span> <span class="ident">C</span>::<span class="ident">is_use_last_modifier</span>() {
<span class="self">self</span>.<span class="ident">last_modified</span>()
} <span class="kw">else</span> {
<span class="prelude-val">None</span>
};
<span class="comment">// check preconditions</span>
@ -2431,7 +2437,7 @@
<span class="doccomment">/// .finish();</span>
<span class="doccomment">/// }</span>
<span class="doccomment">/// ```</span>
<span class="kw">pub</span> <span class="kw">struct</span> <span class="ident">StaticFiles</span><span class="op">&lt;</span><span class="ident">S</span>, <span class="ident">C</span><span class="op">=</span><span class="ident">DefaultConfig</span><span class="op">&gt;</span> {
<span class="kw">pub</span> <span class="kw">struct</span> <span class="ident">StaticFiles</span><span class="op">&lt;</span><span class="ident">S</span>, <span class="ident">C</span> <span class="op">=</span> <span class="ident">DefaultConfig</span><span class="op">&gt;</span> {
<span class="ident">directory</span>: <span class="ident">PathBuf</span>,
<span class="ident">index</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">show_index</span>: <span class="ident">bool</span>,
@ -2466,7 +2472,9 @@
<span class="doccomment">/// Create new `StaticFiles` instance for specified base directory.</span>
<span class="doccomment">///</span>
<span class="doccomment">/// Identical with `new` but allows to specify configiration to use.</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">with_config</span><span class="op">&lt;</span><span class="ident">T</span>: <span class="ident">Into</span><span class="op">&lt;</span><span class="ident">PathBuf</span><span class="op">&gt;&gt;</span>(<span class="ident">dir</span>: <span class="ident">T</span>, <span class="ident">config</span>: <span class="ident">C</span>) <span class="op">-&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span><span class="ident">StaticFiles</span><span class="op">&lt;</span><span class="ident">S</span>, <span class="ident">C</span><span class="op">&gt;</span>, <span class="ident">Error</span><span class="op">&gt;</span> {
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">with_config</span><span class="op">&lt;</span><span class="ident">T</span>: <span class="ident">Into</span><span class="op">&lt;</span><span class="ident">PathBuf</span><span class="op">&gt;&gt;</span>(
<span class="ident">dir</span>: <span class="ident">T</span>, <span class="ident">config</span>: <span class="ident">C</span>,
) <span class="op">-&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span><span class="ident">StaticFiles</span><span class="op">&lt;</span><span class="ident">S</span>, <span class="ident">C</span><span class="op">&gt;</span>, <span class="ident">Error</span><span class="op">&gt;</span> {
<span class="comment">// use default CpuPool</span>
<span class="kw">let</span> <span class="ident">pool</span> <span class="op">=</span> { <span class="ident">DEFAULT_CPUPOOL</span>.<span class="ident">lock</span>().<span class="ident">clone</span>() };
@ -2476,7 +2484,7 @@
<span class="doccomment">/// Create new `StaticFiles` instance for specified base directory with config and</span>
<span class="doccomment">/// `CpuPool`.</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">with_config_pool</span><span class="op">&lt;</span><span class="ident">T</span>: <span class="ident">Into</span><span class="op">&lt;</span><span class="ident">PathBuf</span><span class="op">&gt;&gt;</span>(
<span class="ident">dir</span>: <span class="ident">T</span>, <span class="ident">pool</span>: <span class="ident">CpuPool</span>, <span class="kw">_</span>: <span class="ident">C</span>
<span class="ident">dir</span>: <span class="ident">T</span>, <span class="ident">pool</span>: <span class="ident">CpuPool</span>, <span class="kw">_</span>: <span class="ident">C</span>,
) <span class="op">-&gt;</span> <span class="prelude-ty">Result</span><span class="op">&lt;</span><span class="ident">StaticFiles</span><span class="op">&lt;</span><span class="ident">S</span>, <span class="ident">C</span><span class="op">&gt;</span>, <span class="ident">Error</span><span class="op">&gt;</span> {
<span class="kw">let</span> <span class="ident">dir</span> <span class="op">=</span> <span class="ident">dir</span>.<span class="ident">into</span>().<span class="ident">canonicalize</span>()<span class="question-mark">?</span>;
@ -2495,7 +2503,7 @@
<span class="ident">renderer</span>: <span class="ident">Box</span>::<span class="ident">new</span>(<span class="ident">directory_listing</span>),
<span class="ident">_chunk_size</span>: <span class="number">0</span>,
<span class="ident">_follow_symlinks</span>: <span class="bool-val">false</span>,
<span class="ident">_cd_map</span>: <span class="ident">PhantomData</span>
<span class="ident">_cd_map</span>: <span class="ident">PhantomData</span>,
})
}
@ -2858,7 +2866,6 @@
<span class="ident">resp</span>.<span class="ident">headers</span>().<span class="ident">get</span>(<span class="ident">header</span>::<span class="ident">CONTENT_DISPOSITION</span>).<span class="ident">unwrap</span>(),
<span class="string">&quot;inline; filename=\&quot;test.png\&quot;&quot;</span>
);
}
<span class="attribute">#[<span class="ident">test</span>]</span>
@ -3090,24 +3097,27 @@
<span class="kw">fn</span> <span class="ident">is_method_allowed</span>(<span class="ident">method</span>: <span class="kw-2">&amp;</span><span class="ident">Method</span>) <span class="op">-&gt;</span> <span class="ident">bool</span> {
<span class="kw">match</span> <span class="kw-2">*</span><span class="ident">method</span> {
<span class="ident">Method</span>::<span class="ident">HEAD</span> <span class="op">=&gt;</span> <span class="bool-val">true</span>,
<span class="kw">_</span> <span class="op">=&gt;</span> <span class="bool-val">false</span>
<span class="kw">_</span> <span class="op">=&gt;</span> <span class="bool-val">false</span>,
}
}
}
<span class="attribute">#[<span class="ident">test</span>]</span>
<span class="kw">fn</span> <span class="ident">test_named_file_not_allowed</span>() {
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span> <span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span>
<span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">default</span>().<span class="ident">method</span>(<span class="ident">Method</span>::<span class="ident">POST</span>).<span class="ident">finish</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">file</span>.<span class="ident">respond_to</span>(<span class="kw-2">&amp;</span><span class="ident">req</span>).<span class="ident">unwrap</span>();
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">METHOD_NOT_ALLOWED</span>);
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span> <span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span>
<span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">default</span>().<span class="ident">method</span>(<span class="ident">Method</span>::<span class="ident">PUT</span>).<span class="ident">finish</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">file</span>.<span class="ident">respond_to</span>(<span class="kw-2">&amp;</span><span class="ident">req</span>).<span class="ident">unwrap</span>();
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">METHOD_NOT_ALLOWED</span>);
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span> <span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">file</span> <span class="op">=</span>
<span class="ident">NamedFile</span>::<span class="ident">open_with_config</span>(<span class="string">&quot;Cargo.toml&quot;</span>, <span class="ident">OnlyMethodHeadConfig</span>).<span class="ident">unwrap</span>();
<span class="kw">let</span> <span class="ident">req</span> <span class="op">=</span> <span class="ident">TestRequest</span>::<span class="ident">default</span>().<span class="ident">method</span>(<span class="ident">Method</span>::<span class="ident">GET</span>).<span class="ident">finish</span>();
<span class="kw">let</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">file</span>.<span class="ident">respond_to</span>(<span class="kw-2">&amp;</span><span class="ident">req</span>).<span class="ident">unwrap</span>();
<span class="macro">assert_eq</span><span class="macro">!</span>(<span class="ident">resp</span>.<span class="ident">status</span>(), <span class="ident">StatusCode</span>::<span class="ident">METHOD_NOT_ALLOWED</span>);

View File

@ -557,8 +557,6 @@
<span id="557">557</span>
<span id="558">558</span>
<span id="559">559</span>
<span id="560">560</span>
<span id="561">561</span>
</pre><pre class="rust ">
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">marker</span>::<span class="ident">PhantomData</span>;
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">ops</span>::<span class="ident">Deref</span>;
@ -970,9 +968,7 @@
<span class="bool-val">false</span>
}
<span class="kw">fn</span> <span class="ident">default_resource</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>, <span class="kw">_</span>: <span class="ident">DefaultResource</span><span class="op">&lt;</span><span class="ident">S</span><span class="op">&gt;</span>) {
<span class="macro">unimplemented</span><span class="macro">!</span>()
}
<span class="kw">fn</span> <span class="ident">default_resource</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>, <span class="kw">_</span>: <span class="ident">DefaultResource</span><span class="op">&lt;</span><span class="ident">S</span><span class="op">&gt;</span>) {}
<span class="kw">fn</span> <span class="ident">finish</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>) {}
}

View File

@ -344,9 +344,9 @@
<span class="doccomment">//! dependency</span>
<span class="doccomment">//! * `brotli` - enables `brotli` compression support, requires `c`</span>
<span class="doccomment">//! compiler</span>
<span class="doccomment">//! * `flate-c` - enables `gzip`, `deflate` compression support, requires</span>
<span class="doccomment">//! * `flate2-c` - enables `gzip`, `deflate` compression support, requires</span>
<span class="doccomment">//! `c` compiler</span>
<span class="doccomment">//! * `flate-rust` - experimental rust based implementation for</span>
<span class="doccomment">//! * `flate2-rust` - experimental rust based implementation for</span>
<span class="doccomment">//! `gzip`, `deflate` compression.</span>
<span class="doccomment">//!</span>
<span class="attribute">#![<span class="ident">cfg_attr</span>(<span class="ident">actix_nightly</span>, <span class="ident">feature</span>(

View File

@ -410,7 +410,7 @@
<span class="doccomment">/// default format:</span>
<span class="doccomment">///</span>
<span class="doccomment">/// ```ignore</span>
<span class="doccomment">/// %a %t &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T</span>
<span class="doccomment">/// %a &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T</span>
<span class="doccomment">/// ```</span>
<span class="doccomment">/// ```rust</span>
<span class="doccomment">/// # extern crate actix_web;</span>
@ -479,7 +479,7 @@
<span class="doccomment">/// Create `Logger` middleware with format:</span>
<span class="doccomment">///</span>
<span class="doccomment">/// ```ignore</span>
<span class="doccomment">/// %a %t &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T</span>
<span class="doccomment">/// %a &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T</span>
<span class="doccomment">/// ```</span>
<span class="kw">fn</span> <span class="ident">default</span>() <span class="op">-&gt;</span> <span class="ident">Logger</span> {
<span class="ident">Logger</span> {
@ -528,7 +528,7 @@
<span class="kw">impl</span> <span class="ident">Default</span> <span class="kw">for</span> <span class="ident">Format</span> {
<span class="doccomment">/// Return the default formatting style for the `Logger`:</span>
<span class="kw">fn</span> <span class="ident">default</span>() <span class="op">-&gt;</span> <span class="ident">Format</span> {
<span class="ident">Format</span>::<span class="ident">new</span>(<span class="string">r#&quot;%a %t &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T&quot;#</span>)
<span class="ident">Format</span>::<span class="ident">new</span>(<span class="string">r#&quot;%a &quot;%r&quot; %s %b &quot;%{Referer}i&quot; &quot;%{User-Agent}i&quot; %T&quot;#</span>)
}
}

View File

@ -605,6 +605,14 @@
<span id="605">605</span>
<span id="606">606</span>
<span id="607">607</span>
<span id="608">608</span>
<span id="609">609</span>
<span id="610">610</span>
<span id="611">611</span>
<span id="612">612</span>
<span id="613">613</span>
<span id="614">614</span>
<span id="615">615</span>
</pre><pre class="rust ">
<span class="doccomment">//! User sessions.</span>
<span class="doccomment">//!</span>
@ -966,6 +974,7 @@
<span class="ident">path</span>: <span class="ident">String</span>,
<span class="ident">domain</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">secure</span>: <span class="ident">bool</span>,
<span class="ident">http_only</span>: <span class="ident">bool</span>,
<span class="ident">max_age</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">Duration</span><span class="op">&gt;</span>,
<span class="ident">same_site</span>: <span class="prelude-ty">Option</span><span class="op">&lt;</span><span class="ident">SameSite</span><span class="op">&gt;</span>,
}
@ -979,6 +988,7 @@
<span class="ident">path</span>: <span class="string">&quot;/&quot;</span>.<span class="ident">to_owned</span>(),
<span class="ident">domain</span>: <span class="prelude-val">None</span>,
<span class="ident">secure</span>: <span class="bool-val">true</span>,
<span class="ident">http_only</span>: <span class="bool-val">true</span>,
<span class="ident">max_age</span>: <span class="prelude-val">None</span>,
<span class="ident">same_site</span>: <span class="prelude-val">None</span>,
}
@ -996,7 +1006,7 @@
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">cookie</span> <span class="op">=</span> <span class="ident">Cookie</span>::<span class="ident">new</span>(<span class="self">self</span>.<span class="ident">name</span>.<span class="ident">clone</span>(), <span class="ident">value</span>);
<span class="ident">cookie</span>.<span class="ident">set_path</span>(<span class="self">self</span>.<span class="ident">path</span>.<span class="ident">clone</span>());
<span class="ident">cookie</span>.<span class="ident">set_secure</span>(<span class="self">self</span>.<span class="ident">secure</span>);
<span class="ident">cookie</span>.<span class="ident">set_http_only</span>(<span class="bool-val">true</span>);
<span class="ident">cookie</span>.<span class="ident">set_http_only</span>(<span class="self">self</span>.<span class="ident">http_only</span>);
<span class="kw">if</span> <span class="kw">let</span> <span class="prelude-val">Some</span>(<span class="kw-2">ref</span> <span class="ident">domain</span>) <span class="op">=</span> <span class="self">self</span>.<span class="ident">domain</span> {
<span class="ident">cookie</span>.<span class="ident">set_domain</span>(<span class="ident">domain</span>.<span class="ident">clone</span>());
@ -1140,6 +1150,12 @@
<span class="self">self</span>
}
<span class="doccomment">/// Sets the `http_only` field in the session cookie being built.</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">http_only</span>(<span class="kw-2">mut</span> <span class="self">self</span>, <span class="ident">value</span>: <span class="ident">bool</span>) <span class="op">-&gt;</span> <span class="ident">CookieSessionBackend</span> {
<span class="ident">Rc</span>::<span class="ident">get_mut</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>.<span class="number">0</span>).<span class="ident">unwrap</span>().<span class="ident">http_only</span> <span class="op">=</span> <span class="ident">value</span>;
<span class="self">self</span>
}
<span class="doccomment">/// Sets the `same_site` field in the session cookie being built.</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">same_site</span>(<span class="kw-2">mut</span> <span class="self">self</span>, <span class="ident">value</span>: <span class="ident">SameSite</span>) <span class="op">-&gt;</span> <span class="ident">CookieSessionBackend</span> {
<span class="ident">Rc</span>::<span class="ident">get_mut</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="self">self</span>.<span class="number">0</span>).<span class="ident">unwrap</span>().<span class="ident">same_site</span> <span class="op">=</span> <span class="prelude-val">Some</span>(<span class="ident">value</span>);

View File

@ -1182,7 +1182,7 @@
<span class="ident">_h</span>: <span class="ident">PhantomData</span><span class="op">&lt;</span><span class="ident">H</span><span class="op">&gt;</span>,
}
<span class="attribute">#[<span class="ident">derive</span>(<span class="ident">PartialEq</span>)]</span>
<span class="attribute">#[<span class="ident">derive</span>(<span class="ident">PartialEq</span>, <span class="ident">Debug</span>)]</span>
<span class="kw">enum</span> <span class="ident">RunningState</span> {
<span class="ident">Running</span>,
<span class="ident">Paused</span>,

View File

@ -1555,7 +1555,7 @@
<span class="doccomment">///</span>
<span class="doccomment">/// Panics if path pattern is wrong.</span>
<span class="kw">pub</span> <span class="kw">fn</span> <span class="ident">new</span>(<span class="ident">path</span>: <span class="kw-2">&amp;</span><span class="ident">str</span>) <span class="op">-&gt;</span> <span class="self">Self</span> {
<span class="ident">ResourceDef</span>::<span class="ident">with_prefix</span>(<span class="ident">path</span>, <span class="string">&quot;/&quot;</span>, <span class="bool-val">false</span>)
<span class="ident">ResourceDef</span>::<span class="ident">with_prefix</span>(<span class="ident">path</span>, <span class="kw">if</span> <span class="ident">path</span>.<span class="ident">is_empty</span>() { <span class="string">&quot;&quot;</span> } <span class="kw">else</span> { <span class="string">&quot;/&quot;</span> }, <span class="bool-val">false</span>)
}
<span class="doccomment">/// Parse path pattern and create new `Resource` instance.</span>

View File

@ -440,6 +440,8 @@
<span id="440">440</span>
<span id="441">441</span>
<span id="442">442</span>
<span id="443">443</span>
<span id="444">444</span>
</pre><pre class="rust ">
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">collections</span>::<span class="ident">VecDeque</span>;
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">io</span>::{<span class="ident">Read</span>, <span class="ident">Write</span>};
@ -598,7 +600,9 @@
}
}
<span class="kw">if</span> <span class="op">!</span><span class="ident">item</span>.<span class="ident">flags</span>.<span class="ident">contains</span>(<span class="ident">EntryFlags</span>::<span class="ident">WRITE_DONE</span>) {
<span class="kw">if</span> <span class="ident">item</span>.<span class="ident">flags</span>.<span class="ident">contains</span>(<span class="ident">EntryFlags</span>::<span class="ident">FINISHED</span>)
<span class="op">&amp;&amp;</span> <span class="op">!</span><span class="ident">item</span>.<span class="ident">flags</span>.<span class="ident">contains</span>(<span class="ident">EntryFlags</span>::<span class="ident">WRITE_DONE</span>)
{
<span class="kw">match</span> <span class="ident">item</span>.<span class="ident">stream</span>.<span class="ident">poll_completed</span>(<span class="bool-val">false</span>) {
<span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">NotReady</span>) <span class="op">=&gt;</span> (),
<span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">Ready</span>(<span class="kw">_</span>)) <span class="op">=&gt;</span> {

View File

@ -240,6 +240,26 @@
<span id="240">240</span>
<span id="241">241</span>
<span id="242">242</span>
<span id="243">243</span>
<span id="244">244</span>
<span id="245">245</span>
<span id="246">246</span>
<span id="247">247</span>
<span id="248">248</span>
<span id="249">249</span>
<span id="250">250</span>
<span id="251">251</span>
<span id="252">252</span>
<span id="253">253</span>
<span id="254">254</span>
<span id="255">255</span>
<span id="256">256</span>
<span id="257">257</span>
<span id="258">258</span>
<span id="259">259</span>
<span id="260">260</span>
<span id="261">261</span>
<span id="262">262</span>
</pre><pre class="rust ">
<span class="attribute">#![<span class="ident">cfg_attr</span>(<span class="ident">feature</span> <span class="op">=</span> <span class="string">&quot;cargo-clippy&quot;</span>, <span class="ident">allow</span>(<span class="ident">redundant_field_names</span>))]</span>
@ -251,16 +271,18 @@
<span class="kw">use</span> <span class="ident">std</span>::<span class="ident">rc</span>::<span class="ident">Rc</span>;
<span class="kw">use</span> <span class="ident">std</span>::{<span class="ident">cmp</span>, <span class="ident">io</span>};
<span class="kw">use</span> <span class="ident">http</span>::<span class="ident">header</span>::{<span class="ident">HeaderValue</span>, <span class="ident">CONNECTION</span>, <span class="ident">CONTENT_LENGTH</span>, <span class="ident">DATE</span>, <span class="ident">TRANSFER_ENCODING</span>};
<span class="kw">use</span> <span class="ident">http</span>::{<span class="ident">HttpTryFrom</span>, <span class="ident">Method</span>, <span class="ident">Version</span>};
<span class="kw">use</span> <span class="kw">super</span>::<span class="ident">helpers</span>;
<span class="kw">use</span> <span class="kw">super</span>::<span class="ident">message</span>::<span class="ident">Request</span>;
<span class="kw">use</span> <span class="kw">super</span>::<span class="ident">output</span>::{<span class="ident">Output</span>, <span class="ident">ResponseInfo</span>};
<span class="kw">use</span> <span class="kw">super</span>::<span class="ident">output</span>::{<span class="ident">Output</span>, <span class="ident">ResponseInfo</span>, <span class="ident">ResponseLength</span>};
<span class="kw">use</span> <span class="kw">super</span>::<span class="ident">settings</span>::<span class="ident">WorkerSettings</span>;
<span class="kw">use</span> <span class="kw">super</span>::{<span class="ident">Writer</span>, <span class="ident">WriterState</span>, <span class="ident">MAX_WRITE_BUFFER_SIZE</span>};
<span class="kw">use</span> <span class="ident">body</span>::{<span class="ident">Binary</span>, <span class="ident">Body</span>};
<span class="kw">use</span> <span class="ident">header</span>::<span class="ident">ContentEncoding</span>;
<span class="kw">use</span> <span class="ident">http</span>::<span class="ident">header</span>::{
<span class="ident">HeaderValue</span>, <span class="ident">CONNECTION</span>, <span class="ident">CONTENT_ENCODING</span>, <span class="ident">CONTENT_LENGTH</span>, <span class="ident">DATE</span>, <span class="ident">TRANSFER_ENCODING</span>,
};
<span class="kw">use</span> <span class="ident">httpresponse</span>::<span class="ident">HttpResponse</span>;
<span class="kw">const</span> <span class="ident">CHUNK_SIZE</span>: <span class="ident">usize</span> <span class="op">=</span> <span class="number">16_384</span>;
@ -335,50 +357,63 @@
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">info</span> <span class="op">=</span> <span class="ident">ResponseInfo</span>::<span class="ident">new</span>(<span class="ident">req</span>.<span class="ident">inner</span>.<span class="ident">method</span> <span class="op">==</span> <span class="ident">Method</span>::<span class="ident">HEAD</span>);
<span class="self">self</span>.<span class="ident">buffer</span>.<span class="ident">for_server</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">info</span>, <span class="kw-2">&amp;</span><span class="ident">req</span>.<span class="ident">inner</span>, <span class="ident">msg</span>, <span class="ident">encoding</span>);
<span class="comment">// http2 specific</span>
<span class="ident">msg</span>.<span class="ident">headers_mut</span>().<span class="ident">remove</span>(<span class="ident">CONNECTION</span>);
<span class="ident">msg</span>.<span class="ident">headers_mut</span>().<span class="ident">remove</span>(<span class="ident">TRANSFER_ENCODING</span>);
<span class="comment">// using helpers::date is quite a lot faster</span>
<span class="kw">if</span> <span class="op">!</span><span class="ident">msg</span>.<span class="ident">headers</span>().<span class="ident">contains_key</span>(<span class="ident">DATE</span>) {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">bytes</span> <span class="op">=</span> <span class="ident">BytesMut</span>::<span class="ident">with_capacity</span>(<span class="number">29</span>);
<span class="self">self</span>.<span class="ident">settings</span>.<span class="ident">set_date</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">bytes</span>, <span class="bool-val">false</span>);
<span class="ident">msg</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">DATE</span>, <span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">bytes</span>.<span class="ident">freeze</span>()).<span class="ident">unwrap</span>());
}
<span class="kw">let</span> <span class="ident">body</span> <span class="op">=</span> <span class="ident">msg</span>.<span class="ident">replace_body</span>(<span class="ident">Body</span>::<span class="ident">Empty</span>);
<span class="kw">match</span> <span class="ident">body</span> {
<span class="ident">Body</span>::<span class="ident">Binary</span>(<span class="kw-2">ref</span> <span class="ident">bytes</span>) <span class="op">=&gt;</span> {
<span class="kw">if</span> <span class="ident">bytes</span>.<span class="ident">is_empty</span>() {
<span class="ident">msg</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">CONTENT_LENGTH</span>, <span class="ident">HeaderValue</span>::<span class="ident">from_static</span>(<span class="string">&quot;0&quot;</span>));
<span class="self">self</span>.<span class="ident">flags</span>.<span class="ident">insert</span>(<span class="ident">Flags</span>::<span class="ident">EOF</span>);
} <span class="kw">else</span> {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">val</span> <span class="op">=</span> <span class="ident">BytesMut</span>::<span class="ident">new</span>();
<span class="ident">helpers</span>::<span class="ident">convert_usize</span>(<span class="ident">bytes</span>.<span class="ident">len</span>(), <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">val</span>);
<span class="kw">let</span> <span class="ident">l</span> <span class="op">=</span> <span class="ident">val</span>.<span class="ident">len</span>();
<span class="ident">msg</span>.<span class="ident">headers_mut</span>().<span class="ident">insert</span>(
<span class="ident">CONTENT_LENGTH</span>,
<span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">val</span>.<span class="ident">split_to</span>(<span class="ident">l</span> <span class="op">-</span> <span class="number">2</span>).<span class="ident">freeze</span>()).<span class="ident">unwrap</span>(),
);
}
}
<span class="ident">Body</span>::<span class="ident">Empty</span> <span class="op">=&gt;</span> {
<span class="self">self</span>.<span class="ident">flags</span>.<span class="ident">insert</span>(<span class="ident">Flags</span>::<span class="ident">EOF</span>);
<span class="ident">msg</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">CONTENT_LENGTH</span>, <span class="ident">HeaderValue</span>::<span class="ident">from_static</span>(<span class="string">&quot;0&quot;</span>));
}
<span class="kw">_</span> <span class="op">=&gt;</span> (),
}
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">has_date</span> <span class="op">=</span> <span class="bool-val">false</span>;
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">resp</span> <span class="op">=</span> <span class="ident">Response</span>::<span class="ident">new</span>(());
<span class="kw-2">*</span><span class="ident">resp</span>.<span class="ident">status_mut</span>() <span class="op">=</span> <span class="ident">msg</span>.<span class="ident">status</span>();
<span class="kw-2">*</span><span class="ident">resp</span>.<span class="ident">version_mut</span>() <span class="op">=</span> <span class="ident">Version</span>::<span class="ident">HTTP_2</span>;
<span class="kw">for</span> (<span class="ident">key</span>, <span class="ident">value</span>) <span class="kw">in</span> <span class="ident">msg</span>.<span class="ident">headers</span>().<span class="ident">iter</span>() {
<span class="kw">match</span> <span class="kw-2">*</span><span class="ident">key</span> {
<span class="comment">// http2 specific</span>
<span class="ident">CONNECTION</span> <span class="op">|</span> <span class="ident">TRANSFER_ENCODING</span> <span class="op">=&gt;</span> <span class="kw">continue</span>,
<span class="ident">CONTENT_ENCODING</span> <span class="op">=&gt;</span> <span class="kw">if</span> <span class="ident">encoding</span> <span class="op">!=</span> <span class="ident">ContentEncoding</span>::<span class="ident">Identity</span> {
<span class="kw">continue</span>;
},
<span class="ident">CONTENT_LENGTH</span> <span class="op">=&gt;</span> <span class="kw">match</span> <span class="ident">info</span>.<span class="ident">length</span> {
<span class="ident">ResponseLength</span>::<span class="prelude-val">None</span> <span class="op">=&gt;</span> (),
<span class="kw">_</span> <span class="op">=&gt;</span> <span class="kw">continue</span>,
},
<span class="ident">DATE</span> <span class="op">=&gt;</span> <span class="ident">has_date</span> <span class="op">=</span> <span class="bool-val">true</span>,
<span class="kw">_</span> <span class="op">=&gt;</span> (),
}
<span class="ident">resp</span>.<span class="ident">headers_mut</span>().<span class="ident">insert</span>(<span class="ident">key</span>, <span class="ident">value</span>.<span class="ident">clone</span>());
}
<span class="comment">// set date header</span>
<span class="kw">if</span> <span class="op">!</span><span class="ident">has_date</span> {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">bytes</span> <span class="op">=</span> <span class="ident">BytesMut</span>::<span class="ident">with_capacity</span>(<span class="number">29</span>);
<span class="self">self</span>.<span class="ident">settings</span>.<span class="ident">set_date</span>(<span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">bytes</span>, <span class="bool-val">false</span>);
<span class="ident">resp</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">DATE</span>, <span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">bytes</span>.<span class="ident">freeze</span>()).<span class="ident">unwrap</span>());
}
<span class="comment">// content length</span>
<span class="kw">match</span> <span class="ident">info</span>.<span class="ident">length</span> {
<span class="ident">ResponseLength</span>::<span class="ident">Zero</span> <span class="op">=&gt;</span> {
<span class="ident">resp</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">CONTENT_LENGTH</span>, <span class="ident">HeaderValue</span>::<span class="ident">from_static</span>(<span class="string">&quot;0&quot;</span>));
<span class="self">self</span>.<span class="ident">flags</span>.<span class="ident">insert</span>(<span class="ident">Flags</span>::<span class="ident">EOF</span>);
}
<span class="ident">ResponseLength</span>::<span class="ident">Length</span>(<span class="ident">len</span>) <span class="op">=&gt;</span> {
<span class="kw">let</span> <span class="kw-2">mut</span> <span class="ident">val</span> <span class="op">=</span> <span class="ident">BytesMut</span>::<span class="ident">new</span>();
<span class="ident">helpers</span>::<span class="ident">convert_usize</span>(<span class="ident">len</span>, <span class="kw-2">&amp;</span><span class="kw-2">mut</span> <span class="ident">val</span>);
<span class="kw">let</span> <span class="ident">l</span> <span class="op">=</span> <span class="ident">val</span>.<span class="ident">len</span>();
<span class="ident">resp</span>.<span class="ident">headers_mut</span>().<span class="ident">insert</span>(
<span class="ident">CONTENT_LENGTH</span>,
<span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">val</span>.<span class="ident">split_to</span>(<span class="ident">l</span> <span class="op">-</span> <span class="number">2</span>).<span class="ident">freeze</span>()).<span class="ident">unwrap</span>(),
);
}
<span class="ident">ResponseLength</span>::<span class="ident">Length64</span>(<span class="ident">len</span>) <span class="op">=&gt;</span> {
<span class="kw">let</span> <span class="ident">l</span> <span class="op">=</span> <span class="macro">format</span><span class="macro">!</span>(<span class="string">&quot;{}&quot;</span>, <span class="ident">len</span>);
<span class="ident">resp</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">CONTENT_LENGTH</span>, <span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">l</span>.<span class="ident">as_str</span>()).<span class="ident">unwrap</span>());
}
<span class="kw">_</span> <span class="op">=&gt;</span> (),
}
<span class="kw">if</span> <span class="kw">let</span> <span class="prelude-val">Some</span>(<span class="ident">ce</span>) <span class="op">=</span> <span class="ident">info</span>.<span class="ident">content_encoding</span> {
<span class="ident">resp</span>.<span class="ident">headers_mut</span>()
.<span class="ident">insert</span>(<span class="ident">CONTENT_ENCODING</span>, <span class="ident">HeaderValue</span>::<span class="ident">try_from</span>(<span class="ident">ce</span>).<span class="ident">unwrap</span>());
}
<span class="kw">match</span> <span class="self">self</span>
.<span class="ident">respond</span>
.<span class="ident">send_response</span>(<span class="ident">resp</span>, <span class="self">self</span>.<span class="ident">flags</span>.<span class="ident">contains</span>(<span class="ident">Flags</span>::<span class="ident">EOF</span>))
@ -389,6 +424,7 @@
<span class="macro">trace</span><span class="macro">!</span>(<span class="string">&quot;Response: {:?}&quot;</span>, <span class="ident">msg</span>);
<span class="kw">let</span> <span class="ident">body</span> <span class="op">=</span> <span class="ident">msg</span>.<span class="ident">replace_body</span>(<span class="ident">Body</span>::<span class="ident">Empty</span>);
<span class="kw">if</span> <span class="kw">let</span> <span class="ident">Body</span>::<span class="ident">Binary</span>(<span class="ident">bytes</span>) <span class="op">=</span> <span class="ident">body</span> {
<span class="kw">if</span> <span class="ident">bytes</span>.<span class="ident">is_empty</span>() {
<span class="prelude-val">Ok</span>(<span class="ident">WriterState</span>::<span class="ident">Done</span>)
@ -472,15 +508,19 @@
<span class="kw">let</span> <span class="ident">cap</span> <span class="op">=</span> <span class="ident">cmp</span>::<span class="ident">min</span>(<span class="self">self</span>.<span class="ident">buffer</span>.<span class="ident">len</span>(), <span class="ident">CHUNK_SIZE</span>);
<span class="ident">stream</span>.<span class="ident">reserve_capacity</span>(<span class="ident">cap</span>);
} <span class="kw">else</span> {
<span class="kw">if</span> <span class="ident">eof</span> {
<span class="ident">stream</span>.<span class="ident">reserve_capacity</span>(<span class="number">0</span>);
<span class="kw">continue</span>;
}
<span class="self">self</span>.<span class="ident">flags</span>.<span class="ident">remove</span>(<span class="ident">Flags</span>::<span class="ident">RESERVED</span>);
<span class="kw">return</span> <span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">NotReady</span>);
<span class="kw">return</span> <span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">Ready</span>(()));
}
}
<span class="prelude-val">Err</span>(<span class="ident">e</span>) <span class="op">=&gt;</span> <span class="kw">return</span> <span class="prelude-val">Err</span>(<span class="ident">io</span>::<span class="ident">Error</span>::<span class="ident">new</span>(<span class="ident">io</span>::<span class="ident">ErrorKind</span>::<span class="ident">Other</span>, <span class="ident">e</span>)),
}
}
}
<span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">NotReady</span>)
<span class="prelude-val">Ok</span>(<span class="ident">Async</span>::<span class="ident">Ready</span>(()))
}
}
</pre>