From 1e4fcaaa376899a855c23a1369a6e19eb8dae9dd Mon Sep 17 00:00:00 2001 From: hamistao Date: Wed, 11 Dec 2024 18:35:36 -0300 Subject: [PATCH] doc/source: Document `authenticate` function usage Signed-off-by: hamistao --- doc/source/authentication.rst | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/doc/source/authentication.rst b/doc/source/authentication.rst index f085a844..8043f92e 100644 --- a/doc/source/authentication.rst +++ b/doc/source/authentication.rst @@ -37,10 +37,23 @@ essentially meaning that the authentication has not yet occurred. False In order to authenticate the client, pass the LXD instance's trust -password or token to `Client.authenticate` +password or token to `Client.authenticate`. +The secret provided will be use as a token if it has the proper format +and the server accepts tokens, otherwise it will be used as a password. +To force password authentication, `use_token_auth=False` can be used. .. code-block:: python >>> client.authenticate('a-secret') >>> client.trusted >>> True + +.. code-block:: python + + >>> token = '{"client_name":"foo","fingerprint":"abcd","addresses":["192.0.2.1:8443"],"secret":"I-am-a-secret","expires_at":"0001-01-01T00:00:00Z","type":""}' + >>> client.authenticate(base64.b64encode(json.dumps(token).encode("utf-8")), use_token_auth=False) # Forces password authentication and fails + >>> client.trusted + >>> False + >>> client.authenticate(base64.b64encode(json.dumps(token).encode("utf-8"))) # Token used as token + >>> client.trusted + >>> True