1use tower::ServiceBuilder;
2
3#[allow(unused_imports)]
4use http::header::HeaderName;
5#[allow(unused_imports)]
6use tower_layer::Stack;
7
8mod sealed {
9 #[allow(unreachable_pub, unused)]
10 pub trait Sealed<T> {}
11}
12
13#[cfg(feature = "util")]
46pub trait ServiceBuilderExt<L>: sealed::Sealed<L> + Sized {
48 #[cfg(feature = "propagate-header")]
54 fn propagate_header(
55 self,
56 header: HeaderName,
57 ) -> ServiceBuilder<Stack<crate::propagate_header::PropagateHeaderLayer, L>>;
58
59 #[cfg(feature = "add-extension")]
66 fn add_extension<T>(
67 self,
68 value: T,
69 ) -> ServiceBuilder<Stack<crate::add_extension::AddExtensionLayer<T>, L>>;
70
71 #[cfg(feature = "map-request-body")]
77 fn map_request_body<F>(
78 self,
79 f: F,
80 ) -> ServiceBuilder<Stack<crate::map_request_body::MapRequestBodyLayer<F>, L>>;
81
82 #[cfg(feature = "map-response-body")]
88 fn map_response_body<F>(
89 self,
90 f: F,
91 ) -> ServiceBuilder<Stack<crate::map_response_body::MapResponseBodyLayer<F>, L>>;
92
93 #[cfg(any(
99 feature = "compression-br",
100 feature = "compression-deflate",
101 feature = "compression-gzip",
102 feature = "compression-zstd",
103 ))]
104 fn compression(self) -> ServiceBuilder<Stack<crate::compression::CompressionLayer, L>>;
105
106 #[cfg(any(
112 feature = "decompression-br",
113 feature = "decompression-deflate",
114 feature = "decompression-gzip",
115 feature = "decompression-zstd",
116 ))]
117 fn decompression(self) -> ServiceBuilder<Stack<crate::decompression::DecompressionLayer, L>>;
118
119 #[cfg(feature = "trace")]
129 fn trace_for_http(
130 self,
131 ) -> ServiceBuilder<Stack<crate::trace::TraceLayer<crate::trace::HttpMakeClassifier>, L>>;
132
133 #[cfg(feature = "trace")]
143 fn trace_for_grpc(
144 self,
145 ) -> ServiceBuilder<Stack<crate::trace::TraceLayer<crate::trace::GrpcMakeClassifier>, L>>;
146
147 #[cfg(feature = "follow-redirect")]
154 fn follow_redirects(
155 self,
156 ) -> ServiceBuilder<
157 Stack<
158 crate::follow_redirect::FollowRedirectLayer<crate::follow_redirect::policy::Standard>,
159 L,
160 >,
161 >;
162
163 #[cfg(feature = "sensitive-headers")]
170 fn sensitive_headers<I>(
171 self,
172 headers: I,
173 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveHeadersLayer, L>>
174 where
175 I: IntoIterator<Item = HeaderName>;
176
177 #[cfg(feature = "sensitive-headers")]
184 fn sensitive_request_headers(
185 self,
186 headers: std::sync::Arc<[HeaderName]>,
187 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveRequestHeadersLayer, L>>;
188
189 #[cfg(feature = "sensitive-headers")]
196 fn sensitive_response_headers(
197 self,
198 headers: std::sync::Arc<[HeaderName]>,
199 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveResponseHeadersLayer, L>>;
200
201 #[cfg(feature = "set-header")]
210 fn override_request_header<M>(
211 self,
212 header_name: HeaderName,
213 make: M,
214 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>>;
215
216 #[cfg(feature = "set-header")]
224 fn append_request_header<M>(
225 self,
226 header_name: HeaderName,
227 make: M,
228 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>>;
229
230 #[cfg(feature = "set-header")]
236 fn insert_request_header_if_not_present<M>(
237 self,
238 header_name: HeaderName,
239 make: M,
240 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>>;
241
242 #[cfg(feature = "set-header")]
251 fn override_response_header<M>(
252 self,
253 header_name: HeaderName,
254 make: M,
255 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>>;
256
257 #[cfg(feature = "set-header")]
265 fn append_response_header<M>(
266 self,
267 header_name: HeaderName,
268 make: M,
269 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>>;
270
271 #[cfg(feature = "set-header")]
277 fn insert_response_header_if_not_present<M>(
278 self,
279 header_name: HeaderName,
280 make: M,
281 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>>;
282
283 #[cfg(feature = "request-id")]
289 fn set_request_id<M>(
290 self,
291 header_name: HeaderName,
292 make_request_id: M,
293 ) -> ServiceBuilder<Stack<crate::request_id::SetRequestIdLayer<M>, L>>
294 where
295 M: crate::request_id::MakeRequestId;
296
297 #[cfg(feature = "request-id")]
303 fn set_x_request_id<M>(
304 self,
305 make_request_id: M,
306 ) -> ServiceBuilder<Stack<crate::request_id::SetRequestIdLayer<M>, L>>
307 where
308 M: crate::request_id::MakeRequestId,
309 {
310 self.set_request_id(crate::request_id::X_REQUEST_ID, make_request_id)
311 }
312
313 #[cfg(feature = "request-id")]
319 fn propagate_request_id(
320 self,
321 header_name: HeaderName,
322 ) -> ServiceBuilder<Stack<crate::request_id::PropagateRequestIdLayer, L>>;
323
324 #[cfg(feature = "request-id")]
330 fn propagate_x_request_id(
331 self,
332 ) -> ServiceBuilder<Stack<crate::request_id::PropagateRequestIdLayer, L>> {
333 self.propagate_request_id(crate::request_id::X_REQUEST_ID)
334 }
335
336 #[cfg(feature = "catch-panic")]
342 fn catch_panic(
343 self,
344 ) -> ServiceBuilder<
345 Stack<crate::catch_panic::CatchPanicLayer<crate::catch_panic::DefaultResponseForPanic>, L>,
346 >;
347
348 #[cfg(feature = "limit")]
355 fn request_body_limit(
356 self,
357 limit: usize,
358 ) -> ServiceBuilder<Stack<crate::limit::RequestBodyLimitLayer, L>>;
359
360 #[cfg(feature = "normalize-path")]
366 fn trim_trailing_slash(
367 self,
368 ) -> ServiceBuilder<Stack<crate::normalize_path::NormalizePathLayer, L>>;
369}
370
371impl<L> sealed::Sealed<L> for ServiceBuilder<L> {}
372
373impl<L> ServiceBuilderExt<L> for ServiceBuilder<L> {
374 #[cfg(feature = "propagate-header")]
375 fn propagate_header(
376 self,
377 header: HeaderName,
378 ) -> ServiceBuilder<Stack<crate::propagate_header::PropagateHeaderLayer, L>> {
379 self.layer(crate::propagate_header::PropagateHeaderLayer::new(header))
380 }
381
382 #[cfg(feature = "add-extension")]
383 fn add_extension<T>(
384 self,
385 value: T,
386 ) -> ServiceBuilder<Stack<crate::add_extension::AddExtensionLayer<T>, L>> {
387 self.layer(crate::add_extension::AddExtensionLayer::new(value))
388 }
389
390 #[cfg(feature = "map-request-body")]
391 fn map_request_body<F>(
392 self,
393 f: F,
394 ) -> ServiceBuilder<Stack<crate::map_request_body::MapRequestBodyLayer<F>, L>> {
395 self.layer(crate::map_request_body::MapRequestBodyLayer::new(f))
396 }
397
398 #[cfg(feature = "map-response-body")]
399 fn map_response_body<F>(
400 self,
401 f: F,
402 ) -> ServiceBuilder<Stack<crate::map_response_body::MapResponseBodyLayer<F>, L>> {
403 self.layer(crate::map_response_body::MapResponseBodyLayer::new(f))
404 }
405
406 #[cfg(any(
407 feature = "compression-br",
408 feature = "compression-deflate",
409 feature = "compression-gzip",
410 feature = "compression-zstd",
411 ))]
412 fn compression(self) -> ServiceBuilder<Stack<crate::compression::CompressionLayer, L>> {
413 self.layer(crate::compression::CompressionLayer::new())
414 }
415
416 #[cfg(any(
417 feature = "decompression-br",
418 feature = "decompression-deflate",
419 feature = "decompression-gzip",
420 feature = "decompression-zstd",
421 ))]
422 fn decompression(self) -> ServiceBuilder<Stack<crate::decompression::DecompressionLayer, L>> {
423 self.layer(crate::decompression::DecompressionLayer::new())
424 }
425
426 #[cfg(feature = "trace")]
427 fn trace_for_http(
428 self,
429 ) -> ServiceBuilder<Stack<crate::trace::TraceLayer<crate::trace::HttpMakeClassifier>, L>> {
430 self.layer(crate::trace::TraceLayer::new_for_http())
431 }
432
433 #[cfg(feature = "trace")]
434 fn trace_for_grpc(
435 self,
436 ) -> ServiceBuilder<Stack<crate::trace::TraceLayer<crate::trace::GrpcMakeClassifier>, L>> {
437 self.layer(crate::trace::TraceLayer::new_for_grpc())
438 }
439
440 #[cfg(feature = "follow-redirect")]
441 fn follow_redirects(
442 self,
443 ) -> ServiceBuilder<
444 Stack<
445 crate::follow_redirect::FollowRedirectLayer<crate::follow_redirect::policy::Standard>,
446 L,
447 >,
448 > {
449 self.layer(crate::follow_redirect::FollowRedirectLayer::new())
450 }
451
452 #[cfg(feature = "sensitive-headers")]
453 fn sensitive_headers<I>(
454 self,
455 headers: I,
456 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveHeadersLayer, L>>
457 where
458 I: IntoIterator<Item = HeaderName>,
459 {
460 self.layer(crate::sensitive_headers::SetSensitiveHeadersLayer::new(
461 headers,
462 ))
463 }
464
465 #[cfg(feature = "sensitive-headers")]
466 fn sensitive_request_headers(
467 self,
468 headers: std::sync::Arc<[HeaderName]>,
469 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveRequestHeadersLayer, L>> {
470 self.layer(crate::sensitive_headers::SetSensitiveRequestHeadersLayer::from_shared(headers))
471 }
472
473 #[cfg(feature = "sensitive-headers")]
474 fn sensitive_response_headers(
475 self,
476 headers: std::sync::Arc<[HeaderName]>,
477 ) -> ServiceBuilder<Stack<crate::sensitive_headers::SetSensitiveResponseHeadersLayer, L>> {
478 self.layer(crate::sensitive_headers::SetSensitiveResponseHeadersLayer::from_shared(headers))
479 }
480
481 #[cfg(feature = "set-header")]
482 fn override_request_header<M>(
483 self,
484 header_name: HeaderName,
485 make: M,
486 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>> {
487 self.layer(crate::set_header::SetRequestHeaderLayer::overriding(
488 header_name,
489 make,
490 ))
491 }
492
493 #[cfg(feature = "set-header")]
494 fn append_request_header<M>(
495 self,
496 header_name: HeaderName,
497 make: M,
498 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>> {
499 self.layer(crate::set_header::SetRequestHeaderLayer::appending(
500 header_name,
501 make,
502 ))
503 }
504
505 #[cfg(feature = "set-header")]
506 fn insert_request_header_if_not_present<M>(
507 self,
508 header_name: HeaderName,
509 make: M,
510 ) -> ServiceBuilder<Stack<crate::set_header::SetRequestHeaderLayer<M>, L>> {
511 self.layer(crate::set_header::SetRequestHeaderLayer::if_not_present(
512 header_name,
513 make,
514 ))
515 }
516
517 #[cfg(feature = "set-header")]
518 fn override_response_header<M>(
519 self,
520 header_name: HeaderName,
521 make: M,
522 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>> {
523 self.layer(crate::set_header::SetResponseHeaderLayer::overriding(
524 header_name,
525 make,
526 ))
527 }
528
529 #[cfg(feature = "set-header")]
530 fn append_response_header<M>(
531 self,
532 header_name: HeaderName,
533 make: M,
534 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>> {
535 self.layer(crate::set_header::SetResponseHeaderLayer::appending(
536 header_name,
537 make,
538 ))
539 }
540
541 #[cfg(feature = "set-header")]
542 fn insert_response_header_if_not_present<M>(
543 self,
544 header_name: HeaderName,
545 make: M,
546 ) -> ServiceBuilder<Stack<crate::set_header::SetResponseHeaderLayer<M>, L>> {
547 self.layer(crate::set_header::SetResponseHeaderLayer::if_not_present(
548 header_name,
549 make,
550 ))
551 }
552
553 #[cfg(feature = "request-id")]
554 fn set_request_id<M>(
555 self,
556 header_name: HeaderName,
557 make_request_id: M,
558 ) -> ServiceBuilder<Stack<crate::request_id::SetRequestIdLayer<M>, L>>
559 where
560 M: crate::request_id::MakeRequestId,
561 {
562 self.layer(crate::request_id::SetRequestIdLayer::new(
563 header_name,
564 make_request_id,
565 ))
566 }
567
568 #[cfg(feature = "request-id")]
569 fn propagate_request_id(
570 self,
571 header_name: HeaderName,
572 ) -> ServiceBuilder<Stack<crate::request_id::PropagateRequestIdLayer, L>> {
573 self.layer(crate::request_id::PropagateRequestIdLayer::new(header_name))
574 }
575
576 #[cfg(feature = "catch-panic")]
577 fn catch_panic(
578 self,
579 ) -> ServiceBuilder<
580 Stack<crate::catch_panic::CatchPanicLayer<crate::catch_panic::DefaultResponseForPanic>, L>,
581 > {
582 self.layer(crate::catch_panic::CatchPanicLayer::new())
583 }
584
585 #[cfg(feature = "limit")]
586 fn request_body_limit(
587 self,
588 limit: usize,
589 ) -> ServiceBuilder<Stack<crate::limit::RequestBodyLimitLayer, L>> {
590 self.layer(crate::limit::RequestBodyLimitLayer::new(limit))
591 }
592
593 #[cfg(feature = "normalize-path")]
594 fn trim_trailing_slash(
595 self,
596 ) -> ServiceBuilder<Stack<crate::normalize_path::NormalizePathLayer, L>> {
597 self.layer(crate::normalize_path::NormalizePathLayer::trim_trailing_slash())
598 }
599}