本仓库用于 shiguangschedule 适配脚本的管理和测试。所有适配脚本将集中存放于此,方便软件拉取和测试。
注意为避免代码出现问题,main分支启用分支保护,需要先合并到pending分支等待分支同步
每个学校或工具都有一个独立的目录,包含以下文件:
所有适配学校/工具必须先在 index/root_index.yaml 文件中登记,CI/CD 构建脚本会根据此文件决定处理哪些资源。
每个学校/工具条目需包含如下字段:
| 字段名 | 类型 | 说明 |
|---|---|---|
| id | String | 唯一标识(拼音或缩写,如果可以更建议使用域名) 一般来说我们建议教务使用全大写 工具使用小写 |
| name | String | 中文名称 |
| initial | String | 名称首字母(用于排序) |
| resource_folder | String | 资源文件夹名称 (建议和id保持一致) |
示例:
schools: #固定字段
- id: "GLOBAL_TOOLS"
name: "通用工具与服务"
initial: "G"
resource_folder: "GLOBAL_TOOLS"
- id: "CUST"
name: "长春理工大学"
initial: "C"
resource_folder: "CUST"- 若要适配新学校/工具,必须先在
root_index.yaml添加条目,填写上述字段。 - 在
resources/下创建与resource_folder字段一致的文件夹。 - 在该文件夹内添加
adapters.yaml和适配脚本。 - 只有在
root_index.yaml已登记的学校/工具,才能提交适配文件。 - 新增学校/工具时,请确保在适配 PR 中已将相关条目添加到
root_index.yaml的学校列表,无需单独提交更新 PR。
资源目录名/
├── adapters.yaml # 配置信息
└── xxx.js # 适配脚本
每个适配器配置应包含以下字段(YAML格式,字段全部必填):
| 字段名 | 类型 | 说明 |
|---|---|---|
| adapter_id | String | 唯一标识(建议用拼音或英文缩写),个人建议使用学校id加序号的形式 |
| adapter_name | String | 中文名称 |
| category | String | 分类:BACHELOR_AND_ASSOCIATE(本科/专科)、POSTGRADUATE(研究生)、GENERAL_TOOL(通用工具) |
| asset_js_path | String | 适配脚本的相对路径(如 school.js) |
| import_url | String | 系统登录URL(教务系统适配器必填,工具可为空) |
| maintainer | String | 维护者信息(如姓名或 GitHub 用户名) |
| description | String | 简要说明(如适配用途、备注等) |
示例:
adapters: #固定字段
- adapter_id: "GENERAL_TOOL_01" # id加上序号
adapter_name: "组件测试"
category: "GENERAL_TOOL"
asset_js_path: "school.js" #相对路径
import_url: ""
maintainer: "星河欲转"
description: "这是一个空网站,用于组件测试与演示模式"注意:
- 请严格按照上述字段填写,不要添加或减少字段。
importUrl一定要是登录页面。asset_js_path填写对应学校的适配脚本相对路径。maintainer填写维护者信息,便于后续沟通和维护。
-
Fork 仓库
- 所有开发者需先 fork 本仓库(本仓库带有
lighthouse标签,已经在开发者软件版本关闭检查逻辑,希望各位开发者对使用的git仓库链接负责)。
- 所有开发者需先 fork 本仓库(本仓库带有
-
添加适配代码
在不更新索引的情况下,修改任何yaml文件是没有作用的(任何对于yaml文件的修改都需要编译索引才能应用),所以我们才提供了asset_js_path: "test.js" 占位用于在不更新索引的情况下测试适配代码
fork仓库之后 建议测试代码不要在自己的主分支测试哦,可以在仓库在开一个测试分支,测试完成可以一次将正确的代码提交到主分支,这样你的提交历史就不会充斥错误的提交历史
注意 仓库更改数据结构,我们的索引需要编译,软件只接收编译过的索引文件,如果你要测试适配代码,我建议你在resources\GLOBAL_TOOLS\test.js文件放置适配代码,我们定义这个位置是一个适配占位符,开发者版本添加了网址链接输入,希望了解适配流程,注意提交pr请不要把测试的test.js也发上去哦!!- adapter_id: "GENERAL_TOOL_02" adapter_name: "适配代码测试" category: "GENERAL_TOOL" asset_js_path: "test.js" import_url: "" maintainer: "星河欲转" description: "空网站以及不存在适配代码,用于在不更新索引的情况下给开发者进行适配的软件测试"
-
软件测试
- 开发者需要安装 dev(开发者版,图标红色)版本app,在软件的“我的-更多-更新仓库”中选择自定义仓库或私有仓库,来拉取并更新自己的仓库代码进行实际测试,完成 Beta 阶段适配验证。
-
提交 PR
- 测试通过后,提交 Pull Request,等待审核合并。
本项目基于 MIT 协议开源,致力于教务系统的适配与维护。为保障项目的良性流转,请在参与或使用本项目时遵守以下约定:
我们感谢所有贡献者的无私分享,每一份适配代码都值得被尊重。在引用或二次开发时,请保留原始开发者的贡献记录(如 Git 提交历史)。这既是对他人劳动的认可,也是社区协作的基础。任何抹除或篡改记录的行为,均不符合社区规范。
- 适用范围:本项目主要维护工作集中于官方仓库及官方分支。
- 非官方项目:任何脱离官方管理的第三方分支或衍生项目,其所有行为均与本项目官方无关。
- 责任界定:若第三方项目存在代码滥用、违规适配或分发不当,由此产生的一切后果均由该项目维护者自行承担。本项目及无辜的原始贡献者不承担任何连带责任。
- 请确保
adapters.yaml信息准确完整,符合规范要求。 - 每次提交适配代码或索引信息后,建议自测通过再提交 PR。
- 仓库需保留
lighthouse标签,否则软件无法识别为适配仓库。
如有问题或建议,欢迎提交 Issue 或 PR。