Skip to main content

Automates logging into web UIs to access unofficial APIs

Project description

Introduction

We want to use APIs from web UIs that require login. What we want to do is to set up a session, login and then use the API of the page. The reason we want to do this is to use existing APIs. For instance, the user group management service at KTH, see 1{reference-type="ref" reference="UGEditor"}. We can then use the service, track the requests in the browser's developer tools. Then we can simply make the same requests from Python.

Screenshot of the KTH UG Editor with Firefox's Developer Tools open, showing network requests made.

For instance, we can redo the request in Figure 1 (above) like this:

import weblogin
import weblogin.kth
import os

ug = weblogin.AutologinSession([
                weblogin.kth.UGlogin(os.environ["KTH_LOGIN"],
                                     os.environ["KTH_PASSWD"],
                                     "https://app.kth.se/ug-gruppeditor/")
            ])

response = ug.get("https://app.kth.se/ug-gruppeditor/api/ug/users"
                  "?filter=memberOf eq 'u26yk1i3'")

The code above will access the API used by the KTH UG group editor service. It will automatically sign in when needed. The API URLs don't trigger a redirect to log in, they just give a 401 unauthorized error. However, we can use the main URL to the UI to trigger such an event, log in and then access the API. All this happens automatically in the background.

The way we do this is to subclass the requests.Session class to intercept all requests of a session to check for signs indicating that we must log in. When we detect such sign, we log in and resume as if nothing ever happened.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

weblogin-1.7.tar.gz (14.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

weblogin-1.7-py3-none-any.whl (20.9 kB view details)

Uploaded Python 3

File details

Details for the file weblogin-1.7.tar.gz.

File metadata

  • Download URL: weblogin-1.7.tar.gz
  • Upload date:
  • Size: 14.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.0 CPython/3.10.12 Linux/6.2.0-39-generic

File hashes

Hashes for weblogin-1.7.tar.gz
Algorithm Hash digest
SHA256 f3d8fd912098572bb28ccde9d41c5d0a233467c5e457defa5a131a540958638c
MD5 0a3c572553a26bb77f2a03d838c99fe2
BLAKE2b-256 5a7c5692f800a205a4c1d49f06a354ae07a1e04288ba295f8b3d0f527268b8e8

See more details on using hashes here.

File details

Details for the file weblogin-1.7-py3-none-any.whl.

File metadata

  • Download URL: weblogin-1.7-py3-none-any.whl
  • Upload date:
  • Size: 20.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.0 CPython/3.10.12 Linux/6.2.0-39-generic

File hashes

Hashes for weblogin-1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 7f15235a1c83e5ba11f1c7905900beda275c6cdaae36169f86be466465bd7f2a
MD5 abf2c5d6eb9ea7bec17f5ca3aee31340
BLAKE2b-256 641c5c8b6485179546d9cd046ea7e7b980457c0ff762fc8aab8e196f339e684c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page