教程:手动编写集控配置文件
教程:手动编写集控配置文件
本教程将指引您手动编写集控配置文件,并将其静态托管到网上。
Note
如果您要为一个大型的组织维护集控,手动编辑集控配置会非常麻烦。在这种情况下,建议您使用集控服务器。
每当你看见👉️符号,就说明你应该做一些事情。而其余的只供您参考和更深入的理解。
Tips
在这个教程中,我们将使用 GitHub 作为示例,并使用GitHub Codespaces在线编辑这些配置文件。如果您要使用其它的平台,请自行替换文中与 GitHub 有关的操作。
Tips
如果在您的网络环境下无法正常连接 GitHub,请考虑使用 GitHub 的替代品(如Gitee)完成本教程。
在开始之前
我们需要在本地安装一个 ClassIsland 实例来测试集控。
👉️按照指示下载并安装 ClassIsland 本体。
!!! tip "如果您之前安装过 ClassIsland,建议您在另一位置安装一个新的实例,并在新的实例中完成本教学的内容。"
为了托管我们的集控配置,我们需要在 GitHub 上新建一个存储库。
👉️在 GitHub 上新建一个公开存储库,并命名为classisland-mgmt-cfg
。
👉️在创建仓库界面勾选【Add a README file】复选框
Note
为了方便,我们在这里统一将仓库命名为classisland-mgmt-cfg
,您也可以给仓库起一个您喜欢的名字。
为了在创建仓库时一起将仓库初始化,我们在这里勾选【Add a README file】,让 GitHub 在创建仓库时创建 README 文件,并初始化仓库。
在仓库创建好之后,我们进入了仓库的主界面(如图所示):
现在我们需要进入 GitHub Codespaces 来编辑仓库里的文件。
👉️在仓库界面按下键盘上的.(英文句号)进入 GitHub Codespaces。
现在万事俱备,我们可以开始编写集控的配置文件了。
编写集控清单
集控清单文件包含了要拉取的集控相关文件的信息和组织的相关信息,相当于一个索引文件。ClassIsland 在加入集控后,会拉取这个文件,并根据此文件中的配置来拉取相关的文件。
👉️新建一个文件,并命名为manifest.json
。
👉️将以下文本粘贴到manifest.json中
{
"ServerKind": 0,
"OrganizationName": "Hello"
}
这就是一个最基础的清单文件了。这个文件说明了服务器类型是静态托管的,并且说明了组织名称。我们之后会根据需要逐渐完善这个文件。
Tips
您可以试着根据集控配置文档中的说明修改OrganizationName
字段,设置自定义的组织名。
👉️在编辑器【Git】工具窗口中提交更改。
我们要将当前的更改提交到 GitHub 上。提交完成后,我们就能在 GitHub 上看到我们的文件了。
接下来回到本地,我们在 ClassIsland 安装目录中新建一个集控配置文件,来告诉 ClassIsland 实例应该从哪里拉取集控清单。
👉️在 ClassIsland 安装文件夹中新建一个文件,并命名为ManagementPreset.json
,并用本地文本编辑器打开。
👉将以下文本粘贴到ManagementPreset.json
中,并将ManifestUrlTemplate
字段中用户名部分替换成你的 GitHub 用户名。
{
"ManagementServerKind": 0,
"ManagementServer": "",
"ManifestUrlTemplate": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/manifest.json"
}
编辑好集控配置后,我们就可以将这个文件导入到 ClassIsland 实例中了。
👉运行 ClassIsland。
如果您是第一次运行 ClassIsland,此时 ClassIsland 会弹出欢迎向导。
👉同意许可协议,然后点击【加入集控】按钮。
Tips
如果您先前已经完成欢迎向导,您可以根据此处的文档来加入集控。
此时会弹出集控加入界面,并自动加载了我们刚刚放置在应用目录下的ManagementPreset.json
文件。您可以点击【浏览】按钮选择其它的配置文件。
👉在 ID 一栏填入TEST
ID 在此处可以标识 ClassIsland 实例。在后续的实际应用中,您可以将自定义 id 设置为班级名、教室编号等易于识别的名称。
👉点击【连接】按钮。
此时应用会下载集控清单文件,速度因网络环境而异。在下载完成后,应用会弹出最后的集控加入确认窗口。
👉在弹出的确认提示框上,点击【加入】按钮。
👉在弹出的加入成功提示框上,点击【确定】按钮。
此时应用会重新启动。在重新启动后,进入【应用设置】,您可以看到右上角出现了【由贵单位管理】徽章。
🎉恭喜!您现在已经成功地加入了集控!
拉取档案
尽管我们已经成功加入了集控,但目前它还没有任何作用。接下来我们将引入档案配置。
我们为本教程预制了档案文件,这样我们就可以专注于编写集控配置。
回到 GitHub Codespaces 中,我们接下来的操作将在这上面完成。
👉将此处的文件内容复制到subjects.json
👉将此处的文件内容复制到timelayouts.json
👉将此处的文件内容复制到classplans.json
这些文件分别存储了科目、时间表和课表信息。尽管这些文件仍然以 ClassIsland 档案文件格式存储,但在加载时只会加载相应的部分。您也可以上传并使用自己的档案文件。
👉在manifest.json
中添加以下高亮代码,并将所有 url 中中用户名部分替换成你的 GitHub 用户名。
{
"ServerKind": 0,
"OrganizationName": "Hello",
"ClassPlanSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/classplans.json",
"Version": 1
},
"TimeLayoutSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/timelayouts.json",
"Version": 1
},
"SubjectsSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/subjects.json",
"Version": 1
}
}
在我们刚刚添加的内容中,包含了 3 个 url,以及对应 url 的版本。这些 url 分别指向我们存储到 GitHub 仓库上的科目、时间表和课表信息。这些字段被称为ReVersionString
,可以存储 url 和对应 url 的版本。在 ClassIsland 拉取清单时,只有在检测到 url 版本比本地存储的版本更新时,才会更新相关数据。
Warning
在修改这些字段的 url,或者这些字段的 url 指向的内容时,请务必记得增加版本数,否则 ClassIsland 实例可能不会更新这些数据。
👉️在编辑器【Git】工具窗口中提交更改。
👉️重启 ClassIsland 实例。
如果前面的步骤没有差错,ClassIsland 会自动拉取档案。您可以在启动应用后,进入【档案编辑】界面,查看拉取的档案。
应用 url 模板
我们刚刚成功地完成了集控档案的分发。然而在实际情况下,我们在将集控部署到多台设备上时,还需要为每台设备分配不同的课表等信息。在这里我们可以在清单文件的 url 中填入 url 模板,以让 ClassIsland 实例在获取信息时将模板替换成对应的信息。
比如我们有这样一个 url:
https://example.com/client/{id}/policy.json
其中的{id}
是一个 url 模板,它告诉 ClassIsland 在请求这个 url 时,要将这个模板替换成当前的集控 id。按照本教程设定的的 idTEST
,在请求时刚刚的 url 会被处理成这样:
https://example.com/client/TEST/policy.json
我们可以用利用这一个特性,为每一台设备上的 ClassIsland 实例指派不同的 id,以在 ClassIsland 获取清单文件时,通过将清单中 url 中的模板替换成实例的 id 来实现向不同的设备分配不同的课表配置。
要了解更多关于 Url 模板的用法,可以看看这篇文档。
👉️在仓库中新建两个文件夹,分别命名为TEST
和HELLO
👉将此处的文件内容复制到TEST/classplans.json
👉将此处的文件内容复制到HELLO/classplans.json
👉在manifest.json
中替换以下高亮代码,并将所有 url 中中用户名部分替换成你的 GitHub 用户名。
{
"ServerKind": 0,
"OrganizationName": "Hello",
"ClassPlanSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/{id}/classplans.json",
"Version": 2
},
"TimeLayoutSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/timelayouts.json",
"Version": 1
},
"SubjectsSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/subjects.json",
"Version": 1
}
}
在刚刚的修改中,我们为课表源项目添加了 url 模板,这样在获取课表时可以按照 id 获取对应的课表。同时我们增加了版本号Version
,以告诉 ClassIsland 这个项目已经更新,需要重新获取。
👉️在编辑器【Git】工具窗口中提交更改。
👉️重启 ClassIsland 实例。
现在我们已经成功地添加了模板。您可以试着先退出集控,然后再以HELLO
的 id 加入集控。您可以看到应用已经拉取了不同的课表。
在实际情况下,您可以根据需要,在不同的 url 上添加模板。
策略
除了分发课表,ClassIslad 集控还支持制定策略,限制实例的某些功能。您可以根据需要为您的组织设置策略。
👉️在将下列配置复制到policy.json
{
"DisableSettingsEditing": true
}
上面是一个简单的策略文件,告诉 ClassIsland 应该禁止编辑设置文件。
👉在manifest.json
中替换以下高亮代码,并将所有 url 中中用户名部分替换成你的 GitHub 用户名。
{
"ServerKind": 0,
"OrganizationName": "Hello",
"ClassPlanSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/{id}/classplans.json",
"Version": 2
},
"TimeLayoutSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/timelayouts.json",
"Version": 1
},
"SubjectsSource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/subjects.json",
"Version": 1
},
"PolicySource": {
"Value": "https://raw.githubusercontent.com/(把这里替换成你的 GitHub 用户名)/classisland-mgmt-cfg/master/policy.json",
"Version": 1
}
}
我们在清单中添加了对集控策略的引用。
👉️在编辑器【Git】工具窗口中提交更改。
👉️重启 ClassIsland 实例。
在重启应用后打开设置界面,您可以看到设置编辑功能已被禁用。
您可以进一步阅读策略文件文档,了解其它的策略配置,并根据需要自定义策略。
结语
🎉恭喜!您现在已经对手动编辑集控有了初步的认识。您可以进一步研究其它的文档,来更深入地了解编写集控配置的方法。