Compare commits
	
		
			361 Commits
		
	
	
		
			update-agg
			...
			08183ed952
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 08183ed952 | |||
| 4fac231c43 | |||
| 30e356e3e0 | |||
| 36712557cb | |||
| c6aeca7e2b | |||
| 92c18f8bf7 | |||
| e86f40c620 | |||
| 072235f032 | |||
| 9b76a6b599 | |||
| d94dbd6c03 | |||
| b2db5bde2b | |||
| f8c5cf74f8 | |||
| 231076496a | |||
| a1b3baa5c9 | |||
| 8378f7ae0b | |||
| d4b75bcb71 | |||
| b0c7de2e92 | |||
| 844e218197 | |||
| a7c8e07eb7 | |||
| 5d99ec7673 | |||
| 2f92820895 | |||
| 527113a099 | |||
| 381b4ce0c2 | |||
| 6d8f5d5d65 | |||
| b74fb2b1d7 | |||
| d67b413860 | |||
| ec1f5afb84 | |||
| 1ce4267945 | |||
|  | 2da00ca814 | ||
|  | f7c0dff73c | ||
|  | 422bb77f61 | ||
|  | d51d2491ca | ||
| db39c5a576 | |||
| c6c5971325 | |||
| 5181612f62 | |||
|  | 5f33fae3d7 | ||
| 24fcac9318 | |||
| 514f2ef928 | |||
| 7d252d3cc8 | |||
| a1581379fd | |||
| a5f90ab105 | |||
| ddd7e2d50b | |||
| 3bacc356af | |||
| 797ca3a387 | |||
| ed751f5cdd | |||
| 01a580cee5 | |||
| 6fd14d3c49 | |||
| a1b524ab9d | |||
| 9bd0e237ea | |||
| 97d4f2cbe9 | |||
| 9307fbcbf4 | |||
| 679150326f | |||
| 773a2eaed0 | |||
| 203d343880 | |||
| 26ed50a7a1 | |||
| 050705c370 | |||
| d3c5979d3e | |||
| 8102a0f40b | |||
| 87fabdc8f9 | |||
|  | 7889476bc9 | ||
| abfaf06f1a | |||
| 8bd9e039da | |||
|  | 5cfccb97b1 | ||
|  | 54428112f8 | ||
| 18c12e60fe | |||
| 1000eb6d2c | |||
| 27114615a5 | |||
| 43c1f7be09 | |||
|  | 09bbbf0b3d | ||
|  | 2db886ea13 | ||
|  | e88d875bd9 | ||
| 57c3ee0360 | |||
| e1600751e0 | |||
| be47dcdba2 | |||
| fd30ae04bf | |||
| 19628736c1 | |||
| 4ced3d39df | |||
| be59f7a2c6 | |||
| 1665cf1eb9 | |||
| 47df3adce5 | |||
| f64fc0e54a | |||
| 314957218e | |||
| babb111fa6 | |||
|  | b051809869 | ||
|  | 32ec7a2339 | ||
| 3bce7ea344 | |||
| 76ed63395c | |||
| 19f324a1cf | |||
| 4b41d3b039 | |||
| 2ce41be8cc | |||
| c9f2187cc2 | |||
| a47fb5fed7 | |||
| 318a2a24fd | |||
| 2224a8ccbd | |||
| 48e2bec9ce | |||
| 6a1807efc8 | |||
| 0ad6e63733 | |||
| 6255e246e7 | |||
| 808fae0480 | |||
|  | 44d2402f4b | ||
|  | 7da14dbb6c | ||
| cc597b3cfb | |||
| 60af058ba4 | |||
|  | 608e784205 | ||
|  | 36041dd41b | ||
| 17aee8f220 | |||
| 294198958d | |||
|  | fe824f90ef | ||
|  | a560ebdb70 | ||
| 63faa9397e | |||
| 4df6e51e82 | |||
| cef4119afa | |||
| bee765714e | |||
| edff79abb6 | |||
|  | 2505fc1bf7 | ||
| d400434e89 | |||
| 4bd438d692 | |||
| 828140ed2b | |||
| 9a2cae0c70 | |||
| 3a621b8323 | |||
| 0360fb413c | |||
| 5b86a0f6d9 | |||
| 24c14fb7ca | |||
| fbbcd51df5 | |||
| 5a9578d554 | |||
|  | 5cb1069c1c | ||
|  | 0c8cad6608 | ||
|  | b865f78e22 | ||
|  | bc7b066864 | ||
|  | 7b4af08296 | ||
| c77bc476aa | |||
| b802bb01e6 | |||
| 61f9add741 | |||
| d8e9eef8b1 | |||
| 7bddeca783 | |||
|  | d03565ba26 | ||
|  | 36fe81cb3e | ||
|  | f9edab8f36 | ||
|  | ffe95a12f2 | ||
|  | bcef200765 | ||
|  | dc0e3989d4 | ||
|  | b9f821652c | ||
|  | b04c6aa345 | ||
| b05e354459 | |||
| ce8cfd6a68 | |||
|  | 234d4d0fa9 | ||
|  | 4d05d9a539 | ||
|  | 3f16310f67 | ||
| 762351f76e | |||
|  | 2f33b7fd86 | ||
| 8efbd676ce | |||
| 2fc7c8ab1e | |||
| dc5a90cf1a | |||
|  | 2e49bc4709 | ||
|  | 4e7046bd28 | ||
|  | 3eab510f5a | ||
|  | 8c3b745d4d | ||
| db9475cf3b | |||
|  | 31c212807b | ||
|  | aca8caa5c3 | ||
|  | b30ef2ef2b | ||
| 62637badcb | |||
|  | ddcd9899b3 | ||
|  | d3db06a90c | ||
|  | 92e211a21a | ||
|  | 1098ba4c7d | ||
| 2c5a843835 | |||
| 204e289627 | |||
| fd731b2ecf | |||
| e733e413ef | |||
|  | e1abd8e85c | ||
|  | 3b1abc9ae8 | ||
|  | 6b8737e182 | ||
|  | baab800a1c | ||
|  | e2bde3bd01 | ||
|  | f849780aac | ||
|  | 37004a1f6e | ||
|  | d483be05a6 | ||
| 0c89178542 | |||
| c8999f8250 | |||
| 2fd1f26325 | |||
|  | 03774a540f | ||
| f559c1e215 | |||
|  | ea130df02b | ||
|  | 2ac780bdaa | ||
|  | a9f474fa62 | ||
|  | 3a476e0db4 | ||
|  | b9221fa949 | ||
|  | 07db6e21db | ||
|  | e5e998df36 | ||
| 112ed5b140 | |||
| a781510a41 | |||
| bbbcffcfcb | |||
|  | 13bdfff9f8 | ||
|  | ef7c39e4e9 | ||
|  | ee085cbbb1 | ||
| 35a94b4a75 | |||
|  | da68d87a5f | ||
|  | af28d5c65b | ||
|  | b5ca868050 | ||
| 4a5dd47bc0 | |||
|  | 71a5f72381 | ||
|  | c1ba1ceb7c | ||
|  | 035ce9f1b9 | ||
|  | eb2534ff94 | ||
|  | d93d73dc3a | ||
|  | 6bfd0621ad | ||
|  | b88f5bf2e4 | ||
| 43ff5d416a | |||
| 90fc81776f | |||
| 0e8316b9f5 | |||
| 01f1f94dd6 | |||
| bfd5a58461 | |||
| 240831d6e5 | |||
| 394bff34e5 | |||
| 000918844a | |||
| f44a1597c0 | |||
| 1cfc6a9ae3 | |||
| b4a5fdebab | |||
| 4970018afb | |||
| 8998cc3ac4 | |||
| bee4dc403b | |||
| edbe916247 | |||
| 73334a7dd7 | |||
| 497068627c | |||
| 89361e17e6 | |||
| 18ec4bf9f1 | |||
| 2e75f784dd | |||
| c7179bd0a0 | |||
| b38c099414 | |||
| e7f5d19707 | |||
| 4ae2e70586 | |||
| c93072d9b4 | |||
| 721e728275 | |||
| bfd96d9ccc | |||
| 3f0e0bb9a9 | |||
| 2276605e6d | |||
| a6883a624a | |||
| fc3cf92dcf | |||
| e69f9dc2d8 | |||
| 473d79a32d | |||
| 2f8f0227ba | |||
| 7bf0053974 | |||
| 5f7e7e31bf | |||
| a1bc5377db | |||
| f4b93253a8 | |||
|  | 56733c854c | ||
| 9e170380db | |||
| 23f0beb646 | |||
| a0af0ad300 | |||
|  | 9187021cda | ||
| 4fb8fe7d08 | |||
|  | c882786726 | ||
| 7f6a05c101 | |||
| 06f1aad38e | |||
| 2aa9b4b2d1 | |||
| 152ede26e3 | |||
| 3f43c8d946 | |||
| 85b1cb8759 | |||
| 82069f3bef | |||
| 3a31135807 | |||
|  | 6482d43af0 | ||
|  | e221ef070f | ||
|  | 6b547c4ddd | ||
|  | 63ef099dc3 | ||
| f4cf600d22 | |||
|  | f9111ffe5e | ||
|  | cd3329baae | ||
|  | feafd48443 | ||
|  | eb152bc6c7 | ||
| 4376f9dc26 | |||
|  | 7f7487836c | ||
|  | 7046b23a27 | ||
| 6ebceb4ce7 | |||
|  | 3d9845e1b3 | ||
|  | 07118a870f | ||
| abb718603e | |||
|  | 9f170c1186 | ||
|  | 94d4f13a28 | ||
| 4c6bf597a9 | |||
|  | 4c091745dd | ||
|  | 406f6f5cdd | ||
|  | 4250eca710 | ||
| 3bd414506a | |||
|  | a9dbd503e3 | ||
| ec0904ffb1 | |||
|  | b80b05fbd8 | ||
| d9a4247b8e | |||
|  | 9d5164bd13 | ||
| ec6d36b44c | |||
| 7e7a571f5a | |||
|  | 9a61ea59b2 | ||
|  | 5dc141a14a | ||
|  | a0f8ec156b | ||
|  | 7383c85b58 | ||
|  | aed0faebf0 | ||
| f0b9f8043b | |||
|  | 58dfe98448 | ||
|  | f14ba0e97f | ||
|  | 981b5cebca | ||
| 4e3a93f126 | |||
|  | c391a07d70 | ||
|  | 7faa25e103 | ||
|  | 12c3a6ef6f | ||
| 4c1bd21f3d | |||
| abfc6c4c47 | |||
| afb2ef21f5 | |||
| 06bb8feeb5 | |||
| a112586c2d | |||
|  | 8d40008e5d | ||
|  | a9afd7e0a9 | ||
| 28a0426096 | |||
|  | dee04269bd | ||
|  | 6c7ceb3eb3 | ||
|  | 4dda9eb24c | ||
| 92258f4925 | |||
| 5b1b1cdaaa | |||
| 875989e3a9 | |||
| 74c17f433a | |||
|  | 2903207670 | ||
|  | c0723665af | ||
| 83a648eb90 | |||
| 5204599a08 | |||
| fcdce8706f | |||
| 5192212e0e | |||
| 376d695416 | |||
| e25425ffe9 | |||
| 78d40f1abc | |||
| 78d99da6df | |||
| f797c98d45 | |||
| 491ca28ab2 | |||
| 7f71c89ffb | |||
| 411d5720b9 | |||
| 872dd3fd71 | |||
| 521e9da4e3 | |||
| ed8371e08a | |||
| 160590658b | |||
| 002ac7902d | |||
| e527b198f9 | |||
| d68561b372 | |||
| c292289f29 | |||
| e053517765 | |||
| 66d045c2a7 | |||
| e1410ed402 | |||
| 1031794d85 | |||
| 5d2b45b3e5 | |||
| 73b09fe9cb | |||
| cd2ecb22b1 | |||
| ad66131e01 | |||
| f401c418c5 | |||
| 7b8db90f75 | |||
| 0431ba12c5 | |||
| 3731bb7532 | |||
| a1a3fa45b1 | |||
| 59541ec0e8 | |||
| b334cc377f | |||
| b1467838da | |||
| 20901fb26c | |||
| 295f948104 | |||
| 977ab8f6c9 | |||
| c3e2d23a63 | 
							
								
								
									
										17
									
								
								.gitea/workflows/tests.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								.gitea/workflows/tests.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | name: Tests | ||||||
|  | on: | ||||||
|  |   pull_request: | ||||||
|  |  | ||||||
|  | env: | ||||||
|  |   NIXPKGS_ALLOW_UNFREE: 1 | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   install: | ||||||
|  |     name: Tests | ||||||
|  |     runs-on: nixos-x86_64-linux | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: recursive | ||||||
|  |       - name: codegen causes no changes | ||||||
|  |         run: ./bin/assert-no-changes-wrapper.sh | ||||||
							
								
								
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | node_modules | ||||||
|  | dist | ||||||
|  | .direnv | ||||||
|  | /after.txt | ||||||
|  | /before.txt | ||||||
							
								
								
									
										6
									
								
								bin/assert-no-changes-wrapper.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										6
									
								
								bin/assert-no-changes-wrapper.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | GQL_DIR=$(dirname $(dirname "$(realpath "$BASH_SOURCE")")) | ||||||
|  |  | ||||||
|  | cd $GQL_DIR | ||||||
|  |  | ||||||
|  | LD_LIBRARY_PATH="" nix develop --impure --command bash "$GQL_DIR/bin/assert-no-changes.sh" | ||||||
							
								
								
									
										17
									
								
								bin/assert-no-changes.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										17
									
								
								bin/assert-no-changes.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | git ls-files | xargs md5sum > before.txt | ||||||
|  |  | ||||||
|  | yarn install | ||||||
|  | yarn graphql-codegen | ||||||
|  | prettier ./src --write | ||||||
|  | for proto in $(find ./rbproto -iname '*.proto'); do | ||||||
|  | 		name=$(basename "$proto" .proto) | ||||||
|  | 		protoc -I=./rbproto --python_out=./rbproto/python --pyi_out=./rbproto/python ./rbproto/shot.proto | ||||||
|  |     yarn pbjs ./rbproto/shot.proto --ts ./rbproto/ts/shot.ts | ||||||
|  | done | ||||||
|  | prettier ./rbproto --write | ||||||
|  |  | ||||||
|  | git ls-files | xargs md5sum > after.txt | ||||||
|  |  | ||||||
|  |  | ||||||
|  | diff before.txt after.txt | ||||||
							
								
								
									
										4
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -20,9 +20,7 @@ | |||||||
|     }, |     }, | ||||||
|     "gitignore": { |     "gitignore": { | ||||||
|       "inputs": { |       "inputs": { | ||||||
|         "nixpkgs": [ |         "nixpkgs": ["nixpkgs"] | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1703887061, |         "lastModified": 1703887061, | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ | |||||||
|     in |     in | ||||||
|       with pkgs; { |       with pkgs; { | ||||||
|         devShell = mkShell { |         devShell = mkShell { | ||||||
|           buildInputs = [nodejs yarn watchman alejandra nodePackages.prettier]; |           buildInputs = [nodejs yarn watchman alejandra nodePackages.prettier just protobuf]; | ||||||
|         }; |         }; | ||||||
|       }); |       }); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										39
									
								
								justfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								justfile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | NIX := "LD_LIBRARY_PATH='' nix" | ||||||
|  | PROTOBUF_DIR := "$PWD/rbproto" | ||||||
|  |  | ||||||
|  | prettier-gql: | ||||||
|  | 	#!/usr/bin/env bash | ||||||
|  | 	set -euxo pipefail | ||||||
|  | 	{{NIX}} develop --impure --command prettier ./src --write | ||||||
|  |  | ||||||
|  | gql-codegen: | ||||||
|  | 	#!/usr/bin/env bash | ||||||
|  | 	set -euxo pipefail | ||||||
|  | 	{{NIX}} develop --impure --command bash -c 'yarn install && yarn graphql-codegen' | ||||||
|  |  | ||||||
|  |  | ||||||
|  | gql: gql-codegen prettier-gql | ||||||
|  |  | ||||||
|  | protobuf-compile-a-python name: | ||||||
|  | 	protoc -I={{ PROTOBUF_DIR }} --python_out={{ PROTOBUF_DIR }}/python --pyi_out={{ PROTOBUF_DIR }}/python {{ PROTOBUF_DIR }}/shot.proto | ||||||
|  |  | ||||||
|  | protobuf-compile-a-js name: | ||||||
|  | 	#!/usr/bin/env bash | ||||||
|  | 	set -euxo pipefail | ||||||
|  | 	{{NIX}} develop --impure --command bash -c 'yarn pbjs {{ PROTOBUF_DIR }}/shot.proto --ts {{ PROTOBUF_DIR }}/ts/shot.ts && yarn prettier ./rbproto --write' | ||||||
|  |  | ||||||
|  | protobuf-compile-all-js: | ||||||
|  | 	#!/usr/bin/env bash | ||||||
|  | 	for proto in $(find {{ PROTOBUF_DIR }} -iname '*.proto'); do | ||||||
|  | 		name=$(basename "$proto" .proto) | ||||||
|  | 		just protobuf-compile-a-js $name | ||||||
|  | 	done | ||||||
|  |  | ||||||
|  | protobuf-compile-all-python: | ||||||
|  | 	#!/usr/bin/env bash | ||||||
|  | 	for proto in $(find {{ PROTOBUF_DIR }} -iname '*.proto'); do | ||||||
|  | 		name=$(basename "$proto" .proto) | ||||||
|  | 		just protobuf-compile-a-python $name | ||||||
|  | 	done | ||||||
|  |  | ||||||
|  | protobuf-compile-everything: protobuf-compile-all-js protobuf-compile-all-python | ||||||
							
								
								
									
										10
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								package.json
									
									
									
									
									
								
							| @@ -17,7 +17,15 @@ | |||||||
|     "@graphql-codegen/typescript": "^4.0.1", |     "@graphql-codegen/typescript": "^4.0.1", | ||||||
|     "@graphql-codegen/typescript-operations": "^4.0.1", |     "@graphql-codegen/typescript-operations": "^4.0.1", | ||||||
|     "@graphql-codegen/typescript-react-apollo": "^4.2.0", |     "@graphql-codegen/typescript-react-apollo": "^4.2.0", | ||||||
|     "graphql": "^16.8.1" |     "graphql": "^16.8.1", | ||||||
|  |     "pbjs": "^0.0.14", | ||||||
|  |     "prettier": "^3.2.5", | ||||||
|  |     "prettier-plugin-organize-imports": "^3.2.4" | ||||||
|  |   }, | ||||||
|  |   "prettier": { | ||||||
|  |     "plugins": [ | ||||||
|  |       "prettier-plugin-organize-imports" | ||||||
|  |     ] | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "typescript": "^4.x" |     "typescript": "^4.x" | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								pyproject.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								pyproject.toml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | [tool.poetry] | ||||||
|  | name = "rbproto" | ||||||
|  | version = "0.1.0" | ||||||
|  | description = "" | ||||||
|  | authors = ["Mike Kalange <countablecloud@gmail.com>"] | ||||||
|  | readme = "README.md" | ||||||
|  | packages = [{include = "rbproto"}] | ||||||
|  |  | ||||||
|  | [tool.poetry.dependencies] | ||||||
|  | python = ">=3.10,<3.12" | ||||||
|  | protobuf = "^4.25.3" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | [build-system] | ||||||
|  | requires = ["poetry-core"] | ||||||
|  | build-backend = "poetry.core.masonry.api" | ||||||
							
								
								
									
										1
									
								
								rbproto/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								rbproto/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | from .python.shot_pb2 import *  # noqa: F401 | ||||||
							
								
								
									
										31
									
								
								rbproto/python/shot_pb2.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								rbproto/python/shot_pb2.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | # -*- coding: utf-8 -*- | ||||||
|  | # Generated by the protocol buffer compiler.  DO NOT EDIT! | ||||||
|  | # source: shot.proto | ||||||
|  | """Generated protocol buffer code.""" | ||||||
|  | from google.protobuf import descriptor as _descriptor | ||||||
|  | from google.protobuf import descriptor_pool as _descriptor_pool | ||||||
|  | from google.protobuf import symbol_database as _symbol_database | ||||||
|  | from google.protobuf.internal import builder as _builder | ||||||
|  | # @@protoc_insertion_point(imports) | ||||||
|  |  | ||||||
|  | _sym_db = _symbol_database.Default() | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\nshot.proto\x12\x0fserialized_shot\",\n\x05Point\x12\t\n\x01x\x18\x01 \x01(\x02\x12\t\n\x01y\x18\x02 \x01(\x02\x12\r\n\x05\x63ount\x18\x03 \x01(\x05\"i\n\x04Path\x12\x13\n\x0bstart_frame\x18\x01 \x01(\x05\x12\x11\n\tend_frame\x18\x02 \x01(\x05\x12\x11\n\tis_static\x18\x03 \x01(\x08\x12&\n\x06points\x18\x04 \x03(\x0b\x32\x16.serialized_shot.Point\"J\n\tBallPaths\x12\x17\n\x0f\x62\x61ll_identifier\x18\x01 \x01(\x05\x12$\n\x05paths\x18\x02 \x03(\x0b\x32\x15.serialized_shot.Path\"^\n\x04Shot\x12\x13\n\x0bstart_frame\x18\x01 \x01(\x05\x12\x11\n\tend_frame\x18\x02 \x01(\x05\x12.\n\nball_paths\x18\x03 \x03(\x0b\x32\x1a.serialized_shot.BallPathsb\x06proto3') | ||||||
|  |  | ||||||
|  | _globals = globals() | ||||||
|  | _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals) | ||||||
|  | _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'shot_pb2', _globals) | ||||||
|  | if _descriptor._USE_C_DESCRIPTORS == False: | ||||||
|  |   DESCRIPTOR._options = None | ||||||
|  |   _globals['_POINT']._serialized_start=31 | ||||||
|  |   _globals['_POINT']._serialized_end=75 | ||||||
|  |   _globals['_PATH']._serialized_start=77 | ||||||
|  |   _globals['_PATH']._serialized_end=182 | ||||||
|  |   _globals['_BALLPATHS']._serialized_start=184 | ||||||
|  |   _globals['_BALLPATHS']._serialized_end=258 | ||||||
|  |   _globals['_SHOT']._serialized_start=260 | ||||||
|  |   _globals['_SHOT']._serialized_end=354 | ||||||
|  | # @@protoc_insertion_point(module_scope) | ||||||
							
								
								
									
										46
									
								
								rbproto/python/shot_pb2.pyi
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								rbproto/python/shot_pb2.pyi
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | |||||||
|  | from google.protobuf.internal import containers as _containers | ||||||
|  | from google.protobuf import descriptor as _descriptor | ||||||
|  | from google.protobuf import message as _message | ||||||
|  | from typing import ClassVar as _ClassVar, Iterable as _Iterable, Mapping as _Mapping, Optional as _Optional, Union as _Union | ||||||
|  |  | ||||||
|  | DESCRIPTOR: _descriptor.FileDescriptor | ||||||
|  |  | ||||||
|  | class Point(_message.Message): | ||||||
|  |     __slots__ = ["x", "y", "count"] | ||||||
|  |     X_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     Y_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     COUNT_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     x: float | ||||||
|  |     y: float | ||||||
|  |     count: int | ||||||
|  |     def __init__(self, x: _Optional[float] = ..., y: _Optional[float] = ..., count: _Optional[int] = ...) -> None: ... | ||||||
|  |  | ||||||
|  | class Path(_message.Message): | ||||||
|  |     __slots__ = ["start_frame", "end_frame", "is_static", "points"] | ||||||
|  |     START_FRAME_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     END_FRAME_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     IS_STATIC_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     POINTS_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     start_frame: int | ||||||
|  |     end_frame: int | ||||||
|  |     is_static: bool | ||||||
|  |     points: _containers.RepeatedCompositeFieldContainer[Point] | ||||||
|  |     def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., is_static: bool = ..., points: _Optional[_Iterable[_Union[Point, _Mapping]]] = ...) -> None: ... | ||||||
|  |  | ||||||
|  | class BallPaths(_message.Message): | ||||||
|  |     __slots__ = ["ball_identifier", "paths"] | ||||||
|  |     BALL_IDENTIFIER_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     PATHS_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     ball_identifier: int | ||||||
|  |     paths: _containers.RepeatedCompositeFieldContainer[Path] | ||||||
|  |     def __init__(self, ball_identifier: _Optional[int] = ..., paths: _Optional[_Iterable[_Union[Path, _Mapping]]] = ...) -> None: ... | ||||||
|  |  | ||||||
|  | class Shot(_message.Message): | ||||||
|  |     __slots__ = ["start_frame", "end_frame", "ball_paths"] | ||||||
|  |     START_FRAME_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     END_FRAME_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     BALL_PATHS_FIELD_NUMBER: _ClassVar[int] | ||||||
|  |     start_frame: int | ||||||
|  |     end_frame: int | ||||||
|  |     ball_paths: _containers.RepeatedCompositeFieldContainer[BallPaths] | ||||||
|  |     def __init__(self, start_frame: _Optional[int] = ..., end_frame: _Optional[int] = ..., ball_paths: _Optional[_Iterable[_Union[BallPaths, _Mapping]]] = ...) -> None: ... | ||||||
							
								
								
									
										27
									
								
								rbproto/shot.proto
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								rbproto/shot.proto
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | syntax = "proto3"; | ||||||
|  |  | ||||||
|  | package serialized_shot; | ||||||
|  |  | ||||||
|  | message Point { | ||||||
|  |   float x = 1; | ||||||
|  |   float y = 2; | ||||||
|  |   int32 count = 3; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | message Path { | ||||||
|  |   int32 start_frame = 1; | ||||||
|  |   int32 end_frame = 2; | ||||||
|  |   bool is_static = 3; | ||||||
|  |   repeated Point points = 4; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | message BallPaths { | ||||||
|  |   int32 ball_identifier = 1; | ||||||
|  |   repeated Path paths = 2; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | message Shot { | ||||||
|  |   int32 start_frame = 1; | ||||||
|  |   int32 end_frame = 2; | ||||||
|  |   repeated BallPaths ball_paths = 3; | ||||||
|  | } | ||||||
							
								
								
									
										879
									
								
								rbproto/ts/shot.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										879
									
								
								rbproto/ts/shot.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,879 @@ | |||||||
|  | export interface Point { | ||||||
|  |   x?: number; | ||||||
|  |   y?: number; | ||||||
|  |   count?: number; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function encodePoint(message: Point): Uint8Array { | ||||||
|  |   let bb = popByteBuffer(); | ||||||
|  |   _encodePoint(message, bb); | ||||||
|  |   return toUint8Array(bb); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _encodePoint(message: Point, bb: ByteBuffer): void { | ||||||
|  |   // optional float x = 1; | ||||||
|  |   let $x = message.x; | ||||||
|  |   if ($x !== undefined) { | ||||||
|  |     writeVarint32(bb, 13); | ||||||
|  |     writeFloat(bb, $x); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // optional float y = 2; | ||||||
|  |   let $y = message.y; | ||||||
|  |   if ($y !== undefined) { | ||||||
|  |     writeVarint32(bb, 21); | ||||||
|  |     writeFloat(bb, $y); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // optional int32 count = 3; | ||||||
|  |   let $count = message.count; | ||||||
|  |   if ($count !== undefined) { | ||||||
|  |     writeVarint32(bb, 24); | ||||||
|  |     writeVarint64(bb, intToLong($count)); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function decodePoint(binary: Uint8Array): Point { | ||||||
|  |   return _decodePoint(wrapByteBuffer(binary)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _decodePoint(bb: ByteBuffer): Point { | ||||||
|  |   let message: Point = {} as any; | ||||||
|  |  | ||||||
|  |   end_of_message: while (!isAtEnd(bb)) { | ||||||
|  |     let tag = readVarint32(bb); | ||||||
|  |  | ||||||
|  |     switch (tag >>> 3) { | ||||||
|  |       case 0: | ||||||
|  |         break end_of_message; | ||||||
|  |  | ||||||
|  |       // optional float x = 1; | ||||||
|  |       case 1: { | ||||||
|  |         message.x = readFloat(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // optional float y = 2; | ||||||
|  |       case 2: { | ||||||
|  |         message.y = readFloat(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // optional int32 count = 3; | ||||||
|  |       case 3: { | ||||||
|  |         message.count = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       default: | ||||||
|  |         skipUnknownField(bb, tag & 7); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return message; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface Path { | ||||||
|  |   start_frame?: number; | ||||||
|  |   end_frame?: number; | ||||||
|  |   is_static?: boolean; | ||||||
|  |   points?: Point[]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function encodePath(message: Path): Uint8Array { | ||||||
|  |   let bb = popByteBuffer(); | ||||||
|  |   _encodePath(message, bb); | ||||||
|  |   return toUint8Array(bb); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _encodePath(message: Path, bb: ByteBuffer): void { | ||||||
|  |   // optional int32 start_frame = 1; | ||||||
|  |   let $start_frame = message.start_frame; | ||||||
|  |   if ($start_frame !== undefined) { | ||||||
|  |     writeVarint32(bb, 8); | ||||||
|  |     writeVarint64(bb, intToLong($start_frame)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // optional int32 end_frame = 2; | ||||||
|  |   let $end_frame = message.end_frame; | ||||||
|  |   if ($end_frame !== undefined) { | ||||||
|  |     writeVarint32(bb, 16); | ||||||
|  |     writeVarint64(bb, intToLong($end_frame)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // optional bool is_static = 3; | ||||||
|  |   let $is_static = message.is_static; | ||||||
|  |   if ($is_static !== undefined) { | ||||||
|  |     writeVarint32(bb, 24); | ||||||
|  |     writeByte(bb, $is_static ? 1 : 0); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // repeated Point points = 4; | ||||||
|  |   let array$points = message.points; | ||||||
|  |   if (array$points !== undefined) { | ||||||
|  |     for (let value of array$points) { | ||||||
|  |       writeVarint32(bb, 34); | ||||||
|  |       let nested = popByteBuffer(); | ||||||
|  |       _encodePoint(value, nested); | ||||||
|  |       writeVarint32(bb, nested.limit); | ||||||
|  |       writeByteBuffer(bb, nested); | ||||||
|  |       pushByteBuffer(nested); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function decodePath(binary: Uint8Array): Path { | ||||||
|  |   return _decodePath(wrapByteBuffer(binary)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _decodePath(bb: ByteBuffer): Path { | ||||||
|  |   let message: Path = {} as any; | ||||||
|  |  | ||||||
|  |   end_of_message: while (!isAtEnd(bb)) { | ||||||
|  |     let tag = readVarint32(bb); | ||||||
|  |  | ||||||
|  |     switch (tag >>> 3) { | ||||||
|  |       case 0: | ||||||
|  |         break end_of_message; | ||||||
|  |  | ||||||
|  |       // optional int32 start_frame = 1; | ||||||
|  |       case 1: { | ||||||
|  |         message.start_frame = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // optional int32 end_frame = 2; | ||||||
|  |       case 2: { | ||||||
|  |         message.end_frame = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // optional bool is_static = 3; | ||||||
|  |       case 3: { | ||||||
|  |         message.is_static = !!readByte(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // repeated Point points = 4; | ||||||
|  |       case 4: { | ||||||
|  |         let limit = pushTemporaryLength(bb); | ||||||
|  |         let values = message.points || (message.points = []); | ||||||
|  |         values.push(_decodePoint(bb)); | ||||||
|  |         bb.limit = limit; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       default: | ||||||
|  |         skipUnknownField(bb, tag & 7); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return message; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface BallPaths { | ||||||
|  |   ball_identifier?: number; | ||||||
|  |   paths?: Path[]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function encodeBallPaths(message: BallPaths): Uint8Array { | ||||||
|  |   let bb = popByteBuffer(); | ||||||
|  |   _encodeBallPaths(message, bb); | ||||||
|  |   return toUint8Array(bb); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _encodeBallPaths(message: BallPaths, bb: ByteBuffer): void { | ||||||
|  |   // optional int32 ball_identifier = 1; | ||||||
|  |   let $ball_identifier = message.ball_identifier; | ||||||
|  |   if ($ball_identifier !== undefined) { | ||||||
|  |     writeVarint32(bb, 8); | ||||||
|  |     writeVarint64(bb, intToLong($ball_identifier)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // repeated Path paths = 2; | ||||||
|  |   let array$paths = message.paths; | ||||||
|  |   if (array$paths !== undefined) { | ||||||
|  |     for (let value of array$paths) { | ||||||
|  |       writeVarint32(bb, 18); | ||||||
|  |       let nested = popByteBuffer(); | ||||||
|  |       _encodePath(value, nested); | ||||||
|  |       writeVarint32(bb, nested.limit); | ||||||
|  |       writeByteBuffer(bb, nested); | ||||||
|  |       pushByteBuffer(nested); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function decodeBallPaths(binary: Uint8Array): BallPaths { | ||||||
|  |   return _decodeBallPaths(wrapByteBuffer(binary)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _decodeBallPaths(bb: ByteBuffer): BallPaths { | ||||||
|  |   let message: BallPaths = {} as any; | ||||||
|  |  | ||||||
|  |   end_of_message: while (!isAtEnd(bb)) { | ||||||
|  |     let tag = readVarint32(bb); | ||||||
|  |  | ||||||
|  |     switch (tag >>> 3) { | ||||||
|  |       case 0: | ||||||
|  |         break end_of_message; | ||||||
|  |  | ||||||
|  |       // optional int32 ball_identifier = 1; | ||||||
|  |       case 1: { | ||||||
|  |         message.ball_identifier = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // repeated Path paths = 2; | ||||||
|  |       case 2: { | ||||||
|  |         let limit = pushTemporaryLength(bb); | ||||||
|  |         let values = message.paths || (message.paths = []); | ||||||
|  |         values.push(_decodePath(bb)); | ||||||
|  |         bb.limit = limit; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       default: | ||||||
|  |         skipUnknownField(bb, tag & 7); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return message; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface Shot { | ||||||
|  |   start_frame?: number; | ||||||
|  |   end_frame?: number; | ||||||
|  |   ball_paths?: BallPaths[]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function encodeShot(message: Shot): Uint8Array { | ||||||
|  |   let bb = popByteBuffer(); | ||||||
|  |   _encodeShot(message, bb); | ||||||
|  |   return toUint8Array(bb); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _encodeShot(message: Shot, bb: ByteBuffer): void { | ||||||
|  |   // optional int32 start_frame = 1; | ||||||
|  |   let $start_frame = message.start_frame; | ||||||
|  |   if ($start_frame !== undefined) { | ||||||
|  |     writeVarint32(bb, 8); | ||||||
|  |     writeVarint64(bb, intToLong($start_frame)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // optional int32 end_frame = 2; | ||||||
|  |   let $end_frame = message.end_frame; | ||||||
|  |   if ($end_frame !== undefined) { | ||||||
|  |     writeVarint32(bb, 16); | ||||||
|  |     writeVarint64(bb, intToLong($end_frame)); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // repeated BallPaths ball_paths = 3; | ||||||
|  |   let array$ball_paths = message.ball_paths; | ||||||
|  |   if (array$ball_paths !== undefined) { | ||||||
|  |     for (let value of array$ball_paths) { | ||||||
|  |       writeVarint32(bb, 26); | ||||||
|  |       let nested = popByteBuffer(); | ||||||
|  |       _encodeBallPaths(value, nested); | ||||||
|  |       writeVarint32(bb, nested.limit); | ||||||
|  |       writeByteBuffer(bb, nested); | ||||||
|  |       pushByteBuffer(nested); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export function decodeShot(binary: Uint8Array): Shot { | ||||||
|  |   return _decodeShot(wrapByteBuffer(binary)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function _decodeShot(bb: ByteBuffer): Shot { | ||||||
|  |   let message: Shot = {} as any; | ||||||
|  |  | ||||||
|  |   end_of_message: while (!isAtEnd(bb)) { | ||||||
|  |     let tag = readVarint32(bb); | ||||||
|  |  | ||||||
|  |     switch (tag >>> 3) { | ||||||
|  |       case 0: | ||||||
|  |         break end_of_message; | ||||||
|  |  | ||||||
|  |       // optional int32 start_frame = 1; | ||||||
|  |       case 1: { | ||||||
|  |         message.start_frame = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // optional int32 end_frame = 2; | ||||||
|  |       case 2: { | ||||||
|  |         message.end_frame = readVarint32(bb); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       // repeated BallPaths ball_paths = 3; | ||||||
|  |       case 3: { | ||||||
|  |         let limit = pushTemporaryLength(bb); | ||||||
|  |         let values = message.ball_paths || (message.ball_paths = []); | ||||||
|  |         values.push(_decodeBallPaths(bb)); | ||||||
|  |         bb.limit = limit; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       default: | ||||||
|  |         skipUnknownField(bb, tag & 7); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return message; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export interface Long { | ||||||
|  |   low: number; | ||||||
|  |   high: number; | ||||||
|  |   unsigned: boolean; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | interface ByteBuffer { | ||||||
|  |   bytes: Uint8Array; | ||||||
|  |   offset: number; | ||||||
|  |   limit: number; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function pushTemporaryLength(bb: ByteBuffer): number { | ||||||
|  |   let length = readVarint32(bb); | ||||||
|  |   let limit = bb.limit; | ||||||
|  |   bb.limit = bb.offset + length; | ||||||
|  |   return limit; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function skipUnknownField(bb: ByteBuffer, type: number): void { | ||||||
|  |   switch (type) { | ||||||
|  |     case 0: | ||||||
|  |       while (readByte(bb) & 0x80) {} | ||||||
|  |       break; | ||||||
|  |     case 2: | ||||||
|  |       skip(bb, readVarint32(bb)); | ||||||
|  |       break; | ||||||
|  |     case 5: | ||||||
|  |       skip(bb, 4); | ||||||
|  |       break; | ||||||
|  |     case 1: | ||||||
|  |       skip(bb, 8); | ||||||
|  |       break; | ||||||
|  |     default: | ||||||
|  |       throw new Error("Unimplemented type: " + type); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function stringToLong(value: string): Long { | ||||||
|  |   return { | ||||||
|  |     low: value.charCodeAt(0) | (value.charCodeAt(1) << 16), | ||||||
|  |     high: value.charCodeAt(2) | (value.charCodeAt(3) << 16), | ||||||
|  |     unsigned: false, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function longToString(value: Long): string { | ||||||
|  |   let low = value.low; | ||||||
|  |   let high = value.high; | ||||||
|  |   return String.fromCharCode( | ||||||
|  |     low & 0xffff, | ||||||
|  |     low >>> 16, | ||||||
|  |     high & 0xffff, | ||||||
|  |     high >>> 16, | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // The code below was modified from https://github.com/protobufjs/bytebuffer.js | ||||||
|  | // which is under the Apache License 2.0. | ||||||
|  |  | ||||||
|  | let f32 = new Float32Array(1); | ||||||
|  | let f32_u8 = new Uint8Array(f32.buffer); | ||||||
|  |  | ||||||
|  | let f64 = new Float64Array(1); | ||||||
|  | let f64_u8 = new Uint8Array(f64.buffer); | ||||||
|  |  | ||||||
|  | function intToLong(value: number): Long { | ||||||
|  |   value |= 0; | ||||||
|  |   return { | ||||||
|  |     low: value, | ||||||
|  |     high: value >> 31, | ||||||
|  |     unsigned: value >= 0, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | let bbStack: ByteBuffer[] = []; | ||||||
|  |  | ||||||
|  | function popByteBuffer(): ByteBuffer { | ||||||
|  |   const bb = bbStack.pop(); | ||||||
|  |   if (!bb) return { bytes: new Uint8Array(64), offset: 0, limit: 0 }; | ||||||
|  |   bb.offset = bb.limit = 0; | ||||||
|  |   return bb; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function pushByteBuffer(bb: ByteBuffer): void { | ||||||
|  |   bbStack.push(bb); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function wrapByteBuffer(bytes: Uint8Array): ByteBuffer { | ||||||
|  |   return { bytes, offset: 0, limit: bytes.length }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function toUint8Array(bb: ByteBuffer): Uint8Array { | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   let limit = bb.limit; | ||||||
|  |   return bytes.length === limit ? bytes : bytes.subarray(0, limit); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function skip(bb: ByteBuffer, offset: number): void { | ||||||
|  |   if (bb.offset + offset > bb.limit) { | ||||||
|  |     throw new Error("Skip past limit"); | ||||||
|  |   } | ||||||
|  |   bb.offset += offset; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function isAtEnd(bb: ByteBuffer): boolean { | ||||||
|  |   return bb.offset >= bb.limit; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function grow(bb: ByteBuffer, count: number): number { | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   let offset = bb.offset; | ||||||
|  |   let limit = bb.limit; | ||||||
|  |   let finalOffset = offset + count; | ||||||
|  |   if (finalOffset > bytes.length) { | ||||||
|  |     let newBytes = new Uint8Array(finalOffset * 2); | ||||||
|  |     newBytes.set(bytes); | ||||||
|  |     bb.bytes = newBytes; | ||||||
|  |   } | ||||||
|  |   bb.offset = finalOffset; | ||||||
|  |   if (finalOffset > limit) { | ||||||
|  |     bb.limit = finalOffset; | ||||||
|  |   } | ||||||
|  |   return offset; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function advance(bb: ByteBuffer, count: number): number { | ||||||
|  |   let offset = bb.offset; | ||||||
|  |   if (offset + count > bb.limit) { | ||||||
|  |     throw new Error("Read past limit"); | ||||||
|  |   } | ||||||
|  |   bb.offset += count; | ||||||
|  |   return offset; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readBytes(bb: ByteBuffer, count: number): Uint8Array { | ||||||
|  |   let offset = advance(bb, count); | ||||||
|  |   return bb.bytes.subarray(offset, offset + count); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeBytes(bb: ByteBuffer, buffer: Uint8Array): void { | ||||||
|  |   let offset = grow(bb, buffer.length); | ||||||
|  |   bb.bytes.set(buffer, offset); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readString(bb: ByteBuffer, count: number): string { | ||||||
|  |   // Sadly a hand-coded UTF8 decoder is much faster than subarray+TextDecoder in V8 | ||||||
|  |   let offset = advance(bb, count); | ||||||
|  |   let fromCharCode = String.fromCharCode; | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   let invalid = "\uFFFD"; | ||||||
|  |   let text = ""; | ||||||
|  |  | ||||||
|  |   for (let i = 0; i < count; i++) { | ||||||
|  |     let c1 = bytes[i + offset], | ||||||
|  |       c2: number, | ||||||
|  |       c3: number, | ||||||
|  |       c4: number, | ||||||
|  |       c: number; | ||||||
|  |  | ||||||
|  |     // 1 byte | ||||||
|  |     if ((c1 & 0x80) === 0) { | ||||||
|  |       text += fromCharCode(c1); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // 2 bytes | ||||||
|  |     else if ((c1 & 0xe0) === 0xc0) { | ||||||
|  |       if (i + 1 >= count) text += invalid; | ||||||
|  |       else { | ||||||
|  |         c2 = bytes[i + offset + 1]; | ||||||
|  |         if ((c2 & 0xc0) !== 0x80) text += invalid; | ||||||
|  |         else { | ||||||
|  |           c = ((c1 & 0x1f) << 6) | (c2 & 0x3f); | ||||||
|  |           if (c < 0x80) text += invalid; | ||||||
|  |           else { | ||||||
|  |             text += fromCharCode(c); | ||||||
|  |             i++; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // 3 bytes | ||||||
|  |     else if ((c1 & 0xf0) == 0xe0) { | ||||||
|  |       if (i + 2 >= count) text += invalid; | ||||||
|  |       else { | ||||||
|  |         c2 = bytes[i + offset + 1]; | ||||||
|  |         c3 = bytes[i + offset + 2]; | ||||||
|  |         if (((c2 | (c3 << 8)) & 0xc0c0) !== 0x8080) text += invalid; | ||||||
|  |         else { | ||||||
|  |           c = ((c1 & 0x0f) << 12) | ((c2 & 0x3f) << 6) | (c3 & 0x3f); | ||||||
|  |           if (c < 0x0800 || (c >= 0xd800 && c <= 0xdfff)) text += invalid; | ||||||
|  |           else { | ||||||
|  |             text += fromCharCode(c); | ||||||
|  |             i += 2; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // 4 bytes | ||||||
|  |     else if ((c1 & 0xf8) == 0xf0) { | ||||||
|  |       if (i + 3 >= count) text += invalid; | ||||||
|  |       else { | ||||||
|  |         c2 = bytes[i + offset + 1]; | ||||||
|  |         c3 = bytes[i + offset + 2]; | ||||||
|  |         c4 = bytes[i + offset + 3]; | ||||||
|  |         if (((c2 | (c3 << 8) | (c4 << 16)) & 0xc0c0c0) !== 0x808080) | ||||||
|  |           text += invalid; | ||||||
|  |         else { | ||||||
|  |           c = | ||||||
|  |             ((c1 & 0x07) << 0x12) | | ||||||
|  |             ((c2 & 0x3f) << 0x0c) | | ||||||
|  |             ((c3 & 0x3f) << 0x06) | | ||||||
|  |             (c4 & 0x3f); | ||||||
|  |           if (c < 0x10000 || c > 0x10ffff) text += invalid; | ||||||
|  |           else { | ||||||
|  |             c -= 0x10000; | ||||||
|  |             text += fromCharCode((c >> 10) + 0xd800, (c & 0x3ff) + 0xdc00); | ||||||
|  |             i += 3; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } else text += invalid; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return text; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeString(bb: ByteBuffer, text: string): void { | ||||||
|  |   // Sadly a hand-coded UTF8 encoder is much faster than TextEncoder+set in V8 | ||||||
|  |   let n = text.length; | ||||||
|  |   let byteCount = 0; | ||||||
|  |  | ||||||
|  |   // Write the byte count first | ||||||
|  |   for (let i = 0; i < n; i++) { | ||||||
|  |     let c = text.charCodeAt(i); | ||||||
|  |     if (c >= 0xd800 && c <= 0xdbff && i + 1 < n) { | ||||||
|  |       c = (c << 10) + text.charCodeAt(++i) - 0x35fdc00; | ||||||
|  |     } | ||||||
|  |     byteCount += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4; | ||||||
|  |   } | ||||||
|  |   writeVarint32(bb, byteCount); | ||||||
|  |  | ||||||
|  |   let offset = grow(bb, byteCount); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |  | ||||||
|  |   // Then write the bytes | ||||||
|  |   for (let i = 0; i < n; i++) { | ||||||
|  |     let c = text.charCodeAt(i); | ||||||
|  |     if (c >= 0xd800 && c <= 0xdbff && i + 1 < n) { | ||||||
|  |       c = (c << 10) + text.charCodeAt(++i) - 0x35fdc00; | ||||||
|  |     } | ||||||
|  |     if (c < 0x80) { | ||||||
|  |       bytes[offset++] = c; | ||||||
|  |     } else { | ||||||
|  |       if (c < 0x800) { | ||||||
|  |         bytes[offset++] = ((c >> 6) & 0x1f) | 0xc0; | ||||||
|  |       } else { | ||||||
|  |         if (c < 0x10000) { | ||||||
|  |           bytes[offset++] = ((c >> 12) & 0x0f) | 0xe0; | ||||||
|  |         } else { | ||||||
|  |           bytes[offset++] = ((c >> 18) & 0x07) | 0xf0; | ||||||
|  |           bytes[offset++] = ((c >> 12) & 0x3f) | 0x80; | ||||||
|  |         } | ||||||
|  |         bytes[offset++] = ((c >> 6) & 0x3f) | 0x80; | ||||||
|  |       } | ||||||
|  |       bytes[offset++] = (c & 0x3f) | 0x80; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeByteBuffer(bb: ByteBuffer, buffer: ByteBuffer): void { | ||||||
|  |   let offset = grow(bb, buffer.limit); | ||||||
|  |   let from = bb.bytes; | ||||||
|  |   let to = buffer.bytes; | ||||||
|  |  | ||||||
|  |   // This for loop is much faster than subarray+set on V8 | ||||||
|  |   for (let i = 0, n = buffer.limit; i < n; i++) { | ||||||
|  |     from[i + offset] = to[i]; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readByte(bb: ByteBuffer): number { | ||||||
|  |   return bb.bytes[advance(bb, 1)]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeByte(bb: ByteBuffer, value: number): void { | ||||||
|  |   let offset = grow(bb, 1); | ||||||
|  |   bb.bytes[offset] = value; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readFloat(bb: ByteBuffer): number { | ||||||
|  |   let offset = advance(bb, 4); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |  | ||||||
|  |   // Manual copying is much faster than subarray+set in V8 | ||||||
|  |   f32_u8[0] = bytes[offset++]; | ||||||
|  |   f32_u8[1] = bytes[offset++]; | ||||||
|  |   f32_u8[2] = bytes[offset++]; | ||||||
|  |   f32_u8[3] = bytes[offset++]; | ||||||
|  |   return f32[0]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeFloat(bb: ByteBuffer, value: number): void { | ||||||
|  |   let offset = grow(bb, 4); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   f32[0] = value; | ||||||
|  |  | ||||||
|  |   // Manual copying is much faster than subarray+set in V8 | ||||||
|  |   bytes[offset++] = f32_u8[0]; | ||||||
|  |   bytes[offset++] = f32_u8[1]; | ||||||
|  |   bytes[offset++] = f32_u8[2]; | ||||||
|  |   bytes[offset++] = f32_u8[3]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readDouble(bb: ByteBuffer): number { | ||||||
|  |   let offset = advance(bb, 8); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |  | ||||||
|  |   // Manual copying is much faster than subarray+set in V8 | ||||||
|  |   f64_u8[0] = bytes[offset++]; | ||||||
|  |   f64_u8[1] = bytes[offset++]; | ||||||
|  |   f64_u8[2] = bytes[offset++]; | ||||||
|  |   f64_u8[3] = bytes[offset++]; | ||||||
|  |   f64_u8[4] = bytes[offset++]; | ||||||
|  |   f64_u8[5] = bytes[offset++]; | ||||||
|  |   f64_u8[6] = bytes[offset++]; | ||||||
|  |   f64_u8[7] = bytes[offset++]; | ||||||
|  |   return f64[0]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeDouble(bb: ByteBuffer, value: number): void { | ||||||
|  |   let offset = grow(bb, 8); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   f64[0] = value; | ||||||
|  |  | ||||||
|  |   // Manual copying is much faster than subarray+set in V8 | ||||||
|  |   bytes[offset++] = f64_u8[0]; | ||||||
|  |   bytes[offset++] = f64_u8[1]; | ||||||
|  |   bytes[offset++] = f64_u8[2]; | ||||||
|  |   bytes[offset++] = f64_u8[3]; | ||||||
|  |   bytes[offset++] = f64_u8[4]; | ||||||
|  |   bytes[offset++] = f64_u8[5]; | ||||||
|  |   bytes[offset++] = f64_u8[6]; | ||||||
|  |   bytes[offset++] = f64_u8[7]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readInt32(bb: ByteBuffer): number { | ||||||
|  |   let offset = advance(bb, 4); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   return ( | ||||||
|  |     bytes[offset] | | ||||||
|  |     (bytes[offset + 1] << 8) | | ||||||
|  |     (bytes[offset + 2] << 16) | | ||||||
|  |     (bytes[offset + 3] << 24) | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeInt32(bb: ByteBuffer, value: number): void { | ||||||
|  |   let offset = grow(bb, 4); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |   bytes[offset] = value; | ||||||
|  |   bytes[offset + 1] = value >> 8; | ||||||
|  |   bytes[offset + 2] = value >> 16; | ||||||
|  |   bytes[offset + 3] = value >> 24; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readInt64(bb: ByteBuffer, unsigned: boolean): Long { | ||||||
|  |   return { | ||||||
|  |     low: readInt32(bb), | ||||||
|  |     high: readInt32(bb), | ||||||
|  |     unsigned, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeInt64(bb: ByteBuffer, value: Long): void { | ||||||
|  |   writeInt32(bb, value.low); | ||||||
|  |   writeInt32(bb, value.high); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readVarint32(bb: ByteBuffer): number { | ||||||
|  |   let c = 0; | ||||||
|  |   let value = 0; | ||||||
|  |   let b: number; | ||||||
|  |   do { | ||||||
|  |     b = readByte(bb); | ||||||
|  |     if (c < 32) value |= (b & 0x7f) << c; | ||||||
|  |     c += 7; | ||||||
|  |   } while (b & 0x80); | ||||||
|  |   return value; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeVarint32(bb: ByteBuffer, value: number): void { | ||||||
|  |   value >>>= 0; | ||||||
|  |   while (value >= 0x80) { | ||||||
|  |     writeByte(bb, (value & 0x7f) | 0x80); | ||||||
|  |     value >>>= 7; | ||||||
|  |   } | ||||||
|  |   writeByte(bb, value); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readVarint64(bb: ByteBuffer, unsigned: boolean): Long { | ||||||
|  |   let part0 = 0; | ||||||
|  |   let part1 = 0; | ||||||
|  |   let part2 = 0; | ||||||
|  |   let b: number; | ||||||
|  |  | ||||||
|  |   b = readByte(bb); | ||||||
|  |   part0 = b & 0x7f; | ||||||
|  |   if (b & 0x80) { | ||||||
|  |     b = readByte(bb); | ||||||
|  |     part0 |= (b & 0x7f) << 7; | ||||||
|  |     if (b & 0x80) { | ||||||
|  |       b = readByte(bb); | ||||||
|  |       part0 |= (b & 0x7f) << 14; | ||||||
|  |       if (b & 0x80) { | ||||||
|  |         b = readByte(bb); | ||||||
|  |         part0 |= (b & 0x7f) << 21; | ||||||
|  |         if (b & 0x80) { | ||||||
|  |           b = readByte(bb); | ||||||
|  |           part1 = b & 0x7f; | ||||||
|  |           if (b & 0x80) { | ||||||
|  |             b = readByte(bb); | ||||||
|  |             part1 |= (b & 0x7f) << 7; | ||||||
|  |             if (b & 0x80) { | ||||||
|  |               b = readByte(bb); | ||||||
|  |               part1 |= (b & 0x7f) << 14; | ||||||
|  |               if (b & 0x80) { | ||||||
|  |                 b = readByte(bb); | ||||||
|  |                 part1 |= (b & 0x7f) << 21; | ||||||
|  |                 if (b & 0x80) { | ||||||
|  |                   b = readByte(bb); | ||||||
|  |                   part2 = b & 0x7f; | ||||||
|  |                   if (b & 0x80) { | ||||||
|  |                     b = readByte(bb); | ||||||
|  |                     part2 |= (b & 0x7f) << 7; | ||||||
|  |                   } | ||||||
|  |                 } | ||||||
|  |               } | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   return { | ||||||
|  |     low: part0 | (part1 << 28), | ||||||
|  |     high: (part1 >>> 4) | (part2 << 24), | ||||||
|  |     unsigned, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeVarint64(bb: ByteBuffer, value: Long): void { | ||||||
|  |   let part0 = value.low >>> 0; | ||||||
|  |   let part1 = ((value.low >>> 28) | (value.high << 4)) >>> 0; | ||||||
|  |   let part2 = value.high >>> 24; | ||||||
|  |  | ||||||
|  |   // ref: src/google/protobuf/io/coded_stream.cc | ||||||
|  |   let size = | ||||||
|  |     part2 === 0 | ||||||
|  |       ? part1 === 0 | ||||||
|  |         ? part0 < 1 << 14 | ||||||
|  |           ? part0 < 1 << 7 | ||||||
|  |             ? 1 | ||||||
|  |             : 2 | ||||||
|  |           : part0 < 1 << 21 | ||||||
|  |             ? 3 | ||||||
|  |             : 4 | ||||||
|  |         : part1 < 1 << 14 | ||||||
|  |           ? part1 < 1 << 7 | ||||||
|  |             ? 5 | ||||||
|  |             : 6 | ||||||
|  |           : part1 < 1 << 21 | ||||||
|  |             ? 7 | ||||||
|  |             : 8 | ||||||
|  |       : part2 < 1 << 7 | ||||||
|  |         ? 9 | ||||||
|  |         : 10; | ||||||
|  |  | ||||||
|  |   let offset = grow(bb, size); | ||||||
|  |   let bytes = bb.bytes; | ||||||
|  |  | ||||||
|  |   switch (size) { | ||||||
|  |     case 10: | ||||||
|  |       bytes[offset + 9] = (part2 >>> 7) & 0x01; | ||||||
|  |     case 9: | ||||||
|  |       bytes[offset + 8] = size !== 9 ? part2 | 0x80 : part2 & 0x7f; | ||||||
|  |     case 8: | ||||||
|  |       bytes[offset + 7] = | ||||||
|  |         size !== 8 ? (part1 >>> 21) | 0x80 : (part1 >>> 21) & 0x7f; | ||||||
|  |     case 7: | ||||||
|  |       bytes[offset + 6] = | ||||||
|  |         size !== 7 ? (part1 >>> 14) | 0x80 : (part1 >>> 14) & 0x7f; | ||||||
|  |     case 6: | ||||||
|  |       bytes[offset + 5] = | ||||||
|  |         size !== 6 ? (part1 >>> 7) | 0x80 : (part1 >>> 7) & 0x7f; | ||||||
|  |     case 5: | ||||||
|  |       bytes[offset + 4] = size !== 5 ? part1 | 0x80 : part1 & 0x7f; | ||||||
|  |     case 4: | ||||||
|  |       bytes[offset + 3] = | ||||||
|  |         size !== 4 ? (part0 >>> 21) | 0x80 : (part0 >>> 21) & 0x7f; | ||||||
|  |     case 3: | ||||||
|  |       bytes[offset + 2] = | ||||||
|  |         size !== 3 ? (part0 >>> 14) | 0x80 : (part0 >>> 14) & 0x7f; | ||||||
|  |     case 2: | ||||||
|  |       bytes[offset + 1] = | ||||||
|  |         size !== 2 ? (part0 >>> 7) | 0x80 : (part0 >>> 7) & 0x7f; | ||||||
|  |     case 1: | ||||||
|  |       bytes[offset] = size !== 1 ? part0 | 0x80 : part0 & 0x7f; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readVarint32ZigZag(bb: ByteBuffer): number { | ||||||
|  |   let value = readVarint32(bb); | ||||||
|  |  | ||||||
|  |   // ref: src/google/protobuf/wire_format_lite.h | ||||||
|  |   return (value >>> 1) ^ -(value & 1); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeVarint32ZigZag(bb: ByteBuffer, value: number): void { | ||||||
|  |   // ref: src/google/protobuf/wire_format_lite.h | ||||||
|  |   writeVarint32(bb, (value << 1) ^ (value >> 31)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function readVarint64ZigZag(bb: ByteBuffer): Long { | ||||||
|  |   let value = readVarint64(bb, /* unsigned */ false); | ||||||
|  |   let low = value.low; | ||||||
|  |   let high = value.high; | ||||||
|  |   let flip = -(low & 1); | ||||||
|  |  | ||||||
|  |   // ref: src/google/protobuf/wire_format_lite.h | ||||||
|  |   return { | ||||||
|  |     low: ((low >>> 1) | (high << 31)) ^ flip, | ||||||
|  |     high: (high >>> 1) ^ flip, | ||||||
|  |     unsigned: false, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function writeVarint64ZigZag(bb: ByteBuffer, value: Long): void { | ||||||
|  |   let low = value.low; | ||||||
|  |   let high = value.high; | ||||||
|  |   let flip = high >> 31; | ||||||
|  |  | ||||||
|  |   // ref: src/google/protobuf/wire_format_lite.h | ||||||
|  |   writeVarint64(bb, { | ||||||
|  |     low: (low << 1) ^ flip, | ||||||
|  |     high: ((high << 1) | (low >>> 31)) ^ flip, | ||||||
|  |     unsigned: false, | ||||||
|  |   }); | ||||||
|  | } | ||||||
							
								
								
									
										2633
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										2633
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										12
									
								
								src/operations/aggregate.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/operations/aggregate.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | query GetAggregatedShotMetrics($aggregateInput: AggregateInputGQL!) { | ||||||
|  |   getAggregatedShotMetrics(aggregateInput: $aggregateInput) { | ||||||
|  |     aggregationIdentifiers { | ||||||
|  |       featureName | ||||||
|  |       groupName | ||||||
|  |     } | ||||||
|  |     targetMetrics { | ||||||
|  |       count | ||||||
|  |       makePercentage | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -1,17 +0,0 @@ | |||||||
| query GetAggregateShots($bucketSets: [BucketSetInputGQL!]!) { |  | ||||||
|   getAggregateShots(bucketSets: $bucketSets) { |  | ||||||
|     featureBuckets { |  | ||||||
|       rangeKey |  | ||||||
|       lowerBound |  | ||||||
|     } |  | ||||||
|     targetMetrics { |  | ||||||
|       count |  | ||||||
|       makePercentage |  | ||||||
|       floatFeature { |  | ||||||
|         featureName |  | ||||||
|         average |  | ||||||
|         median |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
							
								
								
									
										8
									
								
								src/operations/config.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/operations/config.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | query getDeployedConfig { | ||||||
|  |   getDeployedConfig { | ||||||
|  |     allowNewUsers | ||||||
|  |     devMode | ||||||
|  |     environment | ||||||
|  |     firebase | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								src/operations/feed.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/operations/feed.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | query GetFeed( | ||||||
|  |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|  |       id | ||||||
|  |       owner { | ||||||
|  |         username | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |       screenshotUri | ||||||
|  |       totalShotsMade | ||||||
|  |       totalShots | ||||||
|  |       makePercentage | ||||||
|  |       createdAt | ||||||
|  |       updatedAt | ||||||
|  |       startTime | ||||||
|  |       endTime | ||||||
|  |       elapsedTime | ||||||
|  |       screenshotUri | ||||||
|  |       stream { | ||||||
|  |         isCompleted | ||||||
|  |       } | ||||||
|  |       tags { | ||||||
|  |         tagClasses { | ||||||
|  |           name | ||||||
|  |         } | ||||||
|  |         name | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     pageInfo { | ||||||
|  |       hasNextPage | ||||||
|  |       endCursor | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										9
									
								
								src/operations/make_percentage_time_series.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/operations/make_percentage_time_series.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | query GetVideoMakePercentageIntervals($videoId: ID!, $intervalDuration: Int!) { | ||||||
|  |   getVideoMakePercentageIntervals( | ||||||
|  |     videoId: $videoId | ||||||
|  |     intervalDuration: $intervalDuration | ||||||
|  |   ) { | ||||||
|  |     makePercentage | ||||||
|  |     elapsedTime | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -1,30 +1,38 @@ | |||||||
| query GetShots( | query GetShots( | ||||||
| 	$filterInput: FilterInput |   $filterInput: FilterInput! | ||||||
| 	$includeCueObjectDistance: Boolean! = false |   $includeCreatedAt: Boolean! = false | ||||||
| 	$includeCueObjectAngle: Boolean! = false |   $includeUpdatedAt: Boolean! = false | ||||||
| 	$includeCueBallSpeed: Boolean! = false |   $includeCueObjectFeatures: Boolean! = false | ||||||
| 	$includeShotDirection: Boolean! = false |   $includePocketingIntentionFeatures: Boolean! = false | ||||||
| 	$includeTargetPocketDistance: Boolean! = false |   $includeCueObjectDistance: Boolean! = false | ||||||
| 	$includeMake: Boolean! = false |   $includeCueObjectAngle: Boolean! = false | ||||||
| 	$includeIntendedPocketType: Boolean! = false |   $includeCueBallSpeed: Boolean! = false | ||||||
|  |   $includeShotDirection: Boolean! = false | ||||||
|  |   $includeTargetPocketDistance: Boolean! = false | ||||||
|  |   $includeMake: Boolean! = false | ||||||
|  |   $includeIntendedPocketType: Boolean! = false | ||||||
| ) { | ) { | ||||||
| 	getShots(filterInput: $filterInput) { |   getShots(filterInput: $filterInput) { | ||||||
| 		id |     id | ||||||
| 		videoId |     videoId | ||||||
| 		startFrame |     startFrame | ||||||
| 		endFrame |     endFrame | ||||||
| 		createdAt |     user { | ||||||
| 		updatedAt |       id | ||||||
| 		cueObjectFeatures { |     } | ||||||
| 			cueObjectDistance @include(if: $includeCueObjectDistance) |     createdAt @include(if: $includeCreatedAt) | ||||||
| 			cueObjectAngle @include(if: $includeCueObjectAngle) |     updatedAt @include(if: $includeUpdatedAt) | ||||||
| 			cueBallSpeed @include(if: $includeCueBallSpeed) |     cueObjectFeatures @include(if: $includeCueObjectFeatures) { | ||||||
| 			shotDirection @include(if: $includeShotDirection) |       cueObjectDistance @include(if: $includeCueObjectDistance) | ||||||
| 		} |       cueObjectAngle @include(if: $includeCueObjectAngle) | ||||||
| 		pocketingIntentionFeatures { |       cueBallSpeed @include(if: $includeCueBallSpeed) | ||||||
| 			targetPocketDistance @include(if: $includeTargetPocketDistance) |       shotDirection @include(if: $includeShotDirection) | ||||||
| 			make @include(if: $includeMake) |     } | ||||||
| 			intendedPocketType @include(if: $includeIntendedPocketType) |     pocketingIntentionFeatures | ||||||
| 		} |       @include(if: $includePocketingIntentionFeatures) { | ||||||
| 	} |       targetPocketDistance @include(if: $includeTargetPocketDistance) | ||||||
|  |       make @include(if: $includeMake) | ||||||
|  |       intendedPocketType @include(if: $includeIntendedPocketType) | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										38
									
								
								src/operations/user.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/operations/user.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | |||||||
|  | mutation getProfileImageUploadLink($fileExt: String = ".png") { | ||||||
|  |   getProfileImageUploadLink(fileExt: $fileExt) { | ||||||
|  |     uploadUrl | ||||||
|  |     headers { | ||||||
|  |       key | ||||||
|  |       value | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation editProfileImageUri($profileImageUri: String!) { | ||||||
|  |   editProfileImageUri(profileImageUri: $profileImageUri) { | ||||||
|  |     id | ||||||
|  |     firebaseUid | ||||||
|  |     username | ||||||
|  |     profileImageUri | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query getLoggedInUser { | ||||||
|  |   getLoggedInUser { | ||||||
|  |     id | ||||||
|  |     firebaseUid | ||||||
|  |     username | ||||||
|  |     profileImageUri | ||||||
|  |     activeVideoId | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetUserPlayTime($userId: Int!) { | ||||||
|  |   getPlayTime(userId: $userId) { | ||||||
|  |     totalSeconds | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										150
									
								
								src/operations/video.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								src/operations/video.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,150 @@ | |||||||
|  | query GetStreamMonitoringDetails($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     totalShots | ||||||
|  |     makePercentage | ||||||
|  |     elapsedTime | ||||||
|  |     homographyHistory { | ||||||
|  |       crop { | ||||||
|  |         left | ||||||
|  |         top | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |       pockets { | ||||||
|  |         left | ||||||
|  |         top | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |       sourcePoints { | ||||||
|  |         topLeft { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         topSide { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         topRight { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomLeft { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomSide { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomRight { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     stream { | ||||||
|  |       linksRequested | ||||||
|  |       uploadsCompleted | ||||||
|  |       segmentProcessingCursor | ||||||
|  |       isCompleted | ||||||
|  |       uploadCompletionCursor | ||||||
|  |       lastIntendedSegmentBound | ||||||
|  |     } | ||||||
|  |     currentProcessing { | ||||||
|  |       errors { | ||||||
|  |         message | ||||||
|  |         startSegmentIndex | ||||||
|  |         endSegmentIndex | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideoUpdatePageDetails($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     name | ||||||
|  |     totalShots | ||||||
|  |     makePercentage | ||||||
|  |     elapsedTime | ||||||
|  |     tags { | ||||||
|  |       tagClasses { | ||||||
|  |         name | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | mutation DeleteVideo($videoId: Int!) { | ||||||
|  |   deleteVideo(videoId: $videoId) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideoDetails($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     name | ||||||
|  |     screenshotUri | ||||||
|  |     averageTimeBetweenShots | ||||||
|  |     elapsedTime | ||||||
|  |     endTime | ||||||
|  |     makePercentage | ||||||
|  |     makePercentage | ||||||
|  |     medianRun | ||||||
|  |     startTime | ||||||
|  |     totalShots | ||||||
|  |     totalShots | ||||||
|  |     totalShotsMade | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|  |     owner { | ||||||
|  |       id | ||||||
|  |       firebaseUid | ||||||
|  |       username | ||||||
|  |       profileImageUri | ||||||
|  |     } | ||||||
|  |     tags { | ||||||
|  |       tagClasses { | ||||||
|  |         name | ||||||
|  |       } | ||||||
|  |       name | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideos($videoIds: [Int!]!) { | ||||||
|  |   getVideos(videoIds: $videoIds) { | ||||||
|  |     id | ||||||
|  |     playlist { | ||||||
|  |       segmentDurations | ||||||
|  |     } | ||||||
|  |     stream { | ||||||
|  |       id | ||||||
|  |       segments { | ||||||
|  |         uploaded | ||||||
|  |         valid | ||||||
|  |         segmentIndex | ||||||
|  |         endFrameIndex | ||||||
|  |         framesPerSecond | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideo($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     playlist { | ||||||
|  |       segmentDurations | ||||||
|  |     } | ||||||
|  |     stream { | ||||||
|  |       segments { | ||||||
|  |         segmentIndex | ||||||
|  |         endFrameIndex | ||||||
|  |         framesPerSecond | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -1,40 +1,60 @@ | |||||||
| mutation CreateUploadStream( | mutation CreateUploadStream($videoMetadataInput: VideoMetadataInput!) { | ||||||
|   $videoName: String!, |   createUploadStream(videoMetadata: $videoMetadataInput) { | ||||||
|   $deviceType: DeviceTypeEnum, |  | ||||||
|   $osVersion: String, |  | ||||||
|   $appVersion: String, |  | ||||||
|   $browserName: String, |  | ||||||
|   $browserVersion: String, |  | ||||||
|   $locale: String, |  | ||||||
|   $timezone: String, |  | ||||||
|   $networkType: String, |  | ||||||
|   $ipAddress: String |  | ||||||
| ) { |  | ||||||
|   createUploadStream( |  | ||||||
|     videoName: $videoName |  | ||||||
|     uploadMetadata: { |  | ||||||
|       deviceType: $deviceType |  | ||||||
|       osVersion: $osVersion |  | ||||||
|       appVersion: $appVersion |  | ||||||
|       browserName: $browserName |  | ||||||
|       browserVersion: $browserVersion |  | ||||||
|       locale: $locale |  | ||||||
|       timezone: $timezone |  | ||||||
|       networkType: $networkType |  | ||||||
|       ipAddress: $ipAddress |  | ||||||
|     } |  | ||||||
|   ) { |  | ||||||
|     videoId |     videoId | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation GetUploadLink($videoId: Int!, $chunkIndex: Int!) { | mutation GetUploadLink($videoId: Int!, $segmentIndex: Int!) { | ||||||
|   getUploadLink(videoId: $videoId, chunkIndex: $chunkIndex) { |   getUploadLink(videoId: $videoId, segmentIndex: $segmentIndex) { | ||||||
|     uploadUrl |     uploadUrl | ||||||
|     linksRequested |     headers { | ||||||
|  |       key | ||||||
|  |       value | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation TerminateUploadStream($videoId: Int!) { | mutation EditUploadStream( | ||||||
|   terminateUploadStream(videoId: $videoId)  |   $videoId: Int! | ||||||
|  |   $videoMetadataInput: VideoMetadataInput! | ||||||
|  | ) { | ||||||
|  |   editUploadStream(videoId: $videoId, videoMetadata: $videoMetadataInput) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetUploadStreams( | ||||||
|  |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|  |       id | ||||||
|  |     } | ||||||
|  |     pageInfo { | ||||||
|  |       hasNextPage | ||||||
|  |       endCursor | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | query GetUploadStreamsWithDetails( | ||||||
|  |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|  |       id | ||||||
|  |       name | ||||||
|  |       startTime | ||||||
|  |       stream { | ||||||
|  |         isCompleted | ||||||
|  |         lastIntendedSegmentBound | ||||||
|  |         uploadCompletionCursor | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     pageInfo { | ||||||
|  |       hasNextPage | ||||||
|  |       endCursor | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										402
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										402
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -1,31 +1,51 @@ | |||||||
| type Query { | type Query { | ||||||
|   getAggregateShots(bucketSets: [BucketSetInputGQL!]!): [AggregateResultGQL!]! |   getAggregatedShotMetrics( | ||||||
|   getUser(userId: Int!): UserGQL |     aggregateInput: AggregateInputGQL! | ||||||
|   getVideo(videoId: Int!): VideoGQL! |   ): [AggregateResultGQL!]! | ||||||
|   getShots(filterInput: FilterInput = null): [ShotGQL!]! |  | ||||||
|   getBucketSet(keyName: String!): BucketSetGQL |   getBucketSet(keyName: String!): BucketSetGQL | ||||||
|  |   getDeployedConfig: DeployedConfigGQL! | ||||||
|  |   getVideoMakePercentageIntervals( | ||||||
|  |     videoId: ID! | ||||||
|  |     intervalDuration: Int! = 300 | ||||||
|  |   ): [MakePercentageIntervalGQL!]! | ||||||
|  |   getShots(filterInput: FilterInput!): [ShotGQL!]! | ||||||
|  |   getUser(userId: Int!): UserGQL | ||||||
|  |   getLoggedInUser: UserGQL | ||||||
|  |   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||||
|  |   getUserVideos( | ||||||
|  |     userId: Int = null | ||||||
|  |     limit: Int! = 5 | ||||||
|  |     after: String = null | ||||||
|  |     filters: VideoFilterInput = null | ||||||
|  |   ): VideoHistoryGQL! | ||||||
|  |   getVideo(videoId: Int!): VideoGQL! | ||||||
|  |   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type AggregateResultGQL { | type AggregateResultGQL { | ||||||
|   featureBuckets: [BucketGQL!]! |   aggregationIdentifiers: [AggregationIdentifierGQL!]! | ||||||
|   targetMetrics: [TargetMetricGQL!]! |   targetMetrics: TargetMetricsGQL! | ||||||
| } | } | ||||||
|  |  | ||||||
| type BucketGQL { | type AggregationIdentifierGQL { | ||||||
|   rangeKey: String! |  | ||||||
|   lowerBound: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type TargetMetricGQL { |  | ||||||
|   count: Int |  | ||||||
|   makePercentage: Float |  | ||||||
|   floatFeature: TargetFloatFeatureGQL |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type TargetFloatFeatureGQL { |  | ||||||
|   featureName: String! |   featureName: String! | ||||||
|   average: Float |   groupName: String! | ||||||
|   median: Float | } | ||||||
|  |  | ||||||
|  | type TargetMetricsGQL { | ||||||
|  |   count: Int! | ||||||
|  |   makePercentage: Float | ||||||
|  |   averageDifficulty: Float | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input AggregateInputGQL { | ||||||
|  |   aggregations: [AggregationInput!]! | ||||||
|  |   filterInput: FilterInput | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input AggregationInput { | ||||||
|  |   bucketSet: BucketSetInputGQL = null | ||||||
|  |   enum: EnumAggregation = null | ||||||
| } | } | ||||||
|  |  | ||||||
| input BucketSetInputGQL { | input BucketSetInputGQL { | ||||||
| @@ -38,67 +58,37 @@ input BucketInputGQL { | |||||||
|   lowerBound: Float! |   lowerBound: Float! | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserGQL { | input EnumAggregation { | ||||||
|   id: Int! |   feature: String! | ||||||
|   username: String! |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   statistics: UserStatisticsGQL! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| """Date with time (isoformat)""" | input FilterInput { | ||||||
| scalar DateTime |   andFilters: AndFilter = null | ||||||
|  |   orFilters: OrFilter = null | ||||||
| type UserStatisticsGQL { |   cueObjectDistance: RangeFilter = null | ||||||
|   totalShots: Int! |   targetPocketDistance: RangeFilter = null | ||||||
|   totalShotsMade: Int! |   cueObjectAngle: RangeFilter = null | ||||||
|   makePercentage: Decimal! |   cueBallSpeed: RangeFilter = null | ||||||
|   averageTimeBetweenShots: Decimal! |   difficulty: RangeFilter = null | ||||||
|   timeSpentPlaying: Decimal! |   intendedPocketType: [PocketEnum!] = null | ||||||
|   medianRun: Decimal |   shotDirection: [ShotDirectionEnum!] = null | ||||||
|  |   videoId: [Int!] = null | ||||||
|  |   userId: [Int!] = null | ||||||
|  |   make: [Boolean!] = null | ||||||
|  |   tags: [VideoTagInput!] = null | ||||||
| } | } | ||||||
|  |  | ||||||
| """Decimal (fixed-point)""" | input AndFilter { | ||||||
| scalar Decimal |   filters: [FilterInput!]! | ||||||
|  |  | ||||||
| type VideoGQL { |  | ||||||
|   id: Int! |  | ||||||
|   totalShotsMade: Int! |  | ||||||
|   totalShots: Int! |  | ||||||
|   makePercentage: Decimal! |  | ||||||
|   medianRun: Decimal! |  | ||||||
|   averageTimeBetweenShots: Decimal |  | ||||||
|   createdAt: DateTime! |  | ||||||
|   updatedAt: DateTime! |  | ||||||
|   shots: [ShotGQL!]! |  | ||||||
|   startTime: DateTime! |  | ||||||
|   endTime: DateTime! |  | ||||||
|   elapsedTime: Decimal! |  | ||||||
|   framesPerSecond: Int! |  | ||||||
|   totalFrames: Int! |  | ||||||
|   stream: UploadStreamGQL |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | input OrFilter { | ||||||
|   id: Int |   filters: [FilterInput!]! | ||||||
|   videoId: Int |  | ||||||
|   startFrame: Int |  | ||||||
|   endFrame: Int |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   features: ShotFeaturesGQL |  | ||||||
|   cueObjectFeatures: CueObjectFeaturesGQL |  | ||||||
|   pocketingIntentionFeatures: PocketingIntentionFeaturesGQL |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotFeaturesGQL { | input RangeFilter { | ||||||
|   cueObjectAngle: Float |   lessThan: Float = null | ||||||
|   cueObjectDistance: Float |   greaterThanEqualTo: Float = null | ||||||
|   targetPocketDistance: Float |  | ||||||
|   intendedPocket: PocketEnum |  | ||||||
|   cueBallSpeed: Float |  | ||||||
|   shotDirection: ShotDirectionEnum |  | ||||||
|   bank: BankFeaturesGQL |  | ||||||
| } | } | ||||||
|  |  | ||||||
| enum PocketEnum { | enum PocketEnum { | ||||||
| @@ -112,17 +102,57 @@ enum ShotDirectionEnum { | |||||||
|   STRAIGHT |   STRAIGHT | ||||||
| } | } | ||||||
|  |  | ||||||
| type BankFeaturesGQL { | input VideoTagInput { | ||||||
|   wallsHit: [WallTypeEnum!]! |   tagClasses: [VideoTagClassInput!]! = [] | ||||||
|   bankAngle: Float! |   name: String! | ||||||
|   distance: Float! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| enum WallTypeEnum { | input VideoTagClassInput { | ||||||
|   LONG |   name: String! | ||||||
|   SHORT |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type BucketSetGQL { | ||||||
|  |   keyName: String! | ||||||
|  |   feature: String! | ||||||
|  |   buckets: [BucketGQL!]! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type BucketGQL { | ||||||
|  |   rangeKey: String! | ||||||
|  |   lowerBound: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type DeployedConfigGQL { | ||||||
|  |   allowNewUsers: Boolean! | ||||||
|  |   firebase: Boolean! | ||||||
|  |   devMode: Boolean! | ||||||
|  |   environment: String! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type MakePercentageIntervalGQL { | ||||||
|  |   makePercentage: Float! | ||||||
|  |   elapsedTime: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type ShotGQL { | ||||||
|  |   id: Int! | ||||||
|  |   videoId: Int! | ||||||
|  |   startFrame: Int! | ||||||
|  |   endFrame: Int! | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  |   cueObjectFeatures: CueObjectFeaturesGQL | ||||||
|  |   pocketingIntentionFeatures: PocketingIntentionFeaturesGQL | ||||||
|  |   bankFeatures: BankFeaturesGQL | ||||||
|  |   serializedShotPaths: SerializedShotPathsGQL | ||||||
|  |   user: UserGQL | ||||||
|  | } | ||||||
|  |  | ||||||
|  | """ | ||||||
|  | Date with time (isoformat) | ||||||
|  | """ | ||||||
|  | scalar DateTime | ||||||
|  |  | ||||||
| type CueObjectFeaturesGQL { | type CueObjectFeaturesGQL { | ||||||
|   cueObjectDistance: Float |   cueObjectDistance: Float | ||||||
|   cueObjectAngle: Float |   cueObjectAngle: Float | ||||||
| @@ -134,100 +164,171 @@ type PocketingIntentionFeaturesGQL { | |||||||
|   targetPocketDistance: Float |   targetPocketDistance: Float | ||||||
|   make: Boolean |   make: Boolean | ||||||
|   intendedPocketType: PocketEnum |   intendedPocketType: PocketEnum | ||||||
|  |   difficulty: Float | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type BankFeaturesGQL { | ||||||
|  |   wallsHit: [WallTypeEnum!]! | ||||||
|  |   bankAngle: Float! | ||||||
|  |   distance: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum WallTypeEnum { | ||||||
|  |   LONG | ||||||
|  |   SHORT | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type SerializedShotPathsGQL { | ||||||
|  |   b64EncodedBuffer: String | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserGQL { | ||||||
|  |   id: Int! | ||||||
|  |   firebaseUid: String! | ||||||
|  |   username: String! | ||||||
|  |   activeVideoId: Int | ||||||
|  |   profileImageUri: String | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserPlayTimeGQL { | ||||||
|  |   totalSeconds: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoHistoryGQL { | ||||||
|  |   videos: [VideoGQL!]! | ||||||
|  |   pageInfo: PageInfoGQL! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoGQL { | ||||||
|  |   id: Int! | ||||||
|  |   owner: UserGQL | ||||||
|  |   name: String | ||||||
|  |   screenshotUri: String | ||||||
|  |   totalShotsMade: Int! | ||||||
|  |   totalShots: Int! | ||||||
|  |   makePercentage: Float! | ||||||
|  |   medianRun: Float | ||||||
|  |   averageTimeBetweenShots: Float | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  |   shots: [ShotGQL!]! | ||||||
|  |   startTime: DateTime | ||||||
|  |   endTime: DateTime | ||||||
|  |   elapsedTime: Float | ||||||
|  |   framesPerSecond: Float! | ||||||
|  |   stream: UploadStreamGQL | ||||||
|  |   playlist: HLSPlaylistGQL | ||||||
|  |   tags: [VideoTag!]! | ||||||
|  |   homographyHistory: [HomographyInfoGQL!]! | ||||||
|  |   currentProcessing: VideoProcessingGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type UploadStreamGQL { | type UploadStreamGQL { | ||||||
|   id: ID! |   id: ID! | ||||||
|   linksRequested: Int! |   linksRequested: Int! | ||||||
|   uploadsCompleted: Int! |   uploadsCompleted: Int! | ||||||
|  |   segmentProcessingCursor: Int! | ||||||
|  |   lastIntendedSegmentBound: Int | ||||||
|   isCompleted: Boolean! |   isCompleted: Boolean! | ||||||
|   uploadMetadata: UploadStreamMetadata! |   lowestUnuploadedSegmentIndex: Int! | ||||||
|  |   uploadCompletionCursor: Int! | ||||||
|  |   errors: [StreamErrorGQL!]! | ||||||
|   createdAt: DateTime! |   createdAt: DateTime! | ||||||
|   updatedAt: DateTime! |   updatedAt: DateTime! | ||||||
|  |   segments: [UploadSegmentGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type UploadStreamMetadata { | type StreamErrorGQL { | ||||||
|   deviceType: DeviceTypeEnum |   message: String! | ||||||
|   osVersion: String |  | ||||||
|   appVersion: String |  | ||||||
|   browserName: String |  | ||||||
|   browserVersion: String |  | ||||||
|   locale: String |  | ||||||
|   timezone: String |  | ||||||
|   networkType: String |  | ||||||
|   ipAddress: String |  | ||||||
| } | } | ||||||
|  |  | ||||||
| enum DeviceTypeEnum { | type UploadSegmentGQL { | ||||||
|   IOS |   segmentIndex: Int! | ||||||
|   ANDROID |   uploaded: Boolean! | ||||||
|   BROWSER |   valid: Boolean! | ||||||
|  |   endFrameIndex: Int | ||||||
|  |   framesPerSecond: Float | ||||||
|  |   durationsInSeconds: Float | ||||||
|  |   linksRequested: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| input FilterInput { | type HLSPlaylistGQL { | ||||||
|   andFilters: AndFilter = null |   videoId: Int! | ||||||
|   orFilters: OrFilter = null |   m3u8Text: String! | ||||||
|   cueObjectDistance: CueObjectDistanceInput = null |   segmentDurations: [Float!]! | ||||||
|   targetPocketDistance: TargetPocketDistanceInput = null |  | ||||||
|   cueObjectAngle: CueObjectAngleInput = null |  | ||||||
|   cueBallSpeed: CueBallSpeedInput = null |  | ||||||
|   intendedPocketType: IntendedPocketTypeInput = null |  | ||||||
|   shotDirection: ShotDirectionInput = null |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input AndFilter { | type VideoTag { | ||||||
|   filters: [FilterInput!]! |   tagClasses: [VideoTagClass!]! | ||||||
|  |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| input OrFilter { | type VideoTagClass { | ||||||
|   filters: [FilterInput!]! |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CueObjectDistanceInput { | type HomographyInfoGQL { | ||||||
|   value: RangeFilter! |   frameIndex: Int! | ||||||
|  |   crop: BoundingBoxGQL! | ||||||
|  |   pockets: [BoundingBoxGQL!]! | ||||||
|  |   sourcePoints: PocketPointsGQL! | ||||||
|  |   destPoints: PocketPointsGQL! | ||||||
| } | } | ||||||
|  |  | ||||||
| input RangeFilter { | type BoundingBoxGQL { | ||||||
|   lessThan: Float = null |   left: Float! | ||||||
|   greaterThanEqualTo: Float = null |   top: Float! | ||||||
|  |   width: Float! | ||||||
|  |   height: Float! | ||||||
| } | } | ||||||
|  |  | ||||||
| input TargetPocketDistanceInput { | type PocketPointsGQL { | ||||||
|   value: RangeFilter! |   topLeft: IntPoint2D! | ||||||
|  |   topSide: IntPoint2D! | ||||||
|  |   topRight: IntPoint2D! | ||||||
|  |   bottomLeft: IntPoint2D! | ||||||
|  |   bottomSide: IntPoint2D! | ||||||
|  |   bottomRight: IntPoint2D! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CueObjectAngleInput { | type IntPoint2D { | ||||||
|   value: RangeFilter! |   x: Int! | ||||||
|  |   y: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CueBallSpeedInput { | type VideoProcessingGQL { | ||||||
|   value: RangeFilter! |   errors: [VideoProcessingErrorGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| input IntendedPocketTypeInput { | type VideoProcessingErrorGQL { | ||||||
|   value: EnumFilter! |   message: String! | ||||||
|  |   startSegmentIndex: Int | ||||||
|  |   endSegmentIndex: Int | ||||||
| } | } | ||||||
|  |  | ||||||
| input EnumFilter { | type PageInfoGQL { | ||||||
|   equals: String = null |   hasNextPage: Boolean! | ||||||
|  |   endCursor: String | ||||||
| } | } | ||||||
|  |  | ||||||
| input ShotDirectionInput { | input VideoFilterInput { | ||||||
|   value: EnumFilter! |   isStreamCompleted: Boolean = null | ||||||
| } |   requireCursorCompletion: Boolean! = true | ||||||
|  |  | ||||||
| type BucketSetGQL { |  | ||||||
|   keyName: String! |  | ||||||
|   feature: String! |  | ||||||
|   buckets: [BucketGQL!]! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type Mutation { | type Mutation { | ||||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! |   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||||
|   processVideoSource(input: ProcessVideoSourceInput!): ProcessVideoSourceReturn! |   setLoggerLevel(path: String!, level: String!): Boolean! | ||||||
|   createUploadStream(uploadMetadata: UploadMetadataInput, videoName: String = null): CreateUploadStreamReturn! |   getProfileImageUploadLink(fileExt: String = ".png"): GetUploadLinkReturn! | ||||||
|   getUploadLink(videoId: Int!, chunkIndex: Int!): GetUploadLinkReturn! |   editProfileImageUri(profileImageUri: String!): UserGQL! | ||||||
|   terminateUploadStream(videoId: Int!): Boolean! |   createUploadStream( | ||||||
|  |     videoMetadata: VideoMetadataInput! | ||||||
|  |   ): CreateUploadStreamReturn! | ||||||
|  |   getUploadLink(videoId: Int!, segmentIndex: Int!): GetUploadLinkReturn! | ||||||
|  |   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! | ||||||
|  |   deleteVideo(videoId: Int!): Boolean! | ||||||
| } | } | ||||||
|  |  | ||||||
| input CreateBucketSetInput { | input CreateBucketSetInput { | ||||||
| @@ -236,19 +337,32 @@ input CreateBucketSetInput { | |||||||
|   buckets: [BucketInputGQL!]! |   buckets: [BucketInputGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type ProcessVideoSourceReturn { | type GetUploadLinkReturn { | ||||||
|   val: Int! |   uploadUrl: String! | ||||||
|  |   headers: [Header]! | ||||||
| } | } | ||||||
|  |  | ||||||
| input ProcessVideoSourceInput { | type Header { | ||||||
|   val: Int! |   key: String! | ||||||
|  |   value: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| type CreateUploadStreamReturn { | type CreateUploadStreamReturn { | ||||||
|   videoId: Int! |   videoId: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| input UploadMetadataInput { | input VideoMetadataInput { | ||||||
|  |   videoName: String = null | ||||||
|  |   startTime: DateTime = null | ||||||
|  |   endTime: DateTime = null | ||||||
|  |   gameType: String = null | ||||||
|  |   tableSize: String = null | ||||||
|  |   uploadStreamMetadataInput: UploadStreamMetadataInput = null | ||||||
|  |   lastIntendedSegmentBound: Int = null | ||||||
|  |   endStream: Boolean! = false | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input UploadStreamMetadataInput { | ||||||
|   deviceType: DeviceTypeEnum = null |   deviceType: DeviceTypeEnum = null | ||||||
|   osVersion: String = null |   osVersion: String = null | ||||||
|   appVersion: String = null |   appVersion: String = null | ||||||
| @@ -260,8 +374,8 @@ input UploadMetadataInput { | |||||||
|   ipAddress: String = null |   ipAddress: String = null | ||||||
| } | } | ||||||
|  |  | ||||||
| type GetUploadLinkReturn { | enum DeviceTypeEnum { | ||||||
|   uploadUrl: String! |   IOS | ||||||
|   linksRequested: Int! |   ANDROID | ||||||
|   uploadsCompleted: Int! |   BROWSER | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -1553,6 +1553,11 @@ colorette@^2.0.16: | |||||||
|   resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" |   resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" | ||||||
|   integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== |   integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== | ||||||
|  |  | ||||||
|  | commander@4.0.1: | ||||||
|  |   version "4.0.1" | ||||||
|  |   resolved "https://registry.yarnpkg.com/commander/-/commander-4.0.1.tgz#b67622721785993182e807f4883633e6401ba53c" | ||||||
|  |   integrity sha512-IPF4ouhCP+qdlcmCedhxX4xiGBPyigb8v5NeUp+0LyhwLgxMqyp3S0vl7TAPfS/hiP7FC3caI/PB9lTmP8r1NA== | ||||||
|  |  | ||||||
| common-tags@1.8.2: | common-tags@1.8.2: | ||||||
|   version "1.8.2" |   version "1.8.2" | ||||||
|   resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.2.tgz#94ebb3c076d26032745fd54face7f688ef5ac9c6" |   resolved "https://registry.yarnpkg.com/common-tags/-/common-tags-1.8.2.tgz#94ebb3c076d26032745fd54face7f688ef5ac9c6" | ||||||
| @@ -2538,6 +2543,14 @@ path-type@^4.0.0: | |||||||
|   resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" |   resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" | ||||||
|   integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== |   integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== | ||||||
|  |  | ||||||
|  | pbjs@^0.0.14: | ||||||
|  |   version "0.0.14" | ||||||
|  |   resolved "https://registry.yarnpkg.com/pbjs/-/pbjs-0.0.14.tgz#5ab3d4a5f06a9ab78dd320c63f72877120d4c48d" | ||||||
|  |   integrity sha512-F4aA0ojrQ37kxFPOg4yRLP/vxb76rYQwMQigmVEljYlA7hZKmjaWjP6IkRn4nA0NdIj4Xxe4iqWrrIhJy+MwWQ== | ||||||
|  |   dependencies: | ||||||
|  |     commander "4.0.1" | ||||||
|  |     protocol-buffers-schema "3.1.0" | ||||||
|  |  | ||||||
| picocolors@^1.0.0: | picocolors@^1.0.0: | ||||||
|   version "1.0.0" |   version "1.0.0" | ||||||
|   resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" |   resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" | ||||||
| @@ -2548,6 +2561,16 @@ picomatch@^2.3.1: | |||||||
|   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" |   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" | ||||||
|   integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== |   integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== | ||||||
|  |  | ||||||
|  | prettier-plugin-organize-imports@^3.2.4: | ||||||
|  |   version "3.2.4" | ||||||
|  |   resolved "https://registry.yarnpkg.com/prettier-plugin-organize-imports/-/prettier-plugin-organize-imports-3.2.4.tgz#77967f69d335e9c8e6e5d224074609309c62845e" | ||||||
|  |   integrity sha512-6m8WBhIp0dfwu0SkgfOxJqh+HpdyfqSSLfKKRZSFbDuEQXDDndb8fTpRWkUrX/uBenkex3MgnVk0J3b3Y5byog== | ||||||
|  |  | ||||||
|  | prettier@^3.2.5: | ||||||
|  |   version "3.2.5" | ||||||
|  |   resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.2.5.tgz#e52bc3090586e824964a8813b09aba6233b28368" | ||||||
|  |   integrity sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A== | ||||||
|  |  | ||||||
| promise@^7.1.1: | promise@^7.1.1: | ||||||
|   version "7.3.1" |   version "7.3.1" | ||||||
|   resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf" |   resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf" | ||||||
| @@ -2564,6 +2587,11 @@ prop-types@^15.7.2: | |||||||
|     object-assign "^4.1.1" |     object-assign "^4.1.1" | ||||||
|     react-is "^16.13.1" |     react-is "^16.13.1" | ||||||
|  |  | ||||||
|  | protocol-buffers-schema@3.1.0: | ||||||
|  |   version "3.1.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/protocol-buffers-schema/-/protocol-buffers-schema-3.1.0.tgz#d8a819549ead3e6bd189ebe9e50e96636bbc5cc7" | ||||||
|  |   integrity sha512-1g9zFjLFhGN1Dc5UVO8D2loVslp6sVxk5sJqgD66CuWUITh2gOaTLRN/pIakGFfB6e0nNF6hImrYFDurEsA1UQ== | ||||||
|  |  | ||||||
| punycode@^1.3.2: | punycode@^1.3.2: | ||||||
|   version "1.4.1" |   version "1.4.1" | ||||||
|   resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" |   resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user