Kyoto University SSO session bootstrapper for KULASIS / KULMS / MyKULINE / PandA.
Project description
kuauth
京都大学の SSO (KULASIS / KULMS / MyKULINE / PandA) を単一のセッションで叩くための Python クライアントです。初回のサービスアクセス時に必要な IdP ウォークが遅延実行され、それ以降は通常の HTTP クライアントとして使えます。
インストール
uv add kuauth
Quickstart
from kuauth import KyotoUAuth, KULASIS, KULMS, MyKULINE, PandA
auth = KyotoUAuth(
username="a0XXXXXX",
password="your-password",
# onetime_password="424242", # 手元の 6 桁コードを 1 回だけ使う
otp_callback=lambda: input("OTP: "), # 対話的スクリプト
# totp_secret="JBSWY3DPEHPK3PXP", # cron / CI など無人実行
)
print(KULASIS(auth).get("/student/la/top").text) # 教務 (Shift_JIS 自動デコード)
print(KULMS(auth).get("/portal").text) # Sakai LMS
print(MyKULINE(auth).get("/opac/opac_search/").text) # 図書館 OPAC
print(PandA(auth).get("/portal").text) # 旧 LMS (ECS CAS)
auth.close()
Cookies
特定サービス向けの認証済みセッション cookie だけ欲しい場合は service.cookies() を使います。必要に応じて対象サービスのセッションを確立したうえで、そのサービスに送られる cookie を httpx.Cookies として返します。返り値は共有 cookie jar そのものではなく、対象サービス向けに切り出したコピーです。
from kuauth import KyotoUAuth, KULASIS
auth = KyotoUAuth(
username="a0XXXXXX",
password="your-password",
totp_secret="JBSWY3DPEHPK3PXP",
)
cookies = KULASIS(auth).cookies()
print(dict(cookies.items()))
auth.close()
認証方法
OTP が必要かどうかは、アクセスする SP によって変わります。
| Service | Base URL | 認証経路 | OTP |
|---|---|---|---|
| KULASIS | https://www.k.kyoto-u.ac.jp |
auth.iimc (SimpleSAMLphp) | 必要 |
| KULMS | https://lms.gakusei.kyoto-u.ac.jp |
auth.iimc (SimpleSAMLphp) | 必要 |
| MyKULINE | https://kuline.kulib.kyoto-u.ac.jp |
authidp1 (Java Shib IdP) | 不要 |
| PandA | https://panda.ecs.kyoto-u.ac.jp |
ECS CAS | 不要 |
OTP は実際に OTP フォームに到達した時点で初めて解決されます。つまり、MyKULINE や PandA しか使わないスクリプトでは totp_secret 等の指定は省略できます。KULASIS / KULMS を叩く場合のみ、下記のいずれかを渡してください。
| 引数 | 用途 |
|---|---|
onetime_password="424242" |
手元の 6 桁コードを 1 回だけ使う |
otp_callback=lambda: input("OTP: ") |
対話的スクリプト |
totp_secret="JBSWY3DPEHPK3PXP" |
cron / CI など無人実行 |
TOTP シークレットは 京大の多要素認証マニュアル に従って認証アプリを登録する際の QR に埋め込まれた otpauth://totp/...?secret=XXXX&... の secret パラメータです。登録後は QR が再表示されないので、登録画面で控えておくか、一度アプリを解除して再登録してください。
KUMOI (Microsoft 365) はテナント admin consent が必要なため、スコープ外です。
個別エンドポイントのラッパメソッドは持たない設計です。HAR ファイルから URL とフォーム構造を特定すれば、KULASIS(auth).post(...) などを使って呼び出し側で任意のページを叩けます。
クレデンシャルの取り扱い
KyotoUAuth はパスワード / TOTP シークレット / 事前生成 OTP を bytearray で保持し、close() または with ブロック終了時にゼロで上書きしてから参照を捨てます。Python の str は immutable なので「完璧に消す」ことは原理的に不可能ですが、マスタコピーの寿命が明示的に短くなるので、コアダンプ・スワップ経由の事故確率は下がります。
auth = KyotoUAuth("a0XXXXXX", "secret", totp_secret="JBSWY3DPEHPK3PXP")
print(auth) # KyotoUAuth(username='a0XXXXXX', password=<redacted>, totp_secret=<redacted>, ...)
auth.close()
auth.password # RuntimeError: closed
__repr__ は常にマスクされるので、print(auth) / f"{auth}" / トレースバックの locals dump 経由でクレデンシャルが流れることはありません。username だけは IdP に EPPN として渡る情報なのでマスク対象外です。
クレデンシャルをどこから取ってくるか (環境変数 / OS キーチェーン / vault など) はライブラリのスコープ外で、呼び出し側の責任です。keyring から取りたい場合の例:
import keyring
from kuauth import KyotoUAuth
# 事前に: python -m keyring set kuauth a0XXXXXX
# python -m keyring set kuauth-totp a0XXXXXX (KULASIS / KULMS を使う場合)
auth = KyotoUAuth(
"a0XXXXXX",
keyring.get_password("kuauth", "a0XXXXXX"),
totp_secret=keyring.get_password("kuauth-totp", "a0XXXXXX"),
)
テスト
uv run pytest tests/unit -q # ネットワーク不要
uv run pytest tests/replay -q # respx でモックした E2E
実 IdP と実サービスを叩く統合テストは KUAUTH_LIVE=1 を指定しない限り、すべてスキップされます。実行するには以下の環境変数をセットしてください。
KUAUTH_TOTP_SECRET は KULASIS / KULMS のテストに必要です。省略すると auth_with_totp を使うテストだけがスキップされます (MyKULINE / PandA は走ります)。
# bash / Git Bash
KUAUTH_LIVE=1 \
KUAUTH_USERNAME=a0XXXXXX \
KUAUTH_PASSWORD=... \
KUAUTH_TOTP_SECRET=JBSWY3DPEHPK3PXP \
uv run pytest tests/integration -q
# PowerShell
$env:KUAUTH_LIVE="1"
$env:KUAUTH_USERNAME="a0XXXXXX"
$env:KUAUTH_PASSWORD="..."
$env:KUAUTH_TOTP_SECRET="JBSWY3DPEHPK3PXP"
uv run pytest tests/integration -q
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kuauth-0.4.0.tar.gz.
File metadata
- Download URL: kuauth-0.4.0.tar.gz
- Upload date:
- Size: 107.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
778134ae17ebf41c3632778b496ed6bb65bf363ba88d1e143507ff92f29a76f2
|
|
| MD5 |
ff28fb2a0061ed640600ce2b03827b52
|
|
| BLAKE2b-256 |
42878e1bbacd2f1022e50bf5105eeac3be1fd9b343c30536c72faf9ea52caef8
|
Provenance
The following attestation bundles were made for kuauth-0.4.0.tar.gz:
Publisher:
release.yml on youseiushida/kuauth
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kuauth-0.4.0.tar.gz -
Subject digest:
778134ae17ebf41c3632778b496ed6bb65bf363ba88d1e143507ff92f29a76f2 - Sigstore transparency entry: 1432636848
- Sigstore integration time:
-
Permalink:
youseiushida/kuauth@3d36153dc636e796d00c4de71d28b65322e3ac6a -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/youseiushida
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3d36153dc636e796d00c4de71d28b65322e3ac6a -
Trigger Event:
push
-
Statement type:
File details
Details for the file kuauth-0.4.0-py3-none-any.whl.
File metadata
- Download URL: kuauth-0.4.0-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
50063f71ba14b191040d2aa9bcf2836cfd7992a73adeb3926c4acde48736c430
|
|
| MD5 |
758d8276760dd8c006cd4c2fcb5926b7
|
|
| BLAKE2b-256 |
49d9fe256db53b57878dadb67a20436fd298961c3e53ef1ba25e47f0f4b16d6c
|
Provenance
The following attestation bundles were made for kuauth-0.4.0-py3-none-any.whl:
Publisher:
release.yml on youseiushida/kuauth
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kuauth-0.4.0-py3-none-any.whl -
Subject digest:
50063f71ba14b191040d2aa9bcf2836cfd7992a73adeb3926c4acde48736c430 - Sigstore transparency entry: 1432636940
- Sigstore integration time:
-
Permalink:
youseiushida/kuauth@3d36153dc636e796d00c4de71d28b65322e3ac6a -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/youseiushida
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3d36153dc636e796d00c4de71d28b65322e3ac6a -
Trigger Event:
push
-
Statement type: