CLI Tool dựa trên MyFAP API dành cho Sinh Viên FPTU
Project description
MyFAP API CLI
Giới thiệu
Chào mứng đến với dự án đầu tiên của kế hoạch lật đổ FBTU. Cli này tương tác giống hoàn toàn với APP MYFAP trên điện thoại. Bạn có thể xem lịch học, lịch thi, điểm số (sự thất vọng của gia đình), thông tin cá nhân, v.v. 1 cách thuận tiện, không bị gò bó trong giao diện app.
- Lưu ý: repo này được thực hiện cùng với sự hỗ trợ của Ai (Gemini 3.1 Pro Preview)
Tính năng chính
- Hỗ trợ đa nền tảng.
- Login thông qua FEID hoặc Google OAuth.
- Xem lịch học (từng tuần hoặc cả Kỳ).
- Xem điểm (từng môn hoặc cả Kỳ).
- Check điểm danh (từng môn hoặc cả Kỳ).
- Check tình trạng đơn từ.
- Xem thông báo của trường.
- Check Info của sinh viên hoặc phòng dvsv.
- Convert lịch học Kỳ sang ICS, dễ dàng import lịch học vào Google Calendar hoặc các dịch vụ tương tự.
- Và nhiều hơn nữa ...
Cách sử dụng
Do dự án đang trong quá trình phát triển nên chưa thể đem lên pip. Bạn có thể tải sauce về và chạy:
-
Cài đặt ứng dụng.
pip install myfap -
Lấy danh sách cơ sở.
myfap campuses -
Login vào feid (chỉ cần làm 1 lần, mặc định chọn cơ sở Hola).
myfap loginSau khi hoàn thành login, phiên đăng nhập sẽ dc lưu ở
~/.myfap-api-cli/session.json -
Login cho cơ sở Xavalo.
myfap login -c HCM -
Lấy Lịch học (tự động lấy kỳ mới nhất).
myfap schedule
Các Options
| Option | Chú thích |
|---|---|
| --help | Hiển thị bảng Commands và Options |
| --config <đường dẫn> | Đường dẫn tới file cấu hình session tùy chỉnh (mặc định: ~/.myfap-api-cli/session.json) |
| -c, --campus <cơ sở> | Mã cơ sở (VD: APHL, HCM, DN) [default: APHL] |
| -s, --semester <kỳ học> | Tên kỳ học (VD: Summer2026) |
| -cid, --courseid <mã môn> | Chọn mã môn, chỉ có ở command marks. (VD: 82934, lấy từ bảng điểm của kỳ, ko phải mã môn như PRO192, SWE201c, ...) |
| -w, --week <số tuần> | Chọn tuần, chỉ có ở command week-timetable |
| -y, --year <số năm> | Chọn năm học, chỉ có ở command week-timetable |
| -d, --date <YYYY-MM-DD> | Chỉ định ngày chính xác, chỉ có ở command week-timetable |
| -sc, --subjectcode <mã môn> | Chọn môn học, chỉ có ở command attendance |
| -cn, --classname <mã lớp> | Chọn lớp học, chỉ có ở command attendance |
| --ics | Convert Sang ICS, dễ dàng import lịch học vào Google Calendar hoặc các dịch vụ tương tự, chỉ có ở command schedule) |
| -p, --pretty | Format lại bảng điểm gốc của trường sang dạng json, chỉ có ở command marks) |
| -r, --refresh | Refresh thủ công authen_key trong file session.json, chỉ có ở command login |
| -f, --force | Buộc đăng nhập lại, bỏ qua file session.json, chỉ có ở command login |
Các ví dụ sử dụng
- Lưu ý:
- Do hầu hết các command đểu trả về json,
*đánh dấu những command trả output ra màn hình. - Nếu ko thêm flag thời gian hoặc kỳ,
myfapsẽ tự động lấy thời gian mới nhất. +nghĩa là bạn sẽ ko cần thêm flag--semesterhoặc-snếu gọi api vào đúng thời gian trong kỳ. Để xem thông tin của kỳ trước, bạn phải thêm flag này.
- Do hầu hết các command đểu trả về json,
- Xem tất cả command
*myfap --help Usage: myfap [OPTIONS] COMMAND [ARGS]... CLI Tool dựa trên MyFAP dành cho Sinh Viên FPTU Options: -c, --campus TEXT Mã cơ sở (VD: APHL, HCM, DN) [default: APHL] --config TEXT Đường dẫn file session tùy chỉnh (thay vì mặc định ~/.myfap-api-cli/session.json) --help Show this message and exit. Commands: login Đăng nhập vào hệ thống FEID campuses Xem danh sách các cơ sở (Campus) semesters Xem danh sách kỳ học schedule Xem lịch học (xuất JSON) marks Xem bảng điểm (xuất JSON) exams Xem lịch thi (xuất JSON) week-timetable Xem lịch học theo tuần (xuất JSON) attendance Xem thông tin điểm danh (xuất JSON) applications Xem danh sách đơn từ đã gửi cho trường (xuất JSON) news Xem 10 thông báo gần nhất (xuất JSON) info Xem thông tin chung (sinh viên, campus) other Các chức năng phụ trợ khác (survey, feedback, fee...) - Xem danh sách kỳ
*myfap semesters - Xem lịch học của Kỳ bất kỳ
myfap schedule -s Summer2026 - Convert lịch học sang ICS (import vào GG Calendar)
myfap schedule -s Summer2026 --ics - Xem lịch thi của Kỳ bất kỳ
myfap exams -s Summer2026 - Xem lịch từng tuần được chỉ định
+myfap week-timetable --week 22 - Xem lịch từng tuần bằng thời gian ngày
+myfap week-timetable --date 2026-6-7 - Xem danh sách điểm danh của Kỳ bất kỳ
myfap attendance -s Spring2026 - Xem danh sách điểm danh của môn bất kỳ trong Kỳ
+myfap attendance -sc CSD201 -cn SE2026 -s Spring2026 - Xem
sự thất vọng của gia đinhđiểm số của Kỳ bất kỳmyfap marks -s Fall2025 - Xem điểm của môn bất kỳ (ví dụ: môn MAD101, xem mã môn ở command trên)
myfap marks -cid 95619 - Xem điểm của môn bất kỳ (thêm
-phoặc--prettycho đẹp)myfap marks -cid 95619 -p - Xem tình trạng gửi đơn của Fap Web
myfap applications - Xem thông báo gửi toàn trường
myfap news - Xem thông tin sinh viên
myfap info student - Xem thông tin phòng dvsv
myfap info campus - Xem thông tin thêm
*myfap other --help Usage: myfap other [OPTIONS] COMMAND [ARGS]... Các chức năng phụ trợ khác (survey, feedback, fee...) Options: --help Show this message and exit. Commands: survey Kiểm tra các survey chưa thực hiện (xuất JSON) feedback Kiểm tra Feedback (xuất JSON) profile Kiểm tra Update Profile (xuất JSON) notification Xem thông báo qua MSSV (xuất JSON) fee Lấy danh sách học phí chưa thanh toán (xuất JSON)
- Refresh thủ công
authen_keytrong trường hợp cli bị lỗimyfap login -r - Đăng nhập lại, bỏ qua file
session.jsonmyfap login -f - Trỏ vào file
session.jsonvào vị trí tuỳ chỉnhmyfap login --config "%appdata%\myfap-api-cli\session.json"
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 myfap-0.1.2.tar.gz.
File metadata
- Download URL: myfap-0.1.2.tar.gz
- Upload date:
- Size: 18.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
701781ef9e11af7ceeed3064ce7fec5938309758632a9ccc61a923dce9875a7f
|
|
| MD5 |
fb8d56b743403bc81ef16e23f31faf1c
|
|
| BLAKE2b-256 |
06906735680f2228210a438a850cf9b8944a3cf9c8157485b2556fb609748059
|
Provenance
The following attestation bundles were made for myfap-0.1.2.tar.gz:
Publisher:
publish.yml on WindowScary321/myfap-api-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
myfap-0.1.2.tar.gz -
Subject digest:
701781ef9e11af7ceeed3064ce7fec5938309758632a9ccc61a923dce9875a7f - Sigstore transparency entry: 1450778647
- Sigstore integration time:
-
Permalink:
WindowScary321/myfap-api-cli@23395e9d34541345111c023f74d30d666ca4c1ec -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/WindowScary321
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@23395e9d34541345111c023f74d30d666ca4c1ec -
Trigger Event:
release
-
Statement type:
File details
Details for the file myfap-0.1.2-py3-none-any.whl.
File metadata
- Download URL: myfap-0.1.2-py3-none-any.whl
- Upload date:
- Size: 18.2 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 |
50d377fa94b32d4df7b015935735db7e9ab7f63d5cbad6e14351d4c4becb3a2c
|
|
| MD5 |
52f9e999e58c36be1bea5915f7b3cd21
|
|
| BLAKE2b-256 |
a36cbe6dbf7cad049aae439b53086a68df0389305b65fab8e829112975fcdfe0
|
Provenance
The following attestation bundles were made for myfap-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on WindowScary321/myfap-api-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
myfap-0.1.2-py3-none-any.whl -
Subject digest:
50d377fa94b32d4df7b015935735db7e9ab7f63d5cbad6e14351d4c4becb3a2c - Sigstore transparency entry: 1450778751
- Sigstore integration time:
-
Permalink:
WindowScary321/myfap-api-cli@23395e9d34541345111c023f74d30d666ca4c1ec -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/WindowScary321
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@23395e9d34541345111c023f74d30d666ca4c1ec -
Trigger Event:
release
-
Statement type: