From 50c88df48875c7f4fb7272501ad53d9d6f5b09b0 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 02:19:18 +0800 Subject: [PATCH 1/6] Add api token thing --- README-zhCN.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/README-zhCN.md b/README-zhCN.md index 285ccd9..44a9b87 100644 --- a/README-zhCN.md +++ b/README-zhCN.md @@ -31,7 +31,10 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 当你将此项目的功能写完并进行了编译后,需要将此 API 服务进行部署。此 API 服务可以部署在本地网络、本机网络或者广域网中。我们强烈建议以「最低延迟」为基准进行部署,以保证 `ServerListener` 可以同时监听 *多个* 游戏服务端。 你可以在游戏服务端的启动配置中对 API 的地址和端口进行设定。 +#### 启动参数 游戏服务端通过启动参数 `"-apiEndpoint=:<端口>"` 来与本 API 实例进行通信, 启动参数中的 `<端口>` 指的是本 API 服务中指定的端口 `` 指的是本 API 服务部署实例的 IP 地址。 +如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。 +#### 调整 API 端口 如果游戏服务端实例与本 API 实例不在同一个实例上进行部署,且你想修改本 API 实例的端口 `29294`,你可以查看 `Progran.cs` 中 `listener.Start(29294);` 并把 `29294` 修改为你想指定或防火墙等安全策略已通过的端口号。 如果你的实例运行在 Docker 容器中,端口 `29294` (或你修改的其他端口)也同时需要在 Docker 容器配置中进行修改并对外暴露。也就是说你需要修改 `Dockerfile` 且(如果有使用到容器集群编排)还有需要修改 `docker-compose.yml` 。相关参考资料可以查看 Docker 官方文档 [EXPOSE in the Dockerfile reference](https://docs.docker.com/engine/reference/builder/#expose) 以及 [networking in Compose](https://docs.docker.com/compose/networking/)。 From 1a2fb44dedada0002376cd757bae8a41712b0846 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 02:22:15 +0800 Subject: [PATCH 2/6] add GameServer Command --- README-zhCN.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README-zhCN.md b/README-zhCN.md index 44a9b87..47a383b 100644 --- a/README-zhCN.md +++ b/README-zhCN.md @@ -33,7 +33,7 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 #### 启动参数 游戏服务端通过启动参数 `"-apiEndpoint=:<端口>"` 来与本 API 实例进行通信, 启动参数中的 `<端口>` 指的是本 API 服务中指定的端口 `` 指的是本 API 服务部署实例的 IP 地址。 -如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。 +如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。当然,在游戏服务端的运行时,你也可以通过在命令行中输入 `setapitoken <新的token>` 来直接修改运行中的服务端的 `Api Token`。 #### 调整 API 端口 如果游戏服务端实例与本 API 实例不在同一个实例上进行部署,且你想修改本 API 实例的端口 `29294`,你可以查看 `Progran.cs` 中 `listener.Start(29294);` 并把 `29294` 修改为你想指定或防火墙等安全策略已通过的端口号。 From afc32754fd343c87bff4b7dbd0be9c8f872a28b5 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 02:22:49 +0800 Subject: [PATCH 3/6] proofreading --- README-zhCN.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README-zhCN.md b/README-zhCN.md index 47a383b..40efc94 100644 --- a/README-zhCN.md +++ b/README-zhCN.md @@ -37,4 +37,4 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 #### 调整 API 端口 如果游戏服务端实例与本 API 实例不在同一个实例上进行部署,且你想修改本 API 实例的端口 `29294`,你可以查看 `Progran.cs` 中 `listener.Start(29294);` 并把 `29294` 修改为你想指定或防火墙等安全策略已通过的端口号。 -如果你的实例运行在 Docker 容器中,端口 `29294` (或你修改的其他端口)也同时需要在 Docker 容器配置中进行修改并对外暴露。也就是说你需要修改 `Dockerfile` 且(如果有使用到容器集群编排)还有需要修改 `docker-compose.yml` 。相关参考资料可以查看 Docker 官方文档 [EXPOSE in the Dockerfile reference](https://docs.docker.com/engine/reference/builder/#expose) 以及 [networking in Compose](https://docs.docker.com/compose/networking/)。 +如果你的实例运行在 Docker 容器中,端口 `29294` (或你修改的其他端口)也同时需要在 Docker 容器配置中进行修改并对外暴露。也就是说你需要修改 `Dockerfile` 且(如果有使用到容器集群编排)还有可能需要修改 `docker-compose.yml` 。相关参考资料可以查看 Docker 官方文档 [EXPOSE in the Dockerfile reference](https://docs.docker.com/engine/reference/builder/#expose) 以及 [networking in Compose](https://docs.docker.com/compose/networking/)。 From 22d80e6cc6a2195e0aa6c465a33a387b1ea2b738 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 02:24:16 +0800 Subject: [PATCH 4/6] more proofreading --- README-zhCN.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/README-zhCN.md b/README-zhCN.md index 40efc94..9d35cd4 100644 --- a/README-zhCN.md +++ b/README-zhCN.md @@ -20,6 +20,7 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 制作对应的功能可以 [查看维基(制作中)](https://github.com/MrOkiDoki/BattleBit-Community-Server-API/wiki). 本 API 将在运行后开启一个`ServerListener` 的监听进程,传递你 *自己定义* 的 `Player` 和 `GameServer` 类型覆盖原本游戏自身的 `Player` 和 `GameServer` 类型。在这些类型中添加任何你想要的功能,以此来定制属于你自己的游戏玩法。 + 如果想给你的游戏服务端添加功能,可以直接把覆盖的功能写入 `Program.cs` 的 `MyPlayer` 和 `MyGameServer`中,当然你也可以按照框架规范进行其他的功能纂写。 ### 编译 @@ -29,12 +30,15 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 ### 连接游戏服务端 当你将此项目的功能写完并进行了编译后,需要将此 API 服务进行部署。此 API 服务可以部署在本地网络、本机网络或者广域网中。我们强烈建议以「最低延迟」为基准进行部署,以保证 `ServerListener` 可以同时监听 *多个* 游戏服务端。 -你可以在游戏服务端的启动配置中对 API 的地址和端口进行设定。 + +你可以在游戏服务端的启动参数配置中对 API 的地址和端口进行设定。 #### 启动参数 游戏服务端通过启动参数 `"-apiEndpoint=:<端口>"` 来与本 API 实例进行通信, 启动参数中的 `<端口>` 指的是本 API 服务中指定的端口 `` 指的是本 API 服务部署实例的 IP 地址。 + 如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。当然,在游戏服务端的运行时,你也可以通过在命令行中输入 `setapitoken <新的token>` 来直接修改运行中的服务端的 `Api Token`。 #### 调整 API 端口 如果游戏服务端实例与本 API 实例不在同一个实例上进行部署,且你想修改本 API 实例的端口 `29294`,你可以查看 `Progran.cs` 中 `listener.Start(29294);` 并把 `29294` 修改为你想指定或防火墙等安全策略已通过的端口号。 + 如果你的实例运行在 Docker 容器中,端口 `29294` (或你修改的其他端口)也同时需要在 Docker 容器配置中进行修改并对外暴露。也就是说你需要修改 `Dockerfile` 且(如果有使用到容器集群编排)还有可能需要修改 `docker-compose.yml` 。相关参考资料可以查看 Docker 官方文档 [EXPOSE in the Dockerfile reference](https://docs.docker.com/engine/reference/builder/#expose) 以及 [networking in Compose](https://docs.docker.com/compose/networking/)。 From d824a2b81a23416e7895f276f72f8d7150eec0d7 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 12:03:57 +0800 Subject: [PATCH 5/6] Update README.md --- README.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/README.md b/README.md index 8451b0c..0b8cf40 100644 --- a/README.md +++ b/README.md @@ -32,6 +32,14 @@ Alternatively, you can use Docker to run it. An easy way to do this it to run `d After writing and compiling this project. You will want to host it somewhere. This could be on the same server that the gameservers run on, or somewhere completely different. We do recommend to keep the latency to the gameserver minimal for smoother and faster communication. The same `ServerListener` can be used for *multiple* gameservers at the same time. You can specify the API server (address & port) in the launch options of the gameserver. +#### Gameserver start arguments + The gameserver connects to the API with the launch argument `"-apiendpoint=:"`, where `` is the port that the listener listens on and the `` is the IP of the API server. +If `Api Token` verification is required in your Server API, you need to add `"-apiToken="` to the startup parameters of the gameserver(s). Should `` the same as `Api Token` defined in Server API, gameserver(s) can communicate with Server API. + +When the gameserver is up, you can also directly modify the `Api Token` of the gameserver by entering `setapitoken ` in its command line. + +#### Adjust API listening port + The project is currently configured to have the API listen on port `29294`. If you want to change this, make sure to change it in the code (on your `listener.start(port)`). Port `29294` is also exposed in Docker and bound to the same port on the host in Docker Compose. This means that when using Docker, you will have to change the port in the `Dockerfile` and in `docker-compose.yml` (when using Compose) as well. See [EXPOSE in the Dockerfile reference](https://docs.docker.com/engine/reference/builder/#expose) and [networking in Compose](https://docs.docker.com/compose/networking/). From 1b5f10e563a05f4242ea74aa6b136769d0ebd6b6 Mon Sep 17 00:00:00 2001 From: Maple Gao Date: Fri, 18 Aug 2023 12:04:21 +0800 Subject: [PATCH 6/6] Update README-zhCN.md --- README-zhCN.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README-zhCN.md b/README-zhCN.md index 9d35cd4..cf15370 100644 --- a/README-zhCN.md +++ b/README-zhCN.md @@ -1,4 +1,3 @@ - # BattleBit Remastered 服务端 API [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) @@ -20,7 +19,6 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 制作对应的功能可以 [查看维基(制作中)](https://github.com/MrOkiDoki/BattleBit-Community-Server-API/wiki). 本 API 将在运行后开启一个`ServerListener` 的监听进程,传递你 *自己定义* 的 `Player` 和 `GameServer` 类型覆盖原本游戏自身的 `Player` 和 `GameServer` 类型。在这些类型中添加任何你想要的功能,以此来定制属于你自己的游戏玩法。 - 如果想给你的游戏服务端添加功能,可以直接把覆盖的功能写入 `Program.cs` 的 `MyPlayer` 和 `MyGameServer`中,当然你也可以按照框架规范进行其他的功能纂写。 ### 编译 @@ -31,12 +29,14 @@ BBR(像素战地)的服务端 API 在部署后可以提供`社区服`所需 当你将此项目的功能写完并进行了编译后,需要将此 API 服务进行部署。此 API 服务可以部署在本地网络、本机网络或者广域网中。我们强烈建议以「最低延迟」为基准进行部署,以保证 `ServerListener` 可以同时监听 *多个* 游戏服务端。 -你可以在游戏服务端的启动参数配置中对 API 的地址和端口进行设定。 +你可以在游戏服务端的启动配置中对 API 的地址和端口进行设定。 #### 启动参数 游戏服务端通过启动参数 `"-apiEndpoint=:<端口>"` 来与本 API 实例进行通信, 启动参数中的 `<端口>` 指的是本 API 服务中指定的端口 `` 指的是本 API 服务部署实例的 IP 地址。 -如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。当然,在游戏服务端的运行时,你也可以通过在命令行中输入 `setapitoken <新的token>` 来直接修改运行中的服务端的 `Api Token`。 +如果你在 API 服务中定义游戏服务端连接 API 服务时需要进行 `Api Token` 的验证,那么在游戏服务端的启动参数中需要增加 `"-apiToken=<你在程序中设置的 ApiToken>"`,当游戏服务端启动项的`Api Token`与 API 服务中`Api Token`的一致时,游戏服务端才可以与指定的 API 服务进行通信。 + +在游戏服务端的运行时,你也可以通过在命令行中输入 `setapitoken <新的token>` 来直接修改运行中的服务端的 `Api Token`。 #### 调整 API 端口 如果游戏服务端实例与本 API 实例不在同一个实例上进行部署,且你想修改本 API 实例的端口 `29294`,你可以查看 `Progran.cs` 中 `listener.Start(29294);` 并把 `29294` 修改为你想指定或防火墙等安全策略已通过的端口号。