Last updated:
0 purchases
bitroom 0.1.5
🚩🏠 bitroom (Book an Incongruent Topological Room Or be Out of Mind)
BIT 场地预约查询接口。
💥 源起
场地预约系统(桌面版)的服务器响应太慢了,每次翻页都要十几秒。
若并发请求,再缓存到本地,会方便不少。
房间资源是时空区间,需求常常是“先时间,后空间”;然而也许为方便调度资源、避免冲突,现有系统全都“先空间,后时间”。
例如,你可能会问:“明天下午还有没有房间?没有的话,后天下午也行。就几个人,也不需要投影。”
而很少专门针对某一房间问。
bitroom 目前已解决登录、包装 API 等底层问题,可供后来者调用。
🧪 例子
🤖编程 API
这是主要支持的接口。
from datetime import date
from httpx import AsyncClient
from bitroom import auth, RoomAPI
async with AsyncClient() as client:
await auth(client, username, password) # 登录“统一身份认证”
api = await RoomAPI.build(client)
# 获取“可预约”的时空区间
bookings = await api.fetch_bookings(date.today())
print(bookings[0])
# 预约
await api.book(
bookings[0],
tel="13806491023",
applicant="Boltzmann",
description="Boltzmann 常数是气体的内能与温度的一种比例系数。",
remark="一般记作 k_B 或 k。",
)
# 获取“已预约”的时空区间
orders = await api.fetch_orders(bookings[0].room_id, date.today())
print(orders[0])
⌨️命令行 CLI
也提供了基础的命令行接口,支持查询,不支持预约。
可结合 fzf,搜索日期、时间、房间。(详见 wiki)
$ bitroom show | fzf
详细帮助如下。
(要先pipx install bitroom)
$ bitroom --help
Usage: python -m bitroom [OPTIONS] COMMAND [ARGS]...
BIT 场地预约查询接口
Options:
--version Show the version and exit.
--help Show this message and exit.
Commands:
config-paths 列出配置文件可能的位置
show 显示所有可预约的时空区间
$ bitroom show --help
Usage: python -m bitroom show [OPTIONS]
显示所有可预约的时空区间
默认从 API 爬取,因服务器响应慢,大约需 10 s。
$ bitroom show
也可直接从 stdin 提供之前的结果。
$ bitroom show --json > ./bookings.json
$ cat ./bookings.json | bitroom show
Options:
--json / --no-json 按 JSON 格式输出
--auth TEXT 认证信息,形如“1120771210:cyberpunk”(<学号>:<密码>);不建议使用,请改用配置文件
--help Show this message and exit.
$ bitroom show
<Booking [【睿信书院】静c-鸿远报告厅] 2023-05-07 16:00–16:45>
<Booking [【睿信书院】静c-鸿远报告厅] 2023-05-07 19:20–20:05>
<Booking [【精工书院】研讨室1] 2023-05-04 12:15–13:20>
<Booking [【睿信书院】静c-自控会议室] 2023-05-04 13:20–14:05>
<Booking [甘棠社区-102春·事定(Multi-function Room)] 2023-05-05 21:00–22:00>
<Booking [甘棠社区-102春·事定(Multi-function Room)] 2023-05-06 13:20–14:05>
<Booking [甘棠社区-102春·事定(Multi-function Room)] 2023-05-06 14:10–14:55>
<Booking [甘棠社区-102春·事定(Multi-function Room)] 2023-05-07 15:10–15:55>
……
🎨图形终端 TUI
目前还在早期测试阶段,仅仅能用而已。支持查询、搜索、预约。
$ pipx install bitroom[tui]
⚙️ 配置
(仅用于 CLI、TUI)
编辑config.toml,写入学号、密码,用于登录“统一身份认证”。
# 仅作示例,非真实信息
username = "1120771210"
password = "cyberpunk"
配置文件的位置遵循各操作系统惯例,可通过bitroom config-paths列出。另外,您也可用环境变量$BITROOM_CONFIG_PATH指定位置。
🌟 致谢
YoungKlaus/BIT_Auto_Leave: 北京理工大学自动请假
BITNP/bitsrun: 北京理工大学 10.0.0.55 校园网登录登出的 Python 实现
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.