From 00da1fb6b51ca4e85a649fc2b200271b42ea3e4c Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 13:34:56 +0000 Subject: [PATCH 01/25] feat: added game export-config --- game-source/export_presets.cfg | 37 ++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 game-source/export_presets.cfg diff --git a/game-source/export_presets.cfg b/game-source/export_presets.cfg new file mode 100644 index 0000000..0078c93 --- /dev/null +++ b/game-source/export_presets.cfg @@ -0,0 +1,37 @@ +[preset.0] + +name="Web" +platform="Web" +runnable=true +dedicated_server=false +custom_features="" +export_filter="all_resources" +include_filter="" +exclude_filter="" +export_path="" +encryption_include_filters="" +encryption_exclude_filters="" +encrypt_pck=false +encrypt_directory=false + +[preset.0.options] + +custom_template/debug="" +custom_template/release="" +variant/extensions_support=false +vram_texture_compression/for_desktop=true +vram_texture_compression/for_mobile=true +html/export_icon=true +html/custom_html_shell="" +html/head_include="" +html/canvas_resize_policy=2 +html/focus_canvas_on_start=true +html/experimental_virtual_keyboard=false +progressive_web_app/enabled=false +progressive_web_app/offline_page="" +progressive_web_app/display=1 +progressive_web_app/orientation=0 +progressive_web_app/icon_144x144="" +progressive_web_app/icon_180x180="" +progressive_web_app/icon_512x512="" +progressive_web_app/background_color=Color(0, 0, 0, 1) From 242275271569531198e6e27ae2d07716b0b6cacf Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 14:47:43 +0000 Subject: [PATCH 02/25] feat: added github action for building client --- .github/workflows/build-game-client.yml | 34 +++++++++++++++ client.Dockerfile | 58 +++++++++++++++++++++++++ 2 files changed, 92 insertions(+) create mode 100644 .github/workflows/build-game-client.yml create mode 100644 client.Dockerfile diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml new file mode 100644 index 0000000..f22e5c7 --- /dev/null +++ b/.github/workflows/build-game-client.yml @@ -0,0 +1,34 @@ +name: "Build CosmicKube game client" +on: push + +env: + GODOT_VERSION: 4.2.1 + EXPORT_NAME: CosmicKube + PROJECT_PATH: game-source + +jobs: + export-web: + name: "Export for Web" + runs-on: ubuntu-20.04 + container: + image: barichello/godot-ci:4.2.1 + steps: + - name: Checkout + uses: actions/checkout@v2 + with: + lfs: true + - name: Setup + run: | + mkdir -v -p ~/.local/share/godot/export_templates/ + mv /root/.local/share/godot/export_templates/${GODOT_VERSION}.stable ~/.local/share/godot/export_templates/${GODOT_VERSION}.stable + - name: Windows Build + run: | + mkdir -v -p build/web + cd $PROJECT_PATH + godot --headless --verbose --export-release "Web" ../build/web/index.html + - name: Upload Artifact + uses: actions/upload-artifact@v1 + with: + name: web + path: build/web + \ No newline at end of file diff --git a/client.Dockerfile b/client.Dockerfile new file mode 100644 index 0000000..61f558e --- /dev/null +++ b/client.Dockerfile @@ -0,0 +1,58 @@ +FROM ubuntu:jammy +LABEL author="https://github.com/aBARICHELLO/godot-ci/graphs/contributors" + +USER root +ENV DEBIAN_FRONTEND=noninteractive +RUN apt-get update && apt-get install -y --no-install-recommends \ + ca-certificates \ + git \ + git-lfs \ + unzip \ + wget \ + zip \ + adb \ + openjdk-17-jdk-headless \ + rsync \ + && rm -rf /var/lib/apt/lists/* + +ARG GODOT_VERSION="4.2.1" +ARG RELEASE_NAME="stable" +ARG SUBDIR="" +ARG GODOT_TEST_ARGS="" +ARG GODOT_PLATFORM="linux.x86_64" + +RUN wget https://downloads.tuxfamily.org/godotengine/${GODOT_VERSION}${SUBDIR}/Godot_v${GODOT_VERSION}-${RELEASE_NAME}_${GODOT_PLATFORM}.zip \ + && wget https://downloads.tuxfamily.org/godotengine/${GODOT_VERSION}${SUBDIR}/Godot_v${GODOT_VERSION}-${RELEASE_NAME}_export_templates.tpz \ + && mkdir ~/.cache \ + && mkdir -p ~/.config/godot \ + && mkdir -p ~/.local/share/godot/export_templates/${GODOT_VERSION}.${RELEASE_NAME} \ + && unzip Godot_v${GODOT_VERSION}-${RELEASE_NAME}_${GODOT_PLATFORM}.zip \ + && mv Godot_v${GODOT_VERSION}-${RELEASE_NAME}_${GODOT_PLATFORM} /usr/local/bin/godot \ + && unzip Godot_v${GODOT_VERSION}-${RELEASE_NAME}_export_templates.tpz \ + && mv templates/* ~/.local/share/godot/export_templates/${GODOT_VERSION}.${RELEASE_NAME} \ + && rm -f Godot_v${GODOT_VERSION}-${RELEASE_NAME}_export_templates.tpz Godot_v${GODOT_VERSION}-${RELEASE_NAME}_${GODOT_PLATFORM}.zip + +# Download and setup android-sdk +ENV ANDROID_HOME="/usr/lib/android-sdk" +RUN wget https://dl.google.com/android/repository/commandlinetools-linux-7583922_latest.zip \ + && unzip commandlinetools-linux-*_latest.zip -d cmdline-tools \ + && mv cmdline-tools $ANDROID_HOME/ \ + && rm -f commandlinetools-linux-*_latest.zip + +ENV PATH="${ANDROID_HOME}/cmdline-tools/cmdline-tools/bin:${PATH}" + +RUN yes | sdkmanager --licenses \ + && sdkmanager "platform-tools" "build-tools;33.0.2" "platforms;android-33" "cmdline-tools;latest" "cmake;3.22.1" "ndk;25.2.9519653" + +# Adding android keystore and settings +RUN keytool -keyalg RSA -genkeypair -alias androiddebugkey -keypass android -keystore debug.keystore -storepass android -dname "CN=Android Debug,O=Android,C=US" -validity 9999 \ + && mv debug.keystore /root/debug.keystore + +RUN godot -v -e --quit --headless ${GODOT_TEST_ARGS} +RUN echo 'export/android/android_sdk_path = "/usr/lib/android-sdk"' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/debug_keystore = "/root/debug.keystore"' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/debug_keystore_user = "androiddebugkey"' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/debug_keystore_pass = "android"' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/force_system_user = false' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/timestamping_authority_url = ""' >> ~/.config/godot/editor_settings-4.tres +RUN echo 'export/android/shutdown_adb_on_exit = true' >> ~/.config/godot/editor_settings-4.tres \ No newline at end of file From 77f4cf19fbe1d392a4aa4c60073bd693f4d6970b Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:11:08 +0000 Subject: [PATCH 03/25] feat: added step to check if build succeeded --- .github/workflows/build-game-client.yml | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index f22e5c7..abb11fe 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -21,11 +21,16 @@ jobs: run: | mkdir -v -p ~/.local/share/godot/export_templates/ mv /root/.local/share/godot/export_templates/${GODOT_VERSION}.stable ~/.local/share/godot/export_templates/${GODOT_VERSION}.stable - - name: Windows Build + - name: Web Build run: | mkdir -v -p build/web cd $PROJECT_PATH - godot --headless --verbose --export-release "Web" ../build/web/index.html + godot --headless --verbose --export-release "Web" ../build/web/index.html &> output.txt + - name: Check if build succeeded + run: | + if search="$(cat output.txt | grep 'ERROR:')" + then + exit 1 - name: Upload Artifact uses: actions/upload-artifact@v1 with: From beb19d045b54f919e310fd29d437445a8e07720e Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:12:25 +0000 Subject: [PATCH 04/25] chore: use etc2_astc compression --- game-source/project.godot | 1 + 1 file changed, 1 insertion(+) diff --git a/game-source/project.godot b/game-source/project.godot index f937ed2..d64f5ba 100644 --- a/game-source/project.godot +++ b/game-source/project.godot @@ -19,3 +19,4 @@ config/icon="res://icon.svg" renderer/rendering_method="gl_compatibility" renderer/rendering_method.mobile="gl_compatibility" +textures/vram_compression/import_etc2_astc=true From e06f8c531ed4ea623cbe6a4e380952afd6beb9ed Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:16:13 +0000 Subject: [PATCH 05/25] fix: whoops --- .github/workflows/build-game-client.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index abb11fe..cfdfc9d 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -28,9 +28,12 @@ jobs: godot --headless --verbose --export-release "Web" ../build/web/index.html &> output.txt - name: Check if build succeeded run: | + echo Reading build logs... + cat output.txt if search="$(cat output.txt | grep 'ERROR:')" then exit 1 + fi ;; - name: Upload Artifact uses: actions/upload-artifact@v1 with: From 26cdf8a5ed7353b89239088dd5bcd71f323c9478 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:19:15 +0000 Subject: [PATCH 06/25] fix: whoops 2 --- .github/workflows/build-game-client.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index cfdfc9d..6b6c89a 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -29,6 +29,7 @@ jobs: - name: Check if build succeeded run: | echo Reading build logs... + cd $PROJECT_PATH cat output.txt if search="$(cat output.txt | grep 'ERROR:')" then From a191f03c8483908380ba8eadf5e7e97b6b62a44c Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:21:15 +0000 Subject: [PATCH 07/25] fix: whoops 3 --- .github/workflows/build-game-client.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 6b6c89a..5ad3033 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -34,7 +34,9 @@ jobs: if search="$(cat output.txt | grep 'ERROR:')" then exit 1 - fi ;; + else + exit 0 + fi ; - name: Upload Artifact uses: actions/upload-artifact@v1 with: From dbf52d94c3628d917421fda4a3a20a887e8318bf Mon Sep 17 00:00:00 2001 From: Steph Flower Date: Sat, 2 Mar 2024 15:23:59 +0000 Subject: [PATCH 08/25] BE: Wireframe structs for websockets --- backend/src/kube.rs | 2 ++ backend/src/websocketstructs.rs | 15 +++++++++++++++ 2 files changed, 17 insertions(+) create mode 100644 backend/src/websocketstructs.rs diff --git a/backend/src/kube.rs b/backend/src/kube.rs index 4ea658b..05384cd 100644 --- a/backend/src/kube.rs +++ b/backend/src/kube.rs @@ -3,3 +3,5 @@ pub struct Kube { name: String, uuid: String, //uuid type? } + +// we should have a placeholder ''loading'' cube we can send over if api is slow diff --git a/backend/src/websocketstructs.rs b/backend/src/websocketstructs.rs new file mode 100644 index 0000000..8b5017d --- /dev/null +++ b/backend/src/websocketstructs.rs @@ -0,0 +1,15 @@ + +// these are the structs intended for use when communicating via websockets + +// this is the data we expect to recieve from the player +pub struct PlayerInfo { + player: Player, //the player requesting the data + coordinates: [u64; 2], //current player coordinates + action: String, //PLACEHOLDER! we need to know what the player is doing. +} + +// this is the data we expect to send to the player +pub struct GameState { + grid: String, //PLACEHOLDER! This will be the partial grid state type +} + From 60cf2ea5384504d1f694e1824c9d20f01d75f621 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:26:56 +0000 Subject: [PATCH 09/25] chore: sanity check --- .github/workflows/build-game-client.yml | 13 +------------ 1 file changed, 1 insertion(+), 12 deletions(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 5ad3033..ecd3237 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -25,18 +25,7 @@ jobs: run: | mkdir -v -p build/web cd $PROJECT_PATH - godot --headless --verbose --export-release "Web" ../build/web/index.html &> output.txt - - name: Check if build succeeded - run: | - echo Reading build logs... - cd $PROJECT_PATH - cat output.txt - if search="$(cat output.txt | grep 'ERROR:')" - then - exit 1 - else - exit 0 - fi ; + godot --headless --verbose --export-release "Web" ../build/web/index.html - name: Upload Artifact uses: actions/upload-artifact@v1 with: From 30eece795ed541b00cb9c4bf2302d34d583af6d5 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:29:38 +0000 Subject: [PATCH 10/25] chroe: aaaaaaaaaaaaa --- .github/workflows/build-game-client.yml | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index ecd3237..94a052d 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -25,7 +25,15 @@ jobs: run: | mkdir -v -p build/web cd $PROJECT_PATH - godot --headless --verbose --export-release "Web" ../build/web/index.html + godot --headless --verbose --export-release "Web" ../build/web/index.html &> output.txt + echo Reading build logs... + cat output.txt + if search="$(cat output.txt | grep 'ERROR:')" + then + exit 1 + else + exit 0 + fi ; - name: Upload Artifact uses: actions/upload-artifact@v1 with: From c8018820f73e4b6a355844926878d29d43cda553 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:36:53 +0000 Subject: [PATCH 11/25] fsgrfdgsf --- .github/workflows/build-game-client.yml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 94a052d..5605d0c 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -25,13 +25,14 @@ jobs: run: | mkdir -v -p build/web cd $PROJECT_PATH - godot --headless --verbose --export-release "Web" ../build/web/index.html &> output.txt + godot --headless --verbose --export-release "Web" ../build/web/index.html 2>&1 | tee output.txt echo Reading build logs... - cat output.txt if search="$(cat output.txt | grep 'ERROR:')" then + echo "Build failed!" exit 1 else + echo "Build succeeded!" exit 0 fi ; - name: Upload Artifact From b742477df98e329494bae0c39a6c41a85b981f78 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:39:00 +0000 Subject: [PATCH 12/25] don't wanna fail on EVERY error --- .github/workflows/build-game-client.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 5605d0c..6666dea 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -27,7 +27,7 @@ jobs: cd $PROJECT_PATH godot --headless --verbose --export-release "Web" ../build/web/index.html 2>&1 | tee output.txt echo Reading build logs... - if search="$(cat output.txt | grep 'ERROR:')" + if search="$(cat output.txt | grep 'ERROR: Project export')" then echo "Build failed!" exit 1 From f1267cb40ab620530a87a0967b1600ef3f305d0c Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:42:21 +0000 Subject: [PATCH 13/25] chore: bumped checkout to v4 --- .github/workflows/build-game-client.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 6666dea..5e69443 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -14,7 +14,7 @@ jobs: image: barichello/godot-ci:4.2.1 steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 with: lfs: true - name: Setup From 70577b0b348a4febd1d970441203bb4ceea469bb Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:48:37 +0000 Subject: [PATCH 14/25] feat: mirrored actions file to Jenkinsfile --- Jenkinsfile | 48 +++++++++++++++++++++++++++++++----------------- 1 file changed, 31 insertions(+), 17 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index 51f57d7..5076dab 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,24 +1,38 @@ pipeline { - agent any + agent { + docker { + image 'barichello/godot-ci:4.2.1' + + } } + environment { + GODOT_VERSION = '4.2.1' + EXPORT_NAME = 'CosmicKube' + PROJECT_PATH = 'game-source' + } stages { - stage('Hello world') { + stage('Setup') { steps { - sh 'echo pee pee' + sh '''mkdir -v -p ~/.local/share/godot/export_templates/ + mv /root/.local/share/godot/export_templates/${GODOT_VERSION}.stable ~/.local/share/godot/export_templates/${GODOT_VERSION}.stable + ''' + } + } + stage('Web Build') { + steps { + sh '''mkdir -v -p build/web + cd $PROJECT_PATH + godot --headless --verbose --export-release "Web" ../build/web/index.html 2>&1 | tee output.txt + echo Reading build logs... + if search="$(cat output.txt | grep 'ERROR: Project export')" + then + echo "Build failed!" + exit 1 + else + echo "Build succeeded!" + exit 0 + fi ;''' } } - - // stage('Push image') { - // steps { - // sh 'docker push localhost:5000/ttt' - // } - // } - // - // stage('Package') { - // steps { - // sh 'helm install ttt ttt | true' - // sh 'helm upgrade ttt ttt' - // } - // } } -} +} \ No newline at end of file From acfe1e17c9135bde603d63db2212be35a2e06a50 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:48:50 +0000 Subject: [PATCH 15/25] feat: added flow to test Jenkinsfile --- .github/workflows/test-jenkinsfile.yml | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 .github/workflows/test-jenkinsfile.yml diff --git a/.github/workflows/test-jenkinsfile.yml b/.github/workflows/test-jenkinsfile.yml new file mode 100644 index 0000000..90f87eb --- /dev/null +++ b/.github/workflows/test-jenkinsfile.yml @@ -0,0 +1,18 @@ +name: "Build CosmicKube game client" +on: push + +env: + GODOT_VERSION: 4.2.1 + EXPORT_NAME: CosmicKube + PROJECT_PATH: game-source + +jobs: + test-jenkins: + name: "Test Jenkinsfile" + runs-on: ubuntu-20.04 + steps: + - uses: actions/checkout@master + - name: jenkinsfile-runner-prepackaged + uses: jenkinsci/jenkinsfile-runner-github-actions/jenkinsfile-runner-prepackaged@master + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file From 5dfc76f2731b3bb22dc8a59cd57f00ac8bdb6da6 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:50:58 +0000 Subject: [PATCH 16/25] chore: make jenkins happy --- .github/workflows/test-jenkinsfile.yml | 2 +- plugins.txt | 0 2 files changed, 1 insertion(+), 1 deletion(-) create mode 100644 plugins.txt diff --git a/.github/workflows/test-jenkinsfile.yml b/.github/workflows/test-jenkinsfile.yml index 90f87eb..31712e7 100644 --- a/.github/workflows/test-jenkinsfile.yml +++ b/.github/workflows/test-jenkinsfile.yml @@ -1,4 +1,4 @@ -name: "Build CosmicKube game client" +name: "Test Jenkinsfile" on: push env: diff --git a/plugins.txt b/plugins.txt new file mode 100644 index 0000000..e69de29 From b3117aa14c1aa31f1e30c1629ab733d376869f5b Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 15:53:01 +0000 Subject: [PATCH 17/25] thing doesn't work (for now) --- .../{test-jenkinsfile.yml => test-jenkinsfile.yml.noworky} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename .github/workflows/{test-jenkinsfile.yml => test-jenkinsfile.yml.noworky} (100%) diff --git a/.github/workflows/test-jenkinsfile.yml b/.github/workflows/test-jenkinsfile.yml.noworky similarity index 100% rename from .github/workflows/test-jenkinsfile.yml rename to .github/workflows/test-jenkinsfile.yml.noworky From be136bfe4a29204de86f28fe94b8c26be7198f85 Mon Sep 17 00:00:00 2001 From: Steph Flower Date: Sat, 2 Mar 2024 16:34:41 +0000 Subject: [PATCH 18/25] BE: Create ws dependencies --- backend/Cargo.toml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/backend/Cargo.toml b/backend/Cargo.toml index aabd03e..8589859 100644 --- a/backend/Cargo.toml +++ b/backend/Cargo.toml @@ -6,3 +6,10 @@ edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] +tokio = { version= "1", features = ["full"] } +tokio-stream = "0.1.6" +warp = "0.3" +serde = { version = "1.0", features = ["derive"]} +serde_json = "1.0" +futures = { version = "0.3", default-features=false} +uuid = { version = "1.1.2", features = ["v4", "fast-rng", "macro-diagnostics"]} From 45d4244c6c9ed271959bcde817d64f4463313168 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:06:46 +0000 Subject: [PATCH 19/25] feat: added azure publish --- .github/workflows/build-game-client.yml | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 5e69443..6dae186 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -35,9 +35,24 @@ jobs: echo "Build succeeded!" exit 0 fi ; + - name: Create staticwebapp.config.json + run: | + cd build/ + echo ${{ vars.STATIC_WEB_APP_CONFIG }} > staticwebapp.config.json - name: Upload Artifact uses: actions/upload-artifact@v1 with: name: web path: build/web - \ No newline at end of file + + - name: Publish to Azure Static Web Apps + id: publishto + uses: Azure/static-web-apps-deploy@v1 + with: + azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN }} + repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for GitHub integrations (i.e. PR comments) + action: "upload" + ###### Repository/Build Configurations ###### + app_location: "build/web" + skip_app_build: true + ###### End of Repository/Build Configurations ###### \ No newline at end of file From f3b39e7938f60b2f554abb902e2edc5557cb9390 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:14:26 +0000 Subject: [PATCH 20/25] fix: escaping json --- .github/workflows/build-game-client.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 6dae186..ae26fb3 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -38,7 +38,7 @@ jobs: - name: Create staticwebapp.config.json run: | cd build/ - echo ${{ vars.STATIC_WEB_APP_CONFIG }} > staticwebapp.config.json + echo "${{ vars.STATIC_WEB_APP_CONFIG }}" > staticwebapp.config.json - name: Upload Artifact uses: actions/upload-artifact@v1 with: From 0176a89edf159870f19b44272fd5117421eca27f Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:18:44 +0000 Subject: [PATCH 21/25] debug: added list --- .github/workflows/build-game-client.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index ae26fb3..3d9b772 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -39,6 +39,7 @@ jobs: run: | cd build/ echo "${{ vars.STATIC_WEB_APP_CONFIG }}" > staticwebapp.config.json + ls - name: Upload Artifact uses: actions/upload-artifact@v1 with: From ad0d9f83f622915c4156147375f3ecbcb80b9432 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:23:28 +0000 Subject: [PATCH 22/25] fix: global headers --- .github/workflows/build-game-client.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 3d9b772..0680a54 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -37,7 +37,7 @@ jobs: fi ; - name: Create staticwebapp.config.json run: | - cd build/ + cd build/web echo "${{ vars.STATIC_WEB_APP_CONFIG }}" > staticwebapp.config.json ls - name: Upload Artifact From 7a16630f1720327843049082ec380c57a6c2efca Mon Sep 17 00:00:00 2001 From: Steph Flower Date: Sat, 2 Mar 2024 17:25:11 +0000 Subject: [PATCH 23/25] BE/ws: Set up basic websocket server --- backend/src/handlers.rs | 9 +++++ backend/src/main.rs | 40 +++++++++++++++++++- backend/src/ws.rs | 81 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 128 insertions(+), 2 deletions(-) create mode 100644 backend/src/handlers.rs create mode 100644 backend/src/ws.rs diff --git a/backend/src/handlers.rs b/backend/src/handlers.rs new file mode 100644 index 0000000..c2a2eb3 --- /dev/null +++ b/backend/src/handlers.rs @@ -0,0 +1,9 @@ +use crate::{ws, Clients, Result}; +use warp::Reply; + +pub async fn ws_handler(ws: warp::ws::Ws, clients: Clients) -> Result +{ + println!("ws_handler"); //debug + + Ok(ws.on_upgrade(move |socket| ws::client_connection(socket, clients))) +} \ No newline at end of file diff --git a/backend/src/main.rs b/backend/src/main.rs index e7a11a9..5e9410d 100644 --- a/backend/src/main.rs +++ b/backend/src/main.rs @@ -1,3 +1,39 @@ -fn main() { - println!("Hello, world!"); +use std::{collections::HashMap, convert::Infallible, sync::Arc}; +use tokio::sync::{mpsc, Mutex}; +use warp::{filters::ws::Message, Filter, Rejection}; + +mod handlers; +mod ws; + +// type that represents a connecting client +#[derive(Debug, Clone)] +pub struct Client { + pub client_id: String, + pub sender: Option>>, } + +// type aliases! +type Clients = Arc>>; +type Result = std::result::Result; + +#[tokio::main] +async fn main() { + + //initialise a hashmap to store currently connected clients. We may want some more logic here if we want currently connected clients to be stored somewhere + let clients: Clients = Arc::new(Mutex::new(HashMap::new())); + + println!("configuring websocket route"); //debug + let ws_route = warp::path("ws") + .and(warp::ws()) + .and(with_clients(clients.clone())) + .and_then(handlers::ws_handler); + + let routes = ws_route.with(warp::cors().allow_any_origin()); + println!("starting server"); //debug + warp::serve(routes).run(([127, 0, 0, 1], 8000)).await; +} + +fn with_clients(clients: Clients) -> impl Filter + Clone { + warp::any().map(move || clients.clone()) +} + diff --git a/backend/src/ws.rs b/backend/src/ws.rs new file mode 100644 index 0000000..ae1c19a --- /dev/null +++ b/backend/src/ws.rs @@ -0,0 +1,81 @@ +use crate::{Client, Clients}; +use futures::{FutureExt, StreamExt}; +use tokio::sync::mpsc; +use tokio_stream::wrappers::UnboundedReceiverStream; +use uuid::Uuid; +use warp::ws::{Message, WebSocket}; + +pub async fn client_connection(ws: WebSocket, clients: Clients) { + println!("establishing client connection... {:?}", ws); //debug + + // splitting the WebSocket stream object into separate 'Sink' and 'Stream' objects. + // This lets us split up the logic of sending and recieving tasks + // 'Stream' lets us recieve messages from the client + // 'Sink' letes us establish a connection from the unbounded channel + let (client_ws_sender, mut client_ws_rcv) = ws.split(); + // creates an unbounded channel. It is configured to send messages to the client. + let (client_sender, client_rcv) = mpsc::unbounded_channel(); + + let client_rcv = UnboundedReceiverStream::new(client_rcv); + + // 'spawns' a new task, that stays alive until the client has disconnected. + tokio::task::spawn(client_rcv.forward(client_ws_sender).map(|result| { + if let Err(e) = result { + println!("error sending websocket msg: {}", e); + } + })); + + // creating a new uuid to use as the key in the 'clients' hashmap, and a new instance of a 'client' + let uuid = Uuid::new_v4().simple().to_string(); + + let new_client = Client { + client_id: uuid.clone(), + //the client_sender object is stored within this new client instance so that we can send messages to this connected client in other parts of the code + sender: Some(client_sender), + }; + + //obtains a lock on the client list and inserts the new client into the hashmap using the uuid as the key. + clients.lock().await.insert(uuid.clone(), new_client); + + // creates a loop that handles incoming messages from the client + while let Some(result) = client_ws_rcv.next().await { + let msg = match result { + Ok(msg) => msg, + Err(e) => { + println!("error receiving message for id {}): {}", uuid.clone(), e); + break; + } + }; + client_msg(&uuid, msg, &clients).await; + } + + // as the above will keep running as long as the client is active, when we exit the loop we can safely remove this client instance from the hashmap. + clients.lock().await.remove(&uuid); + println!("{} disconnected", uuid); //debug +} + +// example function to respond to a clients message, this just responds to 'ping!' with 'pong!', but later we will replace this with; +// ->recieve client game info <- send back client game state +// wwwwwwwwwwwwwwwwwwwww i am so tired +async fn client_msg(client_id: &str, msg: Message, clients: &Clients) { + println!("received message from {}: {:?}", client_id, msg); //debug + + let message = match msg.to_str() { + Ok(v) => v, + Err(_) => return, + }; + + if message == "ping" || message == "ping\n" { + let locked = clients.lock().await; + match locked.get(client_id) { + Some(v) => { + if let Some(sender) = &v.sender { + println!("sending pong"); + let _ = sender.send(Ok(Message::text("pong"))); + } + } + None => return, + } + return; + }; +} \ No newline at end of file From 12081fcc57ace162495e4ce530432951a6a9d3a3 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:31:50 +0000 Subject: [PATCH 24/25] fix: specified branches to run flow on --- .github/workflows/build-game-client.yml | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index 0680a54..dc34095 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -1,5 +1,11 @@ name: "Build CosmicKube game client" -on: push +on: + push: + branches: + - main + pull_request: + branches: + - main env: GODOT_VERSION: 4.2.1 From 2032457bc147f76759931142793d0818bcd64519 Mon Sep 17 00:00:00 2001 From: Leo Durrant Date: Sat, 2 Mar 2024 17:42:40 +0000 Subject: [PATCH 25/25] fix: remove thingy --- .github/workflows/build-game-client.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/build-game-client.yml b/.github/workflows/build-game-client.yml index dc34095..07f8457 100644 --- a/.github/workflows/build-game-client.yml +++ b/.github/workflows/build-game-client.yml @@ -3,9 +3,6 @@ on: push: branches: - main - pull_request: - branches: - - main env: GODOT_VERSION: 4.2.1