1#[cfg(all(any(feature = "client", feature = "server"), feature = "http1"))]
4use bytes::Bytes;
5#[cfg(any(
6    all(any(feature = "client", feature = "server"), feature = "http1"),
7    feature = "ffi"
8))]
9use http::header::HeaderName;
10#[cfg(all(any(feature = "client", feature = "server"), feature = "http1"))]
11use http::header::{HeaderMap, IntoHeaderName, ValueIter};
12#[cfg(feature = "ffi")]
13use std::collections::HashMap;
14#[cfg(feature = "http2")]
15use std::fmt;
16
17#[cfg(any(feature = "http1", feature = "ffi"))]
18mod h1_reason_phrase;
19#[cfg(any(feature = "http1", feature = "ffi"))]
20pub use h1_reason_phrase::ReasonPhrase;
21
22#[cfg(feature = "http2")]
23#[derive(Clone, Eq, PartialEq)]
28pub struct Protocol {
29    inner: h2::ext::Protocol,
30}
31
32#[cfg(feature = "http2")]
33impl Protocol {
34    pub const fn from_static(value: &'static str) -> Self {
36        Self {
37            inner: h2::ext::Protocol::from_static(value),
38        }
39    }
40
41    pub fn as_str(&self) -> &str {
43        self.inner.as_str()
44    }
45
46    #[cfg(feature = "server")]
47    pub(crate) fn from_inner(inner: h2::ext::Protocol) -> Self {
48        Self { inner }
49    }
50
51    #[cfg(all(feature = "client", feature = "http2"))]
52    pub(crate) fn into_inner(self) -> h2::ext::Protocol {
53        self.inner
54    }
55}
56
57#[cfg(feature = "http2")]
58impl<'a> From<&'a str> for Protocol {
59    fn from(value: &'a str) -> Self {
60        Self {
61            inner: h2::ext::Protocol::from(value),
62        }
63    }
64}
65
66#[cfg(feature = "http2")]
67impl AsRef<[u8]> for Protocol {
68    fn as_ref(&self) -> &[u8] {
69        self.inner.as_ref()
70    }
71}
72
73#[cfg(feature = "http2")]
74impl fmt::Debug for Protocol {
75    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
76        self.inner.fmt(f)
77    }
78}
79
80#[cfg(all(any(feature = "client", feature = "server"), feature = "http1"))]
102#[derive(Clone, Debug)]
103pub(crate) struct HeaderCaseMap(HeaderMap<Bytes>);
104
105#[cfg(all(any(feature = "client", feature = "server"), feature = "http1"))]
106impl HeaderCaseMap {
107    #[cfg(feature = "client")]
110    pub(crate) fn get_all<'a>(
111        &'a self,
112        name: &HeaderName,
113    ) -> impl Iterator<Item = impl AsRef<[u8]> + 'a> + 'a {
114        self.get_all_internal(name)
115    }
116
117    #[cfg(any(feature = "client", feature = "server"))]
120    pub(crate) fn get_all_internal(&self, name: &HeaderName) -> ValueIter<'_, Bytes> {
121        self.0.get_all(name).into_iter()
122    }
123
124    #[cfg(any(feature = "client", feature = "server"))]
125    pub(crate) fn default() -> Self {
126        Self(Default::default())
127    }
128
129    #[cfg(any(test, feature = "ffi"))]
130    pub(crate) fn insert(&mut self, name: HeaderName, orig: Bytes) {
131        self.0.insert(name, orig);
132    }
133
134    #[cfg(any(feature = "client", feature = "server"))]
135    pub(crate) fn append<N>(&mut self, name: N, orig: Bytes)
136    where
137        N: IntoHeaderName,
138    {
139        self.0.append(name, orig);
140    }
141}
142
143#[cfg(feature = "ffi")]
144#[derive(Clone, Debug)]
145pub(crate) struct OriginalHeaderOrder {
147    num_entries: HashMap<HeaderName, usize>,
150    entry_order: Vec<(HeaderName, usize)>,
156}
157
158#[cfg(all(feature = "http1", feature = "ffi"))]
159impl OriginalHeaderOrder {
160    pub(crate) fn default() -> Self {
161        OriginalHeaderOrder {
162            num_entries: HashMap::new(),
163            entry_order: Vec::new(),
164        }
165    }
166
167    pub(crate) fn insert(&mut self, name: HeaderName) {
168        if !self.num_entries.contains_key(&name) {
169            let idx = 0;
170            self.num_entries.insert(name.clone(), 1);
171            self.entry_order.push((name, idx));
172        }
173        }
177
178    pub(crate) fn append<N>(&mut self, name: N)
179    where
180        N: IntoHeaderName + Into<HeaderName> + Clone,
181    {
182        let name: HeaderName = name.into();
183        let idx;
184        if self.num_entries.contains_key(&name) {
185            idx = self.num_entries[&name];
186            *self.num_entries.get_mut(&name).unwrap() += 1;
187        } else {
188            idx = 0;
189            self.num_entries.insert(name.clone(), 1);
190        }
191        self.entry_order.push((name, idx));
192    }
193
194    pub(crate) fn get_in_order(&self) -> impl Iterator<Item = &(HeaderName, usize)> {
235        self.entry_order.iter()
236    }
237}