atoti.Session.connect#

classmethod Session.connect(url, *, authentication=None, certificate_authority=None)#

Connect to an existing session.

Here is a breakdown of the Live extension capabilities of the returned session:

  • Local

    • If all the following conditions are met:

        1. the target session requires authentication (e.g. it has security configured)

        1. the provided authentication or certificate_authority arguments grant ROLE_ADMIN

        1. the target session (the one at url) was started with the same version of Atoti Python API (0.9.3)

        1. the target session runs on the same host as the current Python process

    • Then all Session capabilities can be used except for:

Note

Data and data model changes made from a connected session are not persisted on the target session. They will be lost if the target session is restarted.

Parameters:
  • url (str) – The base URL of the target session. The endpoint f"{url}/versions/rest" is expected to exist.

  • authentication (Authenticate | ClientCertificate | None) – The method used to authenticate against the target session.

  • certificate_authority (Path | None) – Path to the custom certificate authority file to use to verify the HTTPS connection. Required when the target session has been configured with an SSL certificate that is not signed by some trusted public certificate authority.

Return type:

Session

Example

>>> session_config = tt.SessionConfig(security=tt.SecurityConfig())
>>> secure_session = tt.Session.start(session_config)
>>> _ = secure_session.create_table("Example", data_types={"Id": "String"})
>>> secure_session.security.basic_authentication.credentials.update(
...     {"user": "passwd", "admin": "passwd"}
... )
>>> secure_session.security.individual_roles.update(
...     {"user": {"ROLE_USER"}, "admin": {"ROLE_USER", "ROLE_ADMIN"}}
... )
>>> admin_session = tt.Session.connect(
...     secure_session.url,
...     authentication=tt.BasicAuthentication("admin", "passwd"),
... )
>>> table = admin_session.tables["Example"]
>>> table += ("foo",)
>>> table.head()
    Id
0  foo

Live extension requires the connected session to be granted ROLE_ADMIN:

>>> user_session = tt.Session.connect(
...     secure_session.url,
...     authentication=tt.BasicAuthentication("user", "passwd"),
... )
>>> list(user_session.tables)  
Traceback (most recent call last):
    ...
atoti._live_extension_unavailable_error.LiveExtensionUnavailableError: ...

Live extension requires the target session to be secure:

>>> unsecure_session = tt.Session.start()
>>> _ = unsecure_session.create_table("Example", data_types={"Id": "String"})
>>> connected_session = tt.Session.connect(unsecure_session.url)
>>> list(connected_session.tables)  
Traceback (most recent call last):
    ...
atoti._live_extension_unavailable_error.LiveExtensionUnavailableError: ...

See also

start()