From c6caacc946517eb8152c327353e177ce387a3478 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Rami=CC=81rez=20Mondrago=CC=81n?= Date: Fri, 3 Feb 2023 12:17:05 -0600 Subject: [PATCH] docs: Add `requests.auth` code sample --- docs/code_samples.md | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/docs/code_samples.md b/docs/code_samples.md index e76db4d46..90d9682e8 100644 --- a/docs/code_samples.md +++ b/docs/code_samples.md @@ -255,6 +255,34 @@ class CachedAuthStream(RESTStream): return APIAuthenticatorBase(stream=self) ``` +### Use one of `requests`'s built-in authenticators + +```python +from requests.auth import HTTPDigestAuth +from singer_sdk.streams import RESTStream + +class DigestAuthStream(RESTStream): + """A stream with digest authentication.""" + + @property + def authenticator(self) -> HTTPDigestAuth: + """Stream authenticator.""" + return HTTPDigestAuth( + username=self.config["username"], + password=self.config["password"], + ) +``` + +[`HTTPBasicAuth`](https://requests.readthedocs.io/en/latest/api/#requests.auth.HTTPBasicAuth) and +[`HTTPProxyAuth`](https://requests.readthedocs.io/en/latest/api/#requests.auth.HTTPProxyAuth) +are also available in `requests.auth`. In addition to `requests.auth` classes, the community +has published a few packages with custom authenticator classes, which are compatible with the SDK. +For example: + +- [`requests-aws4auth`](https://github.com/tedder/requests-aws4auth): AWS v4 authentication +- [`requests_auth`](https://github.com/Colin-b/requests_auth): A collection of authenticators + for various services and protocols including Azure, Okta and NTLM. + ### Custom response validation Some APIs deviate from HTTP status codes to report failures. For those cases,